/* common */
.main {
	margin: 48px 0 0;
	padding: 48px 0 96px;
	background-color: #f1f6f8;
}

.limit-plan .main {
	background-color: #fcf8f8;
}

.section {
	padding: 48px 48px 64px;
	background-color: #fff;
	box-shadow: 4px 4px 5px 0 rgba(0, 0, 0, 0.2);
}
@media screen and (max-width: 1024px) {
	.main {
		margin-top: 24px;
		padding: 24px 0 40px;
	}
	.section {
		padding: 24px calc(16 / 375 * 100%) 40px;
	}
}
h3 {
	font-size: 24px;
	line-height: 40px;
	font-weight: bold;
	border-bottom: 4px solid #6fbec8;
	position: relative;
	z-index: 0;
}

.limit-plan h3 {
	border-bottom: 4px solid #d3938b;
}

@media screen and (max-width: 1024px) {
	h3 {
		border-bottom: none;
		font-size: 16px;
		line-height: 24px;
		padding-left: 16px;
	}
	h3::before {
		content: "";
		background: #6fbec8;
		width: 8px;
		border-radius: 4px;
		margin-right: 8px;
		position: absolute;
		height: 100%;
		left: 0;
		top: 0;
	}

	.limit-plan h3::before {
		background: #d3938b;
	}
}

h4 {
	padding-left: 39px;
	background: #6fbec8;
	height: 45px;
	font-weight: bold;
	font-size: 19px;
	line-height: 30px;
	display: flex;
	align-items: center;
	color: #ffffff;
}

.limit-plan h4 {
	background: #d3938b;
}

.h4_num {
	font-size: 20px;
	margin-right: 11px;
}

@media screen and (max-width: 1024px) {
	h4 {
		font-size: 12px;
		line-height: 19px;
		padding-left: calc(16 / 311 * 100%);
	}
	.h4_num {
		font-size: 16px;
		line-height: 26px;
		margin-right: 18px;
	}
}

ul.funeral-ul {
	font-style: normal;
	font-weight: bold;
	font-size: 16px;
	line-height: 26px;
}

ul.funeral-ul li::before {
	content: "";
	width: 15px;
	height: 15px;
	display: inline-block;
	background-color: #6fbec8;
	border-radius: 50%;
	margin-right: 7px;
}

.limit-plan ul.funeral-ul li::before {
	background-color: #d3938b;
}

@media screen and (max-width: 1024px) {
	ul.funeral-ul li::before {
		width: 10px;
		height: 10px;
		margin-right: 6px;
	}
}
.funeral-next-button {
	display: block;
	position: relative;
	margin: 0 auto;
	width: 494px;
	background: #eca43c;
	border-radius: 4px;
	display: flex;
	justify-content: center;
	align-items: center;
	font-weight: bold;
	height: 71px;
	color: #ffffff;
	font-size: 24px;
	line-height: 36px;
	border: none;
	box-shadow: 0px 2px 6px #ccc2bd;
	border-bottom: 6px solid #e48c3c;
}

.funeral-next-button:hover {
	opacity: 0.7;
}

.funeral-next-button:after {
	position: absolute;
	top: 26px;
	right: 40px;
	content: "";
	width: 14px;
	height: 14px;
	border: 3px solid #ffffff;
	border-left: none;
	border-bottom: none;
	transform: rotate(45deg);
}

.disable-funeral-next-button {
	color: #dad1cf;
	background: #f0edec;
	border-bottom: 4px solid #dad1cf;
}
.disable-funeral-next-button::after {
	border: 3px solid #dad1cf;
	border-left: none;
	border-bottom: none;
}

@media screen and (max-width: 1024px) {
	.funeral-next-button {
		width: calc(247 / 311 * 100%);
		font-size: 16px;
		line-height: 18px;
	}
	.funeral-next-button:after {
		right: calc(11 / 274 * 100%);
	}
}
@media screen and (max-width: 375px) {
	.funeral-next-button {
		min-width: 247px;
		font-size: 14px;
		line-height: 16px;
	}
}

.funeral-return-button {
	display: block;
	position: relative;
	margin: 0 auto;
	width: 247px;
	display: flex;
	justify-content: center;
	align-items: center;
	font-weight: bold;
	height: 24px;
	font-size: 24px;
	border: none;
	background: content-box;
	margin-top: 50px;
	color: #463d3c;
}

.funeral-return-button:after {
	position: absolute;
	top: 6px;
	left: 40px;
	content: "";
	width: 14px;
	height: 14px;
	border: 3px solid;
	border-right: none;
	border-bottom: none;
	transform: rotate(-45deg);
}
.funeral-return-button:hover {
	opacity: 0.7;
}

@media screen and (max-width: 1024px) {
	.funeral-return-button {
		width: calc(247 / 375 * 100%);
		font-size: 16px;
		font-size: 16px;
		line-height: 22px;
		color: #dad1cf;
		margin-top: 19px;
	}
	.funeral-return-button:after {
		border: 3px solid #dad1cf;
		border-right: none;
		border-bottom: none;
		left: calc(90 / 274 * 100%);
	}
}

.funeral-checkbox {
	display: none;
}
.funeral-checkbox-label {
	display: block;
	position: relative;
	margin: 0 auto;
	width: 494px;
	background: #f0edec;
	border-radius: 4px;
	display: flex;
	justify-content: center;
	align-items: center;
	font-weight: bold;
	height: 77px;
	color: #463d3c;
	font-size: 24px;
	line-height: 36px;
	border: none;
	box-shadow: 0px 2px 6px #ccc2bd;
	border-bottom: 6px solid #bdc3c6;
	font-size: 16px;
}
.funeral-checkbox-label::before {
	content: "";
	width: 18px;
	height: 18px;
	position: absolute;
	top: 27px;
	left: 87px;
	border: 2px solid #463d3c;
	box-sizing: border-box;
	border-radius: 1px;
}
input[type="checkbox"].funeral-checkbox:checked + label {
	border-bottom: 6px solid #345d62;
	background: #6fbec8;
	color: #ffffff;
}

.limit-plan input[type="checkbox"].funeral-checkbox:checked + label {
	background: #d3938b;
}

.funeral-checkbox-check {
	position: absolute;
	vertical-align: middle;
	background: url("/img/foursquare-check-in 1.png");
	background-size: 18px 18px;
	width: 18px;
	height: 18px;
	top: 27px;
	left: 89px;
	display: none;
}

@media screen and (max-width: 1024px) {
	.funeral-checkbox-label {
		width: 100%;
		font-size: 12px;
		height: 54px;
		border-bottom: 4px solid #bdc3c6;
	}
	.funeral-checkbox-label::before {
		left: calc(16 / 311 * 100%);
		top: 16px;
		width: 16px;
		height: 16px;
	}
	.funeral-checkbox-check {
		top: 15px;
		left: calc(16 / 311 * 100%);
	}
}
.limit-plan select {
	background-image: linear-gradient(45deg, transparent 50%, #463d3c 50%),
		linear-gradient(135deg, #463d3c 50%, transparent 50%),
		linear-gradient(to right, #e4bcb7, #e4bcb7),
		linear-gradient(to right, #463d3c, #463d3c);
}
select {
	background-image: linear-gradient(45deg, transparent 50%, #463d3c 50%),
		linear-gradient(135deg, #463d3c 50%, transparent 50%),
		linear-gradient(to right, #e7fcff, #e7fcff),
		linear-gradient(to right, #463d3c, #463d3c);
	background-position: calc(100% - 25px) 50%, calc(100% - 17px) 50%, 100% 0,
		calc(100% - 53px) 100%;
	background-size: 8px 8px, 8px 8px, 53px 50px, 2px 100%;
	background-repeat: no-repeat;
	padding-left: 24px;
	font-weight: bold;
	border: 2px solid #463d3c;
	box-sizing: border-box;
	border-radius: 4px;
	height: 50px;
	margin: 0 0 40px;
	-webkit-appearance: none;
	margin-bottom: 0px;
	font-size: 24px;
	line-height: 33px;
	background-color: #fff;
}

.select-button {
	background-color: #e7fcff;
}

.limit-plan .select-button {
	background-color: #e4bcb7;
}

.select-button:hover {
	opacity: 0.7;
}

/* page-title */
.page-title {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin: 0;
	padding: 18px 64px 19px;
	border-bottom: 4px solid #6fbec8;
	position: relative;
}

.limit-plan .page-title {
	border-bottom: 4px solid #d3938b;
}

.page-title-client {
	position: absolute;
	bottom: 0px;
	right: 2px;
	font-size: 9px;
	font-weight: bold;
	color: #333;
	letter-spacing: 0;
}

.page-title-img {
	width: 323px;
}

.page-title-text {
	font-size: 19px;
	text-align: center;
}

.page-title-text span {
	font-size: 10px;
}

.funeral-index-eyacatch-img-pc {
	width: 100%;
	margin: 40px auto;
}

.funeral-index-eyacatch-img-sp {
	width: 100%;
	margin: 40px auto;
	display: none;
}

@media screen and (max-width: 784px) {
	.funeral-index-eyacatch-img-pc {
		display: none;
	}

	.funeral-index-eyacatch-img-sp {
		display: block;
	}
	.page-title {
		padding: 16px calc(50% - 171px);
	}

	.page-title-img {
		width: 139px;
		height: auto;
	}

	.page-title-text {
		font-size: 12px;
		line-height: 12px;
	}
}

@media screen and (max-width: 375px) {
	.funeral-index-main .page-title-text {
		font-size: 12px;
	}
}
@media screen and (max-width: 320px) {
	.funeral-index-main .page-title-text {
		font-size: 10px;
		letter-spacing: -0.06em;
	}
}

/* page_flow */
.page-flow {
	display: block;
	width: 100%;
	margin-top: 24px;
}

.page-flow-num-1-div {
	font-size: 14px;
	margin-top: 16px;
	margin-bottom: -16px;
	color: #463d3c;
}

.page-flow-num-1-div span {
	font-weight: bold;
}
.page-flow-num-1-div div {
	margin-top: 4px;
	padding-left: 1em;
}

@media screen and (max-width: 1024px) {
	.page-flow {
		margin-top: 16px;
	}
}

/* user_info */
.user-info {
	display: flex;
	justify-content: flex-start;
	align-items: center;
	width: 100%;
	height: auto;
	margin: 48px 0 0;
	padding: 16px 48px;
	background-color: #fff;
	box-shadow: 0px 2px 6px 2px rgba(0, 0, 0, 0.2);
	border-radius: 6px;
}

.user-info-thumb {
	width: 72px;
	height: auto;
	margin: 0 20px 0 0;
}

.user-info-text {
	font-size: 20px;
	font-weight: 700;
}
@media screen and (max-width: 1024px) {
	.user-info {
		margin: 24px 0 0;
		padding: 16px 12px;
	}
	.user-info-text {
		font-size: 17px;
	}
}

@media screen and (max-width: 414px) {
	.user-info-text {
		font-size: 14px;
	}
}
@media screen and (max-width: 375px) {
	.user-info-text {
		font-size: 11px;
	}
}
