@charset "utf-8";

/****************************
					共通・構造
****************************/
.header_container {
	display: flex;
	justify-content: space-between;
	align-items: center;
	width: 1180px;
	margin: 0 auto;
}

.container {
	display: block;
	width: 1180px;
	margin: 0 auto;
}

/****************************
					ヘッダー
****************************/
#header {
	width: 100%;
	padding: 10px;
	box-sizing: border-box;
	line-height: 1;
}

.header_menu {
	width: auto;
}

.header_menu ul {
	display: flex;
	align-items: center;
}

.header_menu ul li {
	width: auto;
	margin-right: 30px;
}

.header_menu ul li:last-child {
	margin-right: 0;
}

.header_menu ul li a {
	display: block;
	font-size: 16px;
	color: #333333;
	line-height: 1;
}

.header_menu ul li.sitemap a:before {
	content: url("../../images/common/sitemap.svg");
	padding-right: 5px;
	vertical-align: middle;
	line-height: 1;
}

.header_menu ul li.faq a:before {
	content: url("../../images/common/faq.svg");
	padding-right: 5px;
	vertical-align: middle;
	line-height: 1;
}

.header_menu ul li.contact a:before {
	content: url("../../images/common/mail.svg");
	padding-right: 5px;
	vertical-align: middle;
	line-height: 1;
}

/****************************
			グローバルメニュー
****************************/
nav {
	display: block;
	width: 100%;
	padding: 30px 0 10px 0;
	text-align: center;
	line-height: 1;
}

nav ul {
	display: flex;
	justify-content: center;
	width: 820px;
	margin: 0 auto;
}

nav ul li {
	width: 28%;
	border-right: 1px solid #000;
}

nav ul li.long {
	width: 48%;
}

nav ul li a {
	display: block;
	padding: 5px 20px;
	font-size: 15px;
	font-weight: 500;
	font-family: 'Zen Maru Gothic',
		sans-serif;
	text-align: center;
}

/****************************
				トップページ
****************************/
#main {
	margin-top: -80px;
	padding: 20px 0;
}

.main_ct {
	padding-top: 85px;
	padding-bottom: 30px;
	background-color: #f9f8f4;
}

.top_colum3 {
	display: flex;
	width: 100%;
	margin-bottom: 40px;
}

.top_colum_col {
	width: 49%;
	margin-right: 2%;
}

.top_colum_col:last-child {
	margin-right: 0;
}

.top_colum_col .photo {
	display: block;
	margin-bottom: 10px;
}

.top_colum_col p.title {
	display: block;
	font-size: 21px;
	color: #223889;
	padding: 10px 0;
	text-align: center;
}

.top_colum_col p.title span {
	width: 100%;
}

.top_colum_col p.comment {
	display: block;
	font-size: 16px;
	font-family: 'Zen Maru Gothic',
		sans-serif;
	font-weight: 500;
	line-height: 1.6;
	text-align: left;
}

.top_colum_col p.detail_btn {
	display: block;
	width: 90%;
	margin: 30px auto 0 auto;
}

.top_colum_col p.detail_btn a {
	display: block;
	padding: 15px;
	border-radius: 30px;
	background-color: #e8e5d9;
	color: #223889;
	text-align: center;
	line-height: 1;
}

.top_colum_col p.detail_btn a:after {
	content: url("../images/common/arw_right.svg");
	display: inline-block;
	padding-left: 10px;
	line-height: 1;
	vertical-align: middle;
}


/****************************
				めざす幼児像
****************************/
.purpose {
	display: block;
	padding: 40px 0;
}

.list_box {
	display: flex;
	flex-wrap: wrap;
	width: 100%;
	margin-top: 30px;
}

.list_col {
	display: flex;
	align-items: center;
	width: 49%;
	margin-right: 2%;
	margin-bottom: 20px;
	padding: 20px;
	border-radius: 5px;
	background-color: #ffffff;
	border: 5px solid #d3ccb4;
}

.list_col:after {
	content: "";
	display: block;
	clear: both;
}

.list_col:nth-child(even) {
	margin-right: 0;
}

.list_col p {
	display: block;
	font-size: 16px;
	font-weight: 500;
	line-height: 1.6;
}

#no1:before {
	content: url("../images/no1.svg");
	display: inline-block;
	padding-right: 10px;
	vertical-align: middle;
	line-height: 1;
}

#no2:before {
	content: url("../images/no2.svg");
	display: inline-block;
	padding-right: 10px;
	vertical-align: middle;
	line-height: 1;
	float: left;
}

#no3:before {
	content: url("../images/no3.svg");
	display: inline-block;
	padding-right: 10px;
	vertical-align: middle;
	line-height: 1;
	float: left;
}

#no4:before {
	content: url("../images/no4.svg");
	display: inline-block;
	padding-right: 10px;
	vertical-align: middle;
	line-height: 1;
}

/****************************
					フッター
****************************/
#footer {
	display: block;
	margin-top: 80px;
	padding: 40px 40px 80px 40px;
	background-color: #e8e5d9;
	position: relative;
}

#footer:after {
	content: url("../images/footer_img.png");
	position: absolute;
	bottom: 0;
	left: 50%;
	-webkit-transform: translateX(-50%);
	/* Safari用 */
	transform: translateX(-50%);
}

p#footer_logo {
	display: block;
	margin-bottom: 10px;
	text-align: center;
}

p.address {
	display: block;
	font-size: 16px;
	line-height: 1;
	text-align: center;
}

.footer_renraku {
	display: flex;
	justify-content: center;
	margin-top: 10px;
}

.footer_renraku p {
	width: auto;
	margin-right: 20px;
}

.footer_renraku p:last-child {
	margin-right: 0;
}

.footer_renraku p.footer_tel a {
	font-size: 24px;
	font-weight: normal;
}

.footer_renraku p.footer_mail a {
	display: block;
	background-color: #776b4d;
	border-radius: 20px;
	color: #fff;
	padding: 10px 20px;
	line-height: 1;
}

.footer_renraku p.footer_tel a:before {
	content: url("../images/common/footer_tel.svg");
	display: inline-block;
	padding-right: 5px;
	vertical-align: middle;
	line-height: 1;
}

.footer_renraku p.footer_mail a:before {
	content: url("../images/common/footer_mail.svg");
	display: inline-block;
	padding-right: 5px;
	vertical-align: middle;
	line-height: 1;
}

ul.footer_menu {
	display: flex;
	justify-content: center;
	width: 100%;
	margin-top: 30px;
}


ul.footer_menu li {
	width: auto;
	border-right: 1px solid #776b4d;
}

ul.footer_menu li a {
	display: block;
	color: #776b4d;
	font-size: 16px;
	padding: 3px 15px;
	line-height: 1;
}

p.copyright {
	display: block;
	padding-top: 80px;
	font-size: 16px;
	position: relative;
	z-index: 99;
	text-align: center;
}

#next_main {
	display: block;
	padding: 0 10px;
	box-sizing: border-box;
}

#pagetop {
	position: fixed;
	bottom: 10px;
	right: 10px;
}


.pankuzu {
	display: block;
	width: 100%;
	margin-bottom: 15px;
}

.pankuzu p {
	display: block;
	width: 1180px;
	margin: 0 auto;
	font-size: 14px;
	color: #492c12;
}

.pankuzu a {
	color: #2a66ae;
	text-decoration: none;
}

.pankuzu a:hover {
	text-decoration: underline;
}

#sisetsu_overview {
	display: block;
	padding: 30px 0;
}

#sisetsu_overview table {
	border-collapse: collapse;
	width: 100%;
	border: 1px solid #cccccc;
}

#sisetsu_overview table th {
	width: 20%;
	padding: 15px 30px;
	background-color: #deedcd;
	color: #492c12;
	font-size: 16px;
	border-bottom: 1px solid #cccccc;
	text-align: left;
}

#sisetsu_overview table td {
	width: 80%;
	padding: 15px 30px;
	color: #492c12;
	font-size: 16px;
	border-bottom: 1px solid #cccccc;
	background-color: #fff;
}

/****************************
			お問い合わせ
****************************/
#contact_form input {
	padding: 8px;
	width: 100%;
}

#contact_form select {
	padding: 8px;
	width: 100%;
}

#contact_form select option {
	padding: 8px;
	width: 100%;
}

#contact_form textarea {
	padding: 8px;
	width: 100%;
}

#contact_btn {
	width: 100%;
	margin: 20px auto 1em;
	text-align: center;
}

#contact_btn button,
#contact_btn .submitbutton {
	display: inline-block;
	margin: 0 1%;
	width: 45%;
	padding: 10px 20px;
	background-color: #2a66ae;
	color: #ffffff;
	font-size: 120%;
	border: none;
	cursor: pointer;
	text-align: center;
	font-weight: bold;
}

#contact_btn .backbutton {
	background-color: #808080;
}

#contact_btn button:hover {
	opacity: 0.7;
}

#contact_form span {
	display: block;
	font-size: 14px;
	margin-top: 5px;
}

#contact_form span.req_note {
	display: inline-block;
	padding-left: 5px;
	color: #cb5219;
}

.error_message {
	color: #FF0000;
	font-weight: bold;
	padding: 5px;
	margin: 5px 0 0 0;
	line-height: 1.4;
	background-color: #FFFF80;
	display: inline-block;
}