@charset "utf-8";
/* CSS Document */

/* ---------------------------------------------
ヒーロー
--------------------------------------------- */
.hero {
	background: url("../images/top/fv_back.jpg");
	background-repeat: no-repeat;
	background-size: auto 100%;
	background-position: right center;
	height: auto;
	padding-block: 0px;
	display: flex;
	align-items: center;
	position: relative;
	&::before {
		content: '';
		background: linear-gradient(to right,#E4E1ED 50%,#E4E1EDcc 80%,#E4E1ED00 100%);
		display: inline-block;
		width: 100%;
		height: 100%;
		top: 0px;
		left: 0px;
		position: absolute;
		
	}
}

.hero_inner {
	max-width: 1300px;
	width: 90%;
	height: 100%;
	margin: 0px auto;
	padding: 6vh 0px;
	display: grid;
	grid-template-columns: repeat(auto-fit,minmax(300px,1fr));
	align-items: center;
	gap: 1rem;
	z-index: 1;
}

.production {
	margin: 0px auto;
}

.production_copy_sub {
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	column-gap: 10px;
	&::before {
		content: '';
		background: url("../images/common/icon_materials_purple.svg");
		background-repeat: no-repeat;
		background-size: contain;
		display: inline-block;
		width: 25px;
		height: 31px;
	}
}


/* ---------------------------------------------
葬儀プラン
--------------------------------------------- */
.plan_list {
	display: grid;
	grid-template-columns: repeat(auto-fit,minmax(400px,1fr));
	gap: 2rem;
	@media screen and (max-width: 599px) {
		grid-template-columns: repeat(2, 1fr);
		gap: 1rem;
	}
	li {
		border: 1px solid #B9B9B9;
		border-radius: 10px;
		overflow: hidden;
		background: #FFF;
		filter: drop-shadow(5px 5px 5px rgba(0,0,0,0.08));
		display: flex;
		flex-direction: column;
		align-items: stretch;
	}
}
.plan_list li > a {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	height: 100%;
	color: inherit;
	text-decoration: none;
}
.plan_inner {
	padding: 1rem 1rem 2rem;
	display: flex;
	flex-direction: column;
	align-items: stretch;
	row-gap: 1rem;
	height: 100%;
	@media screen and (max-width: 599px) {
		padding: 0.75rem 0.75rem 1.5rem;
		row-gap: 0.75rem;
	}
	picture {
		display: flex;
		width: 98%;
		margin: 0px auto;
	}
	.detail_btn {
		margin: 0px auto;
	}
}

.plan_catch {
	font-size: clamp(16px,2.2vw,22px);
	font-weight: 500;
	color: #FFF;
	padding: 12px 1rem;
	text-align: center;

}

.plan_mark {
	position: relative;
	&::before {
		content: '';
		background-repeat: no-repeat !important;
		background-size: contain !important;
		display: inline-block;
		width: 9.4vh;
		height: 10.5vh;
		top: 0px;
		left: 0px;
		position: absolute;
	}
	&.mark_no1::before {
		background: url("../images/top/plan_mark_no1.png");
	}
	&.mark_recommend::before {
		background: url("../images/top/plan_mark_recommend.png");
	}
}

.plan_name {
	font-size: clamp(40px,4.7vw,47px);
	font-weight: bold;
	text-align: center;
	small {
		font-size: clamp(26px,3.4vw,34px);
		font-weight: 500;
	}
}

.service_mark {
	display: grid;
	grid-template-columns: repeat(auto-fit,minmax(90px,1fr));
	gap: 5px;
	span {
		color: #FFF;
		font-size: clamp(15px,1.9vw,19px);
		padding: 5px;
		border-radius: 5px;
		text-align: center;
	}
	.no_service {
		background: #DBDBDB !important;
	}
}

.price_content {
	display: grid;
	text-align: center;
	align-items: flex-end;
	flex-grow: 1;
}

.normal_price {
	font-size: clamp(15px,1.8vw,18px);
	big {
		font-size: clamp(18px,2.4vw,24px);
	}
	span {
		display: inline-flex;
		align-items: baseline;
		position: relative;
		&::before {
			content: '';
			background: #000;
			display: inline-block;
			width: 100%;
			height: 1px;
			top: 60%;
			transform: translateY(-50%);
			position: absolute;
		}
	}
}

.materials_sale {
	background: #F4F2F2;
	font-size: clamp(18px,2.2vw,22px);
	font-weight: 500;
	position: relative;
	border-radius: 10px;
	padding: 5px;
	&::before {
		content: '';
		position: absolute;
		top: 100%;
		left: 50%;
		margin-left: -15px;
		border: 15px solid transparent;
		border-top: 15px solid #F4F2F2;
	}
	big {
		font-size: clamp(24px,3.3vw,33px);
		font-weight: bold;
		color: #DB5151;
	}
	small {
		font-size: clamp(22px,2.8vw,28px);
		font-weight: bold;
		color: #DB5151;
	}
}

.sale_price {
	margin-block: 1rem;
	color: #DB5151;
	.sale_price_01 {
		font-feature-settings: 'palt';
		big {
			font-size: clamp(50px,6.6vw,66px);
			font-family: var(--ff-robot);
			letter-spacing: -1px;
			font-weight: bold;
		}
		span {
			font-size: clamp(20px,2.7vw,27px);
			font-weight: 500;
		}
		small {
			font-size: clamp(14px,1.6vw,16px);
			font-weight: 500;
		}
	} 
	.sale_price_02 {
		font-size: clamp(16px,2vw,20px);
		span {
			font-size: clamp(18px,2.2vw,22px);
			font-weight: bold;
		}
	} 
}


.kasou_plan {
	.plan_catch {
		background: var(--kasou-plan);
	}
	.plan_name {
		color: var(--kasou-plan);
	}
	.service_mark {
		span {
			background: var(--kasou-plan);
		}
	}
}

.day_plan {
	.plan_catch {
		background: var(--day-plan);
	}
	.plan_name {
		color: var(--day-plan);
	}
	.service_mark {
		span {
			background: var(--day-plan);
		}
	}
}

.family_plan {
	.plan_catch {
		background: var(--family-plan);
	}
	.plan_name {
		color: var(--family-plan);
	}
	.service_mark {
		span {
			background: var(--family-plan);
		}
	}
}

.tyokusou_plan {
	.plan_catch {
		background: var(--tyokusou-plan);
	}
	.plan_name {
		color: var(--tyokusou-plan);
	}
	.service_mark {
		span {
			background: var(--tyokusou-plan);
		}
	}
}

.seikatuhogo_plan {
	.plan_catch {
		background: var(--seikatuhogo-plan);
	}
	.plan_name {
		color: var(--seikatuhogo-plan);
	}
	.service_mark {
		span {
			background: var(--seikatuhogo-plan);
		}
	}
}

.family_premium_plan {
	.plan_catch {
		background: var(--family-premium-plan);
	}
	.plan_name {
		color: var(--family-premium-plan);
	}
	.service_mark {
		span {
			background: var(--family-premium-plan);
		}
	}
}


.introduction_wrap {
	max-width: 900px;
	width: 90%;
	margin: 5rem auto 0px;
}

.introduction_ttl {
	background: var(--primary-pale2);
	font-size: clamp(20px,2.6vw,26px);
	font-weight: bold;
	position: relative;
	border-radius: 10px;
	padding: 10px;
	color: var(--primary);
	max-width: 760px;
	margin: 0px auto 2rem;
	text-align: center;
	&::before {
		content: '';
		position: absolute;
		top: 100%;
		left: 50%;
		margin-left: -15px;
		border: 15px solid transparent;
		border-top: 15px solid var(--primary-pale2);
	}
}
@media screen and (max-width: 599px) {
	.plan_catch {
		font-size: clamp(13px, 3.8vw, 17px);
		padding: 10px 0.5rem;
	}

	/* バッジ（No.1・おすすめ）が狭いカードで被らないよう少し小さく */
	.plan_mark::before {
		width: 7vh;
		height: 7.8vh;
	}

	.plan_name {
		font-size: clamp(22px, 7vw, 30px);
		small {
			font-size: clamp(15px, 4.5vw, 20px);
		}
	}

	.service_mark {
		grid-template-columns: repeat(2, 1fr); /* 4項目を2×2に */
		span {
			font-size: clamp(12px, 3.4vw, 15px);
		}
	}

	.normal_price {
		font-size: clamp(12px, 3.5vw, 15px);
		big {
			font-size: clamp(14px, 4vw, 18px);
		}
	}

	.materials_sale {
		font-size: clamp(14px, 4vw, 18px);
		big {
			font-size: clamp(18px, 5.5vw, 26px);
		}
		small {
			font-size: clamp(16px, 5vw, 22px);
		}
	}

	.sale_price {
		margin-block: 0.75rem;
		.sale_price_01 {
			big {
				font-size: clamp(20px, 10vw, 28px);
			}
			span {
				font-size: clamp(14px, 4.5vw, 16px);
			}
			small {
				font-size: clamp(11px, 3vw, 14px);
			}
		}
		.sale_price_02 {
			font-size: clamp(12px, 3.5vw, 16px);
			span {
				font-size: clamp(13px, 4vw, 17px);
			}
		}
	}
	.sale_price_01 {
		text-align: right;
		margin-bottom: 10px;
	}
	.sale_price_01 big {
		text-align: left; /* 数字は中央のまま残す場合 */
	}
	.plan_catch,
	.plan_mark,
	.service_mark,
	.detail_btn {
		display: none;
	}
}

section#facility {
	background: var(--primary-pale2);
	.sec_ttl {
		padding-inline: 0px;
	}
}

.facility_inner {
	display: grid;
	row-gap: 6vh;
}

.facility_data {
	display: grid;
	grid-template-columns: repeat(auto-fit,minmax(300px,1fr));
	gap: 2rem 3rem;
}

.facility_name {
	font-weight: 600;
	display: grid;
	line-height: 1.2;
	small {
		font-size: clamp(15px,1.8vw,18px);
	}
	span {
		font-size: clamp(20px,3vw,30px);
	}
}

.facility_info {
	margin-block: 1rem 2rem;
	flex-grow: 1;
	dl {
		display: grid;
		grid-template-columns: 1fr 3fr;
		font-size: clamp(15px,1.8vw,18px);
		font-weight: 500;
	}
}

.hall_list {
	display: grid;
	grid-auto-flow: column;
	justify-content: center;
	gap: 2rem;
	@media screen and (max-width: 768px) {
		grid-auto-flow: row;
	}
	li {
		background: #FFF;
		border: 1px solid #B9B9B9;
		overflow: hidden;
		border-radius: 10px;
		filter: drop-shadow(5px 5px 5px rgba(0,0,0,0.07));
		display: flex;
		flex-direction: column;
		align-items: stretch;
		max-width: 412px;
	}
}

.hall_data {
	padding: 1rem 1rem 2rem;
	display: flex;
	flex-direction: column;
	align-items: stretch;
	flex-grow: 1;
	.detail_btn {
		margin-inline: auto;
	}
}

.hall_top {
	background: var(--primary-pale2);
	display: grid;
	grid-template-columns: 1fr 3fr;
	align-items: center;
	padding: 1rem;
	picture {
		width: 80px;
	}
	.hall_name_wrap {
		display: grid;
		text-align: center;
		height: 100%;
		small {
			font-size: clamp(15px,1.8vw,18px);
			font-weight: 500;
		}
		.hall_name {
			font-size: clamp(24px,2vw,30px);
			font-weight: bold;
			font-feature-settings: 'palt';
			color: var(--primary-dark);
			line-height: 1.2;
		}
	}
}

.beginner_list {
	display: grid;
	grid-template-columns: repeat(auto-fit,minmax(300px,1fr));
	gap: 2rem;
	margin-block: 3rem;
	li {
		background: var(--primary-pale2);
		padding: 1rem 2rem 3rem;
		.detail_btn {
			margin-inline: auto;
			margin-top: 2rem;
		}
	}
}

.begimner {
	margin-top: 10vh;
}

.beginner_ttl {
	display: grid;
	grid-template-columns: 1fr 6fr;
	align-items: center;
	span:nth-of-type(1) {
		color: #FFF;
		font-size: clamp(50px,6vw,100px);
		font-family: var(--ff-robot);
		font-weight: bold;
	}
	span:nth-of-type(2) {
		color: var(--primary-dark);
		font-size: clamp(20px,2vw,30px);
		font-weight: 500;
		text-align: center;
	}
}

.beginner_txt {
	font-size: clamp(15px,1.8vw,18px);
	line-height: 140%;
	text-align: justify;
}


section#voice {
	background: #F8F8F8;
	.detail_btn {
		margin: 3rem auto 0px;
	}
}

.voice-slide {
	overflow: hidden;
}

.voice-slide .slick-track {
	display: flex;
}

.voice-slide li {
	width: 420px;
	height: auto !important;
	border: 1px solid #939393;
	margin-inline: 10px;
	border-radius: 10px;
	padding: 2rem;
	font-size: clamp(15px,1.8vw,18px);
	display: flex !important;
	flex-direction: column;
	align-items: stretch;

}

.voice_plan {
	display: grid;
	grid-template-columns: repeat(2,1fr);
	align-items: center;
	span {
		padding: 5px 1rem;
		text-align: center;
		background: #F8F8F8;
		font-weight: 500;
	}
}

.voice_cate {
	color: #FFF;
}

.voice_txt {
	text-align: justify;
	margin-block: 1rem;
	flex-grow: 1;
}

.custmer_name {
	font-weight: bold;
}

.bottom-cta {
	background: none;
}

section.campaign {
	padding-block: 0;
}






