@charset "utf-8";
@import url("../font/load.css");


/* CSS Document */

body {
	min-width: 1280px;
	font-size: 1.5rem;
	line-height: 2.33;
}

/*========================================
headerの設定
==========================================*/

.h_wrap {
	align-items: flex-start;
	padding: 0 45px 15px;
	background: url(../images/common/h_wrap_border.png) repeat-x center top, #f9f3ec;
}

.h_group {
	padding-top: 15px;
}

.h_group h1 {
	max-width: 470px;
	width: 100%;
	font-size: 1.2rem;
	color: #d0c1b0;
	line-height: 1.3;
	letter-spacing: 0.06em;
	margin-bottom: 12px;
}

.h_block {
	text-align: right;
}

.h_info {
	display: inline-block;
	text-align: center;
	border: 1px solid #ff8ba7;
	border-top: none;
	padding: 8px 20px 10px;
	border-radius: 0 0 5px 5px;
	background: #fff;
	margin-bottom: 15px;
}

.h_info_ads {
	font-size: 1.3rem;
	line-height: 1;
	margin-bottom: 10px;
}

.h_info_card .tel_num {
	margin-right: 15px;
}

.h_nav_list li {
	line-height: 1;
}

.h_nav_list li:not(:last-child) {
	margin-right: 30px;
}

.h_nav_list li a {
	transition: .5s;
}

.h_nav_list li a:hover {
	color: #ff8ba7;
}

/*========================================
footerの設定
==========================================*/

.f_nav {
	padding: 25px 0;
	background: #8fc597;
}

.f_nav li {
	color: #fff;
	line-height: 1;
}

.f_nav li:not(:last-child) {
	margin-right: 15px;
}

.f_boxs {
	text-align: center;
	padding: 30px 0 25px;
}

.f_logo {
	margin-bottom: 20px;
}

.f_ads {
	line-height: 1;
	font-size: 1.3rem;
	margin-bottom: 30px;
}

.f_info {
	margin-bottom: 20px;
}

.f_info .ct_link {
	width: 175px;
	height: 50px;
	margin-left: 20px;
}

.f_sns a:not(:last-child) {
	margin-right: 20px;
}

#copyright {
	font-size: 1.3rem;
	color: #cfc0af;
	text-align: center;
	letter-spacing: 0.04em;
	padding-bottom: 20px;
}


/*========================================
メインビジュアルの設定
==========================================*/

.main_visual {
	position: relative;
	overflow: hidden;
	z-index: 0;
	height: 750px;
	background: url(../images/top/main_visual_bg.jpg) no-repeat center / cover;
}

.catch {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	z-index: 50;
}

.visual_sns{
	position: relative;
}

.visual_sns_in{
	position: absolute;
	top: 50%;
	right: 20px;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	transform: translateY(-50%);
	z-index: 10;
}

.visual_sns_in a{
	display: block;
}

.visual_sns_in a:not(:last-child){
	margin-bottom: 30px;
}

/*========================================
TOPページ
==========================================*/

/*---------------------
top_greeting
----------------------*/

.top_greeting {
	position: relative;
	background: url(../images/top/top_greeting_deco.png) no-repeat center bottom,url(../images/top/top_greeting_bg.jpg) no-repeat center / cover;
	z-index: 0;
}

.top_greeting::before {
	content: '';
	position: absolute;
	bottom: -18px;
	left: 14%;
	width: 93px;
	height: 180px;
	background: url(../images/top/top_greeting_deco01.png) no-repeat center bottom / contain;
	z-index: -1;
}

.top_greeting::after {
	content: '';
	position: absolute;
	bottom: -18px;
	right: 5%;
	width: 350px;
	height: 180px;
	background: url(../images/top/top_greeting_deco02.png) no-repeat center bottom / contain;
	z-index: -1;
}

.top_greeting_boxs {
	padding: 235px 0 60px;
}

.top_greeting_ttl {
	text-align: center;
	line-height: 1;
	font-size: 3.5rem;
	font-family: 'UD デジタル 教科書体 NK-R', 'Kiwi Maru', serif;
	margin-bottom: 100px;
}

.top_greeting_ttl span {
	display: inline-block;
	padding-bottom: 10px;
	border-bottom: 2px dashed #ffc6c7;
}

.top_greeting_txt {
	text-align: center;
	margin-bottom: 40px;
}

.top_greeting_info::before {
	content: '';
	position: absolute;
	top: -40px;
	left: -55px;
	width: 37px;
	height: 32px;
	background: url(../images/top/top_greeting_info_deco.png) no-repeat center / contain;
}

@media screen and (max-width:1560px) {

	.top_greeting::before {
		left: 3%;
		width: 83px;
	}

	.top_greeting::after {
		right: 10px;
		width: 280px;
	}
}

/*---------------------
top_feature
----------------------*/

.top_feature {
	position: relative;
	background: url(../images/top/top_feature_bg.png) no-repeat left bottom;
}

.top_feature::before {
	content: '';
	position: absolute;
	bottom: 0;
	right: 8%;
	width: 196px;
	height: 201px;
	background: url(../images/top/top_feature_deco.png) no-repeat center / contain;
}

.top_feature_boxs {
	padding: 120px 0 100px;
}

.top_feature_list {
	padding: 110px 140px 80px;
	border-radius: 5px;
	background: url(../images/common/pattern01.png);
	margin-bottom: 40px;
}

.top_feature_ttl {
	text-align: center;
	margin-bottom: 100px;
}

.top_feature_ttl span {
	position: relative;
	display: inline-block;
	line-height: 1;
	z-index: 0;
}

.top_feature_ttl span::before {
	content: '';
	position: absolute;
	top: -70px;
	left: 50%;
	transform: translateX(-50%);
	width: 504px;
	height: 166px;
	background: url(../images/top/top_feature_ttl_deco.png) no-repeat center / contain;
	z-index: -1;
}

.top_feature_list li {
	position: relative;
	z-index: 0;
	text-align: center;
	z-index: 5;
	counter-increment: top_feature_list;
}

.top_feature_list li::before {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 240px;
	height: 240px;
	border-radius: 50%;
	background: #fff;
	z-index: -1;
}

.top_feature_list li::after {
	content: counter(top_feature_list, decimal-leading-zero);
	position: absolute;
	top: -60px;
	left: 50%;
	transform: translateX(-50%);
	font-size: 5.0rem;
	color: #fff;
	line-height: 1;
	z-index: -2;
}

.top_feature_list_img {
	display: flex;
	justify-content: center;
	align-items: flex-end;
	width: 161px;
	height: 147px;
	margin: 0 auto 15px;
}

.top_feature_list_txt {
	font-size: 2.2rem;
	line-height: 1;
}

.top_feature_txt {
	text-align: center;
	margin-bottom: 40px;
}

.top_feature_btn {
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 1.8rem;
	color: #fff;
	border-radius: 2px;
	width: 230px;
	height: 50px;
	margin: 0 auto;
	background: #ff8ba7;
}

.top_feature_btn::before {
	content: '';
	position: absolute;
	top: 50%;
	right: 10px;
	transform: translateY(-50%);
	transition: .5s;
	width: 4px;
	height: 7px;
	background: url(../images/top/arrow.png) no-repeat center;
}

.top_feature_btn:hover::before {
	right: 3px;
}

/*---------------------
top_intro
----------------------*/

.top_intro {
	background: #f9f3ec;
}

.top_intro_boxs {
	padding: 50px 20px 80px;
}

.top_intro_block {
	position: relative;
	width: 500px;
	align-items: center;
	transition: .5s;
	padding: 25px 45px 25px 20px;
	box-shadow: 2.723px 4.193px 0px 0px rgba(207, 192, 175, 0.24);
	background: #fff;
}

.top_intro_block::before {
	content: '';
	position: absolute;
	top: 50%;
	right: 15px;
	transform: translateY(-50%);
	transition: .5s;
	width: 7px;
	height: 14px;
	background: url(../images/top/arrow02.png) no-repeat center;
}

.top_intro_block:hover {
	transform: translateY(-15px);
}

.top_intro_img {
	margin-right: 20px;
}

.top_intro_group {
	flex: 1;
}

.top_intro_group_ttl {
	line-height: 1;
	font-size: 2.2rem;
	text-align: center;
	font-family: 'UD デジタル 教科書体 NK-R', 'Kiwi Maru', serif;
	margin-bottom: 20px;
}

.top_intro_group_txt {
	line-height: 1.86;
	letter-spacing: 0.04em;
}

/*---------------------
top_news
----------------------*/

.top_news {
	background: url(../images/top/top_news_deco.png) no-repeat center bottom, #f9f3ec;
}

.top_news_boxs {
	padding: 0 20px 140px;
}

.top_news_block {
	position: relative;
	max-width: 500px;
	width: 100%;
}

.top_news_ttl {
	position: relative;
	font-size: 2.8rem;
	letter-spacing: 0.04em;
	line-height: 1;
	padding-left: 50px;
	padding-bottom: 7px;
	font-family: 'UD デジタル 教科書体 NK-R', 'Kiwi Maru', serif;
}

.top_news_ttl::before {
	content: '';
	position: absolute;
	bottom: 0;
	left: 8px;
	width: 24px;
	height: 54px;
	background: url(../images/top/top_news_ttl_deco01.png) no-repeat center / contain;
}

.top_news_block:nth-child(2) .top_news_ttl::before {
	background-image: url(../images/top/top_news_ttl_deco02.png);
}

.top_news_list {
	padding: 30px 20px;
	background: url(../images/top/top_news_list_border.png) repeat-x center top, url(../images/top/top_news_list_border.png) repeat-x center bottom;
}

.top_news_more {
	position: absolute;
	right: 5px;
	top: 10px;
	padding-right: 15px;
	line-height: 1;
	background: url(../images/top/top_news_more_arrow.png) no-repeat right center;
}

/*========================================
下層メインビジュアルの設定
==========================================*/

.sub_visual {
	display: flex;
	justify-content: center;
	align-items: center;
	height: 365px;
	padding-top: 40px;
}

.sub_visual h2 {
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 556px;
	height: 100px;
	font-size: 3.6rem;
	letter-spacing: 0.12em;
	border-radius: 15px;
	background: linear-gradient(to top, rgba(255, 255, 255, 1), transparent);
	z-index: 0;
	font-family: 'UD デジタル 教科書体 NK-R', 'Kiwi Maru', serif;
}

.sub_visual h2::before {
	content: '';
	position: absolute;
	top: -90px;
	left: 50%;
	transform: translateX(-50%);
	width: 490px;
	height: 249px;
	background: url(../images/common/sub_visual_deco.png) no-repeat center / contain;
	z-index: -1;
}

/*========================================
about
==========================================*/

/*---------------------
about_greeting
----------------------*/

.about_greeting_img {
	text-align: center;
	margin-bottom: 30px;
}

.about_greeting_img span {
	position: relative;
	display: inline-block;
}

.about_greeting_img span::before {
	content: '';
	position: absolute;
	bottom: 0;
	left: -31px;
	width: 31px;
	height: 68px;
	background: url(../images/about/about_greeting_img_deco01.png) no-repeat center / contain;
}

.about_greeting_img span::after {
	content: '';
	position: absolute;
	bottom: 0;
	right: -31px;
	width: 29px;
	height: 68px;
	background: url(../images/about/about_greeting_img_deco02.png) no-repeat center / contain;
}

.about_greeting_txt {
	flex: 1;
	letter-spacing: 0.09em;
	margin-right: 35px;
}

.about_greeting_career {
	max-width: 520px;
	width: 100%;
	border-radius: 10px;
	background: #f9f3ec;
}

.about_greeting_career_ttl {
	font-size: 2.0rem;
	line-height: 1;
	padding: 15px 18px 12px;
	margin-bottom: 10px;
	background: url(../images/about/about_greeting_career_ttl_bdr.png) repeat-x center bottom;
}

.about_greeting_career_list {
	padding: 10px 20px 15px;
	letter-spacing: 0.05em;
}

.about_greeting_career_list span {
	display: inline-block;
	min-width: 115px;
}


/*---------------------
about_history
----------------------*/

.about_history{
	position: relative;
	background: url(../images/about/about_history_deco.png) no-repeat center bottom -120px,#f9f3ec;
}

.about_history::before{
	content: '';
	position: absolute;
	top: -35px;
	right: 20%;
	width: 70px;
	height: 70px;
	background: url(../images/about/about_history_deco01.png) no-repeat center / contain;
}

.about_history::after{
	content: '';
	position: absolute;
	bottom: -59px;
	left: 16%;
	width: 118px;
	height: 118px;
	background: url(../images/about/about_history_deco02.png) no-repeat center / contain;
}

.about_history_boxs{
	position: relative;
	padding-bottom: 120px;
}

.about_history_boxs::before{
	content: '';
	position: absolute;
	bottom: -45px;
	right: -100px;
	width: 185px;
	height: 220px;
	background: url(../images/about/about_history_deco03.png) no-repeat center / contain;
}

.about_history_txt{
	text-align: center;
}

/*---------------------
about_faq
----------------------*/

.about_faq{
	position: relative;
}

.about_faq::before{
	content: '';
	position: absolute;
	bottom: 0;
	left: 6%;
	width: 6%;
	max-width: 118px;
	height: 198px;
	background: url(../images/about/about_faq_deco01.png) no-repeat left bottom / contain;
}

.about_faq_boxs{
	padding: 150px 0 80px;
}

.about_faq_ttl{
	position: relative;
	font-size: 3.5rem;
	letter-spacing: 0.16em;
	line-height: 1.3;
	text-align: center;
	padding-top: 100px;
	margin-bottom: 40px;
	font-family: 'UD デジタル 教科書体 NK-R','Kiwi Maru',serif;
}

.about_faq_ttl::before{
	content: '';
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 97px;
	height: 87px;
	background: url(../images/about/about_faq_ttl_deco.png) no-repeat center / contain;
}

.about_faq_list{
	padding-left: 20px;
	padding-right: 20px;
}

.about_faq_list li:not(:last-child){
	margin-bottom: 60px;
}

.about_faq_list_ttl,
.about_faq_list_txt{
	position: relative;
	padding-left: 70px;
}

.about_faq_list_ttl{
	font-size: 2.0rem;
	margin-bottom: 30px;
}

.about_faq_list_txt{
	line-height: 2.2;
}

.about_faq_list_ttl::before,
.about_faq_list_txt::before{
	content: '';
	position: absolute;
	top: -4px;
	left: 0;
	width: 53px;
	height: 53px;
	background: url(../images/about/about_faq_list_icon01.png) no-repeat center / contain;
}

.about_faq_list_txt::before{
	background-image: url(../images/about/about_faq_list_icon02.png);
}

/*========================================
worship
==========================================*/

/*---------------------
worship_about
----------------------*/

.worship_about{
	position: relative;
	background: #f9f3ec;
}

.worship_about::before{
	content: '';
	position: absolute;
	bottom: 0;
	left: 10%;
	width: 74px;
	height: 176px;
	background: url(../images/worship/worship_about_deco01.png) no-repeat left bottom / contain;
}

.worship_about_boxs{
	position: relative;
}

.worship_about_boxs::before{
	content: '';
	position: absolute;
	top: 100px;
	right: -100px;
	width: 93px;
	height: 180px;
	background: url(../images/worship/worship_about_deco02.png) no-repeat left bottom / contain;
}

.worship_about_list li{
	position: relative;
	display: flex;
	flex-direction: column;
	width: 340px;
}

.worship_about_list li::before{
	content: '';
	position: absolute;
	bottom: -7px;
	right: -16px;
	width: 55px;
	height: 47px;
	background: url(../images/worship/worship_about_list_deco.png) no-repeat center / contain;
}

.worship_about_txt{
	text-align: center;
	margin-bottom: 30px;
}

.worship_about_list_ttl{
	line-height: 1;
	padding: 15px 0;
	border-radius: 4px;
	margin-bottom: 5px;
	font-size: 2.4rem;
	text-align: center;
	background: #ffc6c7;
}

.worship_about_list_in{
	flex: 1;
}

.worship_about_list_in{
	background: #fff;
}

.worship_about_list_time{
	font-size: 1.8rem;
	padding: 10px 0;
	text-align: center;
	border-bottom: 1px dotted;
}

.worship_about_list_txt{
	line-height: 1.8;
	padding: 15px 25px;
}

@media screen and (max-width:1500px) {

	.worship_about::before{
		left: 30px;
	}

}

/*---------------------
worship_charm
----------------------*/

.worship_charm{
	background: url(../images/worship/worship_charm_deco01.png) no-repeat left top 130px,url(../images/worship/worship_charm_deco02.png) no-repeat right top 130px;
}

.worship_charm_ttl{
	z-index: 0;
}

.worship_charm_ttl::before{
	content: '';
	position: absolute;
	top: -27px;
	left: 50%;
	transform: translateX(-50%);
	width: 126px;
	height: 100px;
	background: url(../images/worship/worship_charm_ttl_deco.png) no-repeat center / contain;
	z-index: -1;
}

.worship_charm_list li{
	position: relative;
	padding: 7px 15px 7px 75px;
	border-radius: 4px;
	font-size: 2.2rem;
	background: url(../images/common/pattern02.png);
}

.worship_charm_list li:not(:last-child){
	margin-bottom: 10px;
}

.worship_charm_list li::before{
	content: '';
	position: absolute;
	top: 50%;
	left: 30px;
	transform: translateY(-50%);
	width: 31px;
	height: 31px;
	background: url(../images/worship/worship_charm_list_icon.png) no-repeat center / contain;
}

/*---------------------
worship_flow
----------------------*/

.worship_flow{
	background: url(../images/worship/worship_flow_deco01.png) no-repeat right 5% top 20px,url(../images/worship/worship_flow_deco02.png) no-repeat left top 740px,url(../images/worship/worship_flow_deco03.png) no-repeat right 4% bottom 450px,url(../images/worship/worship_flow_deco04.png) no-repeat left 7% bottom,url(../images/worship/worship_flow_deco05.png) no-repeat right bottom,#f9f3ec;
}

.worship_flow_list{
	position: relative;
}

.worship_flow_list li{
	position: relative;
	display: flex;
	padding-left: 80px;
	counter-increment: worship_flow_list;
}

.worship_flow_list li:not(:last-child){
	margin-bottom: 60px;
}

.worship_flow_list li::before{
	content: counter(worship_flow_list, decimal-leading-zero);
	position: absolute;
	top: 0;
	left: 0;
	font-size: 2.8rem;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 51px;
	height: 51px;
	background: #8abe92;
	border-radius: 10px;
	color: #fff;
	line-height: 1;
}

.worship_flow_list li:not(:last-child)::after{
	content: '';
	position: absolute;
	top: 0;
	left: 25px;
	height: calc(100% + 60px);
	border-left: 1px solid #8abe92;
}

.worship_flow_group{
	flex: 1;
	margin-left: 30px;
	text-shadow:#f9f3ec 2px 0px 10px, #f9f3ec -2px 0px 10px,
		#f9f3ec 0px -2px 10px, #f9f3ec -2px 0px 10px,
		#f9f3ec 2px 2px 10px, #f9f3ec -2px 2px 10px,
		#f9f3ec 2px -2px 10px, #f9f3ec -2px -2px 10px,
		#f9f3ec 1px 2px 10px;
}

.worship_flow_group_ttl{
	font-size: 2.4rem;
	letter-spacing: 0.16em;
	line-height: 1.4;
	margin-bottom: 20px;
}

.worship_flow_group_txt p{
	line-height: 1.8;
}

.worship_flow_group_txt p:not(:last-child){
	margin-bottom: 28px;
}

/*========================================
works
==========================================*/

/*---------------------
works_cmt
----------------------*/

.works_cmt{
	background: url(../images/works/works_cmt_bg01.png) no-repeat left top,url(../images/works/works_cmt_bg02.png) no-repeat right top;
}

.works_cmt_group{
	display: flex;
	flex-direction: column;
	width: 322px;
}

.works_cmt_group_ttl{
	display: flex;
	justify-content: center;
	align-items: center;
	width: 250px;
	height: 65px;
	color: #fff;
	font-size: 2.4rem;
	margin: 0 auto;
	border-radius: 4px;
	background: #ff8ba7;
}

.works_cmt_group:nth-child(2) .works_cmt_group_ttl{
	background: #cfc0af;
}

.works_cmt_group:nth-child(3) .works_cmt_group_ttl{
	background: #8fc597;
}

.works_cmt_item{
	display: flex;
	flex-direction: column;
	flex: 1;
	padding: 25px 15px 20px;
	border-radius: 4px;
	background: url(../images/common/pattern03.png);
}

.works_cmt_group_txt{
	flex: 1;
	line-height: 1.7;
	margin-bottom: 25px;
}

/*---------------------
works_offer
----------------------*/

.works_offer{
	background: url(../images/works/works_offer_deco01.png) no-repeat right 5% top 85px,url(../images/works/works_offer_deco02.png) no-repeat left 10% bottom,#f9f3ec;
}

.works_offer_card:not(:last-child){
	margin-bottom: 50px;
}

.works_offer_group{
	max-width: 653px;
	width: 100%;
}

.works_offer_group_ttl{
	font-size: 2.4rem;
	margin-bottom: 20px;
	background: url(../images/works/works_offer_group_ttl_border.png) repeat-x left bottom;
}

.works_offer_group_ttl span{
	font-size: 2.0rem;
}

.works_offer_group_txt{
	line-height: 1.7;
}

/*---------------------
works_activity
----------------------*/

.works_activity{
	position: relative;
	z-index: 0;
	background: url(../images/common/pattern04.png);
}

.works_activity::before{
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 246px;
	background: url(../images/works/works_activity_deco.png) no-repeat center top / cover;
	z-index: -1;
}

.works_activity::after{
	content: '';
	position: absolute;
	bottom: 0;
	right: 11%;
	width: 70px;
	height: 167px;
	background: url(../images/works/works_activity_illust02.png) no-repeat center top / cover;
	z-index: -1;
}

.works_activity_boxs{
	position: relative;
}

.works_activity_boxs::before{
	content: '';
	position: absolute;
	bottom: 0;
	left: 20px;
	width: 74px;
	height: 176px;
	background: url(../images/works/works_activity_illust01.png) no-repeat center / contain;
}

.works_activity_txt{
	text-align: center;
	margin-bottom: 40px;
}

.works_activity_info{
	background: rgba(255,255,255,.8);
}

/*========================================
event
==========================================*/

/*---------------------
event_hold
----------------------*/

.event_hold_list li{
	line-height: 1;
}

.event_hold_list li:not(:last-child){
	margin-bottom: 20px;
}

.event_hold_list li a{
	position: relative;
	align-items: center;
	padding: 25px 50px 25px 25px;
	border-radius: 4px;
	background: #f9f3ec;
}

.event_hold_list li a::before{
	content: '';
	position: absolute;
	top: 50%;
	right: 17px;
	transform: translateY(-50%);
	width: 10px;
	height: 11px;
	background: url(../images/event/arrow.png) no-repeat center;
}

.event_hold_list_data{
	max-width: 670px;
	width: 100%;
}

.event_hold_list_time{
	display: inline-block;
	color: #331e06;
	line-height: 1;
	padding: 8px 20px;
	border-radius: 4px;
	margin-bottom: 30px;
	background: #cfc0af;
}

.event_hold_list_ttl{
	font-size: 2.0rem;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.event_hold_list_img{
	width: 315px;
	height: 180px;
	border-radius: 4px;
	overflow: hidden;
}

.event_hold_list_img img{
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: .5s;
	position: relative;
}

.event_hold_list li a:hover .event_hold_list_img img{
	transform: scale(1.2);
}

/*---------------------
event_year
----------------------*/

.event_year{
	background: #f9f3ec;
}

.event_year_list li{
	width: 322px;
}

.event_year_list li:nth-last-child(n+4){
	margin-bottom: 60px;
}

.event_year_list_img{
	margin-bottom: 5px;
}

.event_year_list_txt{
	border-radius: 4px;
	background: #fff;
}

.event_year_list_ttl{
	position: relative;
	line-height: 1;
	font-size: 2.8rem;
	text-align: center;
	padding-bottom: 10px;
	font-family: 'UD デジタル 教科書体 NK-R','Kiwi Maru',serif;
	z-index: 0;
}

.event_year_list_ttl::before{
	content: '';
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 201px;
	height: 55px;
	background: url(../images/event/event_year_list_ttl_bg01.png) no-repeat center / contain;
	z-index: -1;
}

.event_year_list li:nth-child(even) .event_year_list_ttl::before{
	background-image: url(../images/event/event_year_list_ttl_bg02.png) ;
}

.event_year_list_txt{
	padding: 15px 20px;
	line-height: 1.75;
}

/*========================================
info
==========================================*/

/*---------------------
info_cmt
----------------------*/

.info_cmt{
	overflow: hidden;
	background: url(../images/info/info_cmt_bg.png) no-repeat right bottom,#f9f3ec;
}

.info_cmt_boxs{
	position: relative;
}

.info_cmt_boxs::before{
	content: '';
	position: absolute;
	bottom: 0;
	left: -150px;
	width: 228px;
	height: 176px;
	background: url(../images/info/info_cmt_deco01.png) no-repeat center / contain;
}

.info_cmt_boxs::after{
	content: '';
	position: absolute;
	bottom: 0;
	right: -240px;
	width: 105px;
	height: 176px;
	background: url(../images/info/info_cmt_deco02.png) no-repeat center / contain;
}

.info_cmt_card{
	align-items: flex-start;
	padding-left: 80px;
}

.info_cmt_tb{
	width: 500px;
}

.info_cmt_tb tr{
	border-bottom: 1px dotted;
}

.info_cmt_tb th,
.info_cmt_tb td{
	padding: 10px 12px;
}

.info_cmt_map{
	width: 435px;
	height: 280px;
}

.info_cmt_map iframe{
	width: 100%;
	height: 100%;
}

@media screen and (max-width:1500px) {
	.info_cmt_boxs::before{
		left: -120px;
		width: 228px;
		height: 176px;
		background: url(../images/info/info_cmt_deco01.png) no-repeat center / contain;
	}

	.info_cmt_boxs::after{
		right: -100px;
	}
}

/*---------------------
info_gallery
----------------------*/


.info_gallery_list li:not(:nth-child(3n)){
	margin-right: 70px;
}

.info_gallery_list li:nth-last-child(n+4){
	margin-bottom: 50px;
}

.info_gallery_img{
	width: 310px;
	height: 200px;
	overflow: hidden;
	border-radius: 4px;
}

.info_gallery_img img{
	width: 100%;
	height: 100%;
	object-fit: cover;
}


/*========================================
newsの設定
==========================================*/

/*.news_list li:not(:last-child) {
	margin-bottom: 30px;
}

.news_list li a {
	justify-content: flex-start;
	border: 1px solid;
	padding: 10px;
}

.news_list li time {
	display: inline-block;
	margin-right: 20px;
}

.news_txt {
	width: calc(100% - 150px);
	overflow: hidden;
	white-space: nowrap;
	text-overflow: ellipsis;
}*/

/*.news_area_inner {
	padding: 30px 30px 50px 30px;
	background: #fff;
}*/

.news_detail_ttl {
	position: relative;
	font-size: 2.3rem;
	border-bottom: 1px solid;
	line-height: 1.6;
	margin-bottom: 30px;
	padding-bottom: 10px;
	padding-left: 60px;
	border-bottom: 4px double;
}

.news_detail_ttl::before{
	content: '';
	position: absolute;
	bottom: 0;
	left: 10px;
	width: 31px;
	height: 68px;
	background: url(../images/common/news_detail_ttl_deco.png) no-repeat center / contain;
}

.news_area_txt img {
	max-width: 100%;
	height: auto;
}

.news_detail_time {
	display: inline-block;
	color: #331e06;
	line-height: 1;
	padding: 7px 7px;
	border-radius: 4px;
	margin-bottom: 15px;
	margin-left: 60px;
	background: #f9f3ec;
}

.news_detail_img{
	max-width: 710px;
	width: 100%;
	border-radius: 4px;
	overflow: hidden;
	margin: 0 auto 30px;
}

.news_detail_img img{
	max-width: 100%;
	height: auto;
}

.news_area_txt {
	margin-bottom: 60px;
	min-height: 200px;
}

/*========================================
privacyの設定
==========================================*/

.privacy_sec_ttl {
	font-size: 2.3rem;
	font-weight: 500;
	margin-bottom: 15px;
	font-family: 'UD デジタル 教科書体 NK-R','Kiwi Maru',serif;
}

.privacy_boxs section {
	border: 1px solid;
	background: #fff;
	padding: 30px;
	margin-bottom: 30px;
}

/*========================================
siteの設定
==========================================*/

.site_list a {
	position: relative;
	display: block;
	border-bottom: 1px solid;
	margin-bottom: 20px;
	padding: 7px 0 7px 30px;
}

.site_list a::before {
	content: '';
	position: absolute;
	top: 50%;
	left: 10px;
	width: 5px;
	height: 5px;
	border-right: 2px solid;
	border-bottom: 2px solid;
	transform: translateY(-50%) rotate(-45deg);
	transition: 0.4s;
}

.site_list a:hover::before {
	left: 20px;
}
