/* ---------------------------- */
/* Common */
/* ---------------------------- */

/* ---------------------------- */
/* Contents-main */
/* ---------------------------- */

.contents-main {
	position: relative;
	width: 92%;
	text-align: center;
	border-radius: 3px;
	margin: auto;
	padding: 60px 0;
}
.contents-main__inner {
	margin: auto;
	width: 88%;
	max-width: 1000px;
}
.contents-main__inner a {
	margin: auto;
}

.contents-main__inner dl {
	text-align: left;
}
.contents-main__inner dl dt {
	margin-bottom: 40px;
	padding-left: 25px;
	position: relative;
	font-size: 24px;
}
.contents-main__inner dl dt::before {
	content: "";
	width: 15px;
	height: 15px;
	display: inline-block;
	border: 2px solid #f8b100;
	border-radius: 50%;
	position: absolute;
	left: 0;
	top: 0.5em;
}
.contents-main__inner dl dd {
	border-bottom: 1px solid #ccc;
	padding-bottom: 60px;
	padding-left: 30px;
	margin-bottom: 40px;
	line-height: 2;
	text-align: justify;
}
.read-more {
	position: relative;
}

.read-more p {
	display: -webkit-box;
	position: relative;
	margin-bottom: 0;
	overflow: hidden;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 4; /* 開く前に見せたい行数を指定 */
}

.read-more:has(:checked) p {
	display: block;
}

.read-more p::after {
	display: block;
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
	height: 60px;
	background: linear-gradient(180deg, hsla(0, 0%, 100%, 0) 0, hsla(0, 0%, 100%, 0.9) 50%, hsla(0, 0%, 100%, 0.9) 0, #fff);
	content: "";
}

.read-more:has(:checked) p::after {
	content: none;
}

.read-more label {
	display: flex;
	align-items: center;
	gap: 0 4px;
	position: absolute;
	bottom: 30px;
	left: 50%;
	transform: translateX(-50%);
	color: #4f96f6;
	font-size: 0.8em;
}

.read-more label:hover {
	text-decoration: underline;
	cursor: pointer;
}

.read-more:has(:checked) label {
	display: none;
}

.read-more label::after {
	display: inline-block;
	width: 10px;
	height: 5px;
	background-color: #b6bdc3;
	clip-path: polygon(0 0, 100% 0, 50% 100%);
	content: "";
}

.read-more input {
	display: none;
}
@media (max-width: 1024px) {
	.contents-main {
		padding: 20px 0;
	}
}

@media (max-width: 768px) {
	.contents-main__inner {
		text-align: center;
	}
}
@media (max-width: 425px) {
	.contents-main__inner {
		margin-bottom: 45px;
	}
	.contents-main__inner dl dt {
		margin-bottom: 20px;
		font-size: 20px;
	}
	.contents-main__inner dl dd {
		padding-bottom: 40px;
		padding-left: 0px;
		margin-bottom: 40px;
	}
}
