#mv{
	background: url(../img/bg_mv.jpg) no-repeat;
	background-size: 100% auto;
	background-position: 50% 50%;
	overflow: hidden;
}
#mv .inside{
	height: 400px;
	position: relative;
}
#mv p{
	background-color: rgba(0, 0, 0, 0.7);
	color: #fff;
	font-size: 150%;
	font-weight: bold;
	left: 50%;
	letter-spacing: 2px;
	padding: 6px 40px 4px;
	position: absolute;
	text-align: center;
	text-shadow: 2px 2px 4px #333;
	top: 60%;
	transform: translate(-50%, -50%);
	width: 100%;
}
section{
	padding: 60px 0;
}
section .inside{
	overflow: hidden;
}
section:nth-of-type(even){
	background-color: #e7f1e0;
}
section h2{
	font-size: 150%;
	font-family: 'Kiwi Maru', serif;
	margin-bottom: 40px;
	text-align: center;
}
section .ques{
	margin-right: 10px;
}
section .box{
	background-color: #fff;
	border: 12px solid #e7f1e0;
	border-radius: 12px;
	float: left;
	font-family: 'UD デジタル 教科書体 NK-R', serif;
	font-size: 18px;
	padding: 40px;
	width: 75%;
}
section:nth-of-type(7) .box{
	width: 78%;
}
section:nth-of-type(even) .box{
	background-color: #e7f1e0;
	border: 12px solid #fff;
	float: right;
}
section .inside>img{
	float: right;
	margin: 0 2.5%;
}
section:nth-of-type(even) .inside>img{
	float: left;
}
section .box.full{
	float: none !important;
	width: 100% !important;
}
section .box p{
	margin-top: 10px;
}
section .box p:first-child{
	margin-top: 0;
}
section .map{
	border: 1px solid #888;
	margin-top: 20px;
}
section .red{
	color: #f00;
	font-weight: bold;
}

#observe img{
	border: 2px solid #c6d187;
}
#observe .inside img{
	float: none;
	margin: 0;
}
.ap1 table{
	border-collapse: collapse;
	font-size: 114%;
	line-height: 1.8;
	margin: 0 auto;
	width: 90%;
}
.ap1 table tr{
	border-bottom: solid 2px white;
}
.ap1 table tr:last-child{
	border-bottom: none;
}
.ap1 table th{
	position: relative;
	text-align: left;
	width: 30%;
	background-color: #db98ac;
	color: white;
	text-align: center;
	padding: 10px 0;
}
.ap1 table th:after{
	display: block;
	content: "";
	width: 0px;
	height: 0px;
	position: absolute;
	top: calc(50% - 10px);
	right: -10px;
	border-left: 10px solid #db98ac;
	border-top: 10px solid transparent;
	border-bottom: 10px solid transparent;
}
.ap1 table td{
	text-align: left;
	width: 70%;
	text-align: center;
	background-color: #eee;
	padding: 10px 0;
}
.ap1 table span.tbl-ttl{
    background-color: #fff;
    display: inline-block;
    width: 100%;
    margin-top: 20px;
}
.ap1 table span.tbl-ttl:first-child{
    margin-top: 0;
}
.ap1 table .price-box{
	margin: 10px auto;
	overflow: hidden;
	width: 60%;
}
.ap1 table .price-box dt{
	display: inline-block;
	text-align: left;
	width: 60%;
}
.ap1 table .price-box dd{
	display: inline-block;
	text-align: right;
	width: 40%;
}
.ap7 table{
	border: none;
	border-collapse: separate;
	border-spacing: 6px;
	margin-top: 20px;
	width: 100%;
}
.ap7 table tr:last-child{
	border-bottom: none;
}
.ap7 table th{
	background-color: #fff;
	border-left: none;
	box-shadow: 0 0 8px #c6d187;
	position: relative;
	text-align: left;
	width: 10%;
	text-align: center;
	padding: 20px 0;
}
.ap7 table td{
	background-color: #fff;
	border-left: none;
	box-shadow: 0 0 8px #c6d187;
	text-align: left;
	width: 40%;
	padding: 20px;
}
.ap7 table tr{
	border-bottom: none;
	box-shadow: 0 0 8px #c6d187;
}
.ap7 table tr:nth-of-type(even) th,
.ap7 table tr:nth-of-type(even) td{
	background-color: #f6f6f6;
}
.ap7 table span{
    background-color: #fff;
    display: inline-block;
    width: 100%;
    margin-top: 20px;
}
.ap7 table span:first-child{
    margin-top: 0;
}
.sp{
	display: none;
}

@media screen and (max-width: 1024px){
	#mv{
		background-position: 50% 0;
		background-size: 100% auto;
	}
	#mv p{
		border: 0;
		font-size: 120%;
	}
	section{
		padding: 40px 0;
	}
	section>h2{
		margin: 0 auto;
		width: 90%;
	}
	section .box{
		margin: 20px auto 0;
		width: 90%;
	}
	table{
		width: 100%;
	}
	section .box,
	section .box.full{
		float: none !important;
		width: 90% !important;
	}
	section .inside>img{
		display: none;
	}
	#observe .inside div{
		margin-top: 20px;
		text-align: center;
	}
	#observe img{
		width: 90%;
	}
}
@media screen and (max-width: 829px){
	#mv{
		background-size: auto 100%;
	}
	section h2{
		font-size: 127%;
	}
	section h2 span{
		display: block;
		margin-top: -10px;
	}
	.ques{
		margin-right: 10px !important;
		width: 40px;
	}
	.ap1 table{
		margin-top: 20px;
	}
	.ap1 th,.ap1 td{
		text-align: left !important;
		padding: 10px !important;
	}
	.ap1 td{
		text-align: left !important;
		padding: 10px 20px !important;
	}
	.ap1 table span{
		padding: 0 10px;
	}
	.ap1 table .price-box{
		width: 100%;
	}
	.pc{
		display: none;
	}
	.sp{
		display: block;
		margin-top: 20px;
	}
	.map{
		width: 100% !important;
	}
}
@media screen and (max-width: 539px){
	section h2{
		font-size: 127%;
	}
	#mv .inside{
		height: 300px;
	}
	.ap1 table{
		display: block !important;
		width: 90% !important;
	}
	.ap1 th,
	.ap1 td{
		display: block !important;
		width: 100% !important;
	}
	.ap1 table th:after{
		display: inline;
		content: "";
		width: 0px;
		height: 0px;
		position: inherit;
		top: 0;
		right: 0;
		border: 0;
	}
	.ap1 table .price-box dt{
		width: auto;
	}
	.ap1 table .price-box dd{
		display: block;
		padding-left: 1em;
		text-align: left;
		width: auto;
	}
	section .box{
		padding: 20px;
	}
	content section h2{
		font-size: 100%;
	}
}