@charset "UTF-8";
/* CSS Document */



#error h2 {
	border-bottom: solid 2px #d60000;
}


/* ===========================
   Contents
=========================== */

#content {
	padding-bottom: 0;
}

#home #content {
	min-height: auto;
}

#mainImage {
	height: 700px;
	height: 85vh;
}

.swiper-container {
	width: 100%;
	height: 100%;
}

.swiper-pagination-bullet {
	width: 10px;
	height: 10px;
	background: #BEBEBE;
	opacity: 0.5;
}

.swiper-pagination-bullet-active {
	background: #d60000;
	opacity: 1;
}

/* Typing Championship バナー用 */

#slide_8 {
	background: #000 url(../images/slide-x0.png) center center;
	background-size: cover;
}

#slide_8 span {
	display: block;
	width: 100%;
	height: 100%;
	background-color: #d60000;
	text-indent: -9999px;
	filter: alpha(opacity=0);
	-ms-filter: "alpha(opacity=0)";
	-moz-opacity: 0;
	opacity: 0;
	zoom: 1;
	transition: opacity .2s ease-in;
}

#slide_8 span:not(:target) {
	filter: none\9;
	-ms-filter: none\9;
}

#slide_8 span:hover {
	filter: alpha(opacity=20);
	-ms-filter: "alpha(opacity=20)";
	-moz-opacity: 0.2;
	opacity: 0.2;
	zoom: 1;
}

#slide_8 span:not(:target) {
	filter: none\9;
	-ms-filter: none\9;
}

/* Typing Championship バナー用 ここまで */


/*-- スライドコンテンツ hover エフェクト --*/

.swiper-slide .txtEffect {
	display: block;
	width: 100%;
	height: 100%;
	filter: alpha(opacity=0);
	opacity: 0;
	transition: opacity .75s ease-in-out;
	line-height: .6;
	background-color: rgba(0,0,0,.2);
}

.swiper-slide .txtEffect:hover {
	opacity: .9;
}

.swiper-slide .hvr {
	color: #fff;
	font-family: 'Scheherazade', serif;
	font-size: 8.8rem;
	position: relative;
	top: calc( 50% - .8em );
	text-shadow: 0px 0px 40px #000;
	text-indent: -9999px;
	vertical-align: baseline;
	transition: top .75s ease-in-out;
}

.swiper-slide a:hover .hvr {
	top: calc( 50% - 1em );
}

.swiper-slide .hvr img {
	height: 6rem;
	vertical-align: baseline;
	opacity: 1 !important;
	filter: drop-shadow(0px 0px 40px rgba(0,0,0,1));
	margin-bottom: 0;
}

.swiper-slide .hvr small {
	font-size: .5em;
}

/* IE8〜11 で無効 */

@media screen\0 {
	.swiper-slide a,
	.swiper-slide span {
		transition-property: none;
	}

	.swiper-slide a:hover {
		opacity: 0;
	}
}

/* Edge12+（Edge全て）で無効 */

@supports (-ms-ime-align: auto) {
	.swiper-slide a,
	.swiper-slide .hvr {
		transition-property: none;
	}

	.swiper-slide a:hover {
		opacity: 0;
	}
}

/*-- スライドコンテンツ hover エフェクト ここまで --*/


#slide_1 {
	background: #000 url(../images/slide-0.jpg) 95% center;
	background-size: cover;
}

#slide_2 {
	background: #000 url(../images/slide-1.jpg) center center;
	background-size: cover;
}

#slide_3 {
	background: #fff url(../images/slide-2.jpg) center center;
	background-size: cover;
}

#slide_4 {
	background: #333 url(../images/slide-3.jpg) center center;
	background-size: cover;
}

#slide_5 {
	background: url("../images/slide-5.jpg") center center;
	background-size: cover;
}

#slide_5 a,
#slide_6 a {
	display: block;
	width: 100%;
	height: 100%;
	transition: background-color .5s ease-in-out;
}

#slide_5 a:hover,
#slide_6 a:hover {
	background-color: rgba(0, 0, 0, .2);
}

#slide_5 a:hover .miri,
#slide_6 a:hover .hoshimi {
	background: linear-gradient(0deg, rgba(7, 9, 23, 0.8), rgba(0, 0, 0, 0));
}

#slide_5 .miri,
#slide_6 .hoshimi {
	position: absolute;
	bottom: 0;
	display: block;
	box-sizing: border-box;
	width: 100%;
	padding: 12rem 1em 5rem 1em;
	font-family: "ＭＳ Ｐ明朝", "MS PMincho","ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "serif";
	font-size: 5rem;
	line-height: 1.3;
	color: #fff;
	background: linear-gradient(0deg, rgba(7, 9, 23, 0.6), rgba(0, 0, 0, 0));
}

#slide_6 {
	background: url("../images/slide-6.jpg") right 10%;
	background-size: cover;
}

#slide_7 {
	position: relative;
	background: #19212f url("../images/bg_bg_gl_apc.png") repeat-y;
	background-size: contain;
}

#slide_7::before {
	position: absolute;
	top: 0;
	left: 0;
	z-index: 0;
	content: '';
	width: 100%;
	height: 100%;
	background: url("../images/bg_gl_apc.png") center center repeat-x;
	background-size: contain;
}

#slide_7 a {
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
	width: 100%;
	height: 100%;
	transition: background-color .5s ease-in-out;
	text-indent: -9999px;
	background: url("../images/gl_apc_top.jpg") no-repeat center center;
	background-size: contain;
}


/*-- バナー --*/

#furusato h2 {
	margin: 0;
	background-color: #333;
	color: #fff;
	font-size: 1.4rem;
	font-weight: 600;
	height: 3em;
	line-height: 3em;
	padding: .25em 0 .5em;
	letter-spacing: .2em;
	position: relative;
}

#furusato h2::after {
	display: block;
	content: url("../images/caret-down.svg");
	width: 1rem;
	position: absolute;
	left: 50%;
	margin-left: -.5rem;
	bottom: -.6rem;
}

#bnr1 {
	font-size: 0;
}

#bnr1 li {
	display: inline-block;
	margin: 0;
	width: 50%;
	height: 3em;
	line-height: 3em;
	text-align: center;
	font-weight: 500;
	font-size: 1.6rem;
}

#bnr1 a {
	display: block;
	width: 100%;
	height: 100%;
}

#bnr1 li:first-of-type a {
	background-color: #ad0003;
	color: #fff;
}

#bnr1 li:last-of-type a {
	background-color: #9b7332;
	color: #fff;
}

@media screen and (max-width: 480px) {
	#bnr1 li {
		display: block;
		width: 100%;
	}
}




@media screen and (min-width: 1000px) {

	.br-forMob {
		display: none;
	}
}

@media screen and (max-width: 600px) {
	#slide_5 .miri,
	#slide_6 .hoshimi {
		padding-top: 3rem;
		font-size: 3rem;
	}
}

video#promoVid {
	position: fixed;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	min-width: 100%;
	min-height: 100%;
	width: auto;
	height: auto;
	z-index: -100;
	background: url(../images/slide-3.jpg) center center;
	background-size: cover;
}

@media screen and (max-device-width: 826px) {
	video#promoVid {
		display: none;
	}
}



/* ===========================
   Responsive
=========================== */

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

	#mainImage h2 {
		font-size: 4rem;
	}

	#mainImage a {
		padding-top: .75em;
	}
}


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

	.swiper-slide .hvr {
		font-size: 6rem;
	}

	.swiper-slide .hvr img {
		height: 4rem;
	}
}


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

	.swiper-button-next,
	.swiper-button-prev {
		display: none;
	}
}


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

	#mainImage {
		height: 75vh;
	}

	.swiper-slide .hvr {
		font-size: 4.4rem;
	}

	.swiper-slide .hvr img {
		height: 3rem;
	}

}

