
@charset "utf-8";
/* ------------------------------------------------------------ common */

body{ min-width: 1400px; color: #313131; }
a { display: block; }
a:link,a:visited,a:hover { color: #fff;}
.SP{ display: none; }

.inner{ width: 1100px;  padding: 0 50px; box-sizing: content-box; }

h3{ font-size: 70px; text-align: center; font-weight: 700; color: #42403c;}
h3 .small{ font-size: 30px;display: inline-block;margin-top: 25px;font-weight: 700;vertical-align: top;}


/* ------------------------------------------------------------ fv */
#fv{ 
	position: relative;
	background: url(../images/bg_fv_2023.jpg?3) no-repeat center center / cover;
	padding: 0;
}
#fv .fv_inner{  box-sizing: border-box; text-align: center;}

#fv .logo{ width: 368px; position: absolute; top: 33px; left: 30px; z-index: 10;}
#fv .logo img{ width: 100%; height: auto; }

#fv .item{ position: relative; display: block; max-width: 1600px; width: 100%; height: auto; margin: 0 auto; box-sizing: content-box; z-index: 1;}
#fv .item.SP{ display: none; }

.btns { display: inline-block; font-size: 18px;font-weight: 700; color: #fff; /*background: #d93924;*/ background: #00A572; border-radius: 30px; width: 400px; line-height: 60px; text-align: center; position: relative; letter-spacing: 0.06em;}
.btns-b { display: inline-block; font-size: 18px;font-weight: 700; color: #00A572 !important; background: #fff; border-radius: 30px; width: 400px; line-height: 60px; text-align: center; position: relative; letter-spacing: 0.06em;}
.btns:after {content: ""; display: block; width: 11px; height:11px; border-top: solid 2px #ffffff; border-right: solid 2px #ffffff; -webkit-transform: rotate(45deg); transform: rotate(45deg); position: absolute;right: 8%; top: 40%;}
.btns-b:after {content: ""; display: block; width: 11px; height:11px; border-top: solid 2px #00A572; border-right: solid 2px #00A572; -webkit-transform: rotate(45deg); transform: rotate(45deg); position: absolute;right: 8%; top: 40%;}
.btns.mail { background: #d93924 url(../images/icn_01.svg) no-repeat 10% center / 28px; padding-left: 20px;}
.btns.long { width: 420px;}

#fv .box { position: relative; display: inline-block;}
#fv .box .human { position: absolute; bottom: 0; left: 0; z-index: 5; width: 100%; height: auto;}
#fv .btns { position: absolute;/* bottom: 10.5%; */bottom: 18.5%;/* right: 211px; */right: 105px;
	z-index: 5; max-width: 690px; width: 43%; min-width: 605px; line-height: 70px; border-radius: 50px; background: #2fa900; filter: drop-shadow(8px 8px 0px rgba(222, 222, 222, 0.6));}
#fv .btns:after { right: 5%;}

/* ------------------------------------------------------------ navigation */
#navigation{ }

#navigation .test { padding: 60px 0 20px; background: #ffffe6;}

#navigation .test .genre { position: relative; display: inline-block; width: 26px; height: 26px; margin-right: 10px;}
#navigation .test .genre em { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); -webkit-transform: translate(-50%,-50%); font-size: 15px; font-weight: 500; color: #fff;}
#navigation .test .typeC { background: #499dea;}
#navigation .test .typeD { background: #33b494;}
#navigation .test .typeP { background: #9357d9;}
#navigation .test .typeS { background: #f4a002;}

#navigation .test h3 { font-size: 43px; margin-bottom: 40px;}
#navigation .test .flex { display: flex; justify-content: center; margin-bottom: 33px;}
#navigation .test .flex p { font-size: 18px; margin: 0 15px;}
#navigation .test .flex p .genre { vertical-align: -6px;}

#navigation .test nav { display: flex; justify-content: space-between; align-items: flex-start; flex-wrap: wrap;}
#navigation .test nav a { display: flex; align-items: center; width: 353px; border-radius: 8px; background: #fff url(../images/icn_arrow.png) no-repeat right 21px center / 15px; border: 1px solid #efefef; margin-bottom: 20px; }
#navigation .test nav a:link,
#navigation .test nav a:hover,
#navigation .test nav a:visited { color: #000; }
#navigation .test nav a .left { width: 62px; padding-bottom: 90px; background-color: #ff7317; background-position: center center; background-repeat: no-repeat; border-radius: 8px 0 0 8px ;}
#navigation .test nav a:nth-child(1) .left { background-image: url(../images/nav_01.svg); background-size: 29px;}
#navigation .test nav a:nth-child(2) .left { background-image: url(../images/nav_02.svg); background-size: 37px;}
#navigation .test nav a:nth-child(3) .left { background-image: url(../images/nav_03.svg); background-size: 42px;}
#navigation .test nav a:nth-child(4) .left { background-image: url(../images/nav_04.svg); background-size: 35px;}
#navigation .test nav a:nth-child(5) .left { background-image: url(../images/nav_05.svg); background-size: 35px;}
#navigation .test nav a:nth-child(6) .left { background-image: url(../images/nav_06.svg); background-size: 32px;}
#navigation .test nav a .right { padding-left: 20px;}
#navigation .test nav a .right p { font-size: 18px;}
#navigation .test nav a .right p .genre { width: 22px; height: 22px; margin-top: 10px; margin-right: 5px;}


#navigation .navi { padding: 30px 0 10px;}
#navigation .navi li{ float: left; width: calc( 100% / 5); text-align: center; border-right: 1px solid #c9c9c9; border-left: 1px solid #c9c9c9; position: relative; margin-left: -1px; margin-bottom: 20px;}
#navigation .navi li:first-of-type{ border-left: 1px solid #c9c9c9; }

#navigation .navi li a{ height: 100px; padding: 32px 26.5px 10px; color: #313131!important; font-size: 18px; line-height: 130%; background: url(../images/icn_arrow.png) center bottom 10px/20px no-repeat; }
#navigation .navi li a small{font-size: 11px;display: block;margin-top: 2px;}
#navigation li:nth-of-type(1) a { padding-top: 5px;}
#navigation li:nth-of-type(2) a,
#navigation li:nth-of-type(3) a { padding-top: 23px;}

/* ------------------------------------------------------------ limited */

#limited{ background: repeating-linear-gradient(-45deg, #fff462, #fff462 5px, #fff898 5px, #fff898 10px); padding: 140px 0 100px;}
#limited .web_campus{ padding: 77px 92px 54px; }
#limited .web_box { position: relative; background: #fff; border-radius: 20px;}
#limited .web_box h3 { position: absolute; top: -44px; left: 50%; transform: translateX(-50%); -webkit-transform: translateX(-50%); width: 874px; font-size: 50px; color: #fff; padding: 20px 0 18px; background: #1654c8; text-align: center;}
#limited .web_campus .box{
	display: flex;
	/* justify-content: space-between; */
	justify-content: center;
	align-items: center;
	padding: 37px 0 28px;
}
#limited .web_campus .box-b { /*width: 89%;*/ margin: 0 15px; line-height: 30px; text-decoration:underline;}
#limited .web_campus .box a{ display: block; background: #ea5c8a; width: 320px; line-height: 60px; border-radius: 30px; text-align: center; color: #ffffff; font-size: 18px; font-weight: 700;}
#limited .web_campus .box .download { background: #ea5c8a url(../images/icon_01.svg) no-repeat center left 68px; background-size: 20px; padding-left: 20px;}
#limited .web_campus .box p{font-size: 25px;font-weight: 700; line-height: 1.3; color: #42403c; font-feature-settings: "palt";}
#limited .web_campus .box p small { font-size: 16px; padding-left: 15px;}
#limited .web_campus .box.anke p { font-size: 25px;font-weight: 700; color: #42403c; line-height: 2;}
#limited .web_campus .box.anke a { display: block; background: #fff462 url(../images/icn_arrow2.png) no-repeat center 75% / 18px; width: 400px; line-height: 1; padding: 21px 0 42px; border-radius: 0; text-align: center; color: #000; font-size: 18px; font-weight: 500;}

#limited .web_campus .explanation{font-size: 16px; color: #4f4d49; line-height: 1.4; padding: 34px 0 0 ;}

#limited h4 { background: url(../images/pic_09.png) no-repeat; background-size: auto 100%; font-size: 50px; font-weight: 700; padding: 0 0 0 180px; line-height: 130%;}
#limited h4 span { font-size: 50px; font-weight: 700; color: #0091db; }
#limited .web_campus .box p { margin: 0 15px; background: #29a9f2; padding: 20px; border-radius: 20px; color: #fff; }


#psychological_health {
	background: #00A572;
	padding: 35px 0;
}

#psychological_health .psychology {
	text-align: center;
    font-size: 30px;
    /* margin-top: 65px; */
}

#psychological_health .psychology h5 {
	font-size: 72px;
    margin-top: 15px;
    line-height: 61px;
    color: #fff;
    letter-spacing: 0.07em;
	line-height: 92px;
}

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

	#psychological_health .psychology {
		width: 90%;
		margin: 0 auto;
	}

	#psychological_health .psychology h5 {
		font-size: 31px;
		line-height: 42px;
	}

	#psychological_health .psychology h5 img {
		width: 100%;
		/* margin: 0 auto; */
	}

	#psychological_health .btns-b {
		width: 100%;
		line-height: 50px;
    font-size: 13px;
    border-radius: 30px;
	}
}

/* 
#psychological_health .psychology h5 span {

} */

/* ------------------------------------------------------------ content */

.contents { 
	/* padding: 100px 0 148px; */
	padding: 96px 0 148px;
	text-align: center;
	background-image: repeating-linear-gradient( 90deg, #ffdcd1 , #ffdcd1 1px, transparent 1px, transparent 8px), repeating-linear-gradient( 0deg, #ffdcd1 , #ffdcd1 1px, #fff 1px, #fff 8px);}
.contents.type2 {background-image: repeating-linear-gradient( 90deg, #f9e1b0 , #f9e1b0 1px, transparent 1px, transparent 8px), repeating-linear-gradient( 0deg, #f9e1b0 , #f9e1b0 1px, #fff 1px, #fff 8px);}
#introduction { background: #ffffe6;}


.examination .genre { font-size: 20px; color: #fff; padding: 8px 17px 10px; border-radius: 10px;}
.examination .typeC { background: #499dea;}
.examination .typeD { background: #33b494;}
.examination .typeP { background: #9357d9;}
.examination .typeS { background: #f4a002;}

.contents .top { margin-bottom: 60px;}
.contents .top h3 { position: relative; z-index: 1; font-size: 70px; font-weight: 700; color: #fff; text-align: center; width: 658px; margin: 0 auto 30px; padding: 13px 0 17px;}
.examination .top h3 { font-size: 60px;}
.examination .top h3 small { display: block; font-size: 36px; margin-top: 5px;}
.contents .top h3:before { transform: skewX(-20deg); content: ""; position: absolute; top: 0; bottom: 0; left: 0; right: 0; z-index: -1;    background-image: -moz-linear-gradient( -62deg, rgba(247,92,72,0.99608) 0%, rgb(255,15,71) 100%); background-image: -webkit-linear-gradient( -62deg, rgba(247,92,72,0.99608) 0%, rgb(255,15,71) 100%); background-image: -ms-linear-gradient( -62deg, rgba(247,92,72,0.99608) 0%, rgb(255,15,71) 100%); filter: drop-shadow(12px 12px 0px rgba(222, 222, 222, 0.6)); }
.contents .top .subt { font-size: 36px; font-weight: 700; letter-spacing: 0.08em; margin-bottom: 30px;}
.contents .top .middle { font-size: 23px; font-weight: 700; letter-spacing: 0.08em; margin-bottom: 60px;}
.contents .top .balloon { font-size: 23px; letter-spacing: 0.08em; font-weight: 700; padding: 16px 0 38px; background: url(../images/bg_01.png) no-repeat center top / contain; margin-bottom: 35px;}
.contents .top .flex { display: flex; justify-content: center;}
.contents .top .flex .item { display: flex; justify-content: space-between; align-items: center; background: #fff; margin: 0 13px;}
.contents .top .flex .item .left {  background: #ff0f47; padding: 20px 18px; text-align: center; color: #fff;}
.contents .top .flex .item .left p { font-size: 20px; font-weight: 700;}
.contents .top .flex .item .right { padding: 10px 20px; text-align: center;}
.contents .top .flex .item .right p { }
.contents .top .flex .item .right p .genre { margin: 0 5px;}

.contents .box { padding: 80px 50px 80px; margin: 0; background-color: #fff;}

.contents .box .con { padding-bottom: 80px; margin-bottom: 72px; background: url(../images/border.jpg) repeat-x left bottom / 17px;}
.contents .box .con:last-child { padding-bottom: 0; margin-bottom: 0; background-image: none;}
.contents .box .con h4 { font-size: 43px; color: #ff0f47; font-weight: 700; line-height: 100%; margin-bottom: 30px; font-feature-settings: "palt";}
.contents .box .con h4 .attention,
.contents .box .con h4 .new { display: inline-block; margin-left: 15px; font-size: 23px; font-weight: 700; color: #000; width: 68px; line-height: 43px; background: #fff600; vertical-align: 5px;}
.contents .box .con h4 .subti { display: block; font-size: 24px; font-weight: 700; margin-top: 10px;}

.contents .box .con .system { display: flex; justify-content: center; align-items: center; margin-bottom: 30px;}
.contents .box .con .system .genre { display: block; margin: 0 5px;}
.contents .box .con .txt { font-size: 20px; line-height: 150%; margin-bottom: 40px;}
.contents .box .con .btns { background-color: #2fa900; margin-top: 60px;}

.contents .box .con .online {
	background: url(../images/border.jpg) repeat-x left bottom / 17px;
	padding-bottom: 70px;
	margin-bottom: 70px;
}

.contents .box .con .online h4 br {
	display: none;
}

.contents .box .con .online h4 .tyu {
	display: inline-block;
    padding: 2px 7px 5px;
    font-size: 30px;
    background-color: #ff0f47;
    color: #fff;
    border-radius: 5px;
    margin-left: 10px;
	font-weight: bold;
}

.contents .box .con .online p {
	/* color: #ff0f47;
	font-size: 20px;
	line-height: 25px;
	margin-bottom: 20px;
	font-weight: bold; */

	font-size: 20px;
    line-height: 150%;
    margin-bottom: 40px;
}

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

	.contents .box .con .online h4 br {
		display: block;
	}

	.contents .box .con .online p {
		font-size: 13px;
    	line-height: 19px;
	}

	.contents .box .con .online img {
		width: 100%;
	}

	.contents .box .con .online {
	    margin-bottom: 45px;
	}

	.contents .box .con .online h4 .tyu {
		font-size: 15px;
	}
}

.contents .box .swiper-tabs { width: 100%; position: relative;}
.contents .box .tab-menu { margin-bottom: 6px;}
.contents .box .tab-menu .swiper-wrapper { display: flex; justify-content: space-between; }
.contents .box .tab-menu .swiper-slide { position: relative; width: 138px; height: 62px; text-align: center; cursor: pointer; border-radius: 10px 10px 0 0; background: #7d7d7d;}
.contents .box .tab-menu .swiper-slide p { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); -webkit-transform: translate(-50%,-50%); font-size: 15px; color: #fff; line-height: 1.333; margin-bottom: 0; width: 100%;}

.contents .box .tab-menu .swiper-slide1.swiper-slide-thumb-active { background: #7d5a9e;}
.contents .box .tab-menu .swiper-slide2.swiper-slide-thumb-active { background: #3d63ac;}
.contents .box .tab-menu .swiper-slide3.swiper-slide-thumb-active { background: #019be1;}
.contents .box .tab-menu .swiper-slide4.swiper-slide-thumb-active { background: #039e9a;}
.contents .box .tab-menu .swiper-slide5.swiper-slide-thumb-active { background: #c75353;}
.contents .box .tab-menu .swiper-slide6.swiper-slide-thumb-active { background: #0067b4;}
.contents .box .tab-menu .swiper-slide7.swiper-slide-thumb-active { background: #003f97;}
.contents .box .tab-menu .swiper-slide8.swiper-slide-thumb-active { background: #007fcc;}
.contents .box .tab-menu .swiper-slide9.swiper-slide-thumb-active { background: #009bba;}
.contents .box .tab-menu .swiper-slide10.swiper-slide-thumb-active { background: #ec8101;}
.contents .box .tab-menu .swiper-slide11.swiper-slide-thumb-active { background: #d93a27;}
.contents .box .tab-menu .swiper-slide12.swiper-slide-thumb-active { background: #ed5083;}
.contents .box .tab-menu .swiper-slide13.swiper-slide-thumb-active { background: #43b232;}
.contents .box .tab-menu .swiper-slide14.swiper-slide-thumb-active { background: #01a570;}
.contents .box .tab-menu .swiper-slide15.swiper-slide-thumb-active { background: #a94b87;}

.contents .box #movie1 .tab-menu .swiper-slide { width: 63.8px;}
.contents .box #movie2 .tab-menu .swiper-slide { width: 66px;}
.contents .box #movie3 .tab-menu .swiper-slide { width: 33%;}
.contents .box #movie4 .tab-menu .swiper-slide { width: 49.5%;}
.contents .box #movie5 .tab-menu .swiper-slide { width: 88px;}


.contents .box #movie5 .tab-menu .swiper-slide:nth-of-type(2) p,
.contents .box #movie5 .tab-menu .swiper-slide:nth-of-type(3) p { font-size: 12px;}

.contents .box .tab-contents .swiper-slide { width: 100%; height: 563px;}


.contents .box .btns2 .btns { margin: 58px 20px 0;}
.contents .box .tab-menu .swiper-slide { width: 122px;}


/*
.examination .box .con .flex{ display: b; justify-content: space-between; }
.examination .box .con .txt { width: 40%;line-height: 190%; text-align: left;}
.examination .box .con .youtube{ width: 50%; }
*/
.examination .box .con .u-youtube-wrap{ position: relative; /* padding-bottom: 56.25%; */ height: 0;  overflow: hidden; }
.examination .box .con .js-youtube-replace{ position: absolute; top: 0; left: 0; width: 100%; height: 100%; }


#introduction .box .con .caution { padding-top: 10px;}

/* ------------------------------------------------------------ cta */

.cta { /*background: #76C1E5;*/ text-align: center;}
.cta img{ max-width: 100%; height: auto; margin: 0 auto; }
.application img{ width: 100%; }

#cta .box{ 
	position: relative;
	background: url(../images/bg_fv_2023.jpg) no-repeat center center / cover;
	padding: 0;
}
#cta .btns { position: absolute; bottom: 18.5%; left: calc(50% - 60px); z-index: 5; max-width: 690px; width: 43%; min-width: 605px; line-height: 70px; border-radius: 50px; background: #2fa900; filter: drop-shadow(8px 8px 0px rgba(222, 222, 222, 0.6));}
#cta .btns:after { right: 5%;}



/* ------------------------------------------------------------ mobile ------------------------------------------------------------ */
@media only screen and (max-width: 768px) {

/* ------------------------------------------------------------ common */
	body{ width: 100%; min-width: 100%; }
	
	.SP{ display: block; }
	.PC{ display: none; }
	
	.inner{ width: 90%; padding: 0; }

	h3{ font-size: 40px;}
	h3 .small{ font-size: 20px;margin-top: 20px;}


/* ------------------------------------------------------------ fv */
	#fv{ background:none; padding: 0 0 ; overflow: hidden;}
	#fv .fv_inner{ height: 100%;}
	
	#fv .logo{ width: 55%; top: 15px; left: 15px; }
	
	#fv .item{ width: 100%; height: auto; padding-left: 0;}
	#fv .item.SP{ display: block; }
	#fv .item.PC{ display: none; }
	

	.btns{ width: 100%; line-height: 50px; font-size: 13px; border-radius: 30px;}
	.btns:after{ width: 9px; height: 9px;  }
	.btns.mail { background: #d93924 url(../images/icn_01.svg) no-repeat 10% center / 16px; padding-left: 20px;}
	.btns.long { font-size: 12px; width: 100%;}
	#fv .btns { 
		position: absolute;
		/* bottom: 31%; */
		bottom: 13%;
		/* left: 50%; */
		left: 44%;
		right: auto;
		transform: translateX(-50%); -webkit-transform: translateX(-50%); z-index: 5; font-size: 12px; max-width: none; width: 82%; min-width: auto; line-height: 45px; border-radius: 50px; padding-right: 10px;}
	#fv .btns:after { right: 4%;}


/* ------------------------------------------------------------ navigation */
	#navigation{ }
	#navigation nav{ width: 100%; }
	
	#navigation .test { padding: 40px 0 20px; background: #ffffe6;}

	#navigation .test .genre { position: relative; display: inline-block; width: 18px; height: 18px; margin-right: 5px;}
	#navigation .test .genre em { font-size: 12px; font-weight: 500; color: #fff;}
	
	#navigation .test h3 { font-size: 30px; margin-bottom: 20px;}
	#navigation .test .flex { justify-content: center; flex-wrap: wrap; margin-bottom: 15px;}
	#navigation .test .flex p { width: 50%; font-size: 12px; margin: 0 0 5px;}
	#navigation .test .flex p .genre { vertical-align: -4px;}
	
	#navigation .test nav { display: block;}
	#navigation .test nav a { display: flex; align-items: center; width: 100%; border-radius: 8px; background: #fff url(../images/icn_arrow.png) no-repeat right 21px center / 15px; border: 1px solid #efefef; margin-bottom: 20px; }
	#navigation .test nav a:hover { color: inherit; }
	#navigation .test nav a .left { width: 62px; padding-bottom: 80px; background-color: #ff7317; background-position: center center; background-repeat: no-repeat; border-radius: 8px 0 0 8px ;}
	#navigation .test nav a:nth-child(1) .left { background-image: url(../images/nav_01.svg); background-size: 29px;}
	#navigation .test nav a:nth-child(2) .left { background-image: url(../images/nav_02.svg); background-size: 37px;}
	#navigation .test nav a:nth-child(3) .left { background-image: url(../images/nav_03.svg); background-size: 42px;}
	#navigation .test nav a:nth-child(4) .left { background-image: url(../images/nav_04.svg); background-size: 35px;}
	#navigation .test nav a:nth-child(5) .left { background-image: url(../images/nav_05.svg); background-size: 35px;}
	#navigation .test nav a:nth-child(6) .left { background-image: url(../images/nav_06.svg); background-size: 32px;}
	#navigation .test nav a .right { padding-left: 15px;}
	#navigation .test nav a .right p { font-size: 15px;}
	#navigation .test nav a .right p .genre { width: 18px; height: 18px; margin-top: 10px; margin-right: 5px;}
	
	
	#navigation .navi li{ /*width: 50%;*/ width: 33.333%; font-feature-settings: "palt"; }
	
	#navigation .navi li a { height: 88px; padding: 16px 0 0; font-size: 12px; background: url(../images/icn_arrow.png) center bottom 5px/15px no-repeat; line-height: 1.417; }
	#navigation .navi li a small {font-size: 10px;}
/*	#navigation .navi li:last-child a { padding-top: 25px;}*/
	#navigation .navi li:nth-child(4),
	#navigation .navi li:nth-child(5) {width: 50%;}
	#navigation .navi li:nth-child(4) a,
	#navigation .navi li:nth-child(5) a { height: 48px; padding-top: 8px; }
	
/* ------------------------------------------------------------ limited */

	#limited{ padding: 50px 0 ;}
	#limited .web_campus{ border-radius: 15px;  padding: 60px 25px 35px ; background: #ffffff;}
	#limited .img { width: 100%; margin: 0 auto 20px;}
	#limited .img img { width: 100%; height: auto;}
	#limited .web_box{ }
	#limited .web_box h3 { top: -24px; width: 80%; font-size: 20px; line-height: 130%; padding: 10px 0 10px; }
	#limited .web_campus .box{display: flex; flex-direction: column; padding: 27px 0 0;}
	#limited .web_campus .box:nth-child(1){padding: 0 0 28px;}
	#limited .web_campus .box a{ background: #ea5c8a url(../images/icon_01.svg) no-repeat center left 28px; background-size: 15px; width: 100%; padding-left: 10px; line-height: 50px;  font-size: 13px; box-shadow: 0px 2px 10px 3px rgba(0,0,0,0.2);}
	#limited .web_campus .box p { font-size: 20px; margin: 0 0 20px; line-height: 140%;}
	#limited .web_campus .box p small { display: block; font-size: 14px;}
	#limited .web_campus .box.anke p { font-size: 20px; line-height: 2;}
	#limited .web_campus .box.anke a { background: #fff462 url(../images/icn_arrow2.png) no-repeat center 75% / 18px; width: 100%; line-height: 1; padding: 15px 0 32px; border-radius: 0; color: #000; font-size: 13px; font-weight: 500;}

	#limited .web_campus .explanation { font-size: 12px; padding: 20px 0 0; line-height: 180%;}
	
	
	#limited h4 { background: url(../images/pic_09.png) no-repeat calc(50% - 10px) top; background-size: auto 100px; font-size: 26px; font-weight: 700; padding: 120px 0 0 ; line-height: 130%; text-align: center;}
#limited h4 span { font-size: 26px; font-weight: 700; color: #0091db; }
#limited .web_campus .box p { background: #29a9f2; padding: 20px; border-radius: 20px; color: #fff; width: 100%; font-size: 1.14em;}
	
	
/* ------------------------------------------------------------ content */
	
	.contents { padding: 50px 0;}
	.examination .genre { font-size: 12px; padding: 8px 17px 10px; border-radius: 5px;}
	.examination .typeC { background: #499dea;}
	.examination .typeD { background: #33b494;}
	.examination .typeP { background: #9357d9;}
	.examination .typeS { background: #f4a002;}
	
	.contents .top { margin-bottom: 40px;}
	.contents .top h3 { font-size: 30px; width: 90%; margin-bottom: 30px; padding: 13px 0 17px;}
	.examination .top h3 { font-size: 28px;}
	.examination .top h3 small { display: block; font-size: 18px; margin-top: 5px;}
	.contents .top .subt { font-size: 24px; margin-bottom: 20px;}
	.contents .top .middle { font-size: 16px; margin-bottom: 0;}
	.contents .top .balloon { font-size: 14px; padding: 11px 0 24px; margin-bottom: 20px;}
	.contents .top .flex { display: block;}
	.contents .top .flex .item { display: flex; justify-content: space-between; align-items: center; background: #fff; margin: 0 auto 10px;}
	.contents .top .flex .item .left { width: 35%; padding: 20px 0; text-align: center;}
	.contents .top .flex .item .left p { font-size: 14px; font-weight: 700;}
	.contents .top .flex .item .right { width: 65%; padding: 10px 10px; text-align: center;}
	/* .contents .top .flex .item .right p { } */
	.contents .top .flex .item .right p .genre { margin: 0 5px;}
	
	.contents .box { padding: 35px 25px 40px; margin: 0; background-color: #fff;}
	
	.contents .box .con { padding-bottom: 50px; margin-bottom: 45px; background: url(../images/border.jpg) repeat-x left bottom / 17px;}
	.contents .box .con:last-child { padding-bottom: 0; margin-bottom: 0; background-image: none;}
	.contents .box .con h4 { font-size: 20px; line-height: 150%; margin-bottom: 14px;}
	.contents .box .con h4 .attention,
	.contents .box .con h4 .new { margin-left: 5px; font-size: 12px; width: 33px; line-height: 21px; vertical-align: 0.2em;}
	.contents .box .con h4 .subti { font-size: 15px; margin-top: 4px;}

	.contents .box .con .system { display: block; justify-content: center; align-items: center; margin-bottom: 15px;}
	.contents .box .con2 .system { display: flex;}
	.contents .box .con .system .genre { display: inline-block; margin: 0 5px 5px;}
	
	.contents .box .con .txt { font-size: 13px; line-height: 180%; margin-bottom: 25px;}
	.contents .box .con .btns { background-color: #2fa900; margin-top: 30px;}
	
	.contents .box .swiper-tabs { width: 100%; position: relative;}
	.contents .box .swiper-tabs .tab-contents { overflow: hidden; }
	.contents .box .tab-menu .swiper-wrapper { width: 508px; display: flex; justify-content: space-between;  margin-bottom: 6px;}
	.contents .box #movie3 .tab-menu .swiper-wrapper,
	.contents .box #movie4 .tab-menu .swiper-wrapper{ width: 100%;}
	.contents .box .tab-menu .swiper-slide { position: relative; width: 70px; height: 65px;  border-radius: 5px 5px 0 0;}
	.contents .box .tab-menu .swiper-slide p { font-size: 12px; line-height: 1.417;}
	.contents .box .tab-contents .swiper-slide { width: 100%; height: auto; aspect-ratio: 16 / 9;}
	.contents .box #movie1 .tab-menu .swiper-slide { width: 63.8px;}
	.contents .box #movie2 .tab-menu .swiper-slide { width: 66px;}
	.contents .box #movie3 .tab-menu .swiper-slide { width: 32%;}
	.contents .box #movie4 .tab-menu .swiper-slide { width: 48%;}
	.contents .box #movie5 .tab-menu .swiper-slide { width: 70px;}
	#content2 .box .tab-menu .swiper-slide { width: 70px;}
	
	.contents .box #movie5 .tab-menu .swiper-slide:nth-of-type(2) p,
	.contents .box #movie5 .tab-menu .swiper-slide:nth-of-type(3) p { font-size: 10px;}
	
	
	.contents .box .btns2 .btns { margin: 30px auto 0;}
	#content2 .box .con2 .btns:last-child { margin: 15px auto 0;}

	#content1 { background-color: #ffe6ee; background-image: repeating-linear-gradient(-45deg,#ffeaf1, #ffeaf1 7px,transparent 0, transparent 14px);}
	#content2 { padding-top: 50px; background-color: #cdf4f3; background-image: repeating-linear-gradient(-45deg,#d5f6f5, #d5f6f5 7px,transparent 0, transparent 14px);}
	#content3 { padding-top: 50px; background-color: #baefee; background-image: repeating-linear-gradient(-45deg,#c3f5f4, #a4dedc 7px,transparent 0, transparent 14px);}
	#content1 h3 { padding: 98px 0 10px; margin-bottom: 20px; background: url(../images/bg_01_sp.png) no-repeat center top / 100%;}
	#content1 h3. { padding: 98px 0 10px; margin-bottom: 20px; background: url(../images/bg_01_sp.png) no-repeat center top / 100%;}
	#content2 h3 { padding: 98px 0 10px; margin-bottom: 20px; background: url(../images/bg_02_sp.png) no-repeat center top / 100%;}
	#content3 h3 { padding: 98px 0 10px; margin-bottom: 20px; background: url(../images/bg_02_sp.png) no-repeat center top / 100%;}

	#content1 .box .con1:after { height: 5px; background: url(../images/border_01.jpg) repeat-x left center / 9px; margin-top: 50px;}
	#content2 .box .con1:after { height: 5px; background: url(../images/border_02.jpg) repeat-x left center / 9px; margin-top: 50px;}
	
	
	#preparation.contents .box .con .flex{ flex-direction: column; }
	#preparation.contents .box .con .txt{ width: 100%; margin-bottom: 20px; }
	#preparation.contents .box .con .youtube{ width: 100%; }
	
	#introduction .box .con .caution small { font-size: 10px;}
	
	/* ------------------------------------------------------------ cta */
	#cta{ background:none; padding: 0 0 ; overflow: hidden;}
	
	#cta .btns { position: absolute; bottom: 16%; left: 50%; right: auto; transform: translateX(-50%); -webkit-transform: translateX(-50%); z-index: 5; font-size: 12px; max-width: none; width: 82%; min-width: auto; line-height: 45px; border-radius: 50px; padding-right: 10px;}
	#cta .btns:after { right: 4%;}


}



/* ----------------------------- */
.u-youtube-wrap { position: relative; width: 100%; padding-top: 56.2%; }
.u-youtube-wrap iframe, .u-youtube-wrap img.replace { position: absolute; top: 0; right: 0; width: 100% !important; height: 100% !important; }
.u-youtube-wrap img.replace {  object-fit: cover; }
/* .u-youtube-wrap .js-youtube-replace:before { display: block; content: ""; background: url(../images/icn_play.png) no-repeat center; background-size: 100px; width: 100px; height: 100px; position: absolute; left: 0; top: 0; right: 0; bottom: 0; margin: auto; z-index: 1; } */

@media screen and (max-width: 767px) {
  .u-youtube-wrap { position: relative; width: 100%; padding-top: 56.2%; }
  .u-youtube-wrap iframe { position: absolute; top: 0; right: 0; width: 100% !important; height: 100% !important; }
/*   .u-youtube-wrap .js-youtube-replace:before { background-size: 50px; width: 50px; height: 50px;} */

}





@media screen and (min-width: 768px) {
	.sp-only {display: none !important;}
}
@media screen and (max-width: 767px) {
	.pc-only {display: none !important;}
}

/*=======================================
ÇóÈË—ÊË÷¥Ü¥¿¥ó
=========================================*/
.l-application {
    position: fixed;
    right: 25px;
    bottom: 25px;
    z-index: 999;
}
.l-application a {
    display: flex;
    justify-content: center;
    align-items: center;
    background: #2fa900;
    border-radius: 100%;
    color: #fff;
    text-align: center;
    font-size: 18px;
    line-height: 1.6;
    letter-spacing: 0.05em;
    text-decoration: none;
    font-weight: 700;
    width: 140px;
    height: 140px;
    transition: .6s ease all;
    box-shadow: 3px 3px 8px rgba(0,0,0,.2);
    position: relative;
    left: 0;
    top: 0;
}
.l-application a:hover {
    opacity: 1;
    background-position: right center;
}
.l-application span {
    display: inline-block;
    background: url(../images/arrow_4-white.svg) no-repeat center bottom;
    background-size: 8px 20px;
    margin-top: 10px;
    padding-bottom: 24px;
}


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

	.l-application {
	    right: 0;
	    bottom: 0;
	    width: 100%;
	}
	.l-application a {
	    width: 100%;
	    height: 50px;
	    font-size: 18px;
	    box-shadow: none;
	    border-radius: 0;
	}
	.l-application span {
	    background-size: 8px 20px;
	    background-position: right center;
	/*    padding-top: 0;*/
	    padding-bottom: 0;
	    padding-right: 25px;
	    margin-top: 0;
	}

}