@charset "UTF-8";

@import url("reset.css");
/* @import url("contents.css"); */

 /* +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
general
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */
.sp {
	display: none !important;
}
	.clearfix:after{
		content: ".";
		display: block;
		height: 0;
		font-size: 0;
		clear: both;
		visibility: hidden;
	}
	.clearfix{
		display: block;
	}

 /* +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
common
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */

html, body {
	height: 100%;
	-webkit-text-size-adjust: none;
	font-family: "游ゴシック", "Yu Gothic", sans-serif;
}
#wrapper {
	overflow: hidden;
	box-sizing: border-box;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	min-height: 100%;
}
#wrapper {
	position: relative;
}
@media only screen and (min-width: 717px){

}

a:hover > img {
	opacity: 0.8;
	filter: alpha(opacity=80);
}


.fs10 { font-size: 10px;}
.fs12 { font-size: 12px;}
.fs13 { font-size: 13px;}
.fs14 { font-size: 14px;}
.fs15 { font-size: 15px;}
.fs16 { font-size: 16px;}



 /* +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
header
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */

.button {
	position: fixed;
	right: 20px;
	bottom: 80px;
	cursor: pointer;
	transition: .3s;
  
  /*デフォルトで非表示にする*/
	opacity: 0;
	visibility: hidden;
	z-index: 9998;
}
.button a {
	line-height: 0;
	display: block;
}
.button a + a {
	margin-top: 10px;
}

/*このクラスが付与されると表示する*/
.active{
	opacity: 1;
	visibility: visible;
}
/*このクラスが付与されると固定する*/
.fixed {
	position: fixed;
	width: 100%;
}


#wrapper .line {
	display: flex;
	position: fixed;
	width: 1000px;
	height: 100%;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	margin: auto;
	border-left: 1px solid #000;
	border-right: 1px solid #000;
	opacity: .1;
	z-index: 9000;
}
#wrapper .line div {
	width: 250px;
	height: 100%;
	border-right: 1px solid #000;
}



header.full {
	position: relative;
	height: 900px;
}
header.full::before {
	content:"";
	display:block;
	position:fixed;
	top:0;
	left:0;
	z-index:-1;
	width:100%;
	height: 900px;
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center center;
	background-image: url(../images/main.jpg);
}


header .logo {
	position: absolute;
	top: 10vw;
	left: 10vw;
	margin: auto;
	z-index: 9001;
}
header .logo img {
	width: 222px;
	height: 214px;
}
header h1 {
	color: #FFF;
	font-size: 90px;
	line-height: 1.0em;
}
header .logo_sub {
	color: #FFF;
	font-size: 20px;
	font-family: "游ゴシック", "Yu Gothic", sans-serif;
	font-weight: bold;
}

header .scroll {
	position: absolute;
	bottom: 0;
	left: 16px;
	margin: auto;
	height: 168px;
}
#cont_head {
	width: auto;
	height: 80px;
	display: flex;
	justify-content: space-between;
	background-color: #FFF;
	position: relative;
	z-index: 9999;
}
#cont_head .site_tt {
	display: flex;
	margin: 9px 0 0 30px;
}
#cont_head .site_tt .tt_name {
	margin: 9px 0 0 12px;
}
#cont_head .site_tt h1 {
	font-size: 25px;
	font-weight: bold;
	color: #008a87;
	line-height: 25px;
}
#cont_head .site_tt .logo_sub {
	color: #000;
	font-size: 12px;
	font-weight: bold;
	margin-top: -15px;
	margin-left: 66px;
}
#cont_head .site_tt .logo img{
	width: 70%;
}

 /* menu */


.nav_con {
	display: inline-block;
	position: fixed;
	top: 0;
	right: 80px;
	margin: auto;
	width: 80px;
	height: 80px;
	background-color: #000950;
	text-align: center;
	padding-top: 28px;
	box-sizing: border-box;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	cursor: pointer;
	z-index: 9999;
}

.nvn {
		display: none !important;
	}
.nvo {
		display: block !important;
	}
img.nvo {
		display: inline-block !important;
	}

.navToggle {
	right: 0;
	background-color: #008a87;
}

.nav_con img {
	height: 25px;
}
.navToggle img {
	height: 17px;
}
.navToggle .clmn {
	padding-top: 23px;
	position: relative;
}
.navToggle .clmn::before,
.navToggle .clmn::after { /* 共通設定 */
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 1px; /* 棒の幅（太さ） */
  height: 30px; /* 棒の高さ */
  background: #fff;
}
 
.navToggle .clmn::before {
  transform: translate(-50%,-50%) rotate(45deg);
}
 
.navToggle .clmn::after {
  transform: translate(-50%,-50%) rotate(-45deg);
}



.navToggle.active p:nth-of-type(1),
.navToggle p:nth-of-type(2) {
	display: none;
}
.navToggle.active p:nth-of-type(2) {
	display: block;
}
.globalMenuSp {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background-color: rgba(0,0,0,0.7);
	z-index: 9998;
}
#globalmenu {
	width: 500px;
	margin: 100px auto 0;
	text-align: center;
}
#globalmenu li {
    color: #FFF;
	padding: 20px 0;
	border-bottom: 1px solid #36bdef;
    letter-spacing: 0.2em;
    font-size: 23px;
}
#globalmenu li a {
	color: #FFF;
	font-size: 23px;
}

.globalMenuSp.active {
	display: block !important;
}



#globalmenu .menu_subpage {
    margin: 5px 0 0;
    letter-spacing: 0.02em;
}
#globalmenu .menu_subpage a {
    font-size: 18px;
}



/* +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
content
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */
.lower_page_head {
	width: auto;
	height: 256px;
	background-color: #f3f3f3;
	text-align: center;
	padding-top: 110px;
	box-sizing: border-box;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	position: relative;
}
.lower_page_head h2 {
	font-size: 30px;
	font-weight: bold;
	color: #000;
	padding-bottom: 10px;
}
.lower_page_head h3 {
	font-size: 14px;
	font-family: "游ゴシック", "Yu Gothic", sans-serif;
	font-weight: bold;
}
#lower_page_cont {
	width: auto;
	background-color: #FFF;
	position: relative;
	z-index: 9001;
}
.lower_page_inner {
	width: 1000px;
	margin: 0 auto;
}



.contact_inner {
    padding: 110px 0;
}



/* +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
iPad(7・8・9)
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */
@media only screen and (max-width: 1080px) {
	.pc {
		display: none !important;
	}
	.sp {
		display: block !important;
	}
	img.sp {
		display: inline-block !important;
	}

	.lower_page_inner {
		width: auto;
		margin: 0 auto;
	}

	.lower_page_head {
		width: auto;
		height: 256px;
		background-color: #f3f3f3;
		text-align: center;
		padding-top: 90px;
		box-sizing: border-box;
		-moz-box-sizing: border-box;
		-webkit-box-sizing: border-box;
		position: relative;
	}
	.lower_page_head h2 {
		font-size: 30px;
		font-weight: bold;
		color: #000;
		padding-bottom: 10px;
	}
	.lower_page_head h3 {
		font-size: 14px;
		font-family: "游ゴシック", "Yu Gothic", sans-serif;
		font-weight: bold;
	}
	#lower_page_cont {
        
	}
	.lower_page_inner {
		width: 100%;
		margin: 0 auto;
	}

	.button img {
		width: 86px;
		height: 86px;
	}
	
	#wrapper .line {
		width: 250px;
	}
	#wrapper .line div {
		display: none;
	}

	header.full {
		height: 700px;
	}
	header.full::before {
		height: 700px;
		background-image: url(../images/main_sp.jpg);
	}


	header .logo {
		top: 100px;
	}
	header .logo img {
		width: 111px;
		height: 111px;
	}
	header h1 {
		margin-top: 20px;
		font-size: 60px;
	}

	header .scroll {
		bottom: 180px;
		right: 16px;
		left: auto;
		height: 217px;
	}
	header .scroll img {
		width: 48px;
		height: 217px;
	}
	#cont_head .site_tt {
		margin: 9px 0 0 10px;
		width: 380px;
	}
	#cont_head .site_tt .tt_name {
		margin: 1px 0 0 12px;
	}
	#cont_head .site_tt h1 {
		font-size: 18px;
		line-height: 18px;
	}
	#cont_head .site_tt .logo_sub {
		font-size: 10px;
		margin-top: -11px;
		margin-left: 60px;
		line-height: 1;
	}
	#cont_head .site_tt .logo img{
		width: 45%;
	}


	#cont_news {
		padding: 60px 0 130px;
	}

 /* menu */
	#globalmenu {
		margin: 0;
		width: auto;
		overflow: scroll;
		max-height: 100vh;
		padding: 80px 30px;
		box-sizing: border-box;
	}
    #globalmenu li {
		padding: 15px 0;
        font-size: 16px;
	}
	#globalmenu li a {
		font-size: 16px;
	}

	#news {
		position: static;
		display: block;
		width: 93%;
		margin: -180px 20px;
	}
	#news .news_tt {
		width: 100%;
		padding: 20px 0 20px 20px;
	}
	#news ul {
		width: auto;
		padding: 25px 20px 10px 20px;
	}
	#news ul li {
		display: flex;
		flex-wrap: wrap;
		margin-bottom: 20px;
	}
	#news li .cate {
		padding: 4px 0 0;
	}
	#news li .more {
		width: 100%;
		margin-top: 10px;
	}




 /* 共通 */


	h2 {
		font-size: 65px;
	}
	h3 {
		font-size: 30px;
	}
	.sec_tt {
		width: 100%;
		margin: 0 0 40px 40px;
	}


 /* about */

	#about {
		margin-top: 180px;
	}
	#about .about_box {
		width: 100%;
		display: block;
		background-position: center 0;
		background-size: auto 385px;
		padding: 330px 40px 0;
		box-sizing: border-box;
		-moz-box-sizing: border-box;
		-webkit-box-sizing: border-box;
	}
	#about .about_box .school {
		width: 100%;
		padding: 30px 30px;
	}
	#about .about_box .school .sc_tt {
		margin-bottom: 30px;
		letter-spacing: 0.01em;
	}
	#about .about_box .tokuten {
		position: static;
		display: block;
		margin-top: 60px;
		width: auto;
	}
	#about .about_box .tokuten .tk_box {
		width: auto;
		padding: 30px 20px 38px;
	}
	#about .about_box .tokuten .tk_box:before {
		display: inline-block;
		content: "";
		position: absolute;
		top: -25px;
		left: 15px;
		right: auto;
		margin: auto;
		width: 65px;
		height: 94px;
	}
	#about .about_box .tokuten .box01:before {
		background: url(../images/tokuten01_sp.png) no-repeat;
		background-size: 65px 94px;
	}
	#about .about_box .tokuten .box02:before {
		background: url(../images/tokuten02_sp.png) no-repeat;
		background-size: 65px 94px;
	}
	#about .about_box .tokuten .box03:before {
		background: url(../images/tokuten03_sp.png) no-repeat;
		background-size: 65px 94px;
	}

	#about .about_box .tokuten .box01 {
		z-index: 9001;
	}
	#about .about_box .tokuten .box02 {
		z-index: 9002;
	}
	#about .about_box .tokuten .box03 {
		z-index: 9003;
	}
	#about .about_box .tokuten .tk_box p {
		text-align: left;
		padding-left: 70px;
	}


	#about .qualification {
		width: auto;
		margin: 90px 20px 0;
	}
	#about .qualification .sub_tt {
		line-height: 1.8em;
	}
	#about .qualification .quali_inner {
		padding: 90px 25px 30px;
	}
	#about .qualification .qua_box {
		display: block;
	}
	#about .qualification .qua_box .left {
		width: auto;
	}
	#about .qualification .qua_box .left dt {
		padding: 8px 0 8px 15px;
	}
	#about .qualification .qua_box .right img {
		width: 100%;
	}



 /* facilities */

	#facilities {
		margin-top: 70px;
		height: auto;
		background: url(../images/facilities_photo_sp.jpg) no-repeat;
		background-size: auto 800px;
	background-position: top center;
	}
	#facilities .faci_tt {
		display: block;
		width: auto;
		margin: 0 0 0 50px;
		padding-top: 55px;
	}
	#facilities .faci_tt h2 {
		margin-left: 0;
	}
	#facilities .faci_tt h3 {
		margin-left: 0;
	}
	#facilities .faci_tt .right {
		width: auto;
		margin-top: 20px;
	}
	#facilities .faci_tt .right p {
		width: auto;
		font-size: 23px;
	}


	#facilities .faci_box {
		position: static;
		padding: 210px 30px 0;
		width: auto;
		box-sizing: border-box;
		-moz-box-sizing: border-box;
		-webkit-box-sizing: border-box;
	}
	#facilities .flight {
		display: block;
	}
	#facilities .flight .flight_box {
		width: auto;
		padding: 30px;
	}
	#facilities .flight .flight_box .icon {
		position: absolute;
		top: 20px;
		left: 30px;
		right: auto;
		width: 60px;
		height: 60px;
		padding-top: 17px;
	}
	#facilities .flight .flight_box.box01 .icon img {
		width: 37px;
		height: 27px;
	}
	#facilities .flight .flight_box.box02 .icon img {
		width: 33px;
		height: 28px;
	}
	#facilities .flight_box02 .icon img {
		width: 34px;
		height: 24px;
	}
	#facilities .faci_box h4 {
		font-size: 30px;
		margin-bottom: 25px;
		padding-left: 70px;
		text-align: left;
	}
	#facilities .faci_box .flight_box02 h4 {
		margin-bottom: 25px;
	}
	#facilities .faci_box img {
		width: 100%;
	}
	#facilities .faci_box p {
		margin: 10px 0 20px;
	}

	#facilities .faci_box .flight_box02 {
		height: auto;
		padding: 30px;
	}
	#facilities .faci_box .flight_box02 .icon {
		position: absolute;
		top: 20px;
		left: 30px;
		width: 60px;
		height: 60px;
		padding-top: 17px;
	}
	#facilities .faci_box .flight_box02 .box_pt {
		position: static;
	}




 /* program */

	#program {
		margin-top: 80px;
	}
	#program h3 {
		margin-bottom: 30px;
	}


/* アコーディオン動作 */

	#program .pro_box {
		width: auto;
		margin: 30px 20px 0;
	}
	.panel {
		padding: 27px 25px;
	}
	.corse01 {
		display: block !important;
	}
	.corse01 img {
		width: 100%;
	}
	.panel ul {
		margin-bottom: 15px;
	}
	.panel li {
		display: flex;
		margin-bottom: 8px;
	}
	.panel li .tt {
		white-space: nowrap;
	}
	.pro_box .ttbtn {
		width: 100%;
		position: relative;
	}
	.pro_box .ttbtn .corse_box {
		display: block;
		width: calc(100% - 100px);
	}
	.pro_box .ttbtn .corse_name {
		width: auto;
		font-size: 22px;
		padding: 12px 0 2px 15px;
	}
	.pro_box .ttbtn .corse_name p {
		font-size: 15px;
	}
	.pro_box .ttbtn .nintei {
		justify-content: flex-start;
		margin: 0 0 5px 15px;
	}
	.pro_box .ttbtn .nintei p {
		margin: 0 8px 10px 0;
	}
	.pro_box .ttbtn .more {
		position: absolute;
		top: 0;
		bottom: 0;
		right: 0;
		margin: auto;
		width: 100px;
		height: 100%;
	}
	.pro_box .ttbtn .more::before {
		content: "詳細を\A開く";
		white-space: pre;
		text-align: center;
		top: 25px;
		left: 35px;
		margin: auto;
		color: #FFF;
		font-size: 12px;
	}
	.pro_box .ttbtn .more::after {
		top: 85px;
		right: 35px;
	}
	.pro_box .ttbtn .more span::after {
		top: 73px;
		right: 47px;
	}
	.pro_box.open .ttbtn .more::before {
		content: "詳細を\A閉じる";
	}
	.pro_box .ttbtn.bg02 {
		height: 90px;
		padding-top: 15px;
	}
	.pro_box .ttbtn.bg02 .more::before {
		top: 15px;
		left: 35px;
	}
	.pro_box .ttbtn.bg02 .more::after {
		top: 70px;
		right: 35px;
	}
	.pro_box .ttbtn.bg02 .more span::after {
		top: 58px;
		right: 47px;
	}
	




 /* instructor */

	#instructor {
		margin-top: 80px;
	}
	#instructor h2 {
		width: auto;
		margin: 0 0 0 40px;
	}
	#instructor .inst_inner h3 {
		width: auto;
		margin: 0 0 0 40px;
	}
	#instructor .inst_box {
		width: auto;
		margin: 30px 20px 0;
	}
	#instructor .inst_box h4 {
		font-size: 24px;
		margin: 0 0 30px 20px;
	}
	#instructor .inst_box .inst_pt {
		position: static;
	}
	#instructor .inst_box .inst_pt img {
		width: 100%;
	}
	#instructor .inst_box .inst_txt {
		width: auto;
		margin: -30px 20px 0;
		padding: 30px;
	}
	#instructor .inst_box .btn_more {
		position: static;
		text-align: right;
		margin: 30px 20px 0 0;
	}
	.btn_more a {
		padding: 0 35px 10px 0;
		box-sizing: border-box;
		-moz-box-sizing: border-box;
		-webkit-box-sizing: border-box;
	}




 /* sodan */

	#sodan {
		height: auto;
		background: url(../images/sodan_photo_sp.jpg) no-repeat;
		background-size: 100% auto;
		background-position: bottom center;
		padding: 0 30px 450px;
		box-sizing: border-box;
		-moz-box-sizing: border-box;
		-webkit-box-sizing: border-box;
		overflow: hidden;
	}
	#sodan::after {
		top: 0;
		left: 0;
		width: 100%;
		height: 70%;
		transform: skewY(-13deg);
		transform-origin: top left;
	}

	#sodan .sodan_inner {
		width: auto;
		margin: 0 auto;
	}
	#sodan .sodan_inner::before {
		background-size: 50%;
		bottom: -120px;
		left: -20px;
		margin: auto;
	}
	#sodan .sodan_inner::after {
		top: -10px;
		right: -50px;
		background-size: 132px 143px;
		width: 132px;
		height: 143px;
	}
	#sodan .sodan_inner .sodan_box {
		width: auto;
		padding-top: 60px;
	}
	#sodan .sodan_inner .sodan_box h4 {
		font-size: 26px;
		padding-bottom: 30px;
	}
	#sodan .sodan_inner .sodan_box p {
		margin-bottom: 40px;
	}
	#sodan .sodan_inner .sodan_box .sodan_btn a {
		width: 100%;
	}




 /* access */

	#access {
		margin-top: 80px;
	}
	#access p {
		width: auto;
		margin: 30px 40px 60px;
		line-height: 1.8em;
	}
	#access .ac_map {
		width: 92%;
		height: 340px;
		margin: 0 20px;
		box-sizing: border-box;
		-moz-box-sizing: border-box;
		-webkit-box-sizing: border-box;
	}



 /* sns */

	#sns {
		margin-top: 80px;
	}
	#sns .sns_inner {
		padding: 80px 0 50px;
	}
	#sns .sns_box {
		display: block;
		width: auto;
		margin: 0 20px;
	}
	#sns .sns_box .box {
		width: auto;
		margin-bottom: 30px;
	}




 /* link */

	#link {
		width: 100%;
		height: auto;
		padding-bottom: 50px;
	}
	#link h3 {
		font-size: 30px;
		color: #FFF;
	}
	#link .link_inner {
		display: block;
		width: auto;
		margin: 0 20px;
		padding-top: 30px;
	}
	#link .link_inner p {
		width: 100%;
		margin-bottom: 15px;
	}








 /* +++++
fotter
++++++++ */


	#fotter .ft_inner {
		display: block !important;
		margin-top: 50px !important;
	}
	/*#fotter .ft_inner::before {*/
		/*background-size: 75px 77px;
		left: -20px;
		top: -9px;
	}*/
	#fotter .ft_inner .ft_left {
		padding-left: 0;
	}
	#fotter .ft_inner .skytec {
		font-size: 20px;
		padding-left: 0px;
		margin-left: -29px;
	}
	#fotter .ft_inner .skytec img{
		width: 200px;
		height: auto;
	}
	#fotter .ft_inner .skytec_sub {
		font-size: 16px;
		margin: 2px 0 0;
		padding-left: 42px;
	}
	#fotter .ft_inner .adress {
		padding-left: 42px;
	}
	#fotter .ft_inner .tel a { 
		display: block;
		width: 100%;
		color: #FFF !important;
		background-color: #000950;
		border-radius: 10px;
		margin: 20px 0 30px;
		padding: 30px 0;
		text-align: center;
		box-sizing: border-box;
		-moz-box-sizing: border-box;
		-webkit-box-sizing: border-box;
	}
}

 /* +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
SP
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */
@media only screen and (max-width: 716px) {
	.button {
		bottom: 20px;
	}
	.lower_page_head {
		width: auto;
		height: 150px;
		background-color: #f3f3f3;
		text-align: center;
		padding-top: 50px;
		box-sizing: border-box;
		-moz-box-sizing: border-box;
		-webkit-box-sizing: border-box;
		position: relative;
	}
	.lower_page_head h2 {
		font-size: 18px;
		font-weight: bold;
		color: #000;
		padding-bottom: 10px;
	}
	.lower_page_head h3 {
		font-size: 14px;
		font-family: "游ゴシック", "Yu Gothic", sans-serif;
		font-weight: bold;
        line-height: 0.8em;
	}
	#lower_page_cont {

	}
	.lower_page_inner {
		width: auto;
	}
}


/* +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
iPad(7・8・9)
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */
@media only screen and (max-width: 1080px) {

}

 /* +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
SP
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */

@media only screen and (max-width: 716px) {
	.pc {
		display: none !important;
	}
	.sp {
		display: block !important;
	}
	img.sp {
		display: inline-block !important;
	}
	
	
	
	.button img {
		width: 60px;
		height: 60px;
	}
	
	#wrapper .line {
		width: 250px;
	}
	#wrapper .line div {
		display: none;
	}

	header.full {
		height: 700px;
	}
	header.full::before {
		height: 700px;
		background-image: url(../images/main_sp.jpg);
	}



	header .logo {
		top: 100px;
	}
	header .logo img {
		width: 111px;
		height: 111px;
	}
	header h1 {
		margin-top: 20px;
		font-size: 60px;
	}

	header .scroll {
		bottom: 180px;
		right: 16px;
		left: auto;
		height: 217px;
	}
	header .scroll img {
		width: 48px;
		height: 217px;
	}
	#cont_head .site_tt {
		margin: 9px 0 0 10px;
	}
	#cont_head .site_tt .tt_name {
		margin: 1px 0 0 12px;
	}
	#cont_head .site_tt h1 {
		font-size: 18px;
		line-height: 18px;
	}
	#cont_head .site_tt .logo_sub {
		font-size: 10px;
		margin-top: -11px;
		margin-left: 60px;
		line-height: 1;
	}
	#cont_head .site_tt .logo img{
		width: 45%;
	}


	#cont_news {
		padding: 60px 0 130px;
	}

 /* menu */
    #globalmenu li {
		font-size: 16px;
	}
	#globalmenu li a {
		font-size: 16px;
	}
	
	
	
	
	
	/* ++++++
top contents
+++++++++++ */

	#news {
		position: static;
		display: block;
		width: 93%;
		margin: -180px 20px;
	}
	#news .news_tt {
		width: 100%;
		padding: 20px 0 20px 20px;
	}
	#news ul {
		width: auto;
		padding: 25px 20px 10px 20px;
	}
	#news ul li {
		display: flex;
		flex-wrap: wrap;
		margin-bottom: 20px;
	}
	#news li .cate {
		padding: 4px 0 0;
	}
	#news li .more {
		width: 100%;
		margin-top: 10px;
	}




 /* 共通 */


	h2 {
		font-size: 65px;
	}
	h3 {
		font-size: 30px;
	}
	.sec_tt {
		width: 100%;
		margin: 0 0 40px 40px;
	}


 /* about */

	#about {
		margin-top: 180px;
	}
	#about .about_box {
		width: 100%;
		display: block;
		background-position: center 0;
		background-size: auto 385px;
		padding: 330px 40px 0;
		box-sizing: border-box;
		-moz-box-sizing: border-box;
		-webkit-box-sizing: border-box;
	}
	#about .about_box .school {
		width: 100%;
		padding: 30px 30px;
	}
	#about .about_box .school .sc_tt {
		margin-bottom: 30px;
		letter-spacing: 0.01em;
	}
	#about .about_box .tokuten {
		position: static;
		display: block;
		margin-top: 60px;
		width: auto;
	}
	#about .about_box .tokuten .tk_box {
		width: auto;
		padding: 30px 20px 38px;
	}
	#about .about_box .tokuten .tk_box:before {
		display: inline-block;
		content: "";
		position: absolute;
		top: -25px;
		left: 15px;
		right: auto;
		margin: auto;
		width: 65px;
		height: 94px;
	}
	#about .about_box .tokuten .box01:before {
		background: url(../images/tokuten01_sp.png) no-repeat;
		background-size: 65px 94px;
	}
	#about .about_box .tokuten .box02:before {
		background: url(../images/tokuten02_sp.png) no-repeat;
		background-size: 65px 94px;
	}
	#about .about_box .tokuten .box03:before {
		background: url(../images/tokuten03_sp.png) no-repeat;
		background-size: 65px 94px;
	}

	#about .about_box .tokuten .box01 {
		z-index: 9001;
	}
	#about .about_box .tokuten .box02 {
		z-index: 9002;
	}
	#about .about_box .tokuten .box03 {
		z-index: 9003;
	}
	#about .about_box .tokuten .tk_box p {
		text-align: left;
		padding-left: 70px;
	}


	#about .qualification {
		width: auto;
		margin: 90px 20px 0;
	}
	#about .qualification .sub_tt {
		line-height: 1.8em;
	}
	#about .qualification .quali_inner {
		padding: 90px 25px 30px;
	}
	#about .qualification .qua_box {
		display: block;
	}
	#about .qualification .qua_box .left {
		width: auto;
	}
	#about .qualification .qua_box .left dt {
		padding: 8px 0 8px 15px;
	}
	#about .qualification .qua_box .right img {
		width: 100%;
	}



 /* facilities */

	#facilities {
		margin-top: 70px;
		height: auto;
		background: url(../images/facilities_photo_sp.jpg) no-repeat;
		background-size: auto 800px;
	background-position: top center;
	}
	#facilities .faci_tt {
		display: block;
		width: auto;
		margin: 0 0 0 50px;
		padding-top: 55px;
	}
	#facilities .faci_tt h2 {
		margin-left: 0;
	}
	#facilities .faci_tt h3 {
		margin-left: 0;
	}
	#facilities .faci_tt .right {
		width: auto;
		margin-top: 20px;
	}
	#facilities .faci_tt .right p {
		width: auto;
		font-size: 23px;
	}


	#facilities .faci_box {
		position: static;
		padding: 210px 30px 0;
		width: auto;
		box-sizing: border-box;
		-moz-box-sizing: border-box;
		-webkit-box-sizing: border-box;
	}
	#facilities .flight {
		display: block;
	}
	#facilities .flight .flight_box {
		width: auto;
		padding: 30px;
	}
	#facilities .flight .flight_box .icon {
		position: absolute;
		top: 20px;
		left: 30px;
		right: auto;
		width: 60px;
		height: 60px;
		padding-top: 17px;
	}
	#facilities .flight .flight_box.box01 .icon img {
		width: 37px;
		height: 27px;
	}
	#facilities .flight .flight_box.box02 .icon img {
		width: 33px;
		height: 28px;
	}
	#facilities .flight_box02 .icon img {
		width: 34px;
		height: 24px;
	}
	#facilities .faci_box h4 {
		font-size: 30px;
		margin-bottom: 25px;
		padding-left: 70px;
		text-align: left;
	}
	#facilities .faci_box .flight_box02 h4 {
		margin-bottom: 25px;
	}
	#facilities .faci_box img {
		width: 100%;
	}
	#facilities .faci_box p {
		margin: 10px 0 20px;
	}

	#facilities .faci_box .flight_box02 {
		height: auto;
		padding: 30px;
	}
	#facilities .faci_box .flight_box02 .icon {
		position: absolute;
		top: 20px;
		left: 30px;
		width: 60px;
		height: 60px;
		padding-top: 17px;
	}
	#facilities .faci_box .flight_box02 .box_pt {
		position: static;
	}




 /* program */

	#program {
		margin-top: 80px;
	}
	#program h3 {
		margin-bottom: 30px;
	}


/* アコーディオン動作 */

	#program .pro_box {
		width: auto;
		margin: 30px 20px 0;
	}
	.panel {
		padding: 27px 25px;
	}
	.corse01 {
		display: block;
	}
	.corse01 img {
		width: 100%;
	}
	.panel ul {
		margin-bottom: 15px;
	}
	.panel li {
		display: flex;
		margin-bottom: 8px;
	}
	.panel li .tt {
		white-space: nowrap;
	}
	.pro_box .ttbtn {
		width: 100%;
		position: relative;
	}
	.pro_box .ttbtn .corse_box {
		display: block;
		width: calc(100% - 100px);
	}
	.pro_box .ttbtn .corse_name {
		width: auto;
		font-size: 22px;
		padding: 12px 0 2px 15px;
	}
	.pro_box .ttbtn .corse_name p {
		font-size: 15px;
	}
	.pro_box .ttbtn .nintei {
		justify-content: flex-start;
		margin: 0 0 5px 15px;
	}
	.pro_box .ttbtn .nintei p {
		margin: 0 8px 10px 0;
	}
	.pro_box .ttbtn .more {
		position: absolute;
		top: 0;
		bottom: 0;
		right: 0;
		margin: auto;
		width: 100px;
		height: 100%;
	}
	.pro_box .ttbtn .more::before {
		content: "詳細を\A開く";
		white-space: pre;
		text-align: center;
		top: 25px;
		left: 35px;
		margin: auto;
		color: #FFF;
		font-size: 12px;
	}
	.pro_box .ttbtn .more::after {
		top: 85px;
		right: 35px;
	}
	.pro_box .ttbtn .more span::after {
		top: 73px;
		right: 47px;
	}
	.pro_box.open .ttbtn .more::before {
		content: "詳細を\A閉じる";
	}
	.pro_box .ttbtn.bg02 {
		height: 90px;
		padding-top: 15px;
	}
	.pro_box .ttbtn.bg02 .more::before {
		top: 15px;
		left: 35px;
	}
	.pro_box .ttbtn.bg02 .more::after {
		top: 70px;
		right: 35px;
	}
	.pro_box .ttbtn.bg02 .more span::after {
		top: 58px;
		right: 47px;
	}
	




 /* instructor */

	#instructor {
		margin-top: 80px;
	}
	#instructor h2 {
		width: auto;
		margin: 0 0 0 40px;
	}
	#instructor .inst_inner h3 {
		width: auto;
		margin: 0 0 0 40px;
	}
	#instructor .inst_box {
		width: auto;
		margin: 30px 20px 0;
	}
	#instructor .inst_box h4 {
		font-size: 24px;
		margin: 0 0 30px 20px;
	}
	#instructor .inst_box .inst_pt {
		position: static;
	}
	#instructor .inst_box .inst_pt img {
		width: 100%;
	}
	#instructor .inst_box .inst_txt {
		width: auto;
		margin: -30px 20px 0;
		padding: 30px;
	}
	#instructor .inst_box .btn_more {
		position: static;
		text-align: right;
		margin: 30px 20px 0 0;
	}
	.btn_more a {
		padding: 0 35px 10px 0;
		box-sizing: border-box;
		-moz-box-sizing: border-box;
		-webkit-box-sizing: border-box;
	}




 /* sodan */

	#sodan {
		height: auto;
		background: url(../images/sodan_photo_sp.jpg) no-repeat;
		background-size: 100% auto;
		background-position: bottom center;
		padding: 0 30px 450px;
		box-sizing: border-box;
		-moz-box-sizing: border-box;
		-webkit-box-sizing: border-box;
		overflow: hidden;
	}
	#sodan::after {
		top: 0;
		left: 0;
		width: 100%;
		height: 70%;
		transform: skewY(-13deg);
		transform-origin: top left;
	}

	#sodan .sodan_inner {
		width: auto;
		margin: 0 auto;
	}
	#sodan .sodan_inner::before {
		background-size: 50%;
		bottom: -120px;
		left: -20px;
		margin: auto;
	}
	#sodan .sodan_inner::after {
		top: -10px;
		right: -50px;
		background-size: 132px 143px;
		width: 132px;
		height: 143px;
	}
	#sodan .sodan_inner .sodan_box {
		width: auto;
		padding-top: 60px;
	}
	#sodan .sodan_inner .sodan_box h4 {
		font-size: 26px;
		padding-bottom: 30px;
	}
	#sodan .sodan_inner .sodan_box p {
		margin-bottom: 40px;
	}
	#sodan .sodan_inner .sodan_box .sodan_btn a {
		width: 100%;
	}




 /* access */

	#access {
		margin-top: 80px;
	}
	#access p {
		width: auto;
		margin: 30px 40px 60px;
		line-height: 1.8em;
	}
	#access .ac_map {
		width: 92%;
		height: 340px;
		margin: 0 20px;
		box-sizing: border-box;
		-moz-box-sizing: border-box;
		-webkit-box-sizing: border-box;
	}



 /* sns */

	#sns {
		margin-top: 80px;
	}
	#sns .sns_inner {
		padding: 80px 0 50px;
	}
	#sns .sns_box {
		display: block;
		width: auto;
		margin: 0 20px;
	}
	#sns .sns_box .box {
		width: auto;
		margin-bottom: 30px;
	}




 /* link */

	#link {
		width: 100%;
		height: auto;
		padding-bottom: 50px;
	}
	#link h3 {
		font-size: 30px;
		color: #FFF;
	}
	#link .link_inner {
		display: block;
		width: auto;
		margin: 0 20px;
		padding-top: 30px;
	}
	#link .link_inner p {
		width: 100%;
		margin-bottom: 15px;
	}

	
}  
