@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@700&display=swap');

/* ---------------------------------------------
    reset
--------------------------------------------- */
#plan body,
div,
dl,
dt,
dd,
ul,
ol,
li,
h1,
h2,
h3,
h4,
h5,
h6,
pre,
form,
fieldset,
input,
textarea,
p,
blockquote,
th,
td,
img {
	margin: 0;
	padding: 0;
}

#plan table {
	border-collapse: collapse;
	border-spacing: 0;
}

#plan fieldset,
img {
	border: 0;
}

#plan img {
	display: block;
	max-width: 100%;
	height: auto;
}

#plan img a {
	border: none;
}

#plan address,
caption,
cite,
code,
dfn,
em,
th,
var {
	font-style: normal;
	font-weight: normal;
}

#plan ol,
ul {
	list-style: none;
}

#plan caption,
th {
	text-align: left;
}

#plan h1,
h2,
h3,
h4,
h5,
h6 {
	font-size: 100%;
	font-weight: normal;
	line-height: 1.0;
}

#plan q:before,
q:after {
	content: "";
}

#plan figure {
	width: 100%;
	margin: 0;
	padding: 0;
}

/* ---------------------------------------------
    common
--------------------------------------------- */
#plan * {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}

#plan body {
	-webkit-text-size-adjust: 100%;
	word-break: break-all;
	color: #333;
	font-family: '游ゴシック Medium', 'Yu Gothic Medium', 'YuGothic M', '游ゴシック', 'Yu Gothic', '游ゴシック体', YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "M+ 1p", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

#plan a {
	text-decoration: none;
	-webkit-transition: all .3s;
	transition: all .3s;
}

#plan a:link {
	color: #426721;
}

#plan a:visited {
	color: #426721;
}

#plan a:hover {
	color: #669933;
	text-decoration: underline;
}

#plan a:active {
	color: #669933;
}

#plan p {
	line-height: 1.6;
}

#plan .txt-red {
	color: #cc0000;
}

#plan #pageTop {
	position: fixed;
	width: 50px;
	right: 0px;
	bottom: 0px;
	z-index: 998;
	cursor: pointer;
}

#plan .wrap {
	padding: 100px 20px;
}

#plan .bg1 {
	background-image: url(../img_plan/bg1.svg);
}

#plan .bg2 {
	background-image: url(../img_plan/bg2.svg);
	background-size: 100px auto;
}

#plan .bg3 {
	background-image: url(../img_plan/bg3.png);
	background-size: 80px auto;
}

#plan .bg4 {
	background-color: #FEF8EE;
}

#plan .contents {
	max-width: 960px;
	margin: 0 auto;
}

#plan .contents-wrap {
	max-width: 880px;
	margin: 0 auto;
}

#plan .headline1 {
	font-size: 30px;
	font-family: 'Noto Serif JP', serif;
	font-weight: 700;
	text-align: center;
	line-height: 1.8;
	color: #426721;
	margin-bottom: 40px;
	padding-bottom: 20px;
	border-bottom: 1px solid #426721;
}

#plan .headline1 br {
	display: none;
}

#plan .mb100 {
	margin-bottom: 100px;
}

#plan .txt1 {
	font-size: 15px;
	margin-bottom: 1em;
}

#plan .txt1-1 {
	font-size: 15px;
}

#plan .table1 {
	width: 100%;
	margin-bottom: 30px;
}

.table1 th,
#plan .table1 td {
	border: 1px solid #426721;
	padding: 15px;
	font-size: 17px;
	font-weight: bold;
	line-height: 1.8;
}

#plan .table1 th {
	width: 180px;
	text-align: center;
	background-color: #B9D08B;
}

#plan .table1 td {
	background-color: #fff;
}

#plan .table1 td.flow {
	text-align: center;
}

#plan .parallax {
	position: relative;
	overflow: hidden;
}

#plan .parallax>img {
	position: absolute;
	top: 0;
	z-index: -1;
	width: 100%;
	object-fit: cover;
	height: 100vh;
}

#plan .bg-img {
	height: 300px;
}

@media only screen and (max-width: 768px) {
	#plan .wrap {
		padding: 80px 20px;
	}

	#plan .bg2 {
		background-size: 80px auto;
	}

	#plan .headline1 {
		font-size: 24px;
		margin-bottom: 30px;
		padding-bottom: 15px;
	}

	#plan .mb100 {
		margin-bottom: 80px;
	}

	.table1 th,
	#plan .table1 td {
		font-size: 15px;
	}

	#plan .table1 th {
		width: 150px;
	}

	#plan .parallax>img {
		display: none;
	}

	#plan .bg-img {
		height: 200px;
		background-size: cover;
		background-position: center center;
		background-repeat: no-repeat;
	}

	#plan .bg-img-1 {
		background-image: url(../img_plan/bg-img1.jpg);
	}

	#plan .bg-img-2 {
		background-image: url(../img_plan/bg-img2.jpg);
	}

	#plan .bg-img-3 {
		background-image: url(../img_plan/bg-img3.jpg);
	}

}

@media only screen and (max-width: 640px) {
	#plan .wrap {
		padding: 60px 20px;
	}

	#plan .headline1 {
		font-size: 20px;
	}

	#plan .headline1 br {
		display: block;
	}

	#plan .mb100 {
		margin-bottom: 60px;
	}

	#plan .table1 {
		border-bottom: 1px solid #426721;
	}

	.table1 th,
	#plan .table1 td {
		display: block;
		padding: 10px;
	}

	#plan .table1 th {
		width: 100%;
		border-bottom: none;
	}

	#plan .table1 td {
		width: 100%;
		border-bottom: none;
	}

	#plan .table1 td.price {
		text-align: center;
	}

}

/* ---------------------------------------------
    header
--------------------------------------------- */
#plan header {
	padding: 30px 20px;
}

#plan .logo1 {
	max-width: 510px;
	margin: 0 auto;
}

@media only screen and (max-width: 768px) {
	#plan .logo1 {
		max-width: 310px;
	}
}

@media only screen and (max-width: 640px) {
	#plan header {
		padding: 20px 20px;
	}

	#plan .logo1 {
		max-width: 240px;
	}
}

/* ---------------------------------------------
    contents
--------------------------------------------- */
#plan .contents-title h1 {
	font-size: 40px;
	font-family: 'Noto Serif JP', serif;
	font-weight: 700;
	color: #AF2F2F;
	margin-bottom: 40px;
	text-align: center;
}

#plan .contents-title p {
	font-size: 18px;
	text-align: center;
	line-height: 1.8;
}

#plan .place {
	font-size: 18px;
	font-weight: bold;
	margin-bottom: 1em;
}

#plan .contact {
	max-width: 560px;
	margin: 0 auto 1em;
	padding: 30px 20px;
	background-color: #F8F4D2;
	border: 1px solid #73A243;
	border-radius: 20px;
}

#plan .contact-address {
	font-size: 20px;
	font-weight: bold;
	text-align: center;
	margin-bottom: 5px;
}

#plan .contact-tel {
	font-size: 30px;
	font-weight: bold;
	text-align: center;
	margin-bottom: 5px;
}

#plan .contact-time {
	font-size: 16px;
	font-weight: bold;
	text-align: center;
}

#plan .faq-list dt {
	position: relative;
	margin-bottom: 20px;
	padding: 10px 20px;
	background-color: #669933;
	font-size: 20px;
	font-weight: bold;
	color: #fff;
	cursor: pointer;
}

#plan .faq-list dt:hover {
	background-color: rgba(102, 153, 51, 0.9);
}

#plan .faq-list dt:first-child::after {
	position: absolute;
	content: url(../img_plan/arrow.svg);
	width: 14px;
	height: auto;
	top: 12px;
	right: 15px;
	transform: rotateX(180deg);
}

#plan .faq-list dt:first-child.open::after {
	position: absolute;
	content: url(../img_plan/arrow.svg);
	width: 14px;
	height: auto;
	top: 8px;
	right: 15px;
	transform: rotateX(0deg);
}

#plan .faq-list dt::after {
	position: absolute;
	content: url(../img_plan/arrow.svg);
	width: 14px;
	height: auto;
	top: 8px;
	right: 15px;
}

#plan .faq-list dt.open::after {
	position: absolute;
	content: url(../img_plan/arrow.svg);
	width: 14px;
	height: auto;
	top: 12px;
	right: 15px;
	transform: rotateX(180deg);
}

#plan .faq-list ul li {
	border: 1px solid #669933;
	background-color: #fff;
	margin-bottom: 20px;
	padding: 20px;
}

#plan .faq-list .question {
	font-size: 17px;
	font-weight: bold;
	color: #669933;
	margin-bottom: 5px;
}

#plan .faq-list .answer {
	font-size: 15px;
}

#plan .faq-list .bold {
	font-weight: bold;
}

@media only screen and (max-width: 768px) {
	#plan .contents-title h1 {
		font-size: 30px;
		margin-bottom: 40px;
	}

	#plan .contents-title p {
		font-size: 16px;
	}
}

@media only screen and (max-width: 640px) {
	#plan .contents-title h1 {
		font-size: 24px;
		margin-bottom: 40px;
	}

	#plan .contents-title p {
		text-align: left;
	}

	#plan .place {
		font-size: 17px;
	}

	#plan .contact-address {
		font-size: 18px;
	}

	#plan .contact-tel {
		font-size: 28px;
	}

	#plan .contact-time {
		font-size: 15px;
	}

	#plan .faq-list dt {
		font-size: 17px;
	}

	#plan .faq-list .question {
		font-size: 15px;
	}

	#plan .faq-list .answer {
		font-size: 14px;
	}
}

/* ---------------------------------------------
    footer
--------------------------------------------- */
#plan footer .logo2 {
	background-color: #669933;
	padding: 30px 20px;
}

#plan footer .logo2 img {
	max-width: 200px;
	margin: 0 auto;
}

#plan footer p {
	font-size: 12px;
	line-height: 2;
	text-align: center;
	padding: 30px 10px;
}

@media only screen and (max-width: 768px) {
	#plan footer .logo2 {
		padding: 20px 20px;
	}

	#plan footer .logo2 img {
		max-width: 180px;
	}

	#plan footer p {
		font-size: 11px;
		padding: 20px 10px;
	}
}