@charset "UTF-8";
/*/*================= キーイメージ /*=================*/
.wrap_keyimage {
	margin-top: 0;
}

.slider_top div {
	height: 100vh;
}

.slider_top div img {
	height: 100vh;
	object-fit:cover;
}

.key_text_top {
	width: 329px;
	position: absolute;
	bottom: 0;
	left: 0;
}

/*/*================= キャンペーン /*=================*/
.wrap_ul_campaign {
	background: url(../images/bg_campaign_sp.jpg) no-repeat;
	background-size: cover;
	padding: 40px 0;
}

.ul_campaign li {
	width: 90%;
	margin: 0 auto 16px;
}

.ul_campaign li:last-child {
	margin-bottom: 0;
}

/*================= 主な活動 /*=================*/
.wrap_activities_contents {
	margin-top: 48px;
	background: url(../images/top/activities_after_sp.png) repeat-x bottom;
	background-size: contain;
	padding-bottom: 74px;
}

.activities_contents {
	padding: 48px 5% 40px;
	border: 4px solid #FBD8CF;
	background: rgba(251, 216, 207, 0.1);
	position: relative;
	margin-bottom: 90px;
}

.activities_contents.activities_contents02 {
	border-color: #F9F177;
	background: rgba(249, 241, 119, 0.1);
}

.activities_contents.activities_contents03 {
	border-color: #C1E5F2;
	background: rgba(193, 229, 242, 0.1);
}

.activities_contents.activities_contents04 {
	border-color: #F0B774;
	background: rgba(240, 183, 116, 0.1);
}

.activities_contents.activities_contents05 {
	border-color: #D5B378;
	background: rgba(213, 179, 120, 0.1);
}

.activities_contents.activities_contents06 {
	border-color: #C2DB79;
	background: rgba(194, 219, 121, 0.1);
}

.activities_contents:last-child {
	margin-bottom: 0;
}

.activities_contents::after {
	content: "";
	display: inline-block;
	background: url(../images/top/icon_footprint.png) no-repeat;
	background-size: contain;
	width: 34px;
	height: 16px;
	position: absolute;
	bottom: 16px;
	left: 5%;
}

.activities_contents .btn a {
	height: 48px;
}

.ttl_h3_activities {
	max-width: 312px;
	width: 100%;
	position: absolute;
	top: 0;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
}

.txt_activities {
	line-height: 1.75;
	letter-spacing: 0.1em;
}

.activities .btn {
	width: 128px;
	position: absolute;
	bottom: 0;
	right: 0;
	-webkit-transform: translateY(50%);
	transform: translateY(50%);
}

/*================= Youtube =================*/
.ttl_h2_video {
	font-size: 24px;
	font-size: 2.4rem;
	letter-spacing: 0.3em;
	font-weight: 500;
	margin-bottom: 16px;
}

.ttl_h2_video .c_orange {
	color: #F0B774;
}

.maker_green {
	position: relative;
	z-index: 1;
}

.maker_green::after {
	content: "";
	display: inline-block;
	background: rgba(194, 219, 121, 0.4);
	width: 100%;
	height: 18px;
	border-radius: 40px;
	position: absolute;
	bottom: 0;
	left: 0;
	z-index: -1;
}

.youtube_link {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	color: #643E2F;
	margin-top: 16px;
}

.youtube_link::before {
	content: "\f431";
	display: inline-block;
	font-family: "Font Awesome 5 Brands";
	font-weight: 900;
	font-size: 28px;
	font-size: 2.8rem;
	margin-right: 16px;
	line-height: 1;
}

.youtube_link a {
	text-decoration: underline;
	color: #643E2F;
}

.wrap_video {
	margin-top: 48px;
}

.wrap_video iframe {
	width: 100%;
	height: 100%;
	min-height: 187px;
}

/*================= お知らせ =================*/
.news {
	position: relative;
	z-index: 1;
}

.news::after {
	content: "";
	display: inline-block;
	background: url(../images/top/img_news_after_sp.jpg) no-repeat;
	background-size: contain;
	width: 188px;
	height: 192px;
	position: absolute;
	bottom: 0;
	left: 0;
	z-index: -1;
	opacity: 0.4;
}

.ul_news li {
	padding: 16px 0;
	border-bottom: 1px dashed #643E2F;
	color: #643E2F;
}

.ul_news li:first-child {
	padding-top: 0;
}

.ul_news .news_time {
	margin-bottom: 16px;
	display: inline-block;
}

.ul_news a {
	line-height: 1.5;
	display: block;
	color: #643E2F;
	text-decoration: underline;
}

.top_news .btn {
	max-width: 210px;
	margin: 48px auto 0;
}

/*================= イベント =================*/
.event {
	position: relative;
	z-index: 1;
}

.event::after {
	content: "";
	display: inline-block;
	background: url(../images/top/img_event_after_sp.jpg) no-repeat;
	background-size: contain;
	width: 163px;
	height: 163px;
	position: absolute;
	bottom: 0;
	right: 0;
	z-index: -1;
	opacity: 0.4;
}

/*================= 迷子猫 =================*/
.stray_cat {
	position: relative;
}

.stray_cat::before {
	content: "";
	display: block;
	background: url(../images/top/bg_mountain_sp.png) repeat-x;
	background-size: 100% 40px;
	width: 100%;
	height: 40px;
	position: absolute;
	top: 0;
	left: 0;
	-webkit-transform: translateY(-100%);
	transform: translateY(-100%);
}

/*================= アクセス =================*/
.access {
	position: relative;
}

.access::before {
	content: "";
	display: block;
	background: url(../images/top/bg_mountain_sp.png) repeat-x;
	background-size: 100% 40px;
	width: 100%;
	height: 40px;
	position: absolute;
	top: 0;
	left: 0;
	-webkit-transform: translateY(-100%);
	transform: translateY(-100%);
}

.google_map {
	margin-top: 48px;
}

.google_map iframe {
	width: 100%;
	display: block;
	border: 1px solid #643E2F;
	height: 33vh;
}

.google_map p {
	letter-spacing: 0.1em;
}

.google_map p span {
	font-size: 18px;
	font-size: 1.8rem;
	letter-spacing: 0.2em;
	color: #643E2F;
	line-height: 1.5;
}

.access_logo {
	width: 216px;
	margin: 48px 0 24px;
}

.dl_access dt {
	font-size: 18px;
	font-size: 1.8rem;
	letter-spacing: 0.2em;
	color: #643E2F;
}

.dl_access dd {
	margin-bottom: 16px;
	line-height: 1.5;
	letter-spacing: 0.1em;
}

.dl_access dd:first-of-type {
	margin-bottom: 24px;
}

.recept_time {
	font-size: 14px;
	font-size: 1.4rem;
	letter-spacing: 0.1em;
}

/*================= バナー =================*/
.ul_top_bnr {
	padding: 80px 5%;
}

.ul_top_bnr li {
	width: 83%;
	margin: 0 auto 48px;
}

.ul_top_bnr li:last-child {
	margin-bottom: 0;
}

@media (min-width: 769px) {
	/*/*================= キーイメージ /*=================*/	
	.slider_top div {
		min-height: 600px;
	}

	.slider_top div img {
		min-height: 600px;
	}

	.key_text_top {
		width: 600px;
		position: absolute;
		bottom: auto;
		top: 50%;
		left: 0;
		-webkit-transform: translateY(-50%);
		transform: translateY(-50%);
	}

	/*/*================= キャンペーン /*=================*/
	.wrap_ul_campaign {
		background: url(../images/bg_campaign_pc.jpg) no-repeat;
		background-size: cover;
	}

	.ul_campaign {
		display: flex;
		width: 95%;
		max-width: 960px;
		margin: 0 auto;
	}

	.ul_campaign li {
		width: calc(100% / 3 - 48px / 3);
		margin: 0 24px 0 0;
	}

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

	.ul_campaign li a {
		display: block;
		border-radius: 20px;
		overflow: hidden;
	}

	.ul_campaign li a img {
		transition: 0.2s;
	}

	.ul_campaign li a:hover img {
		transform: scale(1.2);
	}

	/*================= 主な活動 /*=================*/
	.wrap_activities_contents {
		background: url(../images/top/activities_after_pc.png) repeat-x bottom;
		background-size: 100% 20px;
		margin-top: 72px;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
	}
	.activities_contents {
		padding: 48px 13px 40px;
		width: 48%;
		max-width: 460px;
	}
	.activities_contents:nth-last-child(2) {
		margin-bottom: 0;
	}
	.activities_contents:nth-last-child(2) .txt_activities {
		letter-spacing: 0.05em;
	}
	.activities_contents::after {
		bottom: 16px;
		left: 16px;
	}
	.ttl_h3_activities {
		max-width: 422px;
	}
	.txt_activities {
		text-align: center;
	}
	/*================= Youtube =================*/
	.wrap_video_contents {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
	}
	.wrap_video_text {
		min-width: 360px;
		max-width: 360px;
	}
	.ttl_h2_video {
		font-size: 32px;
		font-size: 3.2rem;
	}
	.youtube_link {
		font-size: 18px;
		font-size: 1.8rem;
	}
	.youtube_link::before {
		font-size: 30px;
		font-size: 3.0rem;
	}
	.youtube_link a {
		text-decoration: underline;
		color: #643E2F;
	}
	.wrap_video {
		margin-top: 0;
		width: 560px;
	}
	/*================= お知らせ =================*/
	.wrap_top_flex_section {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		max-width: 1160px;
		margin: 0 auto;
	}
	.wrap_top_flex_section .section {
		width: 50%;
	}
	.wrap_top_flex_section .section.news {
		border-right: 1px dashed #643E2F;
	}
	.wrap_top_flex_section .section .inner_section {
		max-width: 380px;
	}
	.news {
		position: relative;
		z-index: 1;
	}
	.news::after {
		background: url(../images/top/img_news_after_pc.jpg) no-repeat;
		background-size: contain;
		width: 300px;
		height: 300px;
	}
	/*================= イベント =================*/
	.event::after {
		background: url(../images/top/img_event_after_pc.jpg) no-repeat;
		background-size: contain;
		width: 300px;
		height: 300px;
	}
	/*================= 迷子猫 =================*/
	.stray_cat::before {
		background: url(../images/top/bg_mountain_pc.png) repeat-x;
		background-size: 100% 40px;
	}
	/*================= アクセス =================*/
	.access::before {
		background: url(../images/top/bg_mountain_pc.png) repeat-x;
		background-size: 100% 40px;
	}
	.access .inner_section {
		max-width: 985px;
	}
	.wrap_access_contents {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
		margin-top: 48px;
	}
	.google_map {
		width: 460px;
		margin-top: 0;
	}
	.img_g_map {
		margin-bottom: 24px;
	}
	.wrap_access_right {
		width: 490px;
	}
	.access_logo {
		width: 216px;
		margin: 0 0 24px;
	}
	/*================= バナー =================*/
	.ul_top_bnr {
		max-width: 1020px;
		margin: 0 auto;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
	}
	.ul_top_bnr li {
		width: calc(100% / 4 - 60px / 4);
		margin: 0 20px 0 0;
	}
	.ul_top_bnr li:nth-child(4n) {
		margin-right: 0;
	}
	.ul_top_bnr li:last-child {
		margin-bottom: 0;
	}
	.ul_top_bnr li a:hover {
		opacity: 0.6;	
	}
}

/* 20231122 360°マップ追加 */
.wrap_view360 {
	width: min(100%, 840px);
	margin: 0 auto;
}
.wrap_view360 iframe {
	width: 100%;
	display: block;
}

/* 公式ライン追加 */
.line {
	background: #FDFBF8;
}
.ttl_line {
	font-size: 24px;font-size: 2.4rem;
	font-weight: 500;
}

.ttl_line .marker_green {
	position: relative;
	z-index: 1;
}
.ttl_line .marker_green:after {
	content: "";
	display: inline-block;
	background: rgba(194, 219, 121, 0.4);
	width: 100%;
	height: 18px;
	border-radius: 40px;
	position: absolute;
	bottom: 0;
	left: 0;
	z-index: -1;
}
.img_line {
	width: calc(260 / 375 * 100vw);
	margin: 32px auto;
}

@media (min-width: 769px) {
	.ttl_line {
		font-size: 32px;font-size: 3.2rem;
		letter-spacing: 0.1em;
	}
	.ttl_line .marker_green2 .marker_green:after {
		content: none;
	}

	.ttl_line .marker_green2 {
		position: relative;
		z-index: 1;
	}
	.ttl_line .marker_green2:after {
		content: "";
		display: inline-block;
		background: rgba(194, 219, 121, 0.4);
		width: 100%;
		height: 18px;
		border-radius: 40px;
		position: absolute;
		bottom: 0;
		left: 0;
		z-index: -1;
	}
	.wrap_line_contents {
		display: flex;
		gap: 40px;
		margin-top: 48px;
	}
	.img_line {
		min-width: 260px;
		max-width: 260px;
		width: auto;
		margin: 0;
	}
}