@charset "utf-8";


/*	メインビジュアル
------------------------------------------------------------ */
#main-visual {
	width: 100%;
	height: auto;
	background-size: cover;
	overflow: hidden;
}

.main_cover {
	background: url(../images/main_visual_bg.jpg) center center no-repeat;
}

#main-visual p {
	text-align: center;
}


/* --- SP ---------- */
@media screen and (max-width: 740px) {
	
	#main-visual {
		margin: 3rem 0 1rem;
	}
	
	div.movie01, div.movie02{
		max-width: 640px;
		width: 90%;
		margin: 15px auto;
	}
}


/* --- PC ---------- */
@media screen and (min-width: 741px) {
	
	#main-visual {
		margin: 4rem 0 2rem;
	}
	
	div.movie01{
		max-width: 640px;
		width: 49%;
		margin-top: 15px;
		float: left;
	}

	div.movie02{
		max-width: 640px;
		width: 49%;
		margin-top: 15px;
		margin-left: 2px;
		float: left;
	}
}



/*	コンテンツ共通 [index]
------------------------------------------------------------ */

/* --- SP ---------- */
@media screen and (max-width: 740px) {
	
	.contents {
		box-sizing: border-box;
		margin: 0 auto 1rem;
		padding: 0 0.6rem;
		max-width: 100%;
		text-align: center;
	}
	
}


/* --- PC ---------- */
@media screen and (min-width: 741px) {
	
	.contents {
		box-sizing: border-box;
		margin: 0 auto 6rem;
		max-width: 960px;
		text-align: center;
	}
	
	.contents ul:after {
		content: "";
		clear: both;
		display: block;
	}
	
	.contents ul li {
		float: left;
		box-sizing: border-box;
	}
	
}



/*	タイトル
------------------------------------------------------------ */
.contents h2 {
	overflow: hidden;
	color: #26b9eb;
}

h2 span {
	position: relative;
	display: inline-block;
	margin: 0 2.5rem;
	padding: 0 1rem;
	text-align: left;
}

h2 span.ttl-1:before,
h2 span.ttl-1:after,
h2 span.ttl-2:before,
h2 span.ttl-2:after {
	position: absolute;
	top: 50%;
	content: '';
	height: 2px;
	background-color: #26b9eb;
}
	h2 span.ttl-1:before,
	h2 span.ttl-1:after { width: 30%; }
	h2 span.ttl-1:before { right: 90%; }
	h2 span.ttl-1:after { left: 90%; }

	h2 span.ttl-2:before,
	h2 span.ttl-2:after { width: 10%; }
	h2 span.ttl-2:before { right: 98%; }
	h2 span.ttl-2:after { left: 98%; }

.contents h3 {
	font-size: 20px;
}


/* --- SP ---------- */
@media screen and (max-width: 740px) {

	.contents h2 {
		font-size: 25px;
	}

}

/* --- PC ---------- */
@media screen and (min-width: 741px) {

	.contents h2 {
		font-size: 30px;
	}
}



/*	機能
------------------------------------------------------------ */
.contents .func-box {
	box-sizing: border-box;
}

.contents .func-box ul + p {
	margin-top: 0.5rem;
}


/* --- SP ---------- */
@media screen and (max-width: 740px) {
	
	.contents .func-box {
		margin-bottom: 2rem;
	}
	
	.contents .func-box ul {
		margin-top: 0.5rem;
	}
	
	.contents .func-box ul li {
		margin-bottom: 0.6rem;
		padding: 0.6rem;
		background: #26b9eb;
		color: #fff;
	}
		.contents .func-box ul.column-1 li,
		.contents .func-box ul.column-2 li { padding: 1.5rem }
	
	.contents .func-box ul li dl dt {
		font-weight: bold;
	}
	
	.contents .func-box ul li dl dd {
		font-size: 14px;
	}
	
	.contents .func-box p {
		font-size: 14px;
	}

}


/* --- PC ---------- */
@media screen and (min-width: 741px) {
	
	.contents .func-box {
		margin-bottom: 4rem;
	}
	
	.contents .func-box ul li {
		margin: 0  0.1rem 0.1rem;
		padding: 0.6rem;
		background: #26b9eb;
		color: #fff;
	}
		.contents .func-box ul.column-1 li { width: 98.2%; padding: 1.5rem; }
		.contents .func-box ul.column-2 li,
		.contents .func-box ul.column-2-img li { width: 49%; }
		.contents .func-box ul.column-2 li { padding: 1.5rem; }

	.contents .func-box ul li:first-child {
		margin: 0;
	}
	
	.contents .func-box ul li dl dt {
		font-weight: bold;
	}
	
	.contents .func-box ul li dl dd {
		font-size: 14px;
	}
	
	.contents .func-box p {
		font-size: 14px;
	}

}



/*	アジャスト
------------------------------------------------------------ */
.adjust-wrap:after {
	position: absolute;
	top: 100%;
	content: url("../images/arrow_dot.png");
}

.adjust-wrap {
	position: relative;
	background: url(../images/adjust_bg.png) repeat;
}


.adjust-wrap .contents div + div > p span {
	display: block;
	margin-top: 0.4rem;
	padding: 0.4rem 0.6rem;
	background:#26b9eb;
	color: #fff;
}


/* --- SP ---------- */
@media screen and (max-width: 740px) {
	
	.adjust-wrap:after {
		left: 45%;
	}

	.adjust-wrap .contents {
		padding: 2rem 0.5rem;
		margin-bottom: 0;
	}
	
	.adjust-wrap .contents div {
		margin-top: 1rem;
	}
	
	.adjust-wrap .contents div + div > p + p {
		margin: 0 auto;
		width: 70%;
		font-weight: bold;
	}
	
}


/* --- PC ---------- */
@media screen and (min-width: 741px) {
	
	.adjust-wrap:after {
		left: 48%;
	}

	.adjust-wrap .contents {
		padding: 4rem 0;
		margin-bottom: 0;
	}
	
	.adjust-wrap .contents:after {
		content: "";
		clear: both;
		display: block;
	}
	
	.adjust-wrap .contents div {
		float: left;
		box-sizing: border-box;
		margin-top: 2rem;
		width: 50%;
	}
	
	.adjust-wrap .contents div + div {
		padding-left: 4rem;
	}
	
	.adjust-wrap .contents div + div > p:after {
		content: "";
		clear: both;
		display: block;
	}
	
	.adjust-wrap .contents div + div > p {
		float: left;
	}
	
	.adjust-wrap .contents div + div > p + p {
		margin: 2.5rem 0 0 2rem;
		font-weight: bold;
	}

}



/*	図
------------------------------------------------------------ */
.contents .illust-box h3 {
	margin: 0;
	padding: 0.5rem 0;
	background: #26b9eb;
	color: #fff;
}


/* --- SP ---------- */
@media screen and (max-width: 740px) {

	.illust-wrap {
		margin-bottom: 2rem;
		padding: 3rem 0 2rem;
		background: #efefef;
	}
	
	.illust-wrap .contents {
		margin-bottom: 0;
	}
	
	.contents .illust-box {
		box-sizing: border-box;
	}
	
	.contents .illust-box li {
		margin: 0 0 1rem 0;
		background: #fff;
		border: 3px solid #26b9eb;
	}
	
}


/* --- PC ---------- */
@media screen and (min-width: 741px) {

	.illust-wrap {
		margin-bottom: 6rem;
		padding: 4rem 0;
		background: #efefef;
	}
	
	.illust-wrap .contents {
		margin-bottom: 0;
	}
	
	.contents .illust-box:after {
		content: "";
		clear: both;
		display: block;
	}
	
	.contents .illust-box {
		box-sizing: border-box;
	}
	
	.contents .illust-box li {
		float: left;
		margin: 0 0 0.3rem 0.3rem;
		background: #fff;
		width: 49%;
		border: 3px solid #26b9eb;
	}
	
	.contents .illust-box li:first-child {
		margin-left: 0;
	}

}



/*	問い合わせ
------------------------------------------------------------ */
.contact-wrap {
	background: url(../images/contact_bg.png) repeat;
}

.contact-wrap .contents {
	margin-bottom: 0;
}


/* --- SP ---------- */
@media screen and (max-width: 740px) {
	
	.contact-wrap {
		padding: 2rem 0;
	}
	
}


/* --- PC ---------- */
@media screen and (min-width: 741px) {
	
	.contact-wrap {
		padding: 4rem 0;
	}
	
}


