@charset "UTF-8";
/**
 * newsとblogで同じスタイルを使いたいのでscssファイルを同じにする
 */
#single {
		padding-block: 140px 80px;
		padding-inline: 20px;
}
@media screen and (min-width: 425px) {
		#single {
				padding-inline: 30px;
		}
}
@media screen and (min-width: 768px) {
		#single {
				padding-inline: 40px;
		}
}
@media screen and (min-width: 992px) {
		#single {
				padding-inline: 70px min(100vw - 435px, 250px);
		}
}
@media screen and (min-width: 1300px) {
		#single {
				padding-inline: 70px;
		}
}

.post_date {
		font-size: 1.2rem;
		line-height: 1.4;
}

.post_title {
		font-size: 2.5rem;
		line-height: 1.8;
		-webkit-margin-before: 25px;
		        margin-block-start: 25px;
}
@media screen and (min-width: 768px) {
		.post_title {
				font-size: 3rem;
		}
}
@media screen and (min-width: 992px) {
		.post_title {
				font-size: 3.5rem;
				-webkit-margin-before: 20px;
				        margin-block-start: 20px;
		}
}

.post_tags {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-ms-flex-wrap: wrap;
		    flex-wrap: wrap;
		-webkit-margin-before: 15px;
		        margin-block-start: 15px;
		gap: 15px 4px;
}
.post_tags li span {
		display: block;
		padding-block: 3px;
		padding-inline: 15px;
		border-radius: 6px;
		font-size: 1.4rem;
		line-height: 1.8;
		color: #222222;
		border: solid 1px #dbd9cd;
}

.post_thumbnail {
		-webkit-margin-before: 50px;
		        margin-block-start: 50px;
}

.single_body h2 {
		position: relative;
		font-size: 2.5rem;
		font-weight: 500;
		line-height: 1.5;
		-webkit-padding-start: 20px;
		        padding-inline-start: 20px;
		-webkit-padding-after: 15px;
		        padding-block-end: 15px;
		border-bottom: solid 1px #DBD9CD;
		-webkit-margin-before: 50px;
		        margin-block-start: 50px;
}
@media screen and (min-width: 992px) {
		.single_body h2 {
				font-size: 3rem;
		}
}
.single_body h2::before {
		content: "";
		position: absolute;
		top: 0.8em;
		left: 0;
		translate: 0 -50%;
		width: 10px;
		height: 8px;
		background-color: #008C64;
		border-radius: 0 100vmax 100vmax 0;
}
.single_body p {
		font-size: 1.6rem;
		line-height: 1.8;
		-webkit-margin-before: 35px;
		        margin-block-start: 35px;
}
.single_body p a {
		color: #008C64;
		text-decoration: underline;
		-webkit-transition: opacity 0.3s;
		transition: opacity 0.3s;
}
@media (hover: hover) and (pointer: fine) {
		.single_body p a:hover {
				opacity: 0.7;
		}
}
.single_body p strong {
		font-weight: 400;
		background-color: #B8E5D8;
}
.single_body ul {
		-webkit-margin-before: 35px;
		        margin-block-start: 35px;
		list-style: none;
}
.single_body ul li {
		position: relative;
		-webkit-padding-start: 18px;
		        padding-inline-start: 18px;
		font-size: 1.6rem;
		line-height: 1.8;
}
.single_body ul li::before {
		content: "";
		position: absolute;
		top: 0.7em;
		left: 0;
		width: 8px;
		height: 8px;
		border-radius: 50%;
		background-color: #222222;
}
.single_body ul li a {
		color: #008C64;
		text-decoration: underline;
		-webkit-transition: opacity 0.3s;
		transition: opacity 0.3s;
}
@media (hover: hover) and (pointer: fine) {
		.single_body ul li a:hover {
				opacity: 0.7;
		}
}
.single_body ul li + li {
		-webkit-margin-before: 5px;
		        margin-block-start: 5px;
}
.single_body ol {
		-webkit-margin-before: 35px;
		        margin-block-start: 35px;
		list-style: none;
}
.single_body ol li {
		position: relative;
		-webkit-padding-start: 30px;
		        padding-inline-start: 30px;
		font-size: 1.6rem;
		line-height: 1.8;
		counter-increment: list;
}
.single_body ol li::before {
		content: counter(list, decimal-leading-zero);
		position: absolute;
		top: 0em;
		left: 0;
}
.single_body ol li a {
		color: #008C64;
		text-decoration: underline;
		-webkit-transition: opacity 0.3s;
		transition: opacity 0.3s;
}
@media (hover: hover) and (pointer: fine) {
		.single_body ol li a:hover {
				opacity: 0.7;
		}
}
.single_body ol li + li {
		-webkit-margin-before: 5px;
		        margin-block-start: 5px;
}
.single_body figure, .single_body img {
		-webkit-margin-before: 40px;
		        margin-block-start: 40px;
}
.single_body h3 {
		font-size: 2rem;
		font-weight: 500;
		line-height: 1.8;
		-webkit-margin-before: 40px;
		        margin-block-start: 40px;
}
.single_body h3 + * {
		-webkit-margin-before: 20px;
		        margin-block-start: 20px;
}

.post_single_buttonblock {
		-webkit-margin-before: 80px;
		        margin-block-start: 80px;
		border-top: solid 1px #222222;
}
@media screen and (min-width: 992px) {
		.post_single_buttonblock {
				display: -webkit-box;
				display: -ms-flexbox;
				display: flex;
				gap: 25px;
				-webkit-box-align: center;
				    -ms-flex-align: center;
				        align-items: center;
				-webkit-box-pack: justify;
				    -ms-flex-pack: justify;
				        justify-content: space-between;
				-webkit-padding-before: 40px;
				        padding-block-start: 40px;
		}
}

.archive_link {
		position: relative;
		display: block;
		text-align: center;
		font-size: 2.5rem;
		color: #222222;
		-webkit-margin-before: 30px;
		        margin-block-start: 30px;
		-webkit-transition: color 0.3s, opacity 0.3s;
		transition: color 0.3s, opacity 0.3s;
}
@media screen and (min-width: 992px) {
		.archive_link {
				-webkit-box-ordinal-group: 3;
				    -ms-flex-order: 2;
				        order: 2;
				-webkit-margin-before: 0;
				        margin-block-start: 0;
				padding-inline: 30px;
		}
}
.archive_link span {
		width: -webkit-fit-content;
		width: -moz-fit-content;
		width: fit-content;
		padding-inline: 5px;
		color: #008C64;
}
.archive_link::before, .archive_link::after {
		position: absolute;
		top: 50%;
		width: 1px;
		height: 40px;
		background-color: #DBD9CD;
		translate: 0% -50%;
}
@media screen and (min-width: 992px) {
		.archive_link::before, .archive_link::after {
				content: "";
		}
}
.archive_link::before {
		left: 0;
}
.archive_link::after {
		right: 0;
}
@media (hover: hover) and (pointer: fine) {
		.archive_link:hover {
				color: #008C64;
				opacity: 0.7;
		}
}

.single_post_button_group {
		position: relative;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		border-top: solid 1px #DBD9CD;
		-webkit-padding-before: 20px;
		        padding-block-start: 20px;
		-webkit-margin-before: 30px;
		        margin-block-start: 30px;
		gap: 45px;
}
@media screen and (min-width: 992px) {
		.single_post_button_group {
				display: contents;
		}
}
.single_post_button_group::before {
		content: "";
		position: absolute;
		top: 50%;
		left: 50%;
		width: 1px;
		height: 40px;
		background-color: #DBD9CD;
		translate: 0% -25%;
}
@media screen and (min-width: 992px) {
		.single_post_button_group::before {
				display: none;
		}
}

.single_post_link {
		position: relative;
		color: #222222;
		-webkit-box-flex: 1;
		    -ms-flex: 1;
		        flex: 1;
}
@media screen and (min-width: 768px) {
		.single_post_link {
				font-size: 1.6rem;
				max-width: 215px;
				min-width: 215px;
		}
}
.single_post_link span {
		font-size: 1.2rem;
		display: -webkit-box;
		-webkit-box-orient: vertical; /* 垂直方向に配置 */
		overflow: hidden; /* 溢れた部分を隠す */
		text-overflow: ellipsis; /* 溢れた部分に「...」を表示 */
		-webkit-line-clamp: 2;
		text-align: left;
		color: #222222;
		-webkit-transition: color 0.3s;
		transition: color 0.3s;
}
@media screen and (min-width: 768px) {
		.single_post_link span {
				font-size: 1.6rem;
		}
}
@media (hover: hover) and (pointer: fine) {
		.single_post_link:hover span {
				color: #008C64;
		}
		.single_post_link:hover::before {
				background-color: #008C64;
		}
}
.single_post_link::before {
		content: "";
		position: absolute;
		top: 50%;
		width: 10px;
		height: 18px;
		background-color: #222222;
		-webkit-transition: translate 0.3s, background-color 0.3s;
		transition: translate 0.3s, background-color 0.3s;
}
.single_post_link::after {
		content: "";
		position: absolute;
		top: 50%;
		width: 10px;
		height: 18px;
		background-color: #FAF8F4;
		-webkit-transition: translate 0.3s;
		transition: translate 0.3s;
}
.single_post_link._prev {
		-webkit-padding-start: 45px;
		        padding-inline-start: 45px;
		-webkit-box-ordinal-group: 2;
		    -ms-flex-order: 1;
		        order: 1;
}
@media screen and (min-width: 992px) {
		.single_post_link._prev {
				-webkit-padding-start: 30px;
				        padding-inline-start: 30px;
		}
}
.single_post_link._prev:is(a)::before {
		left: 0%;
		translate: 0% -50%;
		clip-path: polygon(0 50%, 100% 100%, 100% 0%);
}
.single_post_link._prev:is(a)::after {
		left: 0%;
		clip-path: polygon(0 50%, 100% 100%, 100% 0%);
		translate: 1.5px -50%;
}
@media (hover: hover) and (pointer: fine) {
		.single_post_link._prev:is(a):hover::before {
				translate: -3px -50%;
		}
		.single_post_link._prev:is(a):hover::after {
				translate: 0 -50%;
		}
}
.single_post_link._next {
		-webkit-padding-end: 45px;
		        padding-inline-end: 45px;
		-webkit-box-ordinal-group: 4;
		    -ms-flex-order: 3;
		        order: 3;
}
@media screen and (min-width: 992px) {
		.single_post_link._next {
				-webkit-padding-end: 30px;
				        padding-inline-end: 30px;
		}
}
.single_post_link._next:is(a)::before {
		right: 0;
		translate: 0% -50%;
		clip-path: polygon(0% 0%, 100% 50%, 0% 100%);
}
.single_post_link._next:is(a)::after {
		right: 0;
		clip-path: polygon(0% 0%, 100% 50%, 0% 100%);
		translate: -1.5px -50%;
}
@media (hover: hover) and (pointer: fine) {
		.single_post_link._next:is(a):hover::before {
				translate: 3px -50%;
		}
		.single_post_link._next:is(a):hover::after {
				translate: 0 -50%;
		}
}