@charset "utf-8";

/*--------------------------------------------------------------------------------------------------

   page
			   - index
						- course
						- curriculum
						- staff

--------------------------------------------------------------------------------------------------*/



/*------------------------------------------------------------------------------------------------
  index
--------------------------------------------------------------------------------------------------*/
#mainVisual {
	position: relative;
	background: url(../image/back-01.png) no-repeat 0 0;
}

#mainVisual .image {
	position: relative;
	width: 80%;
	margin-left: auto;
}

#mainVisual .image .photo {
	text-align: right;
}

#mainVisual .image .photo img {
	max-width: 100%;
	height: auto;
}

/*@media screen and (min-width:1281px) {
#mainVisual .image .tokusetu {
	position: absolute;
	top: 12%;
	left: 20%;
}
}


#mainVisual .image h2 img {
	width: 80%;
}

#mainVisual .image .tokusetu img {
	width: 80%;
}

#mainVisual .image ul li {
	margin: 0 0 10px;
	padding: 0;
}

#mainVisual .image ul li span {
	display: inline-block;
	font-weight: 700;
	font-size: 24px;
	padding: 0 16px;
	background-color: #FFF;
}

#mainVisual .scroll {
	position: absolute;
	bottom: -20px;
	right: 10%;
}
*/

.scrolltop {
	position: absolute;
	top: 636px;
	right: 5%;
	z-index: 20;
	width: 52px;
	animation: fuwa 1.4s infinite;
	animation-timing-function: ease-in-out;
	animation-direction: alternate;
}


@keyframes fuwa {
  0% {
    transform: translate(0,0px);
  }
  100% {
    transform: translate(0,-30px)
  }
}


@media screen and (min-width: 1200px) and ( max-width:1300px) {
#mainVisual .image h2 {
	position: absolute;
	top: 10%;
	left: -6%;
}
	
#mainVisual .image ul {
	position: absolute;
	bottom: 15%;
	left: -6%;
	margin: 0;
	padding: 0;
	list-style: none;
}

#mainVisual .image .text {
	position: absolute;
	bottom: 4%;
	left: 5%;
	font-weight: 500;
	font-size: 20px;
}

#mainVisual .image .tokusetu {
	position: absolute;
	top: 20px;
	left: 20%;
}

}

@media screen and (min-width: 1301px) and ( max-width:1400px) {
#mainVisual .image h2 {
	position: absolute;
	top: 15%;
	left: -6%;
}
	
#mainVisual .image ul {
	position: absolute;
	bottom: 15%;
	left: -6%;
	margin: 0;
	padding: 0;
	list-style: none;
}

#mainVisual .image .text {
	position: absolute;
	bottom: 4%;
	left: 5%;
	font-weight: 500;
	font-size: 20px;
}

#mainVisual .image .tokusetu {
	position: absolute;
	top: 50px;
	left: 20%;
}
}

@media screen and (min-width: 1401px) and ( max-width:1600px) {

#mainVisual .image h2 {
	position: absolute;
	top: 20%;
	left: -6%;
}

#mainVisual .image ul {
	position: absolute;
	bottom: 16%;
	left: -6%;
	margin: 0;
	padding: 0;
	list-style: none;
}

#mainVisual .image .text {
	position: absolute;
	bottom: 4%;
	left: 5%;
	font-weight: 500;
	font-size: 20px;
}

#mainVisual .image .tokusetu {
	position: absolute;
	top: 12%;
	left: 18%;
}

}


@media screen and (min-width:1601px) {
	
#mainVisual .image h2 {
	position: absolute;
	top: 20%;
	left: -6%;
}

#mainVisual .image ul {
	position: absolute;
	bottom: 24%;
	left: -6%;
	margin: 0;
	padding: 0;
	list-style: none;
}

#mainVisual .image .text {
	position: absolute;
	bottom: 10%;
	left: 5%;
	font-weight: 500;
	font-size: 20px;
}

#mainVisual .image .tokusetu {
	position: absolute;
	top: 12%;
	left: 18%;
}

}

#intro {
	padding: 100px 0 0;
	background: url(../image/back-02.png) no-repeat center 0;
	display: flex;
}

#intro .image {
	width: 50%;
	margin: 0 0 0 40px;
}

#intro .image ul {
	margin: 0;
	padding: 0;
	list-style: none;
	display: flex;
	justify-content: center;
}

#intro .image ul li {
	width: 48%;
	margin: 0 1%;
	padding: 0;
	text-align: right;
}

#intro .image ul li:nth-child(2) {
	margin-top: 80px;
	text-align: left;
}

#intro .image ul li img {
	max-width: 100%;
}

#intro .text {
	width: 50%;
	max-width: 500px;
	padding: 80px 0 0 100px;
}

#intro .text h2 {
	color: #142850;
	font-weight: 700;
	font-size: 25px;
	margin: 0 0 20px;
	letter-spacing: 0.05em;
}

#intro .text p {
	margin: 0 0 16px;
	line-height: 2;
}

#indexCourse {
	position: relative;
	padding: 100px 0 0;
}

#indexCourse:before {
	position: absolute;
	top: 0;
	right: 60px;
	content: "";
	background: url(../image/back-03.png) no-repeat 0 0;
	width: 173px;
	height: 173px;
}

#indexCourse h2 {
	font-size: 32px;
	font-weight: 700;
	color: #142850;
	letter-spacing: 0.05em;
	text-align: center;
	margin: 0 0 48px;
}

#indexCourse h2 span {
	font-size: 16px;
	font-family: 'Lato', sans-serif;
	display: block;
}

#indexCourse .wrap {
	position: relative;
}

#indexCourse .wrap:before {
	position: absolute;
	top: 224px;
	right: 0;
	width: 92%;
	min-height: 800px;
	margin: 0 0 0 auto;
	background-color: #218FD2;
	content: "";
	z-index: -1;
}

#indexCourse .wrap .content {
	width: 1160px;
	margin: 0 auto;
}

#indexCourse .wrap .content ul {
	margin: 0;
	padding: 0;
	list-style: none;
	display: flex;
	justify-content: space-between;
}

#indexCourse .wrap .content ul li {
	text-align: center;
	color: #FFF;
}

#indexCourse .wrap .content ul li img {
	margin-bottom: 36px;
}

#indexCourse .wrap .content ul li h3 {
	margin: 0 0 24px;
	font-size: 22px;
	line-height: 1.3;
}

#indexCourse .wrap .content ul li p {
	line-height: 1.8;
}

#indexCourse .wrap .content ul li:nth-child(2) {
	margin-top: 42px;
}

#indexCourse .wrap .content ul li:nth-child(3) {
	margin-top: 84px;
}

#indexCourse .special {
	position: relative;
	width: 100%;
	height: 300px;
	z-index: -10;
	background: url(../image/back-01.png) #E5F4F8 no-repeat 0 0;
}

#indexCourse .banner {
	position: relative;
	background: url(../image/banner_sports.png) no-repeat 0 0;
	width: 920px;
	height: 290px;
	top: -230px;
	display: block;
	margin: 0 auto;
}

#indexCourse .banner::before {
	background: url(../image/focus.png) no-repeat 0 0;
	width: 106px;
	height: 67px;
	position: absolute;
	top: -60px;
	left: -80px;
	content: "";
	animation-name: rotatefocus;
 animation-duration: 3s;
	animation-iteration-count: infinite;
}

#indexCourse .bannersp {
	display: none;
}

@keyframes rotatefocus{
  0% {
    transform: rotateZ(0);
  }
		33% {
    transform: rotateZ(0);
		}
  100% {
    transform: rotateZ(360deg);
  }
}

#indexCourse .banner .arrowbtn2 {
	position: absolute;
	top: 160px;
	left: 110px;
}

#indexCourse .menus {
	margin: -320px 0 0;
	padding: 180px 0 120px;
	background: url(../image/back-04.png) #E5F4F8 no-repeat 100% 100%;
}

#indexCourse .menus ul {
	width: 1060px;
	margin: 0 auto;
	padding: 0;
	list-style: none;
	display: flex;
	justify-content: space-between;
}

#indexCourse .menus ul li {
	margin: 0;
	padding: 0;
	border-bottom: 1px solid #828282;
}

#indexCourse .menus ul li a {
	color: #000;
	text-decoration: none;
	font-size: 18px;
}

#indexCourse .menus ul li img {
	display: block;
}

#indexCourse .menus ul li h3 {
	position: relative;
	padding: 20px 10px;
	font-weight: 500;
}

#indexCourse .menus ul li h3:before {
	position: absolute;
	top: calc( 50% - 4px);
	right: 16px;
	width: 40px;
 height: 8px;
	content: "";
 border-bottom: 1px solid #828282;
 border-right: 1px solid #828282;
 transform: skew(45deg);
	transition: all .3s;
}

#indexCourse .menus ul li a:hover h3:before {
	right: 8px;
	border-color: #218FD2;
}

#indexCourse .pamphlet {
	padding: 120px 0;
	background: url(../image/back-05.png) no-repeat center 100%;
	background-size: cover;
	text-align: center;
}

#indexCourse .pamphlet a img {
	transition: all .3s ease;
}

#indexCourse .pamphlet a:hover img {
	opacity: .8;
}


/*------------------------------------------------------------------------------------------------
  course
--------------------------------------------------------------------------------------------------*/
#second.course {
}

#second.course .pagettl .wrap:before {
	position: absolute;
	width: 100%;
	height: 320px;
	top: 0;
	right: 0;
	content: "";
	background: url(../image/course_back.jpg) no-repeat center 90%;
	background-size: cover;
	z-index: -10;
}

#second.course .content h2 span {
	float: right;
	color: rgba(255, 255, 255, 0.7);
}

#second.course .content .newCourse {
	position: relative;
	margin: -60px 0 0;
}

#second.course .content .newCourse:before {
	content: "NEW";
	position: relative;
	display: block;
	width: 60px;
	height: 60px;
	top: 16px;
	left: -20px;
	background-color: #FF0;
	color: #142850;
	border-radius: 50%;
	font-weight: 700;
	text-align: center;
	line-height: 60px;
	font-size: 20px;
	z-index: 15;
	transform:rotate(-15deg); 
}

#second.course .content .newCourse a {
	position: relative;
	display: block;
	width: 480px;
	text-decoration: none;
	text-align: center;
	padding: 12px 8px;
	border: 2px solid #142850;
	line-height: 1.4;
	margin: 20px 0 0;
	border-radius: 40px;
	color: #000;
}

#second.course .content .newCourse a:before {
	position: absolute;
	top: calc( 50% - 4px);
	right: 24px;
	width: 40px;
 height: 8px;
	content: "";
 border-bottom: 1px solid #828282;
 border-right: 1px solid #828282;
 transform: skew(45deg);
	transition: all .3s;
}

#second.course .content .newCourse a:hover {
	background-color: #142850;
	color: #FFF;
}

#second.course .content .newCourse a:hover:before {
	right: 16px;
	border-color: #FFF;
}




/*------------------------------------------------------------------------------------------------
  curriculum
--------------------------------------------------------------------------------------------------*/

#second.curriculum {
}

#second.curriculum .pagettl .wrap:before {
	position: absolute;
	width: 100%;
	height: 320px;
	top: 0;
	right: 0;
	content: "";
	background: url(../image/curriculum_back.jpg) no-repeat 0 60%;
	background-size: cover;
	z-index: -10;
}

.curriculumTb {
	width: 100%;
	margin: 0 auto 30px;
	border-collapse: separate;
	border-spacing: 3px;
	font-size: 13px;
	line-height: 1.4;
}

.curriculumTb th {
	padding: 8px 4px;
	font-size: 16px;
	background-color: #FFDF7D;
	border-bottom: 2px solid #AAAAAA;
	text-align: center;
}

.curriculumTb td {
	padding: 8px 4px;
	border-bottom: 1px dashed #AAAAAA;
	vertical-align: top;
}

.curriculumTb td.nen {
	background-color: #FFF3CE;
}

.curriculumTb td.cat {
	background-color: #DBF084;
	vertical-align:top;
	text-align: center;
}

.curriculumTb td.cat span {
	display: none;
}

.curriculumTb td.cat2 {
	background-color: #E4F4A6;
}

.curriculumTb td.bd {
	border-bottom: 2px solid #AAAAAA;
}

.curriculumTb td.bd2 {
	border-bottom: 1px solid #AAAAAA;
}

.curriculumTb td.nobd {
	border: none;
}



/*------------------------------------------------------------------------------------------------
  staff
--------------------------------------------------------------------------------------------------*/

#second.staff {
}

#second.staff .pagettl .wrap:before {
	position: absolute;
	width: 100%;
	height: 320px;
	top: 0;
	right: 0;
	content: "";
	background: url(../image/staff_back.jpg) no-repeat 0 60%;
	background-size: cover;
	z-index: -10;
}

#second.staff .staffAll {
}

#second.staff .staffAll .staffBox {
	width: 100%;
	display: flex;
	justify-content: space-between;
	margin: 0 0 80px;
}

#second.staff .staffAll .staffBox .info {
	width: 64%;
}

#second.staff .staffAll .staffBox .info p {
	margin: 0 0 20px;
}

#second.staff .staffAll .staffBox .info dt {
	background-color: #D8EFF9;
	padding: 6px;
	font-weight: 500;
}

#second.staff .staffAll .staffBox .info dd {
	border: 1px solid #D8EFF9;
	margin: -20px 0 0 40px;
	padding: 20px 10px 10px;
}

#second.staff .staffAll .staffBox .info dd li {
	line-height: 1.4;
}

#second.staff .staffAll .staffBox h2 span {
	font-size:18px;
	margin-right: 20px;
}

#second.staff .staffAll .staffBox h2 a {
	color: #FFF;
}

#second.staff .staffAll .staffBox .photo {
	position: relative;
}

#second.staff .staffAll .staffBox .photo::before {
	position: absolute;
	width: 40px;
	height: 40px;
	content: "";
	background-color: #D8EFF9;
	right: -20px;
	bottom: -14px;
	z-index: -1;
	transform: rotate(45deg);
}

#second.staff .staffAll .staffBox .photo img {
	display: block;
	margin: 0 auto;
	transition: all  .3s;
}

#second.staff .staffAll .staffBox .photo img:hover {
	opacity: .8;
}





