@charset "UTF-8";
/* CSS Document */
.wrapper {
  width: 100%;
  text-align: center;
  position: relative;
	text-align: center;
}
.section_innner {
  margin: auto;
  width: 100%;
  text-align: center;
	;
}
.contents_inner {
	margin-bottom: 50px;
}
/***********************************/
/*　共通：プロモエリア　*/
body.article .section_panel {
  position: relative;
  background: #1a1965;
  margin-bottom: 10px;
}
body.article .page_image {
	height: 140px;
	background: #bbb;
}
body.article .page_image h1 {
	position: relative;
	/*display: table;*/
 	width: 100%;
  height: 140px;
  margin: 0 auto;
}
body.article .page_image h1 span {
	position: absolute;
  color: #fff;
	font-size: 30px;
  left: 380px;
  top: 50%;
	font-weight: 700;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
}
body.article  #main_contents {
  position: relative;
  width: 1030px;
  margin: auto;
	text-align: center;
}
body.article .page_image {
	display:-webkit-box;
  display:-ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
}
body.article .page_image .left {
	background: #2a2a8a;
	 width: calc((100% - 1030px)/2);
}
body.article .page_image .center {
	background: #fff;
	width: 1030px;
}
body.article .page_image .right {
	background: #fff;
	width: calc((100% - 1030px)/2);
}

@media only screen and (max-width:767px) {
	body.article .page_image {
		height: 90px;
	}
	body.article .page_image .left {
	background: #2a2a8a;
	 width: 0;
	}
	body.article .page_image h1 span {
  	left: inherit;
		font-size: 16px;
		width: 100%;
	}
}

/*　共通：h2　*/
body.article .pagecatch {
	border-bottom: 1px solid #313198;
	margin-top: 30px;
	padding-bottom: 25px;
	margin-bottom: 50px;
	text-align: center;
}
body.article .pagecatch h2 {
	font-size: 38px;
	color: #313198;
	font-weight: bold;
	letter-spacing: 0.02em;
	line-height: 1.5;
}
body.article .pagecatch p {
	font-size: 18px;
	color: #000;
	font-weight: bold;
	letter-spacing: 0.02em;
}
@media only screen and (max-width:767px) {
	body.article .pagecatch {
    margin-top: 10px;
    margin-bottom: 20px;
}
	body.article .pagecatch h2 {
    font-size: 18px;
    line-height: 1.5;
	}
	body.article .pagecatch p {
    font-size: 12px;
	}
}

/* 動画 */
body#movie .page_image h1 {
	background-image: url("../../img/movie/bg_header.jpg");
	background-repeat: no-repeat;
  background-position: center center;
}
body#movie .pagecatch {
	margin-bottom: 75px;
}

@media only screen and (max-width:767px) {
	body#movie .page_image .center {
		background-image: url("../../img/bg_sp.png");
		background-repeat: no-repeat;
  	background-position: center center;
		background-size: cover;
		width: 65%;
	}
	body#movie .page_image .right {
		background-image: url("../../img/movie/bg_icon.png");
		background-repeat: no-repeat;
  	background-position: center center;
		background-size: contain;
		width: 35%;
	}
	body#movie .page_image h1 {
		height: 90px;
		background: none;
	}
	
	body#movie .pagecatch {
		margin-bottom: 30px;
	}

}

/* FAQ */
body#faq .page_image h1 {
	background-image: url("../../img/faq/bg_header.jpg");
	background-repeat: no-repeat;
  background-position: center center;
}
body#faq .pagecatch {
	border-bottom: none;
	padding-bottom: 0;
}

@media only screen and (max-width:767px) {
	body#faq .page_image .center {
		background-image: url("../../img/bg_sp.png");
		background-repeat: no-repeat;
  	background-position: center center;
		background-size: cover;
		width: 65%;
	}
	body#faq .page_image .right {
		background-image: url("../../img/faq/bg_icon.png");
		background-repeat: no-repeat;
  	background-position: center center;
		background-size: contain;
		width: 35%;
	}
	body#faq .page_image h1 {
		height: 90px;
		background: none;
	}
}
/* イベントカレンダー */
body#calendar .page_image h1 {
	background-image: url("../../img/calendar/bg_header.jpg");
	background-repeat: no-repeat;
  background-position: center center;
}

@media only screen and (max-width:767px) {
	body#calendar .page_image .center {
		background-image: url("../../img/bg_sp.png");
		background-repeat: no-repeat;
  	background-position: center center;
		background-size: cover;
		width: 65%;
	}
	body#calendar .page_image .right {
		background-image: url("../../img/calendar/bg_icon.png");
		background-repeat: no-repeat;
  	background-position: center center;
		background-size: contain;
		width: 35%;
	}
	body#calendar .page_image h1 {
		height: 90px;
		background: none;
	}
}
/* 制服 */
body#uniform .page_image h1 {
	background-image: url("../../img/uniform/bg_header.jpg");
	background-repeat: no-repeat;
  background-position: center center;
}

@media only screen and (max-width:767px) {
	body#uniform .page_image .center {
		background-image: url("../../img/bg_sp.png");
		background-repeat: no-repeat;
  	background-position: center center;
		background-size: cover;
		width: 65%;
	}
	body#uniform .page_image .right {
		background-image: url("../../img/uniform/bg_icon.png");
		background-repeat: no-repeat;
  	background-position: center center;
		background-size: contain;
		width: 35%;
	}
	body#uniform .page_image h1 {
		height: 90px;
		background: none;
	}
}
/* ニュース */
body#news .page_image h1 {
	background-image: url("../../img/news/bg_header.jpg");
	background-repeat: no-repeat;
  background-position: center center;
}

@media only screen and (max-width:767px) {
	body#news .page_image .center {
		background-image: url("../../img/bg_sp.png");
		background-repeat: no-repeat;
  	background-position: center center;
		background-size: cover;
		width: 65%;
	}
	body#news .page_image .right {
		background-image: url("../../img/news/bg_icon.png");
		background-repeat: no-repeat;
  	background-position: center center;
		background-size: contain;
		width: 35%;
	}
	body#news .page_image h1 {
		height: 90px;
		background: none;
	}
}




	




/***********************************/
/*Gナビ*/
.section_panel .navi {
  display: block;
  text-align: center;
  width: 100%;
  background: #e4e4e4;
}
.section_panel .navi ul {
	display:-webkit-box;
  display:-ms-flexbox;
  display: flex;
  margin: auto;
  width: 1030px;
}
.section_panel .navi ul li {
  margin: 22px 0 22px;
  border-right: solid 1px #e4e4e4;
}
body.article .section_panel .navi ul li.top {
	flex-basis: 8%;
}
body.article .section_panel .navi ul li.movie,
body.article .section_panel .navi ul li.uniform,
body.article .section_panel .navi ul li.faq,
body.article .section_panel .navi ul li.calender{
	flex-basis: 23%;
}
.section_panel .navi ul li:last-child {
  /*background: #1a1965;*/
  border-right: none;
}
.section_panel .navi ul li a {
  position: relative;
  display: table;
  width: 100%;
  height: 54px;
  font-size: 16px;
	line-height: 1.25em;
	text-decoration: none;
	background: #1a1965;
  -webkit-transition: all .35s ease;
  -o-transition: all .35s ease;
  transition: all .35s ease;
}
.section_panel .navi ul li a:hover {
	background: #5d5dba;
  -webkit-transition: all .35s ease;
  -o-transition: all .35s ease;
  transition: all .35s ease;
}
.section_panel .navi ul li a span {
  /*position: absolute;
  width: 100%;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  color: #fff;*/
	display: table-cell;
  vertical-align: middle;
  text-align: center;
	color: #fff;
	font-weight: 700;
}
.section_panel .navi ul li a.current,
footer .map .map_navi a.current {
	background: #5d5dba;
}

/***********************************/
/*　パンクズ　*/
body.article .breadcrumb {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
	-webkit-box-pack: start;
  -webkit-justify-content: flex-start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  margin: 0;
  margin: 16px 0;
  padding: 0;
  padding: 0 2px 0 0;
  font-size: 13px;
  list-style: none;
}
body.article .breadcrumb li ~ li:before {
    margin: 0 5px;
    content: '>';
}

/***********************************/
/*　アンカーナビ　*/
body.article .ancher_navi {
	display:-webkit-box;
  display:-ms-flexbox;
  display: flex;
  margin: 0 auto 60px;
  width: 1030px;
}
body.article .ancher_navi li {
  width: 20%;
  border-right: solid 1px #e4e4e4;
}
body.article .ancher_navi li a {
  position: relative;
  display: table;
  width: 100%;
  font-size: 14px;
	line-height: 1.25em;
	background: #313198;
	text-decoration: none;
  -webkit-transition: all .35s ease;
  -o-transition: all .35s ease;
  transition: all .35s ease;
}
body.article .ancher_navi li a:hover {
	background: #6363d0;
  -webkit-transition: all .35s ease;
  -o-transition: all .35s ease;
  transition: all .35s ease;
}
body.article .ancher_navi li a span {
	position: relative;
	display: table-cell;
  padding: 14px 0 28px;
  color: #fff;
}

body.article .ancher_navi li a span:after {
	content: "";
  display: inline-block;
  position: absolute;
  width: auto;
  height: auto;
  background-repeat: no-repeat;
  background-position: 0 0;
  background-size: contain;
  top: 70%;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  width: 11px;
  height: 6px;
  background-image: url("../img/icon/icon_ancher.png");
}

body.article .ancher_navi li a span:hover::after {
  top: 75%;
}

/***********************************/
/*　各ページ共通タイトル　*/
body.article .contents_inner h2 {
  background: #e0e0fc;
  color: #313198;
  width: 100%;
  margin-bottom: 50px;
	border-bottom: solid 6px #313198;
	font-weight: bold;
}
body.article .contents_inner h2 span {
  display: inline-block;
  font-size: 32px;
  padding: 18px 0 18px;
}
body.article .contents_inner h3 {
  color: #313198;
  margin-bottom: 30px;
	border-bottom: solid 1px #313198;
	text-align: left;
	/*margin-top: 50px;*/
}
body#news.news_list .contents_inner h3 {
  margin-bottom: 0;
}

body.article .contents_inner h3 span {
  display: inline-block;
	font-weight: bold;
  font-size: 23px;
  padding: 0 0 0 20px;
	line-height: 1.75;
	border-left: solid 6px #313198;
	margin-bottom: 10px;
}
/***********************************/
/*進路*/
#course h3 {
	border: 2px solid #313198;
	font-size: 28px;
	color: #313198;
	padding: 5px 0;
	font-weight: bold;
}

#course .course_wrapper {
    padding: 40px 40px 0 40px;
}
#course .lead {
	text-align: left;
	margin-bottom: 40px;
}
#course h4 {
	font-size: 18px;
	background: #313198;
	color: #fff;
	padding: 5px 0;
	margin-bottom: 40px;
}

#course .image_course {
	margin-bottom: 50px;
}

/***********************************/
/*進路*/
#course h3 {
	border: 2px solid #313198;
	font-size: 28px;
	color: #313198;
	padding: 5px 0;
	font-weight: bold;
}

/***********************************/
/*マップ*/
footer .map {
	width: 810px;
	display:-webkit-box;
  display:-ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	margin: auto;
	margin-top: 50px;
}

footer .map .map_navi {
	margin-top: 175px;
}
footer .map .map_navi a {
	display: block;
	background: #191965;
	color: #fff;
	font-size: 16px;
	width: 270px;
	padding: 10px 0;
	margin-bottom: 10px;
	text-decoration: none;
	background: #1a1965;
  -webkit-transition: all .35s ease;
  -o-transition: all .35s ease;
  transition: all .35s ease;
}
footer .map .map_navi a:hover {
	background: #5d5dba;
  -webkit-transition: all .35s ease;
  -o-transition: all .35s ease;
  transition: all .35s ease;
}

footer {
	border-top: 1px solid #ccc;
}

/***********************************************************
************************************************************
PC：FAQページ
************************************************************
************************************************************/

body#faq .qa {
	text-align: left;
}
body#faq .qa .question {
	display: table;
	padding: 20px 0 20px 120px;
	min-height: 85px;
	background: #f9f5d9;
	width: 100%;
	background-image: url("../../img/faq/img_faq_q.png");
	background-repeat: no-repeat;
  background-position: left bottom;
	margin-bottom: 30px;
	-moz-background-size:82px;
	-webkit-background-size:82px;
	-o-background-size:82px;
	-ms-background-size:82px;
	background-size: 82px;
}
body#faq .qa .question span {
	display: table-cell;
  vertical-align: middle;
	font-weight: bold;
}

body#faq .qa .anser {
	padding: 0px 0 20px 120px;
	/*min-height: 85px;*//*アコーディオンに影響*/
	width: 100%;
	background-image: url("../../img/faq/img_faq_a.png");
	background-repeat: no-repeat;
  background-position: left top;
	background-size: 80px;
	margin-bottom: 30px;
}
.acd_opener span:before {
  content: "";
  display: inline-block;
  position: absolute;
  width: auto;
  height: auto;
  background-repeat: no-repeat;
  background-position: 0 0;
  background-size: contain;
  top: 50%;
  right: 10px;
  height: 26px;
  width: 6px;
  margin-top: -13px;
	margin-right: 20px;
  background-color: #ffb85c;
  -webkit-transition: opacity .3s,-webkit-transform .3s cubic-bezier(.45,.01,.27,1.4);
  transition: opacity .3s,-webkit-transform .3s cubic-bezier(.45,.01,.27,1.4);
  -o-transition: opacity .3s,transform .3s cubic-bezier(.45,.01,.27,1.4);
  transition: opacity .3s,transform .3s cubic-bezier(.45,.01,.27,1.4);
  transition: opacity .3s,transform .3s cubic-bezier(.45,.01,.27,1.4),
	-webkit-transform .3s cubic-bezier(.45,.01,.27,1.4);
}

.acd_opener.open span:before {
    opacity: 0;
    -webkit-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    transform: rotate(-45deg);
}
.acd_opener.open span:after,
.acd_opener.opening span:after {
    -webkit-transform: rotate(-180deg);
    -ms-transform: rotate(-180deg);
    transform: rotate(-180deg);
}

.acd_opener span:after {
   content: "";
   display: inline-block;
   position: absolute;
   width: auto;
   height: auto;
   background-repeat: no-repeat;
   background-position: 0 0;
   background-size: contain;
   top: 50%;
   right: 0;
   width: 26px;
   height: 6px;
   margin-top: -3px;
	margin-right: 20px;
   background-color: #ffb85c;
   -webkit-transition: -webkit-transform .3s cubic-bezier(.45,.01,.27,1.4);
   transition: -webkit-transform .3s cubic-bezier(.45,.01,.27,1.4);
   -o-transition: transform .3s cubic-bezier(.45,.01,.27,1.4);
   transition: transform .3s cubic-bezier(.45,.01,.27,1.4);
   transition: transform .3s cubic-bezier(.45,.01,.27,1.4),
	-webkit-transform .3s cubic-bezier(.45,.01,.27,1.4);
}

.acd_opener.open span:before,
.acd_opener.opening span:before {
    /*background-color: #f9f5d9;*/
	opacity: 0;
}

body#faq .contents_inner {
   margin-bottom: 0; 
}

@media only screen and (max-width:767px) {
	body#faq .ancher_navi li {
		width: auto;
	}
	body#faq .ancher_navi li:first-child{
		flex-grow: 2.2;
	}
	body#faq .ancher_navi li:nth-child(n+2){
		flex-grow: 1.95;
	}
	body#faq .contents_inner h3 {
		margin-top: 40px;
	}
}

/***********************************************************
************************************************************
PC：制服大図鑑ページ
************************************************************
************************************************************/

body#uniform .uniform_wrapper {
	margin-bottom: 100px;
}

body#uniform .ancher_navi li {
    width: 25%;
    border-right: solid 1px #e4e4e4;
}
body#uniform .title {
	display:-webkit-box;
  display:-ms-flexbox;
	display: flex;
	text-align: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	margin: 5px 0 50px 0;
}

body#uniform .title_sp {
	display: none;
}
body#uniform .title h2 {
	font-size: 38px;
	color: #313198;
	line-height: 2;
	margin-top: 10px;
	font-weight: 700;
}
body#uniform .title h2  span {
	font-size: 18px;
	display: block;
	color: #000;
	line-height: 1;
	font-weight: normal;
	margin-top: -5px;
	margin-left: 5px;
}

body#uniform .title img {
	margin-left: 20px;
}

body#uniform h3 {
  color: #313198;
  margin-bottom: 30px;
  border-bottom: solid 1px #313198;
  text-align: left;
	margin-bottom: 40px;
	border-top: solid 1px #313198;
}

body#uniform h3 span {
    display: inline-block;
    font-weight: bold;
    font-size: 23px;
    padding: 0 0 0 20px;
    line-height: 1.75;
    border-left: solid 6px #313198;
    margin-bottom: 10px;
    margin-top: 10px;
}

body#uniform .dai_h {
	width: 100%;
	text-align: center;
}
body#uniform .dot_line {
	height: 100px;
	background-image: url("../../img/uniform/dot_uni.png");
	background-repeat: repeat-x;
	background-position: center;
	background-size: auto 16px;
	margin: 0;
	padding: 0;
}
body#uniform .btn {
	text-align: center;
	margin: 40px 0;
}
body#uniform .btn a {
	display: inline-block;
	padding: 15px 20px;
	background: #313198;
	color: #fff;
	text-decoration: none;
}
body#uniform .btn a span {
	position: relative;
	padding-left: 15px;
	font-size: 17px;
	font-weight: 700;
}
body#uniform .btn a span:before {
  content: "";
  display: inline-block;
  position: absolute;
  width: auto;
  height: auto;
  background-repeat: no-repeat;
  background-position: 0 0;
  background-size: contain;
  top: 15%;
	left: 0;
  width: 7px;
  height: 11px;
  margin-top: -0;
  background-image: url(../../img/index/icon_white_arrow.png);
}
body#uniform .acd {
	width: 950px;
	margin: 0 auto 80px;
}
body#uniform .acd dt {
	border: 3px solid #b2a986;
}
body#uniform .acd_opener {
	display: table;
 	padding: 10px 20px;
 	background: #b2a986;
 	width: 100%;
 	margin-bottom: 0;
	color: #fff;
	text-align: left;
	font-size: 20px;
}

body#uniform .acd_opener span {
  display: table-cell;
  vertical-align: middle;
  font-weight: bold;
}
body#uniform .acd_opener span:before,
body#uniform .acd_opener span:after {
	background-color: #fff;
}

body#uniform .virtual {
	padding: 30px;
	border: 3px solid #b2a986;
	border-top: none;
	text-align: left;
}

body#uniform .upper {
	display:-webkit-box;
  display:-ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	margin-bottom: 30px;
}


body#uniform .virtual .right img {
	width: 345px;
}
body#uniform .virtual .upper .left {
	width: 490px;
}
body#uniform .virtual .left .v_title{
	font-size: 18px;
	font-weight: bold;
	margin-bottom: 10px;
}
body#uniform .virtual .left .v_text{
	font-size: 15px;
}

body#uniform .virtual h5 {
	background: #b2a986;
  color: #fff;
  text-align: center;
  padding: 5px;
  font-size: 18px;
  font-weight: bold;
}
body#uniform .virtual ol {
	list-style: decimal;
	margin-right: 20px;
}

body#uniform .virtual li {
	font-weight: bold;
	font-size: 15px;
	margin-bottom: 15px;
}
body#uniform .virtual li span {
	font-weight: normal;
	font-size: 13px;
}
body#uniform .virtual .bottom {
	display:-webkit-box;
  display:-ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	padding: 30px 10px 10px 30px;
}
body#uniform .virtual .bottom .exp {
	font-size: 13px;
}
body#uniform .virtual .bottom .right img {
	width: 159px;
}
body#uniform img.pc {
	display: block;
	margin: auto;
}
body#uniform img.sp {
	display: none;
}


@media only screen and (max-width:767px) {
	body#uniform .title {
		display: none;
	}
	body#uniform .dot_line {
    background-size: auto 8px;
}
	body#uniform .title_sp {
		display: block;
		width: 294px;
		margin: auto;
		margin-bottom: 20px;
	}
	body#uniform h3 {
		margin-bottom: 20px;
	}
	body#uniform h3 span {
    font-size: 16px;
	}
	body#uniform img.pc {
		display: none;
	}
		body#uniform img.sp {
		display: block;
	}
	body#uniform .btn a {
		padding: 7px 20px;
		line-height: 1.5;
	}
	body#uniform .btn a span {
    font-size: 15px;
    font-weight: normal;
	}
	body#uniform .acd_opener {
    padding: 10px 20px;
    margin-bottom: 0;
    font-size: 16px;
	}
	body#uniform .acd {
		width: 100%;
		margin: 0 auto 50px;
	}
	body#uniform .upper {
    display: block;
    margin-bottom: 30px;
	}
	body#uniform .virtual .upper .left {
    width: 100%;
	}
	body#uniform .virtual {
    padding: 10px;
	}
	body#uniform .virtual .left .v_title {
    font-size: 15px;
    margin-bottom: 7px;
	}
	body#uniform .virtual .left .v_text {
    margin-bottom: 10px;
	}
	body#uniform .virtual .right {
   text-align: center;
	}
	body#uniform .virtual .right img {
    width: 225px;
		margin: auto;
	}
	body#uniform .virtual .bottom {
    display: block;
    padding: 20px 0 15px 20px;
	}
	body#uniform .virtual ol {
    margin-right: 0;
	}
	body#uniform .virtual .bottom .left {
		margin-bottom: 10px;
	}
}
/***********************************************************
************************************************************
PC：動画ギャラリーページ
************************************************************
************************************************************/
body#movie .ancher_navi li a {
  position: relative;
  display: table;
  width: 100%;
  font-size: 14px;
	line-height: 1.25em;
	background: #313198;
	text-decoration: none;
  -webkit-transition: all .35s ease;
  -o-transition: all .35s ease;
  transition: all .35s ease;
}
body#movie .ancher_navi li a:hover {
	background: #6363d0;
  -webkit-transition: all .35s ease;
  -o-transition: all .35s ease;
  transition: all .35s ease;
}
body#movie .ancher_navi li a span {
	position: relative;
	display: table-cell;
  padding: 10px 0 25px;
  color: #fff;
}
body#movie .ancher_navi li a span:after {
	content: "";
  display: inline-block;
  position: absolute;
  width: auto;
  height: auto;
  background-repeat: no-repeat;
  background-position: 0 0;
  background-size: contain;
  top: 80%;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  width: 11px;
  height: 6px;
  background-image: url("../img/icon/icon_ancher.png");
}

body#movie .ancher_navi li a span:hover::after {
  top: 85%;
}
body#movie .ancher_navi li a.yet {
	background: #ccc;
	cursor: default;
}
body#movie .ancher_navi li a.yet span:hover::after {
  top: 80%;
}
body#movie .program dd span {
	display: block;
	width: 3em;
	text-align: right;
}
body#movie .block {
	display:-webkit-box;
  display:-ms-flexbox;
	display: flex;
	margin-bottom: 40px;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -ms-flex-direction: row-reverse;
	flex-direction:row-reverse
}
body#movie .block:last-child {
	margin-bottom: 60px;
}
body#movie .block .text {
	width: 550px;
	text-align: left;
}
body#movie .program,
body#movie .video {
	display:-webkit-box;
  display:-ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
  text-align: left;
}
body#movie .program dt {
	width: 8em;
}
body#movie .video dt {
	width: 25em;
}
body#movie .program dd {
	width: calc(100% - 8em);
}
body#movie .video dd {
	width: 4em;
	text-align: right;
}
@media only screen and (max-width:767px) {
	body#movie .video dt {
		width: 18em;
	}
	body#movie .video dd {
		width: calc(100% - 18em);
	}
}
body#movie h3 {
  color: #313198;
  margin-bottom: 30px;
	border-bottom: solid 1px #313198;
	text-align: left;
}
body#movie h3 span {
  display: inline-block;
	font-weight: bold;
  font-size: 21px;
  padding: 5px 0 5px 20px;
	line-height: 1.25;
	border-left: solid 6px #313198;
	margin-bottom: 10px;
}
body#movie h3 span.txt_indent {
	text-indent: -0.5em;
}
body#movie h3 span.image img {
	width: 227px;
}
body#movie .youtube_area {
  box-sizing: border-box;
  border: none;
  margin: 0 0 0 0;
  padding: 0;
  width: 430px;
	/*height: 239px;*/
	height: 251px;
}
body#movie .youtube_area iframe {
  vertical-align: bottom;
  border-width: 0;
	border: 10px solid #dfdfdf;
}

/***********************************************************
************************************************************
PC：カレンダーページ
************************************************************
************************************************************/
body#calendar .contents_inner {
    padding-top: 0;
    margin-bottom: 50px;
}
body#calendar .calendar {
	margin-bottom: 20px;
}
body#calendar .calendar iframe {
	border: none;
}
body#calendar .exp {
	width: 800px;
	margin: auto;
	text-align: left;
	margin-bottom: 30px;
	font-family:YakuHanJP-Light,'Noto Sans JP','Noto Sans SC','Noto Sans TC','Noto Sans KR',"メイリオ", Meiryo,"ヒラギノ角ゴ Pro W3","HIragino Kaku Gothic Pro W3","HIragino Kaku Gothic Pro",Osaka,"ＭＳ Ｐゴシック", "MS P Gothic",sans-serif;
}
body#calendar .exp span {
	background:linear-gradient(transparent 60%, #c1e0ff 60%);
}
body#calendar .exp2 {
	width: 800px;
	margin: auto;
	text-align: left;
	margin-bottom: 30px;
}
@media only screen and (max-width:767px) {
	body#calendar .calendar {
	overflow: scroll;
	}
	body#calendar .calendar iframe {
		width: 100%;
		height: 400px;
		min-width: 400px
	}
	body#calendar .exp {
		width: 100%;
	}
	body#calendar .exp2 {
	width: 100%;
	}
}

/***********************************************************
************************************************************
PC：NEWS
************************************************************
************************************************************/

body#news .news_wrapper {
	margin-top: 20px;
	text-align: left;
	min-height: 500px;;
}
body#news .news_wrapper .article {
	margin-top: 0px;
}
body#news .news_wrapper .date {
	text-align: right;
	/*margin-bottom: 20px;*/
}

/*ニュース*/
body#news .news {
  width: 1030px;
}

body#news .news a {
	color: #000;
}
/*body#top #news .news .newslist {
  display: inline-block;
  padding: 5px 60px;
  border: 1px solid #000;
}*/



body#news .news .newslist a {
  position: relative;
  display: inline-block;
	padding: 5px 60px;
  color: #000;
  background-repeat: no-repeat;
  background-position: 100% 0;
  background-size: 200% auto;
  background-image: linear-gradient(to right, #000 0%, #000 50%, #fff 50%, #fff 100%);
  -webkit-transition: color ease 0.4s, background-position ease 0.2s;
  -o-transition: color ease 0.4s, background-position ease 0.2s;
  transition: color ease 0.4s, background-position ease 0.2s;
  color: #000;
  text-decoration: none;
	border: 1px solid #000;
}
body#news  .news .newslist a:hover {
  background-position: 0 0;
  color: #fff;
  -webkit-transition: color ease 0.4s, background-position ease 0.2s;
  -o-transition: color ease 0.4s, background-position ease 0.2s;
  transition: color ease 0.4s, background-position ease 0.2s;
}


body#news .news {
  margin-bottom: 70px;
}
body#news .news h2 strong {
  line-height: 1;
  font-family: 'Roboto Condensed', sans-serif;
  font-size: 45px;
}

body#news .news h3 {
	display:-webkit-box;
  display:-ms-flexbox;
  display: flex;
	justify-content: space-between;
	align-content: normal;
}
body#news .news h3 a span {
		position: relative;
	  display: inline-block;
    border: 1px solid #313198;
    padding: 0px;
    line-height: 1;
    font-size: 15px;
    font-weight: normal;
    padding: 5px 15px;
}

body#news .news dl {
	/*display:-webkit-box;
  display:-ms-flexbox;
  display: flex;
	-ms-flex-wrap: wrap;
  flex-wrap: wrap;
  text-align: left;
  border-top: 1px solid #e6e6e6;
  margin-top: 25px;
  margin-bottom: 35px;*/
}
body#news .news dt {
  font-size: 13px;
  color: #999999;
  width: 10em;
  padding: 20px 0 10px;
  /*border-bottom: 1px solid #e6e6e6;*/
}
body#news .news dd {
  width: 100%;
  padding: 0 0 20px;
  border-bottom: 1px solid #e6e6e6;
}

body#news .news dl {
	/*display:-webkit-box;
  display:-ms-flexbox;
  display: flex;
	-ms-flex-wrap: wrap;
  flex-wrap: wrap;
  text-align: left;*/
  /*border-top: 1px solid #e6e6e6;*/
  margin-top: 0;
  margin-bottom: 35px;
}
body#news .news dt {
  font-size: 13px;
  color: #999999;
  /*width: 10em;*/
  padding: 20px 0 0;
  /*border-bottom: 1px solid #e6e6e6;*/
}
body#news .news dt img {
  width: 110px;
	height: 28px;
}
body#news .news dd {
	text-align: left;
  /*width: calc(100% - 10em);*/
  padding: 10px 0 20px 0;
  border-bottom: 1px solid #e6e6e6;
}

/*ラベル表示*/
body#news .news .news_lavel {
	display: flex;
	justify-content: flex-start;
	align-items: center;
	width: 100%;
}

body#news .news .news_lavel .lavel {
	margin-right: 20px;
}
body#news .news .news_lavel .category,
body#news .news .category {
	margin-right: 2px;
}

body#news .news dd .date {
	display: inline-block;
  margin-right: 30px;
  font-size: 14px;
  color: #9c9c9c;
}

body#news .news dd.content {
	display: flex;
	justify-content: flex-start;
}
body#news.news_list .news .lavel {
	margin-bottom: 0;
}
body#news .news .lavel {
	margin-bottom: 20px;
}
body#news .news .category_wraper {
	padding: 20px;
  background: #eee;
  margin-top: 30px;
	line-height: 0;
}
body#news .news .category_wraper img {
	width: 110px;
	height: 28px;
	margin-bottom: 2px;
}
body#news .news .lavel {
	display: flex;
	width: 110px;
	height: 28px;
	margin-right: 20px;
}

@media only screen and (max-width:767px) {
		body#news .news .news_lavel {
		flex-wrap: wrap;
	}
		body#news .news .news_lavel .lavel {
	margin-right: 2px;
		margin-bottom: 2px;
	}
		body#news .news dd .date {
		margin-top: 10px;
  	display: block;
		text-align: left;
			margin-right: 0;
	}
	body#news .news .category_wraper {
	padding: 9px;
	}
	body#news .news dd.content {
	display: block;
	}
	body#news .news .news_lavel .category {
	margin-bottom: 2px
	}
}




@media only screen and (max-width:767px) {
 /***********************************/
  /*ニュース*/
	body#news .news_wrapper {
	min-height: 300px;;
}
	
  body#news .news {
		width: 100%;
    position: relative;
    margin-bottom: 40px;
  }
  body#news .news dl {
    margin-top: 10px;
    margin-bottom: 25px;
  }
  body#news .news h2 strong {
    font-size: 21px;
  }
  body#news .news dl {
    display: block;
  }
  body#news .news dt {
    padding: 10px 0 0 0;
    border-bottom: none;
  }
  body#news .news dd {
    width: 100%;
    padding: 0 0 10px 0;
    border-top: none;
  }
}

/*********************************************************************************************************
**********************************************************************************************************
**********************************************************************************************************
スマホ
**********************************************************************************************************
**********************************************************************************************************
**********************************************************************************************************/
@media only screen and (max-width:767px) {
  .section_panel {
    margin-bottom: 30px;
  }
 	
  /***********************************/
  /*Gナビ*/
  .section_panel .navi ul {
		-ms-flex-wrap: wrap;
    flex-wrap: wrap;
    width: 100%;
    padding: 10px;
  }
  .section_panel .navi ul li {
    width: 50%;
    margin: 0px;
    border-bottom: solid 1px #e4e4e4;
  }
  .section_panel .navi ul li:nth-child(3) {
    border-right: none;
  }
  .section_panel .navi ul li:nth-child(5) {
    border-right: none;
  }
	.section_panel .navi ul li a {
		height: 40px;
  	font-size: 12px;
	}
	/*　アンカーナビ　*/
	body.article .ancher_navi {
  	width: 100%;
	}
	body.article .ancher_navi li a {
		font-size: 12px;
	}
	body.article  #main_contents {
  	width: 100%;
		padding: 0 10px;
	}
  
	body.article .ancher_navi li a span {
		position: relative;
		display: inline-block;
  	padding: 6px 0 20px;
		font-size: 11px;
  	color: #fff;
	}

	body.article .section_panel .navi ul {
		display: block;
	}
	body.article .section_panel .navi ul li {
		float: left;
	}
	body.article .section_panel .navi ul li.top {
		width: 32%;
	}
	
	body.article .section_panel .navi ul:after {
		content: ".";
  	display: block;
  	height: 0;
  	clear: both;
  	visibility: hidden;
	}
	
	body.article .section_panel .navi ul li.movie,
	body.article .section_panel .navi ul li.uniform{
		width: 34%;
		}
	body.article .section_panel .navi ul li.faq,
	body.article .section_panel .navi ul li.calender {
		width: 50%;
	}
	
	/***********************************/
	/*進路*/
	#course h3 {
		font-size: 16px;
		line-height: 1.25em;
		padding: 7px 0;
	}
	
	#course .course_wrapper {
    padding: 20px 0;
	}
	#course .course_inner {
		padding: 0 10px;
	}
	#course .lead {
	margin-bottom: 20px;
	}
	#course .image_course {
		margin-bottom: 40px;
	}
/***********************************/
/*マップ*/
	footer .map {
		display: block;
		width: 100%;
		padding: 0 10px;
	}
	footer .map img {
		padding: 0	40px;
	}
	footer .map .map_navi {
		width: 100%;
		margin-top: 20px;
		display:-webkit-box;
  	display:-ms-flexbox;
		display: flex;
		-ms-flex-wrap: wrap;
		flex-wrap:wrap;
		-webkit-box-pack: center;
		-ms-flex-pack: center;
		justify-content: center;
	}
	footer .map .map_navi li {
		width: 49.5%;
		margin-right: 2px;
		margin-bottom: 2px;
	}
	footer .map .map_navi li:nth-child(2n) {
		margin-right: 0;
	}
	footer .map .map_navi a {
		width: 100%;
		line-height: 1.25;
		min-height: 3.5em;
		margin-bottom: 0;
		position: relative;
		font-size: 12px;
	}
	
	footer .map .map_navi a span {
		position: absolute;
		width: 100%;
		top: 50%;
  	left: 50%;
	  transform: translate(-50%, -50%);
	  -webkit-transform: translate(-50%, -50%);
	  -ms-transform: translate(-50%, -50%);
	}
	
	/***********************************/
	/*　パンクズ　*/
	body.article .breadcrumb {
    margin: 15px 0;
	}
	
	body.article .ancher_navi {
    margin: 0 auto 30px;
	}
	
	/***********************************************************
	************************************************************
	スマホ：FAQページ
	************************************************************
	************************************************************/
	body.article .contents_inner h2 span {
    font-size: 17px;
    padding: 10px 0 10px;
	}
	body#faq .qa .question {
		padding: 20px 0 20px 90px;
		background-size: 70px auto;
		background-position: left 55%;
	}
	body#faq .qa .anser {
		padding: 0px 0 20px 90px;
		background-size: 70px auto;
	}
	
	body.article .contents_inner h2 {
    width: 100%;
    margin-bottom: 20px;
	}
	
	body.article .contents_inner h3 span {
    font-size: 16px;
		padding: 0 0 0 10px;
	}
	
	/***********************************************************
	************************************************************
	スマホ：動画ギャラリーページ
	************************************************************
	************************************************************/
	body#movie h3 {
    margin-bottom: 20px;
	}
	body#movie h3 span {
    font-size: 16px;
		padding: 5px 0 5px 10px;
		border-left: solid 5px #313198;
	}
	body#movie h3 span.image {
    padding: 0 0 0 10px;
		border-left: solid 5px #313198;
	}
	body#movie h3 span.image img {
    width: 180px;
	}
	body#movie .block {
    display: block;
    margin-bottom: 40px;
	}
	body#movie .block .text {
    width: 100%;
    text-align: left;
		margin: 0 auto 20px;
	}
	body#movie .youtube_area {
    position: relative;
    width: 100%;
		height: 0;
    /*padding-bottom: 56.25%;*/
		padding-bottom: 58.5%;
		max-width: 747px;
	}
	body#movie .youtube_area iframe {
      position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
	}
	
	body#movie .ancher_navi {
		display: block;
	}
	body#movie .ancher_navi li {
		float: left;
		width: 33.33%;
		margin-top: 5px;
	}
	body#movie .ancher_navi li:nth-child(4) {
		margin-left: 16.66666%
	}
	body#movie .ancher_navi li a span {
		padding: 5px 0 15px;
		line-height: 1.25;
	}
	body#movie .ancher_navi:after {
		content: ".";
  	display: block;
  	height: 0;
  	clear: both;
  	visibility: hidden;
	}
	
	.calendar  .nav-table {
		font-size: 6px;
	}
}




/*********************************************************************************************************
**********************************************************************************************************
**********************************************************************************************************
共通パーツ
**********************************************************************************************************
**********************************************************************************************************
**********************************************************************************************************/

/*--------------------------
フッタ PC
--------------------------*/
#footer {
	background: #eee;
	padding: 30px 0;
	text-align: center;
	width: 100%;
	font-size: 12px;
	margin-top: 50px;
}

#footer .footer_inner  {
	width: 1030px;
	text-align: left;
	margin: auto;
}

@media only screen and (max-width: 767px) {
	#footer {
		padding: 20px 20px;
		font-size: 9px;
		margin-top: 30px;
}
	#footer .footer_inner  {
	width: 100%;
	text-align: left;
	margin: auto;
	}
}

/*--------------------------
トップへ戻る PC
--------------------------*/
#pageBottom a {
  display: block;
  width: 50px;
  height: 50px;
}
#pageBottom {
  position: fixed;
  right: 11px;
  bottom: 10px;
  z-index: 10001;
}
#pageBottom a:hover:hover {
  text-decoration: none;
  filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=70);
  opacity: 0.7;
}
#pageBottom a:hover:hover img {
  filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=70);
}

/*--------------------------
トップへ戻る SP
--------------------------*/
@media only screen and (max-width: 767px) {
	#pageBottom {
   	 right: 10px;
  	}
 	 #pageBottom:after {
  	  content: ".";
  	  display: block;
  	  margin-top: -1em;
  	  line-height: 1;
  	  color: transparent;
  	}
  	#pageBottom a {
  	  width: 50px;
  	  height: 50px;
  	  background-image: url(../img/icon/icon_pagetop_sp.png);
  	  -moz-background-size: 50px 50px;
  	  -o-background-size: 50px 50px;
  	  -webkit-background-size: 50px 50px;
  	  background-size: 50px 50px;
  	}
  	#pageBottom a:hover:hover {
  	  filter: progid:DXImageTransform.Microsoft.Alpha(enabled=false);
  	  opacity: 1;
  	}
  	#pageBottom a:hover:hover img {
  	  filter: progid:DXImageTransform.Microsoft.Alpha(enabled=false);
  	}
  	#pageBottom a img {
  	  visibility: hidden;
  	}
	#pageBottom a:hover:hover {
	    filter: progid:DXImageTransform.Microsoft.Alpha(enabled=false);
	    opacity: 1;
	}
	#pageBottom a:hover:hover img {
	  filter: progid:DXImageTransform.Microsoft.Alpha(enabled=false);
	}
	#pageBottom a:hover:hover {
	  filter: progid:DXImageTransform.Microsoft.Alpha(enabled=false);
	  opacity: 1;
	}
	#pageBottom a:hover:hover img {
	  filter: progid:DXImageTransform.Microsoft.Alpha(enabled=false);
	}
}

/*------------------------------------

MT NEWS

------------------------------------*/
body#news .news_wrapper .article .article_inner h1 {
	font-size:  2em;
	font-weight: bold;
	background-image: none;
	height: initial;
	background: initial;
	color: initial;
	padding: initial;
	border: initial;
	margin: initial;
	position: initial;
	
}
body#news .news_wrapper .article .article_inner h2 {
	font-size:  1.5em;
	font-weight: bold;
	background-image: none;
	height: initial;
	background: initial;
	color: initial;
	padding: initial;
	border: initial;
	margin: initial;
	position: initial;
}
body#news .news_wrapper .article .article_inner h2 span {
	display: initial; 
  font-size: initial; 
  padding: initial;
}
body#news .news_wrapper .article .article_inner h3 {
	font-size:  1.17em;
	font-weight: bold;
	background-image: none;
	height: initial;
	background: initial;
	color: initial;
	padding: initial;
	border: initial;
	margin: initial;
	position: initial;
}
body#news .news_wrapper .article .article_inner h4 {
	font-size:  1em;
	font-weight: bold;
	background-image: none;
	height: initial;
	background: initial;
	color: initial;
	padding: initial;
	border: initial;
	margin: initial;
	position: initial;
}
body#news .news_wrapper .article .article_inner h5 {
	font-size:  0.83em;
	font-weight: bold;
	background-image: none;
	height: initial;
	background: initial;
	color: initial;
	padding: initial;
	border: initial;
	margin: initial;
	position: initial;
}
body#news .news_wrapper .article .article_inner h6 {
	font-size:  0.67em;
	font-weight: bold;
	background-image: none;
	height: initial;
	background: initial;
	color: initial;
	padding: initial;
	border: initial;
	margin: initial;
	position: initial;
}
body#news .news_wrapper .article .article_inner p {
	display: block;
  margin-block-start: 1em;
  margin-block-end: 1em;
  margin-inline-start: 0px;
  margin-inline-end: 0px;
  unicode-bidi: isolate;
}
body#news .news_wrapper .article .article_inner ul {
	margin: initial;
	padding: initial;
	list-style: initial;
	display: block;
  list-style-type: disc;
  margin-block-start: 1em;
  margin-block-end: 1em;
  margin-inline-start: 0px;
  margin-inline-end: 0px;
  padding-inline-start: 40px;
  unicode-bidi: isolate;
}
body#news .news_wrapper .article .article_inner ul li {
	list-style: initial;
	display: list-item;
  text-align: -webkit-match-parent;
  unicode-bidi: isolate;
}
body#news .news_wrapper .article .article_inner ol {
	list-style-position:inherit;
	display: block;
  list-style-type: decimal;
  margin-block-start: 1em;
  margin-block-end: 1em;
  margin-inline-start: 0px;
  margin-inline-end: 0px;
  padding-inline-start: 40px;
  unicode-bidi: isolate;
}

