@charset "UTF-8";

/*------------------------------------------
PC
------------------------------------------*/
@media print, screen and (min-width: 768px){
	/*-----------------------
	index
	-------------------------*/
	.header-top{
		width: 100%;
		aspect-ratio: 840 / 600;
		max-height: 60rem;
		background: url(../images/bg-mv-img01.png);
		background-size: cover;
		position: relative;
	}
	.header-top::before{
		content: "";
		position: absolute;
		bottom: calc(50% - 260px);
		left: calc(50% - 230px);
		width: 100%;
		max-width: 85.5rem;
		height: 100%;
		max-height: 10.2rem;
		background-image: url(../images/bg-mv-img02.png);
		background-repeat: no-repeat;
		background-size: contain;
	}
	.header-top::after{
		content: "";
		position: absolute;
		bottom: 0;
		left: 0;
		width: 100%;
		height: 7.4rem;
		background-image: url(../images/mv-wave.png);
		background-repeat: repeat-x;
		background-size: 120rem 7.4rem;
	}
	.header-top .header-area .mv-area{
		width: 100%;
		max-width: 820px;
		margin-top: 2rem;
		position: relative;
	}
	.header-top .header-area .mv-area .mv-img01{
		display: block;
		width: 59.3902%;
		max-width: 487px;
		position: absolute;
		top: 0;
		left: calc(50% + 50px);
	}
	.header-top .header-area .mv-area .mv-img02{
		display: block;
		width: 36.5853%;
		max-width: 300px;
		position: absolute;
		top: calc(50% + 150px);
		right: calc(50% + 200px);
	}
	.header-top .header-area .mv-area .catch-txt-area{
		position: absolute;
		top: calc(50% + 10px);
		left: calc(50% - 18.3414%);
		font-size: 2.4rem;
		font-family: "游明朝 Medium", "Yu Mincho Medium", "YuMincho Medium", "ヒラギノ明朝 ProN", "Hiragino Mincho ProN", serif;
		font-weight: 700;
		z-index: 1;
	}
	.header-top .header-area .mv-area .catch-txt-area .catch-txt{
		display: block;
		writing-mode: vertical-rl;
		font-weight: 700;
		color: #3b7452;
		text-shadow:0 0 3px #fff,
					0 0 3px #fff,0 0 3px #fff,
					0 0 3px #fff,0 0 3px #fff,
					0 3px #fff,0 0 3px #fff,
					0 0 3px #fff,0 0 3px #fff,
					0 0 3px #fff,0 0 3px #fff,
					0 0 3px #fff,0 0 3px #fff,
					0 0 3px #fff,0 0 3px #fff,0 0 3px #fff;
	}
	.header-top .header-area .mv-area .catch-txt-area .catch-txt span:nth-child(1){
		display: block;
		padding-top: 1em;
	}
	.header-top .header-area .mv-area .catch-txt-area .catch-txt span:nth-child(2){
		display: block;
		padding-top: 1.5em;
	}
	.header-top .header-area .mv-area .catch-txt-area .catch-txt span:nth-child(3){
		display: block;
		padding-top: 2em;
	}
	.event-area{
		width: 100%;
		background-color: #fcf9ef;
		border-radius: 3rem;
		padding: 3rem;
		box-sizing: border-box;
		position: relative;
	}
	.event-area .tbl-event{
		width: 100%;
	}
	.event-area::before{
		content: "";
		width: 100%;
		max-width: 30rem;
		height: 100%;
		max-height: 20rem;
		background: url(../images/event01.png) no-repeat;
		background-size: 30rem 20rem;
		position: absolute;
		top: calc(50% + 220px);
		right: -15%;
	}
	.event-area::after{
		content: "";
		width: 100%;
		max-width: 20rem;
		height: 100%;
		max-height: 14.9rem;
		background: url(../images/event02.png) no-repeat;
		background-size: 20rem 14.9rem;
		position: absolute;
		top: calc(100% - 20px);
		right: 15%;
	}
	.event-area .tbl-event .date{
		width: 30.2631%;
		max-width: 23rem;
		padding-left: 3rem;
		vertical-align: top;
		position: relative;
		box-sizing: border-box;
	}
	.event-area .tbl-event .date::before{
		content: "";
		position: absolute;
		top: 0.8rem;
		left: 0.5rem;
		width: 1.4rem;
		height: 1.4rem;
		border-radius: 50%;
		background-color: #81c795;	
	}
	.event-area .tbl-event .content{
		width: 65.7894%;
		max-width: 50rem;
		padding-left: 3rem;
		vertical-align: top;
	}
	.news-area{
		margin-top: 20rem;
	}
	.member-area{
		width: 100%;
	}
	.member-area .img-member img{
		display: block;
		width: 100%;
		max-width: 82rem;
		margin: 6rem auto 0 auto;
		border-radius: 3rem;
	}
	.greeting-are{
		width: 100%;
	}
	/*.greeting-area{
		width: 100%;
		margin-top: 5rem;
		position: relative;
	}
	.greeting-area p{
		font-size: 1.9rem;
	}
	.greeting-area::before{
		content: "";
		position: absolute;
		top: calc(100% - 120px);
		right: 0;
		background: url(../images/bg-greeting.png) no-repeat center center;
		background-size: cover;
		width: calc(100% - 45%);
		height: 100%;
		min-height: 25rem;
		border-top-left-radius: 30px;
		border-bottom-left-radius: 30px;
	}
	.greeting-area::after{
		content: "";
		background-color: rgba(0,0,0,0.5);
		position: absolute;
		top: calc(100% - 120px);
		right: 0;
		width: calc(100% - 45%);
		height: 100%;
		min-height: 25rem;
		border-top-left-radius: 30px;
		border-bottom-left-radius: 30px;
	}
	.greeting-area .contents{
		width: 100%;
		max-width: 70rem;
		background-color: #fff;
		border-radius: 30px;
		padding: 2rem;
		margin: 0 auto;
		box-shadow: -3px 3px 0px 0px rgba(193, 193, 193, 0.5);
		position: relative;
		z-index: 2;
	}
	.greeting-area .contents .category-ttle{
		background: none;
		text-align: left;
		padding-top: 0;
	}*/
	/*-----------------------
	member
	-------------------------*/
	.header-contents{
		width: 100%;
		aspect-ratio: 840 / 400;
		max-height: 40rem;
		background: url(../images/bg-mv-img01.png);
		background-size: cover;
		position: relative;
	}
	.header-contents::before{
		content: "";
		position: absolute;
		bottom: calc(50% - 160px);
		left: calc(50% - 230px);
		width: 100%;
		max-width: 85.5rem;
		height: 100%;
		max-height: 10.2rem;
		background-image: url(../images/bg-mv-img02.png);
		background-repeat: no-repeat;
		background-size: contain;
	}
	.header-contents::after{
		content: "";
		position: absolute;
		bottom: 0;
		left: 0;
		width: 100%;
		height: 7.4rem;
		background-image: url(../images/mv-wave.png);
		background-repeat: repeat-x;
		background-size: 120rem 7.4rem;
	}
	.breadcrumb{
		width: 100%;
		max-width: 820px;
		font-size: 1.4rem;
		margin: 2rem auto 0 auto;
	}
	.breadcrumb a{
		position: relative;
		margin-right: 2rem;
	}
	.breadcrumb a::after{
		content: "";
		position: absolute;
		top: calc(50% - 0.1em);
		right: -1rem;
		width: 0.5em;
		height: 0.5em;
		transform: rotate(45deg) translate(0, -50%);
		border-top: 1px solid #333;
		border-right: 1px solid #333;
	}
	.new-tbl{
		width: 100%;
		max-width: 82rem;
		border-collapse: collapse;
 		border-spacing: 0;
		margin-top: 1rem;
		font-weight: 700;
	}
	.new-tbl tr:nth-child(even){
		background: #fcf9ef;
	}
	.new-tbl tr td.name{
		width: 60.9756%;
		max-width: 50rem;
		border-top-left-radius: 1rem;
		border-bottom-left-radius: 1rem;
		padding: 1rem 0 1rem 1.5rem;
	}
	.new-tbl tr td.branch{
		width: 39.0243%;
		max-width: 32rem;
		border-top-right-radius: 1rem;
		border-bottom-right-radius: 1rem;
		padding: 1rem 1.5rem 1rem 1.5rem;
		vertical-align: top;
	}
	.deceased-tbl{
		width: 100%;
		border-collapse: collapse;
 		border-spacing: 0;
		font-weight: 700;
	}
	.deceased-tbl tr:nth-child(even){
		background: #E3F1F3;
	}
	.deceased-tbl .name,
	.deceased-tbl .address{
		width: 30%;
	}
	.deceased-tbl .day,
	.deceased-tbl .age{
		width: 20%;
	}
	.deceased-tbl td{
		padding: 1rem 0 1rem 1.5rem;
		vertical-align: top;
	}
	.deceased-tbl td:first-child{
		border-top-left-radius: 1rem;
		border-bottom-left-radius: 1rem;
	}
	.deceased-tbl td:last-child{
		padding-right: 1rem;
		border-top-right-radius: 1rem;
		border-bottom-right-radius: 1rem;
	}
	.deceased-list{
		width: 100%;
		background: #E3F1F3;
		padding: 2rem;
		border-radius: 1rem;
		box-sizing: border-box;
		margin-bottom: 4rem;
	}
	.deceased-list table{
		width: 100%;
		font-weight: 700;
	}
	.deceased-list .name,
	.deceased-list .address{
		width: 30%;
		vertical-align: top;
	}
	.deceased-list .day{
		width: 23%;
		vertical-align: top;
	}
	.deceased-list .age{
		width: 17%;
		vertical-align: top;
	}
	.deceased-list td{
		padding: 0 1rem 1rem 0;
	}
	.deceased-list td:last-child{
		padding-right: 0;
	}
	.deceased-list .item-area{
		border-bottom: 2px dotted #3f5e63;
		padding-bottom: 0.5rem;
		margin-bottom: 1.5rem;
	}
	.deceased-list .item-area:last-child{
		border-bottom: none;
		margin-bottom: 0;
	}
	.deceased-list .item-area dl{
		display: flex;
		justify-content: flex-start;
		align-items: stretch;
		width: 100%;
		margin-bottom: 1rem;
	}
	.deceased-list .item-area dl .item{
		width: 16.0256%;
		max-width: 12.5rem;
		background: #3f5e63;
		padding: 1rem;
		border-radius: 1rem;
		box-sizing: border-box;
		color: #fff;
		font-weight: 700;
		text-align: center;
		align-content: center;
	}
	.deceased-list .item-area dl .item-body{
		width: 82.6923%;
		max-width: 64.5rem;
		padding-left: 1.5rem;
		box-sizing: border-box;
		align-content: center;
	}
}

/*------------------------------------------
sp
------------------------------------------*/
@media only screen and (max-width: 767px){
	.header-top{
		width: 100%;
	}
	.header-top .header-area .mv-area{
		display: flex;
		justify-content: space-between;
		width: 100%;
		padding: 5rem 1rem 10rem 1rem;
		background: url(../images/bg-mv-img01.png);
		background-size: cover;
		position: relative;
	}
	.header-top .header-area .mv-area::before{
		content: "";
		position: absolute;
		top: calc(100% - 70px);
		right: 0;
		width: 100%;
		max-width: 42.7rem;
		height: 100%;
		max-height: 5.1rem;
		background-image: url(../images/bg-mv-img02.png);
		background-repeat: no-repeat;
		background-size: 42.7rem 5.1rem;
	}
	.header-top .header-area .mv-area::after{
		content: "";
		position: absolute;
		bottom: -0.1rem;
		left: 0;
		width: 100%;
		height: 3.7rem;
		background-image: url(../images/mv-wave.png);
		background-repeat: repeat-x;
		background-size: 60rem 3.7rem;
	}
	.header-top .header-area .mv-area .mv-img01{
		display: none;
	}
	.header-top .header-area .mv-area .mv-img02{
		display: block;
		width: 100%;
		max-width: 15em;
		margin-left: auto;
		margin-right: 0;
	}
	.header-top .header-area .mv-area .catch-txt-area{
		position: absolute;
		top: 5%;
		left: 5%;
		font-size: 1.8rem;
		font-family: "游明朝 Medium", "Yu Mincho Medium", "YuMincho Medium", "ヒラギノ明朝 ProN", "Hiragino Mincho ProN", serif;
		font-weight: 700;
	}
	.header-top .header-area .mv-area .catch-txt-area .catch-txt{
		display: block;
		writing-mode: vertical-rl;
		font-weight: 700;
		color: #3b7452;
		text-shadow:0 0 3px #fff,
					0 0 3px #fff,0 0 3px #fff,
					0 0 3px #fff,0 0 3px #fff,
					0 3px #fff,0 0 3px #fff,
					0 0 3px #fff,0 0 3px #fff,
					0 0 3px #fff,0 0 3px #fff,
					0 0 3px #fff,0 0 3px #fff,
					0 0 3px #fff,0 0 3px #fff,0 0 3px #fff;
	}
	.header-top .header-area .mv-area .catch-txt-area .catch-txt span:nth-child(1){
		display: block;
		padding-top: 1em;
	}
	.header-top .header-area .mv-area .catch-txt-area .catch-txt span:nth-child(2){
		display: block;
		padding-top: 1.5em;
	}
	.header-top .header-area .mv-area .catch-txt-area .catch-txt span:nth-child(3){
		display: block;
		padding-top: 2em;
	}
}

/*------------------------------------------
sp
------------------------------------------*/
@media only screen and (max-width: 767px){
	.event-area{
		background-color: #fcf9ef;
		border-radius: 15px;
		padding: 1.5rem;
		box-sizing: border-box;
	}
	.event-area .tbl-event{
		width: 100%;
		position: relative;
	}
	.event-area .tbl-event::after{
		content: "";
		width: 100%;
		max-width: 15rem;
		height: 100%;
		max-height: 10rem;
		background: url(../images/event01.png) no-repeat;
		background-size: 15rem 10rem;
		position: absolute;
		top: 100%;
		right: -1rem;
	}
	.event-area .tbl-event .date{
		display: block;
		width: 100%;
		padding-left: 3rem;
		position: relative;
		box-sizing: border-box;
	}
	.event-area .tbl-event .date::before{
		content: "";
		position: absolute;
		top: 0.8rem;
		left: 0.5rem;
		width: 1.4rem;
		height: 1.4rem;
		border-radius: 50%;
		background-color: #81c795;	
	}
	.event-area .tbl-event .content{
		display: block;
		width: 100%;
		padding-left: 3rem;
		margin: 0.5rem 0 1rem 0;
	}
	.news-area{
		margin-top: 6rem;
	}
	.member-area{
		width: 100%;
	}
	.member-area .img-member img{
		display: block;
		width: 100%;
		margin: 3rem auto 0 auto;
		border-radius: 1.5rem;
	}
	.greeting-area{
		width: 100%;
	}
	/*.greeting-area{
		width: 100%;
		margin-top: 2.5rem;
		position: relative;
	}
	.greeting-area::before{
		content: "";
		position: absolute;
		top: calc(50% + 45px);
		right: 0;
		background: url(../images/bg-greeting.png) no-repeat center center;
		background-size: cover;
		width: 75%;
		height: 80%;
		min-height: 15rem;
		border-top-left-radius: 15px;
		border-bottom-left-radius: 15px;
	}
	.greeting-area::after{
		content: "";
		background-color: rgba(0,0,0,0.5);
		position: absolute;
		top: calc(50% + 45px);
		right: 0;
		width: 75%;
		height: 80%;
		min-height: 15rem;
		border-top-left-radius: 15px;
		border-bottom-left-radius: 15px;
	}
	.greeting-area .contents{
		width: calc(100% - 2rem);
		background-color: #fff;
		border-radius: 30px;
		padding: 2rem;
		margin: 0 auto;
		position: relative;
		z-index: 2;
	}
	.greeting-area .contents .category-ttle{
		background: none;
		text-align: left;
		padding-top: 0;
	}*/
	/*-----------------------
	member
	-------------------------*/
	.header-contents .contents-mv{
		display: flex;
		align-items: center;
		justify-content: center;
		width: 100%;
		height: 15rem;
		background: url(../images/bg-mv-img01.png);
		background-size: cover;
		position: relative;
	}
	.header-contents .contents-mv::before{
		content: "";
		position: absolute;
		top: calc(50% + 0.9rem);
		right: 0;
		width: 100%;
		max-width: 42.7rem;
		height: 100%;
		max-height: 5.1rem;
		background-image: url(../images/bg-mv-img02.png);
		background-repeat: no-repeat;
		background-size: contain;
	}
	.header-contents .contents-mv::after{
		content: "";
		position: absolute;
		bottom: 0;
		left: 0;
		width: 100%;
		height: 3.7rem;
		background-image: url(../images/mv-wave.png);
		background-repeat: repeat-x;
		background-size: 60rem 3.7rem;
	}
	.breadcrumb{
		width: 100%;
		font-size: 1.2rem;
		padding: 1rem;
		box-sizing: border-box;
	}
	.breadcrumb a{
		position: relative;
		margin-right: 2rem;
	}
	.breadcrumb a::after{
		content: "";
		position: absolute;
		top: calc(50% - 0.1em);
		right: -1rem;
		width: 0.5em;
		height: 0.5em;
		transform: rotate(45deg) translate(0, -50%);
		border-top: 1px solid #333;
		border-right: 1px solid #333;
	}
	.new-tbl{
		width: 100%;
		max-width: 82rem;
		border-collapse: collapse;
 		border-spacing: 0;
		font-weight: 700;
	}
	.new-tbl tr:nth-child(even){
		background: #fcf9ef;
	}
	.new-tbl tr td.name{
		display: block;
		width: 100%;
		border-top-left-radius: 1rem;
		border-bottom-left-radius: 1rem;
		padding: 1rem 0 0 1.5rem;
	}
	.new-tbl tr td.branch{
		display: block;
		width: 100%;
		border-top-right-radius: 1rem;
		border-bottom-right-radius: 1rem;
		padding: 0 1.5rem 1rem 1.5rem;
	}
	.deceased-tbl-area{
		position: relative;
		overflow-x: scroll;
	}
	.deceased-tbl{
		width: 82rem;
		border-collapse: collapse;
 		border-spacing: 0;
		font-weight: 700;
	}
	.deceased-tbl tr:nth-child(even){
		background: #E3F1F3;
	}
	.deceased-tbl .name,
	.deceased-tbl .address{
		width: 30%;
	}
	.deceased-tbl .day,
	.deceased-tbl .age{
		width: 20%;
	}
	.deceased-tbl td{
		padding: 1rem 0 1rem 1.5rem;
		vertical-align: top
	}
	.deceased-tbl td:first-child{
		border-top-left-radius: 1rem;
		border-bottom-left-radius: 1rem;
	}
	.deceased-tbl td:last-child{
		padding-right: 1rem;
		border-top-right-radius: 1rem;
		border-bottom-right-radius: 1rem;
	}
	.deceased-list{
		width: 100%;
		background: #E3F1F3;
		padding: 2rem;
		border-radius: 1rem;
		box-sizing: border-box;
		margin-bottom: 4rem;
	}
	.deceased-list table{
		width: 100%;
		font-weight: 700;
	}
	.deceased-list .name,
	.deceased-list .address,
	.deceased-list .day,
	.deceased-list .age{
		display: block;
		text-align: center;
	}
	.deceased-list td{
		padding-bottom: 1rem;
	}
	.deceased-list .item-area{
		border-bottom: 2px dotted #3f5e63;
		padding-bottom: 0.5rem;
		margin-bottom: 1.5rem;
	}
	.deceased-list .item-area:last-child{
		border-bottom: none;
		margin-bottom: 0;
	}
	.deceased-list .item-area dl{
		display: block;
		width: 100%;
		margin-bottom: 1.5rem;
		text-align: center;
	}
	.deceased-list .item-area dl .item{
		width: 100%;
		background: #3f5e63;
		padding: 1rem;
		border-radius: 1rem;
		box-sizing: border-box;
		color: #fff;
		font-weight: 700;
		text-align: center;
	}
	.deceased-list .item-area dl .item-body{
		width: 100%;
		padding-top: 1rem;
		box-sizing: border-box;
	}
}

/*------------------------------------------
scrollElement
------------------------------------------*/
.deceased-tbl-area .wa-scroll{
	position: absolute;
	top: 0;
	left: -50000%;
}
@media screen and (max-width: 767px) {
	.deceased-tbl-area .wa-scroll{
		position: absolute;
		top: 50px;
		left: 50%;
		display: flex;
		flex-direction: column;
		align-items: center;
		width: 50%;
		background: rgba(0, 0, 0, 0.5);
		padding: 16px;
		transition: 1s;
		transform: translateX(-50%);
		opacity: 1;
	}
	.wa-scroll-img{
		width: 20px;
		height: auto;
	}
	.wa-scroll-text{
		color: #fff;
		text-align: center;
		font-size: 1.4rem;
		font-weight: bold;
		line-height: 23px;
		margin-top: 8px;
	}
}

