@charset "UTF-8";

html { 
-webkit-tap-highlight-color: transparent;
}
 
html ::selection {
        background: #fbb24b;
        color: #38342C;
}

body{
	position: relative;
	width: 100%; min-height: 100%;
	letter-spacing: 0;
}



.wrapper {
	width: 100%; height: auto;
}

/* ================================*/
/* ------- header */
/* ================================*/

header {
	position: fixed;
	z-index: 50;
	top: 0; left: 0;
	width: 100%; height: 124px;
	background-color: transparent;
	border-bottom: 3px solid transparent;
	transition: all .3s cubic-bezier(0.25, 0.1, 0.25, 1.0);
}

header .hamber {
	display: none;
}

header.isScroll  {
	background-color:rgba(255, 255, 255, .7);
	border-bottom: 3px solid white;
}

header .logo {
	position: absolute;
	top: 0; left: 20px;
	width: 297px; height: 124px;
	border-bottom: 3px solid white;
}

header .logo .img {
	position: absolute;
	left: 0; top: 0; bottom: 0;
	margin: auto 0;
	width: 235px; height: 88px;
	background-image: url(../images/logo@2x.png);
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}

header nav.menu {
	position: absolute;
	top: 0; right: 0;
	height: 100%;
}

header nav.menu::after {
	content: '';
	position: absolute;
	z-index: -1	;
	right: 0; top: 0;
	width: calc(100% + 60px); height: 100%;
	opacity: .64;
	background-color: white;
	transform-origin:bottom;
	transform:skewX(-15deg);
}

header nav.menu ul {
	display: flex;
	height: 100%;
}

header nav.menu ul a {
	display: flex;
	flex-direction: column;
	flex-wrap: wrap;
	justify-content: center;
	width: 100%; height: 100%;
	padding: 0 25px;
}

header nav.menu ul a .number,
header nav.menu ul a .text {
	position: relative;
	width: 100%;
	height: 24px; line-height: 24px;
	font-weight: bold;
	color: #919191;
}

header nav.menu ul a .text {
	color: #393939;
}

header nav.menu ul a .number::before {
	content: '///';
	position: absolute;
	left: -24px; top: 0;
	width: 24px; height: 24px;
	line-height: 24px;
	letter-spacing: -1px;
	font-weight: bold;
}

header nav.menu ul a .number::after {
	content: '';
	position: absolute;
	right: 0; bottom: 5px;
	width:calc( 100% - 44px); height: 1px;
	background-color: #919191;
}
/* ================================*/
/* ------- navegation */
/* ================================*/
.Navi-selcet{
	display: flex;
    width: 60%;
    margin: 0 auto;
    text-align: center;
}
.navi{
    width: 60%;
    text-align: center;
    padding: 30px 0px 0px;
}
.navi a{
    display: inline-block;
    background: #a9d0ff;
    border-radius: 10rem;
    padding: 0px 30px;
    margin-right: 0px;
    text-align: center;
    font-weight: bold;
    word-break: keep-all;
    line-height: 55px;
}
.navi a:hover{
	color: #ffffff;
	background: #368ff8;
	transition: 0.3s;
}
@media screen and (min-width: 991px){
	section .Navi-selcet {
		display: flex;
		width: 48%;
		margin: 0 auto;
		text-align: center;
	}
	section .Navi-text {
		word-break: keep-all;
		white-space: nowrap;
		width: 220px;
		padding: 44px 0px 0px 0px;
		display: inline-block;
	}
}
@media screen and (max-width: 990px){
	.Navi-selcet{
		display: flex;
		width: 60%;
		margin: 0 auto;
		text-align: center;
	}
	.navi{
		width: 60%;
		text-align: center;
		padding: 16px 0px 17px;
	}
	.navi a {
		display: inline-block;
		background: #a9d0ff;
		border-radius: 10rem;
		margin-left: 19px;
		text-align: center;
		font-weight: bold;
		word-break: keep-all;
	}
}
@media screen and (min-width: 768px) and (max-width: 990px){ 
	section .Navi-text {
		word-break: keep-all;
		white-space: nowrap;
		width: 220px;
		padding: 30px 0px 0px 0px;
		display: inline-block;
	}
}
@media screen and (max-width: 767px){
	.Navi-selcet{
		display: flex;
		width: 90%;
	}
	.navi{
		width: 60%;
		text-align: center;
		padding: 16px 0px 17px;
	}
	.navi a{
		display: block;
	}
	section .Navi-text{
		padding: 32px 0px 0px 0px;
		white-space: nowrap;
	}
}
@media screen and (max-width: 565px){
	.Navi-selcet{
		display: block;
		width: 100%;
		margin: 0 auto;
		text-align: center;
		margin-bottom: 20px;
	}
	.navi{
		width: 80%;
		text-align: center;
		padding: 10px 0px 6px;
		margin: 0 auto;
	}

}
/* ================================*/
/* ------- footer */
/* ================================*/

footer {
	padding-top: 20px;
    padding-bottom: 20px;
    background-color: #4E897A;
}

.copyright {
	font-size: 14px;
	text-align: center;
	color: #fff;
    letter-spacing: 1px;
}

/* ================================*/
/* ------- loaderGroup */
/* ================================*/

.loaderGroup {
	position: fixed;
	z-index: 99;
	top: 0; left: 0;
	width: 100%; height: 100vh;
	background-color: #F7F7F7;
}

.loaderGroup .loader {
	position: absolute;
	left: 0;  top: 0; 
	margin: auto;
	height: 100vh;
	width: 100%;
	text-align: center;
	padding: 1em;
	margin: 0 auto 1em;
	display: flex;
	justify-content: center;
	align-items: center;
	vertical-align: top;
}

/*
  Set the color of the icon
*/
.loaderGroup svg path,
.loaderGroup svg rect {
  fill: #76DDC6;
}

/* ================================*/
/* ------- l-more */
/* ================================*/

.l-more {
	width: 100%; max-width: 334px; height: 50px;
	line-height: 50px;
	text-align: center;
	margin-top: 40px;
	color:#585858;
	font-weight: bold;
	background-color: #76DDC6;
	border-radius: 50px;
}

.l-moreGroup.tm-m {
	display: none;
}
.pphe{
	padding: 20px 0px;
}
.l-moreGroup ul{
	width: 100%;
    display: flex;
}
.l-moreGroup ul li:nth-child(1){
	background-color: #CBEEFF;
}
.l-moreGroup ul li:nth-child(2){
	background-color: #CBEEFF;
}
.l-moreGroup ul li:nth-child(3){
	background-color: #FEDB77;
}	
.l-moreGroup ul li{
	list-style-type: none;
    margin: 0px 5px;
	width: 100%;
	border-radius: 50px;
	height: 50px;
	line-height: 50px;
}	
.l-moreGroup ul li a{
	list-style-type: none;
	word-break: keep-all;
    padding: 0px 25px;
    width: 100%;
}
.l-moreGroup ul li :nth-child(3) a{
	list-style-type: none;
    margin: 0px 5px;
	background: #fdf5a7;
}	

.l-moreGroup {
	display: flex; 
	width: 75%; height: 55px;
	justify-content: space-between;
	margin-top: 30px;
}

.l-moreGroup a {
	height: 55px;
	border-radius: 55px;
	text-align: center;
	font-weight: bold;
	color: #585858;
}
/*  */
.l-moreGroup_n {
	display: flex; 
	width: 100%; height: 55px;
	justify-content: space-between;
	margin-top: 30px;
}
.l-moreGroup_n a {
	width: calc(100%/2);
	height: 55px;
	border-radius: 55px;
	line-height: 55px;
	text-align: center;
	font-weight: bold;
	color: #585858;
	margin: 0px 5px;
}

.Navi-text{
    word-break: keep-all;
	white-space: nowrap;
    width: 220px;
    padding: 36px 0px 0px 0px;
    display: inline-block;
}
/* ================================*/
/* ------- bigTextGroup */
/* ================================*/


.bigTextGroup {
	position: absolute;
	z-index: 1;
	left: 0; top: 0; bottom: 0; 
	margin: auto 0;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 574px; height: 688px;
	/* background-color: #000000; */
}

.bigTextGroup .cameraBg {
	position: absolute;
	left: 0; top: 0; bottom: 0;
	margin: auto 0;
	width: 700px; height: 650px;
	perspective: 70px;
}

.bigTextGroup .cameraBg::after {
	content: '/////';
	position: absolute;
	left: 400px; bottom: 40px;
	font-size: 50px;
	color: #989898;
}

.bigTextGroup .cameraBg .space {
	width: 100%; height: 100%;
	transform-style: preserve-3d;
}

.bigTextGroup .cameraBg .space .box1 {
	position: absolute;
	top: 0; bottom: 0; left: 0; right: 0;
	margin: auto;
	width: 100%; height: 100%;
	opacity: .67;
	background-color: #000000;
	transform: translateX(-20px) translateZ(-40px) rotateY(5deg);
}
.bigTextGroup .cameraBg .space .box2 {
	top: 0; bottom: 0; left: 0; right: 0;
	margin: auto;
	width: 100%; height: 100%;
	opacity: .67;
	border: 3px solid white;
	transform: translateX(0px) translateY(20px) translateZ(-40px) rotateY(5deg);
}

.bigTextGroup .in {
	position: relative;
	width: 334px; height: 350px;
}

.bigTextGroup .in .top {
	margin-bottom: 20px;
}

.bigTextGroup .in .num {
	width: 100px; height: 80px;
	margin-bottom: 10px;
	line-height: 1em;
	font-size: 90px;
	font-weight: bold;
	color: #76DDC6;
}

.bigTextGroup .in .num::after {
	content: '///////////////';
	margin-left: 20px;
	letter-spacing: 2px;
	font-weight: normal;
	font-size: 20px;
	color: white;
}

.bigTextGroup .in h1.h2title {
	color: #76DDC6;
}

.bigTextGroup .in p {
	color: white;
}


/* ================================*/
/* ------- sMainVision */
/* ================================*/

.sMainVision {
	width: 100%; height: 90vh;
	background-color: #efefef;
}

.sMainVision .slick-dots {
	width: 160px;
	left: 40px; bottom: 20px;
	z-index: 32;
}

.sMainVision .slick-dots li {
	margin: 0;
	margin-right: 10px;
}

.sMainVision .slick-dots li button:before {
	content: '';
	width: 14px; height: 14px;
	border-radius: 14px;
	border: 1px solid white;
	background-color: white;
	opacity: 1;
}

.sMainVision .slick-dots li.slick-active button:before {
	background-color: #76DDC6;
}

.sMainVision  .effectGroup {
	position: absolute;
	left: 0; top: 0;
	width: 100%; height: 90vh;
	overflow: hidden;
}

.sMainVision  .effectGroup .greenRectangle01 {
	position: absolute;
	z-index: 30;
	left: -15%; top: 0;
	width: 45%; height: 100%;
	background-color: #3FBEB2;
	opacity: .46;
	transform-origin: bottom;
	transform: skewX(-15deg) translateX(-100%);
	transition: all .3s .8s cubic-bezier(0.4, 0, 0.2, 1);
	pointer-events: none;
}

.sMainVision  .effectGroup .yellowRectangle02 {
	position: absolute;
	z-index: 29;
	left: 0; bottom: 0;
	width: 80%; height: 50%;
	width: 0; height: 0;
	border-style: solid;
	border-width: 600px 0 0 260px;
	border-color: transparent transparent transparent #FFC76E;
	transform: translateX(0) translateY(80%);
	transition: transform .55s .95s cubic-bezier(0.4, 0, 0.2, 1);
	/* background-color: #FFC76E; */
	opacity: .78;
	pointer-events: none;
}

.sMainVision  .effectGroup .blueRectangle03 {
position: absolute;
	right: 0;
	bottom: 0;
	width: 35%;
	height: 60%;
	background-color: #407088;
	opacity: .6;

	clip-path: polygon(
		60% 0%,   /* 左上 */
		100% 0%,  /* 右上 */
		100% 100%,/* 右下 */
		0% 100%   /* 左下 */
	);

	transform: translateX(100%);
	transition: transform .5s .85s cubic-bezier(0.4, 0, 0.2, 1);
	pointer-events: none;
}

.sMainVision  .effectGroup .textGroup {
	position: absolute;
	z-index: 31;
	left: -3%; top: 0; bottom: 0;
	margin: auto 0;
	width: 800px; height: 380px;
	/* background-color: red; */
	pointer-events: none;
}

.sMainVision  .effectGroup .textGroup .text01 {
	position: absolute;
	top: 0; left: 0;
	width: 100%; height: 300px;
	line-height: 120px;
	font-size: 120px;
	font-style: italic;
	color: #ffffff;
	opacity: 0;
	transform: translateY(50%);
	transition: 
	transform .5s .9s cubic-bezier(0.4, 0, 0.2, 1) , 
	opacity .5s .9s cubic-bezier(0.4, 0, 0.2, 1);
	pointer-events: none;
}

.sMainVision  .effectGroup .textGroup .text02 {
	position: absolute;
	top: 160px; left: 120px;
	width: 100%; height: 220px;
	pointer-events: none;
}

.sMainVision  .effectGroup .textGroup .text02 .-text1 {
	position: absolute;
	top: 0; left: 0;
	width: 100%; height: 180px;
	line-height: 180px;
	font-size: 180px;
	font-weight: bold;
	font-style: italic;
	color: white;
	opacity: 0;
	transform: translateY(50%);
	transition: 
	transform .5s 1s cubic-bezier(0.4, 0, 0.2, 1),
	opacity .5s 1s cubic-bezier(0.4, 0, 0.2, 1);
	pointer-events: none;
}

.sMainVision  .effectGroup .textGroup .text02 .-text2 {
	position: absolute;
	top: 170px; left: 260px;
	width: 300px; height: 40px;
	line-height: 40px;
	font-size: 40px;
	font-weight: bold;
	color: white;
	opacity: 0;
	transform: translateY(50%);
	transition: 
	transform .5s 1.2s cubic-bezier(0.4, 0, 0.2, 1),
	opacity .5s 1.2s cubic-bezier(0.4, 0, 0.2, 1);
	pointer-events: none;
}


.is-ready .sMainVision  .effectGroup .greenRectangle01 {
	transform: skewX(-15deg) translateX(0);
}

.is-ready .sMainVision  .effectGroup .yellowRectangle02 {
	transform: translateX(0) translateY(0);
}

.is-ready .sMainVision  .effectGroup .blueRectangle03 {
	transform: translateX(0);
}

.is-ready .sMainVision  .effectGroup .textGroup .text01 {
	opacity: .33;
	transform: translateX(0);
}

.is-ready .sMainVision  .effectGroup .textGroup .text02 .-text1 {
	opacity: 1;
	transform: translateX(0);
}

.is-ready .sMainVision  .effectGroup .textGroup .text02 .-text2 {
	opacity: 1;
	transform: translateX(0);
}

.sMainVision .js_slickMainVision .img {
	width: 100%; height: 90vh;
}



/* ================================*/
/* ------- sPrincipal */
/* ================================*/

.sPrincipal.l-inner {
	position: relative;
	display: flex;
	justify-content: flex-end;
	margin: 30px auto;
}

.sPrincipal .l-more.tm-m {
	display: none;
}

.sPrincipal .arrowNext {
	position: absolute;
	z-index: 1;
	top: 0; bottom: 0; right: 0;
	margin: auto 0;
	width: 30px; height: 120px;
	background-image: url(../images/slickArrowNext@2x.png);
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}

.js_slickPrincipal {
	width: calc(100% - 400px)
}

.js_slickPrincipal .slick-next.slick-arrow,
.js_slickPrincipal .slick-prev.slick-arrow {
	display: none;
	right: 99999999999px;
}

.js_slickPrincipal .item {
	position: relative;
	width: calc(523px + 30px); height: calc(510px + 110px);
	padding-top: 30px;
	padding-right: 30px;
	padding-bottom: 80px;
}

.js_slickPrincipal .item .img {
	position: relative;
	width: 523px; height: 510px;
}

.js_slickPrincipal .item .img::after {
	content: '';
	position: absolute;
	z-index: -1;
	top: -30px; right: -30px;
	width: 523px; height: 510px;
	background-size: 40%;
	background-position: top right;
	background-repeat: no-repeat;
	background-image: url(../images/principalBg@2x.png);
}

.js_slickPrincipal .item .img .text {
	position: absolute;
	z-index: 1;
	bottom: -30px; right: -30px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	width: 288px; height: 136px;
	background-color: #7ADEC6;
}

.js_slickPrincipal .item .text::before {
	content: '';
	position: absolute;
	top: -10px; left: 10px;
	width: 100%; height: 100%;
	border: 2px solid white;
}

.js_slickPrincipal .item .text .in {
	height: 82px;
	overflow: hidden;
}

.js_slickPrincipal .item .text sub {
	line-height: 30px;
	height: 30px;
	opacity: .7;
}

.js_slickPrincipal .item .text h2 span {
	margin-left: 20px;
	font-size: 24px;
	font-weight: 400;
	opacity: .7;
}


/* ================================*/
/* ------- sSchool */
/* ================================*/

.sSchool {
	width: 100%; height: auto;
	background-image: url(../images/schoolBg.png);
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}

.sSchool figure {
	position: relative;
	width: 100%; height: auto;
	margin-bottom: 100px;
	padding-left: 30px;
	padding-top: 30px;
}

.sSchool figure img {
	width: 100%;
}

.sSchool figure .img {
	width: 100%; height: 720px;
}

.sSchool figure .img .l-more.tm-m {
	display: none;
}

.sSchool .greenTriangleBg {
	position: absolute;
	z-index: 1;
	left: 0; top: 0;
	width: 440px; height: 370px;
	background-image: url(../images/schoolTriangleBg@2x.png);
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}

.sSchool .longBg {
	background-color: #4C897A;
}

.sSchool .longBg,
.sSchool .longBg img {
	width: 100%; height: auto;
}

.sSchool figure figcaption.bigTextGroup {
	left: auto; right: 100px;
	width: 452px; height: 600px;
	align-items: normal;
}

.sSchool figure figcaption.bigTextGroup .normalBG {
	position: absolute;
	left: 0; top: 0; right: 0; bottom: 0;
	margin: auto;
	width: 100%; height: 100%;
	opacity: .67;
	background-color: #000000;
}

.sSchool figure figcaption.bigTextGroup .in {
	position: absolute;
	bottom: 50px;
}

.sSchool figure figcaption.bigTextGroup .in::before {
	content: '/////';
	position: absolute;
	left: 0; top: -140px;
	font-size: 50px;
	color: white;
}


/* ================================*/
/* ------- sQuickstudy */
/* ================================*/

.sQuickstudy {
	width: 100%; height: auto;
	background-image: url(../images/quickstudyBg@2x.png);
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}


.sQuickstudy .img {
	position: relative;
	z-index: 1;
	width: 70%; height: 720px;
	margin-top: 100px;
	margin-bottom: 100px;
}

.sQuickstudy .img::after {
	content: '';
	position: absolute;
	left: 20px; top: 20px;
	width: 60px; height: 56px;
	background-image: url(../images/quickstudyTriangleBg2@2x.png);
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}

.sQuickstudy figure {
	position: relative;
	width: 100%;
	overflow: hidden;
}

.sQuickstudy .bigTextGroup {
	position: absolute;
	z-index: 2;
	right: 32px; left: auto;
	width: 832px; height: 458px;
	justify-content: normal;
}

.sQuickstudy .bigTextGroup .in {
	position: absolute;
	right: 80px;
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	width: 480px; height: 250px;

}

.sQuickstudy .bigTextGroup .in .top {
	display: flex;
	align-items: flex-end;
}

.sQuickstudy .bigTextGroup .in .num {
	position: relative;
	width: auto; height: 76px;
	line-height: 80px;
	margin-bottom: 0;
	margin-right: 5px;
}

.sQuickstudy .bigTextGroup .in .num::after {
	position: absolute;
	top: -20px; left: 110px;
}

.sQuickstudy .bigTextGroup .in h1.h2title {
	vertical-align: bottom;
}

.sQuickstudy .bigTextGroup .in .num,
.sQuickstudy .bigTextGroup .in h1.h2title  {
	color: #4C897A;
}

.sQuickstudy .bigTextGroup .in p {
	padding-left: 120px;
}


.sQuickstudy .bigTextGroup .normalBG {
	position: absolute;
	width: 100%; height: 100%;
	background-color: #76DDC6;
}

.sQuickstudy .bigTextGroup .normalBG2 {
	position: absolute;
	left: 30px; top: 30px;
	width: 100%; height: 100%;
	border: 3px solid white;
}

.sQuickstudy .bigTextGroup .normalBG2::after {
	content: '/////';
	position: absolute;
	left: 30px; top: 20px;
	width: 84px; height: 60px;
	line-height: 60px;
	color: white;
	font-size: 50px;
}

.sQuickstudy .bigTextGroup .in .l-moreGroup {
	margin-top: 30px;
}

/* ================================*/
/* ------- sSelf */
/* ================================*/

.sSelf {
	width: 100%; height: auto;
	margin-top: 100px;
	margin-bottom: 100px;
	background-image: url(../images/selfBg@2x.png);
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}

.sSelf figure {
	position: relative;
	padding-right: 30px;
	padding-bottom: 30px;
}

.sSelf figure .img {
	position: relative;
	width: 100%; height: 720px;
	padding-right: 30px;
}

.sSelf figure .bigTextGroup {
	left: 50px;
	width: 458px; height: 606px;
	align-items: normal;
}

.sSelf figure .bigTextGroup::after {
	content: '/////';
	position: absolute;
	left: 30px; top: 20px;
	width: 84px; height: 60px;
	line-height: 60px;
	color: white;
	font-size: 50px;
}

.sSelf figure .bigTextGroup .normalBG {
	position: absolute;
	width: 100%; height: 100%;
	opacity: .49;
	background-color: #000000;
}

.sSelf figure .bigTextGroup .in {
	position: absolute;
	bottom: 30px;
}

.sSelf figure .bigTextGroup .l-more {
	background-color: #FDDD77;
}

.sSelf figure .greenTriangleBg {
	position: absolute;
	z-index: 1;
	right: 0; bottom: 0;
	width: 616px; height: 520px;
	background-image: url(../images/selfTriangleBg@2x@2x.png);
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}


/* ================================*/
/* ------- sFuture */
/* ================================*/

.sFuture {
	width: 100%; height: auto;
	margin-top: 100px;
	margin-bottom: 100px;
}

.sFuture figure {
	position: relative;
}

.sFuture figure .img {
	width: 100%; height: 850px;
}

.sFuture figure .bigTextGroup {
	position: absolute;
	z-index: 5;
	left: 0; right: 0; top: 0; bottom: 0;
	margin: auto;
	width: 810px; height: 640px;
}

.sFuture figure .bigTextGroup .normalBG {
	position: absolute;
	left: 0; top: 0;
	width: 100%; height: 100%;
	opacity: .57;
	background-color: #000000;
}

.sFuture figure .bigTextGroup .out {
	position: absolute;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	width: 596px; height: 524px;
	border: 10px solid white;
}

.sFuture figure .bigTextGroup .in {
	height: 290px;
}

.sFuture .greenTriangleBg {
	position: absolute;
	left: 0; top: 0;
	width: 278px; height: 254px;
	background-image: url(../images/futureTriangleBg@2x.png);
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}

.sFuture .greenTriangleBg2 {
	position: absolute;
	right: 30px; bottom: 0;
	width: 594px; height: 372px;
	background-image: url(../images/futureTriangleBg2@2x.png);
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}


/* ================================*/
/* ------- sFource */
/* ================================*/

.sFource .l-inner {
	display: flex;
	justify-content: space-between;
	margin-top: 100px;
	margin-bottom: 100px;
	padding-right: 30px;
	padding-bottom: 30px;
}

.sFource .bigTextGroup {
	position: relative;
	align-items: normal;
	width: 506px; height: 676px;
	background-color: #76DDC6;
}

.sFource .bigTextGroup::before {
	content: '';
	position: absolute;
	left: 30px; top: 30px;
	width: 60px; height: 56px;
	background-image: url(../images/fourceTriangleBg@2x.png);
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}

.sFource .bigTextGroup::after {
	content: '/////';
	position: absolute;
	right: 30px; top: 30px;
	width: 84px; height: 60px;
	line-height: 60px;
	color: white;
	font-size: 50px;
}

.sFource .bigTextGroup .in {
	position: absolute;
	bottom: 80px;
	height: 290px;
}

.sFource .bigTextGroup .num ,
.sFource .bigTextGroup h1.h2title {
	color: #4C897A;
}

.sFource .bigTextGroup .l-more {
	background-color: #CEEEFF;
}

.sFource .img {
	position: relative;
	width: calc(100% - 506px - 50px); height: 676px;
}

.sFource .img .l-more.tm-m {
	display: none;
}

.sFource .img::after {
	content: '';
	position: absolute;
	z-index: -1;
	right: -30px; bottom: -30px; 
	width: 80%; height: 100%;
	background-color: #76DDC6;
}



@media screen and (max-width: 1800px){
/*---Desktop ------------------------------------------------*/

	.l-inner {
		max-width: 1580px;
	}

}


@media screen and (max-width: 1600px){
	/*---15" ------------------------------------------------*/
	
		.l-inner {
			max-width: 1366px;
		}

		.sMainVision .effectGroup .textGroup {
			height: 300px;
		}

		.sMainVision .effectGroup .textGroup .text01 {
			height: 180px;
			line-height: 90px;
			font-size: 90px;
		}

		.sMainVision .effectGroup .textGroup .text02 {
			top: 110px;
			height: 200px;
		}

		.sMainVision .effectGroup .textGroup .text02 .-text1 {
			height: 150px; line-height: 150px;
			font-size: 150px;
		}

		.sMainVision .effectGroup .textGroup .text02 .-text2 {
			top: 160px; left: 190px;

		}

		.sMainVision .effectGroup .yellowRectangle02 {
			border-width: 400px 0 0 1175px;
		}

		.sMainVision .effectGroup .blueRectangle03 {
			border-width: 0 0 500px 990px;
		}




		.js_slickPrincipal .item {
			width: calc(860px + 30px); height: calc(600px + 110px);

		}
		
		.js_slickPrincipal .item .img {
			width: 860px; height: 600px;
		}
		
		.js_slickPrincipal .item .img::after {
			width: 860px; height: 600px;
		}

		.sSchool figure figcaption.bigTextGroup {
			right: 50px
		}

		.sFuture figure .bigTextGroup {
			height: 540px;
		}
	
		.sFuture figure .bigTextGroup .out {
			height: 424px;
			border: 4px solid white;
		}

}

@media screen and (max-width: 1440px){
	/*---13" ------------------------------------------------*/

	.l-more {
		max-width: 134px;
		margin-top: 30px;
	}

	.l-moreGroup {
		width: 324px;
	}
	.l-moreGroup_n {
		width: 324px;
	}

	/* .l-moreGroup a {
		width: calc(100%/2);
	} */

	.h2title {
		font-size: 30px;
	}

	.h3title {
		font-size: 16px;
	}

	.bigTextGroup .in {
		height: 270px;
	}

	.bigTextGroup .in .num {
		width: 80px; height: 60px;
		font-size: 60px;
	}
	
	header {
		height: 80px;
	}

	header .logo {
		width: 220px; height: 80px;
	}

	header .logo .img {
		width: 190px; height: 71px;
	}
	
	header nav.menu ul a .number {
		height: 20px; line-height: 20px;
		font-size: 14px;
	}

	header nav.menu ul a .number::before {
		height: 20px; line-height: 20px;
		font-size: 10px;
	}
	
	.js_slickPrincipal .item {
		padding-top: 20px;
		padding-right: 20px;
	}

	.sPrincipal .arrowNext {
		width: 20px; height: 80px;
	}

	.js_slickPrincipal .item .img::after {
		top: -20px; right: -20px;
	}

	.js_slickPrincipal .item .img .text {
		width: 248px; height: 106px;
	}

	.js_slickPrincipal .item .text h2 span {
		font-size: 16px;
	}

	.sSchool figure {
		padding-left: 20px;
		padding-top: 20px;
	}

	.sSchool .greenTriangleBg {
		width: 200px; height: 168px;
	}
	
	.sQuickstudy .bigTextGroup {
		width: 632px; height: 388px;
	}

	.sQuickstudy .bigTextGroup .in {
		height: 230px;
	}

	.sQuickstudy .bigTextGroup .normalBG2 {
		left: 20px; top: 20px;
	}

	.sQuickstudy .bigTextGroup .in .num {
		height: 50px; line-height: 50px;
	}

	.sQuickstudy .bigTextGroup .in .num::after {
		left: 70px;
	}

	.sSelf figure {
		padding-right: 20px;
		padding-bottom: 20px;

	}

	.sSelf figure .greenTriangleBg {
		width: 300px; height: 253px;
	}
	
	.sSelf figure .bigTextGroup {
		width: 450px; height: 400px;
	}

	.sFuture figure .img {
		height: 580px;	
	}

	.sFuture figure .bigTextGroup {
		width: 640px; height: 460px;
	}

	.sFuture .greenTriangleBg {
		width: 100px; height: 91px;
	}

	.sFuture .greenTriangleBg2 {
		width: 300px; height: 187px;
	}

	.sFource .l-inner {
		padding-right: 20px;
		padding-bottom: 20px;
	}

	.sFource .bigTextGroup {
		height: 550px;
	}

	.sFource .bigTextGroup::before {
		width: 30px; height: 28px;
	}

	.sFource .img {
		height: 550px;
	}

}

@media screen and (max-width: 1280px){
	/*---MOBILE 8 plus ------------------------------------------------*/
	

	.l-inner {
		max-width: 1000px;
	}

	.sMainVision .effectGroup .greenRectangle01 {
		width: 50%;
	}

	.sMainVision .effectGroup .yellowRectangle02 {
		border-width: 300px 0 0 1175px;
	}

	.sMainVision .effectGroup .blueRectangle03 {
		border-width: 0 0 300px 490px;
	}

	.sMainVision .effectGroup .textGroup {
		height: 200px;
	}

	.sMainVision .effectGroup .textGroup .text01 {
		height: 120px; line-height: 60px;
		font-size: 60px;
	}

	.sMainVision .effectGroup .textGroup .text02 {
		top: 80px;
		height: 150px;
	}

	.sMainVision .effectGroup .textGroup .text02 .-text1 {
		height: 100px; line-height: 100px;
		font-size: 100px;
	}

	.sMainVision .effectGroup .textGroup .text02 .-text2 {
		top: 100px; left: 100px;
		height: 30px; line-height: 30px;
		font-size: 30px;
	}

	.js_slickPrincipal .item {
		width: calc(560px + 30px); height: calc(400px + 110px);

	}
	
	.js_slickPrincipal .item .img {
		width: 560px; height: 400px;
	}
	
	.js_slickPrincipal .item .img::after {
		width: 560px; height: 400px;
	}

	.sPrincipal .bigTextGroup {
		width: 500px; height: 388px;

	}

	.sPrincipal .bigTextGroup .cameraBg {
		width: 100%; height: 100%;
		perspective: none;
	}

	.sPrincipal .bigTextGroup .cameraBg .space .box1 {
		transform: translateX(0) translateZ(0) rotateY(0);
	}

	.sPrincipal .bigTextGroup .cameraBg .space .box2 {
		display: none;
	}
	
	.sPrincipal .bigTextGroup .cameraBg::after {
		display: none;
	}

	.sSchool figure .img {
		height: 520px;
	}

	.sSchool figure figcaption.bigTextGroup {
		height: 400px;
	}

	.sSchool figure figcaption.bigTextGroup .in::before {
		display: none;
	}

	.sQuickstudy .img {
		height: 520px;
	}

	.sQuickstudy .bigTextGroup {
		width: 532px;
	}

	.sQuickstudy .bigTextGroup .normalBG2::after {
		display: none;
	}
	
	.sFuture figure .img {
		height: 520px;
	}

}
	


@media screen and (max-width: 1100px){
	/*---MOBILE 8 plus ------------------------------------------------*/
	
	header {
		background-color: rgba(255, 255, 255, .7);
		border-bottom: 2px solid white;
	}

	header .hamber {
		position: fixed;
		z-index: 51;
		right: 20px; top: 28px;
		display: block;
		width: 40px; height: 24px;
		cursor: pointer;
		/* background-color: red; */
	}

	header .hamber .in {
		position: absolute;
		top: 13px; left: 0;
		width: 100%; height: 2px;
		background-color: #707070;
		transition: all .3s cubic-bezier(0.0, 0.0, 1.0, 1.0) ;
	}

	header .hamber .in::before {
		content: '';
		position: absolute;
		top: -8px; left: 0;
		width: 100%; height: 2px;
		background-color: #707070;
		transition: all .3s cubic-bezier(0.0, 0.0, 1.0, 1.0) ;
	}

	header .hamber .in::after {
		content: '';
		position: absolute;
		top: 8px; left: 0;
		width: 100%; height: 2px;
		background-color: #707070;
		transition: all .3s cubic-bezier(0.0, 0.0, 1.0, 1.0) ;
	}

	.isOpen header .hamber .in {
		background-color: transparent;
	}

	.isOpen header .hamber .in::before {
		opacity: 1;
		transform: rotate(-45deg) translateY(6px) translateX(-3px);
		/* transform-origin: 50% 0; */
	}

	.isOpen header .hamber .in::after {
		opacity: 1;
		transform: rotate(45deg) translateY(-8px) translateX(-4px);
	}

	.isOpen header nav.menu {
		transform: translateX(0);
		transition: all .3s cubic-bezier(0.0, 0.0, 1.0, 1.0) ;
	}



	header .logo {
		border-bottom: 0;
	}

	header nav.menu {
		position: fixed;
		z-index: 50;
		display: flex;
		justify-content: center;
		align-items: center;
		width: 100%; height: 100vh;
		background-color: #76DDC6;
		transform: translateX(100%);
		transition: all .3s cubic-bezier(0.0, 0.0, 1.0, 1.0) ;
	}

	header nav.menu::after {
		display: none;
	}

	header nav.menu ul {
		flex-direction: column;
		height: auto;
	}

	header nav.menu ul a {
		width: 200px;
		height: auto; 
		margin: 0 auto 20px auto;
		text-align: center;
	}

	header nav.menu ul a .number {
		left: 30px;
		width: 20px;
		text-align: left;
	}

	header nav.menu ul a .number::after {
		display: none;
	}

	header nav.menu ul a .number::before {
		left: -14px;
		width: 20px;
	}
	
	
	
}


@media screen and (max-width: 900px){
	/*---MOBILE 8 plus ------------------------------------------------*/
	

	.sMainVision .effectGroup .greenRectangle01 {
		left: -40%;
		width: 70%; 
	}

	.bigTextGroup .in .top {
		display: flex;
		align-items: flex-end;
	}

	.bigTextGroup .in .num {
		margin-bottom: 0;
	}

	.bigTextGroup .in .num::after {
		position: absolute;
		top: -15px;
		font-size: 12px;

	}

	.bigTextGroup .in h1.h2title {
		height: 42px;
		line-height: 42px;
	}

	.js_slickPrincipal {
		width: 100%;
	}

	.sPrincipal .arrowNext {
		right: 9999px;
	}

	.sPrincipal .l-more.tm-m {
		display: block;
		margin-bottom: 30px;
		margin-left: auto;
		margin-right: auto;
	}

	.js_slickPrincipal .item {
		width: 100%; height: calc(400px + 0px);
		padding-bottom: 0;
		padding-top: 0;
		padding-right: 0;
		padding-left: 0;

		
	}

	
	
	.js_slickPrincipal .item .img {
		width: 100%; height: 400px;
	}
	
	.js_slickPrincipal .item .img::after {
		width: 100%; height: 400px;
	}

	.js_slickPrincipal .item .img .text {
		right: 30px; bottom: 30px;
	}

	.sPrincipal.l-inner {
		flex-direction: column;
		margin: 0;
	}
	

	.sPrincipal .bigTextGroup {
		position: relative;
		left: 0; top: 0; bottom: auto;
		width: 100%; height: 288px;
	}

	.sPrincipal .bigTextGroup::after {
		content:'';
		position: absolute;
		top: 30px; left: 32px;
		width: calc(100% - 30px); height: calc(100% - 0px);
		border: 2px solid white;
	}

	.sPrincipal .bigTextGroup .in {
		height: 140px;
		left: 24px;
		padding: 0px 10px;
	}

	.bigTextGroup .in .l-more {
		display: none;
	}

	.sSchool .greenTriangleBg {
		top: 50px;
		width: 100px; height: 84px;
	}

	.sSchool figure {
		padding-left: 0;
		padding-top: 50px;
	}

	.sSchool figure .img {
		position: relative;
	}

	.sSchool figure .img .l-more.tm-m {
		position: absolute;
		left: 0; right: 0; bottom: 30px;
		display: block;
		margin: 0 auto;
	}
	
	.sSchool figure figcaption.bigTextGroup {
		left: 0; right: 0;
		margin: 0 auto;
		width: 568px; height: 256px;
	}

	.sSchool figure figcaption.bigTextGroup .in .num {
		margin-right: 10px;
	}
	.sSchool figure figcaption.bigTextGroup::after {
		content: '';
		position: absolute;
		top: 20px; left: 20px;
		width: 100%; height: 100%;
		border: 2px solid white;
	}

	.sSchool figure figcaption.bigTextGroup .in { 
		top: 0; bottom: 0;
		margin: auto;
		height: 168px;
		left: 24px;
		padding: 0px 10px;
	}

	.sQuickstudy figure {
		padding-top: 50px;
		padding-left: 50px;
		padding-right: 50px;
	}

	.sQuickstudy figure .l-moreGroup.tm-m {
		width: 100%; height: auto;
		display: flex;
		justify-content: center;
		padding-top: 20px;
		padding-bottom: 20px;
		background-color: #76DDC6;
	}

	.sQuickstudy figure .l-moreGroup.tm-m  a {
		list-style-type: none;
		margin: 0px 5px;
		border-radius: 50px;
		height: 50px;
		line-height: 50px;
		background-color: #CBEEFF;
		width: calc(100% / 3);
	}
	.sQuickstudy figure .l-moreGroup.tm-m a:nth-child(3){
		background-color: #FEDB77;
	}
	.sQuickstudy .img {
		width: 100%;
		margin-top: 0;
		margin-bottom: 0;
	}

	.sQuickstudy .bigTextGroup {
		left: 0; right: 0;
		margin: 0 auto;
		width: 555px; height: 250px;
	}

	.sQuickstudy .bigTextGroup .in {
		height: 100px;
	}

	.sQuickstudy .bigTextGroup .in .num {
		width: 80px;
		margin-right: 10px;
	}

	.sQuickstudy .bigTextGroup .in .num::after {
		top: -10px; bottom: 0;
		height: 20px; line-height: 20px;
	}

	.sQuickstudy .bigTextGroup .in .l-moreGroup {
		display: none;
	}
	
	.sSelf {
		margin-top: 50px;
		margin-bottom: 0;
	}

	.sSelf figure {
		padding-right: 0;
		padding-bottom: 0;

	}

	.sSelf .bigTextGroup .in .num {
		margin-right: 16px;
	}

	.sSelf .bigTextGroup .in .num::after {
		left: 80px;
	}

	.sSelf figure .greenTriangleBg {
		right: 0; bottom: 0;
		width: 120px; height: 101px;
	}

	.sSelf figure .bigTextGroup {
		left: 0; right: 0; top: 0; bottom: 0;
		margin: auto;
	}

	.sSelf figure .bigTextGroup .l-more {
		display: block;
		margin-left: auto;
		margin-right: auto;
	}

	.sSelf figure .bigTextGroup::after {
		display: none;
	}

	.sFuture {
		margin-top: 0;
		margin-bottom: 0;
	}

	.sFuture figure .img {
		height: 620px;
	}

	.sFuture figure .bigTextGroup .in {
		height: 220px;
	}

	.sFuture .bigTextGroup .in .l-more {
		display: block;
		margin-left: auto;
		margin-right: auto;
	}
	

	.sFource .l-inner {
		position: relative;
		flex-direction: column;
		margin-bottom: 0;
		margin-top: 0;
		padding-top: 50px;
	}

	.sFource .img {
		width: 100%;
	}

	.sFource .bigTextGroup {
		position: absolute;
		left: 0; right: 0; top: 0;
		margin: 0 auto;
		width: 550px; height: 280px;
	}

	.sFource .bigTextGroup::after {
		content:'';
		position: absolute;
		left: 20px; top: 20px;
		width: 100%; height: 100%;
		border: 2px solid white;
	}

	.sFource .bigTextGroup .in {
		height: 130px;
	}

	.sFource .bigTextGroup .in .num {
		margin-right: 10px;
	}

	.sFource .bigTextGroup .in .num::after {
		left: 70px;
	}
	
	.sFource .img .l-more.tm-m {
		position: absolute;
		left: 0; right: 0; bottom: 50px;
		display: block;
		margin: 0 auto;
	}


}


@media screen and (max-width: 660px){
	/*---MOBILE 8 plus ------------------------------------------------*/

	.l-moreGroup {
		width: 90%;
		margin: 0 auto;
	}
	.l-moreGroup {
		display: flex; 
		width: 100%; height: 55px;
		justify-content: space-between;
	}
	
	.l-moreGroup a {
		width: 48%;
		height: 55px;
		border-radius: 55px;
		text-align: center;
		font-weight: bold;
		color: #585858;
		margin: 0 auto;
		word-break: keep-all;
	}
	.l-more.tm-m, .l-more  {
		max-width: 320px;
	}

	.h2title {
		font-size: 24px;
	}

	.bigTextGroup .in {
		width: 100%;
		padding: 12px;
	}

	.sMainVision .effectGroup .yellowRectangle02 {
		border-width: 200px 0 0 575px;
	}

	.sMainVision .effectGroup .blueRectangle03 {
		border-width: 0 0 100px 290px;
	}

	.sMainVision .slick-dots {
		left: 0; bottom: 0;
		width: 100%;
		padding: 10px 0;
		
	}

	.sMainVision .effectGroup .textGroup {
		width: 400px;
		left: 0; right: 0;
		margin: 0 auto;
		bottom: auto; top: 150px;
	}

	.sSchool figure {
		display: flex;
		flex-direction: column;
		flex-wrap: wrap;
		margin-bottom: 0;
		padding-top:0;
	}

	.sSchool figure figcaption.bigTextGroup {
		position: relative;
		order: 1;
		width: 100%;
	}

	.sSchool figure .imgGroup {
		order: 2;
	}

	.sSchool .greenTriangleBg {
		z-index: 1;
		left: 20px; top: 326px;
	}
	
	.sQuickstudy figure {
		display: flex;
		flex-direction: column;
		flex-wrap: wrap;
		padding: 0;
		overflow: hidden;
	}

	.sQuickstudy .bigTextGroup {
		position: relative;
		width: 100%;
		order: 1;
	}

	.sQuickstudy .bigTextGroup .in {
		left: 0; right: 0;
		width: 300px;
		margin: 0 auto;
	}

	.sQuickstudy .img {
		order: 2;
	}

	.sQuickstudy figure .l-moreGroup.tm-m {
		display: flex;
		order: 3;
	}

	.sQuickstudy .bigTextGroup .in {
		align-items: center;
	}

	.sQuickstudy .bigTextGroup .in p {
		padding-left: 0;
	}

	.sSelf {
		margin-top: 0;
	}

	
	.sSelf figure .bigTextGroup {
		width: 95%; height: 95%; 
		max-width: 450px; max-height: 450px;
	}

	.sFuture figure .bigTextGroup {
		width: 95%;
	}

	.sFuture figure .bigTextGroup .out {
		width: calc(100% - 20px); height: calc(100% - 20px);
		border: 2px solid white;
	}

	.sFource .l-inner {
		padding-top: 0;
		padding-right: 0;
	}

	.sFource .bigTextGroup {
		position: relative;
		width: 100%;
	}
	

}

@media screen and (max-width:414px){

	p { 
		line-height: 1.4em;
	}

	header {
		height: 60px;
	}

	header .hamber {
		top: 18px;
	}

	header .logo {
		top: 7px;
		width: 123px; height: 45px;
	}

	header .logo .img {
		width: 120px; height: 45px;
	}

	.sPrincipal {
		height: calc(100vh - 60px);
	}

	.sPrincipal .bigTextGroup,
	.sSchool figure figcaption.bigTextGroup,
	.sQuickstudy .bigTextGroup,
	.sFource .bigTextGroup {
		height: 160px;
	}

	.sPrincipal .bigTextGroup::after,
	.sSchool figure figcaption.bigTextGroup::after,
	.sQuickstudy .bigTextGroup .normalBG2,
	.sFource .bigTextGroup::after {
		left: 8px;
		top: 8px;
		width: calc(100% - 8px);
	}

	.sPrincipal .bigTextGroup .in,
	.sSchool figure figcaption.bigTextGroup .in {
		height: 110px;
	}

	.bigTextGroup .in .top {
		margin-bottom: 8px;
	}

	.sPrincipal .l-more.tm-m {
		margin-top: 22px;
		margin-bottom: 22px;
		/* background-color: white; */
	}

	.js_slickPrincipal {
		height: calc(100vh - 160px - 94px - 50px);
		overflow: hidden;
	}

	.js_slickPrincipal .item,
	.js_slickPrincipal .item .img {
		height: calc(100vh - 160px - 94px - 50px);
	}

	.js_slickPrincipal .item .text::before {
		top: -8px; left: 8px;
	}

	.js_slickPrincipal .item .text .in {
		height: 62px;
	}


	.sSchool {
		height: calc(100vh - 60px);
	}

	.sSchool figure .img {
		height: calc( 100vh - 160px - 80px);
	}

	.sSchool .greenTriangleBg {
		left: 8px;
		top: 176px;
	}

	.sQuickstudy {
		height: calc(100vh - 60px);
	}

	.sQuickstudy .img {
		height: calc(100vh - 160px - 20px - 135px);
	}

	.sSelf,
	.sSelf figure .img,
	.sFuture figure .img,
	.sFource {
		height: calc(100vh - 60px);
	}

	.sFource .bigTextGroup .in {
		top: 0; bottom: 0;
		margin: auto;
		height: 110px;
	}

	.sFource .img {
		height: calc( 100vh - 160px - 80px);
	}


}


@media screen and (max-width:380px){

	.l-more {
		max-width: 320px;
	}
	.sMainVision .effectGroup .textGroup {
		width: 300px;
	}

	.sMainVision .effectGroup .textGroup .text02 {
		left: 20px;
	}

	.sMainVision .effectGroup .greenRectangle01 {
		left: -57%; width: 80%;
	}


	.sPrincipal .bigTextGroup::after,
	.sSchool figure figcaption.bigTextGroup::after,
	.sQuickstudy .bigTextGroup .normalBG2,
	.sQuickstudy .img::after,
	.sFource .bigTextGroup::after {
		top: 8px; left: 8px;
	}

	.sFource .bigTextGroup::before {
		left: 20px; top: 20px;
	}

}

@media screen and (max-width: 350px){
	.sPrincipal .bigTextGroup::after,
	.js_slickPrincipal .item .text::before,
	.sSchool figure figcaption.bigTextGroup::after,
	.sQuickstudy .bigTextGroup .normalBG2,
	.sFource .bigTextGroup::after {
		display: none;
	}

	.sFuture figure .bigTextGroup .out {
		border:0;
	}

	.js_slickPrincipal .item .text .in {
		height: auto;
	}

	.js_slickPrincipal .item .img .text {
		left: 0; right: 0;
		margin: 0 auto;
	}
}