@charset "utf-8";

/*-------------------------------
basic
---------------------------------*/
* {
	box-sizing: border-box;
}

html {
	font-size: 16px;
}

body {
	margin: 0;
	padding: 0;
	width: 100%;
	line-height: 1.625;
	color: #000;
	font-family: 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', Meiryo, メイリオ, Osaka, 'MS PGothic', arial, helvetica, sans-serif;
}

a {
	text-decoration: none;
	color: #6FB2E6;
}

img {
	max-width: 100%;
	height: auto;
	margin-left: auto;
	margin-right: auto;
}

#wrapper {
	position: relative;
	overflow: hidden;
	max-width: 100%;
}

/*-------------------------------
header
---------------------------------*/
header {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	width: 100%;
	background: transparent;
	margin: 0;
	z-index: 1;
}

.logo {
	position: absolute;
  top: 0;
  left: 50%;
  -ms-transform: translate(-50%,0);
  -webkit-transform: translate(-50%,0);
  transform: translate(-50%,0);
	margin: 0 auto;
	line-height: 0;
}

.logo a {
	text-decoration: none;
	line-height: 0;
	display: block;
	transition: all .4s;
}

.logo a:hover {
	opacity: .8;
}

.logo a img {
	width: 250px;
	height: auto;
	display: block;
}

/*-------------------------------
footer
---------------------------------*/
footer {
	padding: 30px 0;
	background: #000 url(../img/common/footer-bg.png) no-repeat center center/cover;
}

footer h3 {
	font-size: 1.25rem;
	font-weight: 700;
	color: #fff;
	text-align: center;
	margin: 2em auto 0;
}

footer ul.btn-list {
  list-style: none;
  font-size: 0;
	text-align: center;
  margin: 0;
  padding: 0;
  display: inline-block;
  width: 100%;
}

footer ul.btn-list > li {
  font-size: .875rem;
  display: inline-block;
  vertical-align: top;
	margin: 1%;
}

footer ul.btn-list > li:nth-child(1) {
  margin-left: 0;
}

footer ul.btn-list > li:last-child {
  margin-right: 0;
}

footer ul.btn-list > li .btn {
	color: #000;
	text-align: center;
	text-decoration: none;
	line-height: 1;
  display: block;
	padding: 1em;
	background: #fff;
	transition: all .4s;
}

footer ul.btn-list > li .btn:hover {
	color: #fff;
	background: #000;
}

footer .footer-text01,
footer .copyright {
	color: #fff;
	text-align: center;
	margin: 0 auto;
}

footer .footer-text01 {
	font-size: .875rem;
	line-height: 2;
	margin-top: 50px;
}

footer .copyright {
	font-size: .75rem;
	margin-top: 60px;
}

#page_top {
  position: fixed;
  bottom: 20px;
  right: 20px;
	line-height: 0;
  z-index: 10;
}

#page_top a {
  position: relative;
  font-size: 1.5rem;
	background: -moz-linear-gradient(19.27% 184.09% 45deg,rgba(144, 0, 0, 1) 0%,rgba(156, 0, 3, 1) 10.93%,rgba(196, 0, 11, 1) 49.91%,rgba(220, 0, 16, 1) 80.95%,rgba(229, 0, 18, 1) 100%);
  background: -webkit-linear-gradient(45deg, rgba(144, 0, 0, 1) 0%, rgba(156, 0, 3, 1) 10.93%, rgba(196, 0, 11, 1) 49.91%, rgba(220, 0, 16, 1) 80.95%, rgba(229, 0, 18, 1) 100%);
  background: -webkit-gradient(linear,19.27% 184.09% ,80.73% -84.09% ,color-stop(0,rgba(144, 0, 0, 1) ),color-stop(0.1093,rgba(156, 0, 3, 1) ),color-stop(0.4991,rgba(196, 0, 11, 1) ),color-stop(0.8095,rgba(220, 0, 16, 1) ),color-stop(1,rgba(229, 0, 18, 1) ));
  background: -o-linear-gradient(45deg, rgba(144, 0, 0, 1) 0%, rgba(156, 0, 3, 1) 10.93%, rgba(196, 0, 11, 1) 49.91%, rgba(220, 0, 16, 1) 80.95%, rgba(229, 0, 18, 1) 100%);
  background: -ms-linear-gradient(45deg, rgba(144, 0, 0, 1) 0%, rgba(156, 0, 3, 1) 10.93%, rgba(196, 0, 11, 1) 49.91%, rgba(220, 0, 16, 1) 80.95%, rgba(229, 0, 18, 1) 100%);
  background: linear-gradient(45deg, rgba(144, 0, 0, 1) 0%, rgba(156, 0, 3, 1) 10.93%, rgba(196, 0, 11, 1) 49.91%, rgba(220, 0, 16, 1) 80.95%, rgba(229, 0, 18, 1) 100%);
  color: #fff;
  text-align: center;
  text-decoration: none;
  width: 45px;
  height: 45px;
  display: block;
	border-radius: 50%;
  transition: all .4s;
}

#page_top a:before {
  font-family: FontAwesome;
  position: absolute;
  top: 50%;
  left: 50%;
  -ms-transform: translate(-50%,-50%);
  -webkit-transform: translate(-50%,-50%);
  transform: translate(-50%,-50%);
  content: "\f106";
}

#page_top a:hover {
  color: #d61f2a;
	border: 1px solid #d61f2a;
  background: #fff;
}

@media screen and (min-width: 1025px) {
	footer ul.btn-list > li {
	  width: 10.7%;
	}

	footer ul.btn-list > li:nth-child(8) {
	  margin-right: 0;
	}
}

@media screen and (min-width: 769px) and (max-width: 1024px) {
	footer ul.btn-list > li {
	  width: 23.5%;
	}

	footer ul.btn-list > li:nth-child(5) {
	  margin-left: 0;
	}

	footer ul.btn-list > li:nth-child(4) {
	  margin-right: 0;
	}
}

@media screen and (max-width: 1024px) {
	footer ul.btn-list.list_school {
	  margin-top: 1rem;
	}
}

@media screen and (max-width: 768px) {
	footer {
		padding: 5px 0 30px;
	}

	footer ul.btn-list > li {
	  width: 49%;
	}

	footer ul.btn-list > li:nth-child(odd) {
	  margin-left: 0;
	}

	footer ul.btn-list > li:nth-child(even) {
	  margin-right: 0;
	}
}

/*-------------------------------
frontpage
---------------------------------*/
/* mainvisual */
.mv,
.mv .mainimg,
.mv .mainimg .slick-slide > div {
  height: 100vh;
}

.mv {
	position: relative;
	width: 100%;
	background: #fafafa;
}

.mv .mainimg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}

.mv .mainimg img {
  width: 100%;
  height: 100vh;
  object-fit: cover;
	font-family: "object-fit: cover;";
  pointer-events: none;
	display: block;
}

.mv .mv-catch {
	position: absolute;
  top: 50%;
  left: 50%;
  -ms-transform: translate(-50%,-50%);
  -webkit-transform: translate(-50%,-50%);
  transform: translate(-50%,-50%);
	text-align: center;
	margin: 0 auto;
	width: 100%;
}

.mv .mv-catch span {
	font-size: 2.25rem;
	font-weight: 700;
	color: #fff;
	text-align: center;
	line-height: 1.44444444;
	margin: 0 auto;
	display: block;
}

.mv .mv-link {
	position: absolute;
  top: 0;
	display: block;
}

.mv .mv-link.mv-link_top {
	left: 0;
}

.mv .mv-link.mv-link_top img {
	width: 90px;
	height: auto;
	display: block;
	transition: all .4s;
}

.mv .mv-link.mv-link_top:hover img {
	opacity: .7;
}

.mv .mv-link.mv-link_tel {
	right: 0;
	font-size: 1.5rem;
	color: #fff;
	text-align: center;
	text-decoration: none;
	background: #d61f2a;
	display: block;
	padding: 1em;
	transition: all .4s;
}

.mv .mv-link.mv-link_tel:hover {
	opacity: .7;
}

.mv .mv-link.mv-link_tel span {
	line-height: 1;
	display: block;
}

.mv .mv-link.mv-link_tel .num {
	position: relative;
	font-weight: 700;
	padding-left: 1.1em;
}

.mv .mv-link.mv-link_tel .num:before {
	position: absolute;
  top: 50%;
  left: 0;
  -ms-transform: translate(0,-50%);
  -webkit-transform: translate(0,-50%);
  transform: translate(0,-50%);
	content: "";
	width: 21px;
	height: 21px;
	background: transparent url(../img/common/icon_tel.png) no-repeat center center/contain;
}

.mv .mv-link.mv-link_tel .time {
	font-size: .75rem;
	margin-top: .3em;
}

/* facility */
.facility-wrap .col-1 {
	margin: 0;
}

.facility-wrap .img-wrap {
	width: 100%;
	line-height: 0;
}

.facility-wrap .img-wrap img {
	width: 100%;
	display: block;
	pointer-events: none;
}

.facility-wrap .text-wrap .inner {
	width: 100%;
	max-width: 500px;
	padding: 0 30px;
	padding-bottom: 40px;
}

.facility-wrap .text-wrap h3 {
	font-size: 1.875rem;
	font-weight: 700;
	margin: 1em 0;
}

.facility-wrap .text-wrap h3 span {
	font-size: .875rem;
	color: #d61f2a;
	display: block;
}

.facility-wrap .text-wrap p {
	margin: 0;
}

/* information */
.information-wrap .img-wrap {
	line-height: 0;
}

.information-wrap .img-wrap img {
	width: 100%;
	height: auto;
	display: block;
	pointer-events: none;
}

/* event */
.img-wrap_event01 {
	line-height: 0;
}

.img-wrap_event01 img {
	width: 100%;
	height: auto;
	display: block;
	pointer-events: none;
}

/* access */
.access-wrap .img-wrap {
	line-height: 0;
}

.access-wrap .img-wrap img {
	width: 100%;
	height: auto;
	margin: 0;
	display: block;
	pointer-events: none;
}

.access-wrap .text-wrap p {
	margin: 0;
}

#access .map-wrap {
	line-height: 0;
	margin-top: 40px;
}

#access .map-wrap iframe {
	width: 100%;
	height: 560px;
}

@media screen and (min-width: 769px) {
	.facility-wrap .img-wrap {
		height: 100%;
		min-height: 400px;
	}

	.facility-wrap .img-wrap img {
		height: 100%;
		object-fit: cover;
		font-family: "object-fit: cover;";
	}

	.facility-wrap.text-left .text-wrap .inner {
		margin: 0 0 0 auto;
	}
}

@media screen and (max-width: 1024px) {
	.logo a img {
    width: 200px;
	}

	.mv .mv-link.mv-link_top img {
    width: 75px;
	}

	.mv .mv-link.mv-link_tel {
    font-size: 1.25rem;
		padding: .7em;
	}

	.mv .mv-link.mv-link_tel .num:before {
    width: 17px;
    height: 17px;
	}

	.mv .mv-catch span {
    font-size: 1.875rem;
	}
}

@media screen and (max-width: 768px) {
	.logo a img {
    width: 165px;
	}

	.mv .mv-link.mv-link_top img {
    width: 52px;
	}

	.mv .mv-link.mv-link_tel {
    font-size: 1.125rem;
		padding: .5em .7em;
	}

	.mv .mv-link.mv-link_tel .num:before {
    width: 14px;
    height: 14px;
	}

	.facility-wrap .img-wrap img {
		height: auto;
	}

	.facility-wrap .text-wrap .inner {
    max-width: 100%;
    padding: 0 20px;
    padding-bottom: 30px;
	}

	.facility-wrap .text-wrap h3 {
    font-size: 1.5675rem;
    margin: 1.5em 0 .8em;
	}

	.access-wrap .img-wrap img {
		margin: 0 auto;
		max-width: 300px;
	}

	#access .map-wrap iframe {
		height: 300px;
	}
}

@media screen and (max-width: 600px) {
	.logo a img {
    width: 150px;
	}

	.mv .mv-link.mv-link_tel {
    font-size: 1rem;
		padding: .5em;
	}

	.mv .mv-link.mv-link_tel .num:before {
    width: 12px;
    height: 12px;
	}
}

@media screen and (max-width: 568px) {
	.mv .mv-link.mv-link_top img {
    width: 50px;
	}

	.mv .mv-link.mv-link_tel {
    width: 50px;
		height: 50px;
		padding: 0;
	}

	.mv .mv-link.mv-link_tel:after {
		position: absolute;
	  top: 50%;
	  left: 50%;
	  -ms-transform: translate(-50%,-50%);
	  -webkit-transform: translate(-50%,-50%);
	  transform: translate(-50%,-50%);
		content: "";
		width: 20px;
		height: 20px;
		background: transparent url(../img/common/icon_tel.png) no-repeat center center/contain;
	}

	.mv .mv-link.mv-link_tel .num,
	.mv .mv-link.mv-link_tel .time {
    display: none;
	}
}

@media screen and (max-width: 480px) {
	.mv .mv-catch span {
    font-size: 1.5625rem;
	}

	.access-wrap .img-wrap img {
		max-width: 250px;
	}
}

@media screen and (max-width: 375px) {
	.logo a img {
    width: 130px;
	}

	.mv .mv-catch span {
    font-size: 1.375rem;
	}
}

/*-------------------------------
display
---------------------------------*/
.pc {
  display: block !important;
}

.sp {
  display: none !important;
}

@media screen and (max-width: 768px) {
  .pc {
    display: none !important;
  }

  .sp {
    display: block !important;
  }
}

/*-------------------------------
layout
---------------------------------*/
/* container */
.container500,
.container600,
.container800,
.container1000 {
  margin: 0 auto;
  position: relative;
}

.container500 {
  max-width: 500px;
}

.container600 {
  max-width: 600px;
}

.container800 {
  max-width: 800px;
}

.container1000 {
  max-width: 1000px;
}

/* column */
.row {
	display:-webkit-box;
  display: -webkit-flex;
  display:-ms-flexbox;
  display: flex;
  -webkit-flex-wrap:wrap;
  -ms-flex-wrap:wrap;
  flex-wrap:wrap;
}
.col-1 {flex:1;}
.col-2 {flex:2;}
.col-3 {flex:3;}
.col-4 {flex:4;}
.col-5 {flex:5;}
.col-6 {flex:6;}
.col-7 {flex:7;}
.col-8 {flex:8;}
.col-1,
.col-2,
.col-3,
.col-4,
.col-5,
.col-6,
.col-7,
.col-8 {
  margin: 0 20px;
}

.order-1 {
  -webkit-box-ordinal-group: 1;
  -ms-flex-order: 1;
  -webkit-order: 1;
  order: 1;
}

.order-2 {
  -webkit-box-ordinal-group: 2;
  -ms-flex-order: 2;
  -webkit-order: 2;
  order: 2;
}

@media screen and (min-width: 769px) {
	.row > div:first-child {
	    margin-left: 0;
	}
	.row > div:last-child {
	    margin-right: 0;
	}
}

@media screen and (max-width: 1040px) {
	.container1000 {
    padding-left: 20px;
		padding-right: 20px;
	}
}

@media screen and (max-width: 840px) {
	.container800 {
    padding-left: 20px;
		padding-right: 20px;
	}
}

@media screen and (max-width: 768px) {
	.row {
		-webkit-flex-direction: column;
		flex-direction: column;
	}
	.col-1,
	.col-2,
	.col-3,
	.col-4,
	.col-5,
	.col-6,
	.col-7,
	.col-8 {
		margin: 20px 0;
	}

	.order-1 {
		-webkit-box-ordinal-group: 2;
		-ms-flex-order: 2;
		-webkit-order: 2;
		order: 2;
	}

	.order-2 {
		-webkit-box-ordinal-group: 1;
		-ms-flex-order: 1;
		-webkit-order: 1;
		order: 1;
	}
}

@media screen and (max-width: 640px) {
	.container600 {
    padding-left: 20px;
		padding-right: 20px;
	}
}

@media screen and (max-width: 540px) {
	.container500 {
    padding-left: 20px;
		padding-right: 20px;
	}
}

/*-------------------------------
background
---------------------------------*/
.bg_wh {
	position: relative;
	background: #fff;
}

.bg_wh01 {
	padding: 90px 0 35px;
}

.bg_wh02 {
	padding: 35px 0;
}

.bg_wh03 {
	padding: 35px 0 70px;
}

@media screen and (max-width: 768px) {
	.bg_wh01 {
		padding: 70px 0 35px;
	}
}

/*-------------------------------
text
---------------------------------*/
.ta-l {
  text-align: left !important;
}

.ta-c {
  text-align: center !important;
}

.ta-r {
  text-align: right !important;
}

/*-------------------------------
heading
---------------------------------*/
.heading_sub {
	font-size: 1.75rem;
	font-weight: 700;
	text-align: center;
	line-height: 1.25;
	letter-spacing: .1em;
  margin: 0 auto 2em;
	display: table;
}

.heading_sub span {
	font-size: .875rem;
	color: #d61f2a;
	display: block;
	margin-bottom: .3em;
}

/*-------------------------------
link
---------------------------------*/
.link-bnr01,
.link-bnr01 img {
	display: block;
}

.link-bnr01 img {
	width: 100%;
	height: auto;
	display: block;
	transition: all .4s;
}

.link-bnr01:hover img {
	opacity: .7;
}

/*-------------------------------
customize
---------------------------------*/
@supports (-webkit-touch-callout: none) {
	.mv,
	.mv .mainimg,
	.mv .mainimg .slick-slide > div,
	.mv .mainimg img {
    /* Safari用のハック */
    height: -webkit-fill-available;
  }
}

/*-------------------------------
animation
---------------------------------*/
.fadein {
    opacity : 0;
    transition : .7s all;
}

.fadein.ttb {
	transform : translate(0, -40px);
}
.fadein.btt {
	transform : translate(0, 40px);
}
.fadein.ltr {
	transform : translate(-40px, 0);
}
.fadein.rtl {
	transform : translate(40px, 0);
}

.fadein.scrollin {
    opacity : 1;
}

.fadein.ttb.scrollin,
.fadein.btt.scrollin,
.fadein.ltr.scrollin,
.fadein.rtl.scrollin {
	transform : translate(0, 0) !important;
}

.fadein02 {
	-moz-transition-delay: 400ms;
    -webkit-transition-delay: 400ms;
    -o-transition-delay: 400ms;
    -ms-transition-delay: 400ms;
}
.fadein03 {
    -moz-transition-delay: 600ms;
    -webkit-transition-delay: 600ms;
    -o-transition-delay: 600ms;
    -ms-transition-delay: 600ms;
}
.fadein04 {
    -moz-transition-delay: 800ms;
    -webkit-transition-delay: 800ms;
    -o-transition-delay: 800ms;
    -ms-transition-delay: 800ms;
}
.fadein05 {
    -moz-transition-delay: 1000ms;
    -webkit-transition-delay: 1000ms;
    -o-transition-delay: 1000ms;
    -ms-transition-delay: 1000ms;
}
.fadein06 {
    -moz-transition-delay: 1200ms;
    -webkit-transition-delay: 1200ms;
    -o-transition-delay: 1200ms;
    -ms-transition-delay: 1200ms;
}

@media screen and (max-width: 768px) {
    .fadein02,
    .fadein03,
    .fadein04,
    .fadein05,
    .fadein06 {
        -moz-transition-delay: 0s;
        -webkit-transition-delay: 0s;
        -o-transition-delay: 0s;
        -ms-transition-delay: 0s;
    }
}
