@charset "UTF-8";

/*
font-family: "新丸ゴ R", Shin Maru Go Regular, "メイリオ";
color: #f5a70f;
*/

/* ===================================================================
	frontpage
=================================================================== */

#frontpage .mainimg {
	background: url(../images/main_bg.jpg) no-repeat center center;
	background-size: cover;
	height: 100%;
	width: 100%;
	max-height: 580px;
	text-align: center;
	position: relative;
	overflow: hidden;
	font-family: "新丸ゴ R", Shin Maru Go Regular, "メイリオ";
}

#frontpage .mainimg::before {
	content: '';
	padding-top: 100%;
	display: block;
	position: relative;
}

#frontpage .mainimg section {
	position: absolute;
	top: calc(50% + 1em);
	left: 50%;
	width: 100%;
	max-width: 1160px;
	display: block;
	text-align: center;
	transform: translate(-50%, -50%);
	-webkit- transform: translate(-50%, -50%);
	margin-top: -1em;
}

/*
#frontpage .mainimg section::after {
	content: '';
	background: url(../images/sample.png) no-repeat center center;
	background-size: contain;
	width: 295px;
	height: 600px;
	display: block;
	position: absolute;
	top: -65%;
}
*/

#frontpage .mainimg section h1 {
	padding: 0;
	margin: 0 0 0.8em;
	font-size: 1.7em;
	letter-spacing: 0.2em;
}

#frontpage .mainimg section p {
	padding: 0;
	margin: 0 5% 0.8em;
	text-align: center;
	letter-spacing: 0.1em;
}

#frontpage .mainimg section a {
	margin-top: 1em;
	display: inline-block;
	background: #f5a70f;
	border-radius: 2em;
	padding: 0.2em 2em;
	color: #fff;
}

#frontpage .mainimg section a::before {
	content: ' >';
	margin-right: 1em;
}

#frontpage .tokucho,
#frontpage .movie,
#frontpage .qa,
#frontpage .news {
	text-align: center;
}

#frontpage .tokucho h1,
#frontpage .movie h1,
#frontpage .faq h1,
#frontpage .news h1 {
	padding: 0;
	margin: 0 0 0.8em;
	font-size: 1.7em;
	letter-spacing: 0.2em;
	color: #f5a70f;
	font-family: "新丸ゴ R", Shin Maru Go Regular, "メイリオ";
}

#frontpage .tokucho h1 small,
#frontpage .movie h1 small,
#frontpage .faq h1 small,
#frontpage .news h1 small {
	display: block;
	margin-bottom: 0.5em;
	font-size: 0.7em;
}

#frontpage .tokucho {
	padding: 8em 5%;
}

#frontpage .tokucho ol {
	max-width: 930px;
	margin: 2em auto;
	padding: 0;
	counter-reset: number;
	list-style: none;
	font-size: 1.3em;
	line-height: 1.6em;
	display: block;
	text-align: left;
}

#frontpage .tokucho ol li {
	border-top: 1px dotted #000;
	padding: 1em 0.5em;
}

#frontpage .tokucho ol li::before {
	counter-increment: number;
	content: counter(number, decimal-leading-zero);
	color: #f5a70f;
	margin-right: 1em;
	float: left;
}

#frontpage .tokucho ol li:nth-of-type(1) {
	border-top: none;
}

#frontpage .tokucho ol li p {
	overflow: hidden;
	zoom: 1;
	padding: 0;
	margin: 0;
	letter-spacing: 0.1em;
}

#frontpage .tokucho a {
	border: 2px solid #f5a70f;
	color: #f5a70f;
	border-radius: 2em;
	padding: 0.5em 2.5em;
	font-size: 1.2em;
	line-height: 1.8em;
	display inline-block;
	margin: 0 auto;
}

#frontpage .tokucho a::before {
	content: ' >';
	margin-right: 1em;
}

#frontpage .movie {
	background: #f2f2f2;
	text-align: center;
	padding: 4em 5%;
	display: block;
}

#frontpage .movie section {
	max-width: 825px;
	margin: 0 auto;
}

#frontpage .movie p {
	text-align: left;
}

#frontpage .movie .youtube {
	position: relative;
	width: 100%;
	padding-top: 56.25%;
	margin: 0 auto;
	overflow: hidden;
}

#frontpage .movie .youtube iframe {
	position: absolute;
	top: 0;
	right: 0;
	width: 100% !important;
	height: 100% !important;
}

#frontpage .faq {
	text-align: center;
	padding: 4em 5% 5em;
	display: block;
}

#frontpage .faq .maxwidth {
	max-width: 1000px;
	margin: 0 auto;
}

footer article#fadd {
	border-top: 3px solid #f5a70f;
}

#frontpage .news {
	padding: 8em 5%;
}

#frontpage .news ul {
	padding: 0;
	margin: 2em auto 0;
	list-style: none;
	text-align: left;
	max-width: 1060px;
	font-weight: 400;
}

#frontpage .news ul li {
	padding: 1em 10% 1em;
	margin: 0;
	list-style: none;
	line-height: 1.1em;
}

#frontpage .news ul li:nth-of-type(odd) {
	background: #f2f2f2;
}

#frontpage .news ul li time {
	width: 8em;
	float: left;
	display: inline-block;
	line-height: 1.6em;
}

#frontpage .news ul li div {
	overflow: hidden;
	zoom: 1;
}

#frontpage .news ul li div p {
	display: inline-block;
	padding: 0;
	margin: 0;
	overflow: hidden;
	zoom: 1;
	line-height: 1.6em;
}

/* =======================================================
==========================================================

レスポンシブ

==========================================================
======================================================= */

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

#frontpage .mainimg {
	max-height: 460px;
}

}

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

#frontpage .mainimg {
	max-height: 380px;
	background-size: cover;
}

#frontpage .tokucho {
	padding: 6em 5%;
}

#frontpage .tokucho ol {
	margin: 1em auto;
	font-size: 1.1em;
    line-height: 1.6em;
}

#frontpage .faq {
	text-align: center;
	padding: 3em 5% 1em;
	display: block;
}

#frontpage .news {
    padding: 3em 5% 4em;
}

}

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

#frontpage .mainimg {
	background: url(../images/main_bg_sp.jpg) no-repeat center center;
	background-size: cover;
	height: 100%;
	width: 100%;
	max-height: 240px;
	text-align: center;
	position: relative;
	overflow: hidden;
	font-family: "新丸ゴ R", Shin Maru Go Regular, "メイリオ";
}

#frontpage .tokucho,
#frontpage .news {
	padding: 4em 5%;
}

#frontpage .qa {
	text-align: center;
	padding: 4em 5% 1em;
	display: block;
}

#frontpage .qa ul li {
    margin-bottom: 1em;
}

}

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

#frontpage .news ul li {
	padding: 1em 5%;
}

#frontpage .news ul li time {
	width: 100%;
	float: none;
	display: inline-block;
}

}

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

#frontpage .mainimg {
	background: url(../images/main_bg_sp.jpg) no-repeat center bottom;
	background-size: cover;
	max-height: none;
	padding: 0.5em 0 1em;
}

#frontpage .mainimg section h1 {
	margin-bottom: 0.5em;
}

#frontpage .mainimg::before {
    padding: 1em 0;
}

#frontpage .mainimg p {
	line-height: 1.5em;
}

#frontpage .mainimg section {
	position: relative;
	top: 0;
	left: 0;
	transform: translate(0,0);
	-webkit- transform: translate(0,0);
}

#frontpage .mainimg section a {
    margin-top: 0;
}

}

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

#frontpage .mainimg,
#frontpage .tokucho,
#frontpage .movie,
#frontpage .qa,
#frontpage .news {
	font-size: 0.9em;
}

#frontpage .mainimg p br,
#frontpage .movie p br {
	display: none;
}

#frontpage .news ul {
	font-size: 1.1em;
}

}