@charset "UTF-8";
#page_head {
		padding-inline: 20px;
		-webkit-margin-before: 140px;
		        margin-block-start: 140px;
}
@media screen and (min-width: 425px) {
		#page_head {
				padding-inline: 30px;
		}
}
@media screen and (min-width: 768px) {
		#page_head {
				padding-inline: 40px;
		}
}
@media screen and (min-width: 992px) {
		#page_head {
				padding-inline: 70px min(100vw - 435px, 250px);
		}
}
@media screen and (min-width: 1300px) {
		#page_head {
				padding-inline: 70px;
		}
}
@media screen and (min-width: 992px) {
		#page_head {
				-webkit-margin-before: 160px;
				        margin-block-start: 160px;
		}
}

.page_title {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		gap: 10px 10px;
		-webkit-box-align: baseline;
		    -ms-flex-align: baseline;
		        align-items: baseline;
		-webkit-padding-after: 15px;
		        padding-block-end: 15px;
		border-bottom: solid 1px #222222;
		-ms-flex-wrap: wrap;
		    flex-wrap: wrap;
}
@media screen and (min-width: 992px) {
		.page_title {
				gap: 20px;
		}
}

.page_title_ja {
		font-size: 3.5rem;
		line-height: 1.3;
		font-weight: 500;
}
@media screen and (min-width: 768px) {
		.page_title_ja {
				font-size: 4.5rem;
		}
}
@media screen and (min-width: 992px) {
		.page_title_ja {
				font-size: 5rem;
		}
}

.page_title_en {
		font-size: 1.6rem;
		line-height: 1.5;
}

.section_title {
		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;
}
@media screen and (min-width: 992px) {
		.section_title {
				font-size: 3rem;
		}
}
.section_title::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;
}

.download_head {
		-webkit-margin-before: 50px;
		        margin-block-start: 50px;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		gap: 30px;
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		    -ms-flex-direction: column;
		        flex-direction: column;
		-webkit-box-align: center;
		    -ms-flex-align: center;
		        align-items: center;
}
@media screen and (min-width: 768px) {
		.download_head {
				-webkit-box-orient: horizontal;
				-webkit-box-direction: normal;
				    -ms-flex-direction: row;
				        flex-direction: row;
				gap: 40px;
				-webkit-box-align: start;
				    -ms-flex-align: start;
				        align-items: flex-start;
		}
}
@media screen and (min-width: 992px) {
		.download_head {
				-webkit-margin-before: 80px;
				        margin-block-start: 80px;
		}
}

.download_info {
		-webkit-box-flex: 1;
		    -ms-flex: 1;
		        flex: 1;
}

.download_thumbnail {
		width: 255px;
		border: solid 1px #DBD9CD;
}
@media screen and (min-width: 768px) {
		.download_thumbnail {
				width: 280px;
		}
}
.download_thumbnail img {
		display: block;
}

.download_title {
		font-size: 2rem;
		font-weight: 500;
		line-height: 1.5;
}

.download_item_text {
		font-size: 1.6rem;
		line-height: 1.8;
		-webkit-margin-before: 25px;
		        margin-block-start: 25px;
}

#download_form {
		-webkit-margin-before: 80px;
		        margin-block-start: 80px;
		-webkit-padding-after: 80px;
		        padding-block-end: 80px;
		padding-inline: 20px;
}
@media screen and (min-width: 425px) {
		#download_form {
				padding-inline: 30px;
		}
}
@media screen and (min-width: 768px) {
		#download_form {
				padding-inline: 40px;
		}
}
@media screen and (min-width: 992px) {
		#download_form {
				padding-inline: 70px min(100vw - 435px, 250px);
		}
}
@media screen and (min-width: 1300px) {
		#download_form {
				padding-inline: 70px;
		}
}
#download_form .form_wrap {
		-webkit-margin-before: 30px;
		        margin-block-start: 30px;
}
#download_form .mktoForm {
		max-width: 100%;
		width: 100% !important;
}
#download_form .mktoForm:has(input[name=BA_personalinformation]:checked) .mktoButton {
		pointer-events: auto;
		background-color: #222222;
		border-color: #222222;
}
@media (hover: hover) and (pointer: fine) {
		#download_form .mktoForm:has(input[name=BA_personalinformation]:checked) .mktoButton:hover {
				background-color: #ffffff;
				color: #222222 !important;
		}
		#download_form .mktoForm:has(input[name=BA_personalinformation]:checked) .mktoButton:hover::before {
				border-color: #222222;
				translate: 3px -50%;
		}
}
#download_form .mktoFormRow {
		padding-block: 30px;
		border-top: solid 1px #DBD9CD;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		gap: 15px;
		width: 100%;
}
#download_form .mktoFormCol {
		-webkit-box-flex: 1;
		    -ms-flex: 1;
		        flex: 1;
}
#download_form .mktoClear {
		display: none;
}
#download_form .mktoGutter {
		display: none;
}
#download_form .mktoForm .mktoOffset {
		display: none;
}
#download_form .mktoFieldWrap {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		    -ms-flex-direction: column;
		        flex-direction: column;
		gap: 15px;
		width: 100%;
}
#download_form .mktoLabel {
		font-size: 1.6rem;
		font-weight: 400;
		font-family: "Noto Serif JP";
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-orient: horizontal;
		-webkit-box-direction: reverse;
		    -ms-flex-direction: row-reverse;
		        flex-direction: row-reverse;
		-webkit-box-pack: end;
		    -ms-flex-pack: end;
		        justify-content: flex-end;
		-webkit-box-align: center;
		    -ms-flex-align: center;
		        align-items: center;
		gap: 5px;
		width: 100% !important;
}
@media screen and (min-width: 992px) {
		#download_form .mktoLabel {
				font-size: 1.8rem;
		}
}
#download_form .mktoAsterix {
		position: relative;
		float: none !important;
		text-indent: 100%;
		overflow: hidden;
		white-space: nowrap;
		min-width: 34px;
		display: block;
		padding: 5px 0;
		font-size: 1.4rem;
}
#download_form .mktoAsterix::before {
		content: "必須";
		position: absolute;
		top: 50%;
		left: 0px;
		display: inline-block;
		color: #fff;
		font-size: 1.2rem;
		line-height: 1;
		font-weight: 400;
		background-color: #C8102E;
		padding: 5px;
		border-radius: 5px;
		text-indent: 0;
		-webkit-transform: translateY(-50%);
		        transform: translateY(-50%);
}
#download_form .mktoFormCol {
		margin-bottom: 0 !important;
}
#download_form .mktoField {
		border-color: #222222 !important;
		border-radius: 6px;
		font-size: 1.6rem !important;
		line-height: 1.5;
		padding: 20px 1em !important;
		display: block;
		min-height: 60px;
		background-color: #FAF8F4 !important;
		width: 100% !important;
		border-width: 1px;
}
#download_form .mktoField::-webkit-input-placeholder {
		font-family: "Noto Serif JP";
}
#download_form .mktoField::-moz-placeholder {
		font-family: "Noto Serif JP";
}
#download_form .mktoField:-ms-input-placeholder {
		font-family: "Noto Serif JP";
}
#download_form .mktoField::-ms-input-placeholder {
		font-family: "Noto Serif JP";
}
#download_form .mktoField::placeholder {
		font-family: "Noto Serif JP";
}
#download_form .mktoField[type=radio] {
		-webkit-appearance: none;
		   -moz-appearance: none;
		        appearance: none;
		display: none;
}
#download_form .mktoField[type=radio]:checked + label::before {
		border-color: #008C64;
}
#download_form .mktoField[type=radio]:checked + label::after {
		opacity: 1;
}
@media (hover: hover) and (pointer: fine) {
		#download_form .mktoField[type=radio]:checked + label:hover::before {
				border-color: #ffffff;
		}
}
#download_form .mktoRadioList {
		display: -ms-grid;
		display: grid;
		gap: 10px;
}
@media screen and (min-width: 768px) {
		#download_form .mktoRadioList {
				width: 100% !important;
				-ms-grid-columns: (1fr)[3];
				grid-template-columns: repeat(3, 1fr);
		}
}
#download_form .mktoRadioList label {
		position: relative;
		margin: 0;
		padding: 20px;
		display: block;
		border: solid 1px #222222;
		width: 100%;
		border: solid 1px #222222;
		border-radius: 6px;
		-webkit-padding-start: 50px;
		        padding-inline-start: 50px;
		font-family: "Noto Serif JP";
		font-size: 1.6rem;
		line-height: 1.8;
		font-weight: 400;
		-webkit-transition: background-color 0.3s, color 0.3s;
		transition: background-color 0.3s, color 0.3s;
}
#download_form .mktoRadioList label::before {
		content: "";
		position: absolute;
		left: 20px;
		top: 50%;
		-webkit-transform: translateY(-50%);
		        transform: translateY(-50%);
		width: 20px;
		height: auto;
		aspect-ratio: 1/1;
		border-radius: 50%;
		border: solid 1px #222222;
		-webkit-transition: border-color 0.3s;
		transition: border-color 0.3s;
}
#download_form .mktoRadioList label::after {
		content: "";
		position: absolute;
		top: 50%;
		left: 20px;
		background-color: #008C64;
		border-radius: 50%;
		width: 22px;
		height: auto;
		aspect-ratio: 1/1;
		translate: 0 -50%;
		scale: 0.6;
		-webkit-transition: opacity 0.3s;
		transition: opacity 0.3s;
		opacity: 0;
}
@media (hover: hover) and (pointer: fine) {
		#download_form .mktoRadioList label:hover {
				cursor: pointer;
				background-color: #008C64;
				color: #ffffff;
		}
		#download_form .mktoRadioList label:hover::before {
				border-color: #ffffff;
		}
		#download_form .mktoRadioList label:hover::after {
				background-color: #ffffff;
		}
}
#download_form .mktoRadioList {
		width: 100% !important;
}
#download_form .mktoLogicalField {
		width: -webkit-fit-content !important;
		width: -moz-fit-content !important;
		width: fit-content !important;
}
#download_form .mktoHtmlText {
		line-height: 1.5;
		text-align: left;
		font-family: "Noto Serif JP";
		font-size: 1.6rem;
}
#download_form .mktoLogicalField input {
		-webkit-appearance: none;
		   -moz-appearance: none;
		        appearance: none;
		display: none;
}
#download_form .mktoLogicalField label {
		position: relative;
		display: block;
		border: solid 1px #222222;
		margin: 0;
		padding: 20px;
		-webkit-padding-start: 50px;
		        padding-inline-start: 50px;
		border-radius: 6px;
		font-size: 1.5rem;
		line-height: 1.5;
		font-family: "Noto Serif JP";
		color: #222222;
		-webkit-transition: background-color 0.3s, color 0.3s;
		transition: background-color 0.3s, color 0.3s;
}
#download_form .mktoLogicalField label::before {
		content: "";
		position: absolute;
		width: 20px;
		height: 20px;
		background-color: #008C64;
		border-radius: 2px;
		left: 20px;
		top: 50%;
		-webkit-transform: translateY(-50%);
		        transform: translateY(-50%);
		border: solid 1px #222222;
		background-color: #FAF8F4;
		-webkit-transition: background-color 0.3s, border-color 0.3s;
		transition: background-color 0.3s, border-color 0.3s;
}
#download_form .mktoLogicalField label::after {
		content: "";
		position: absolute;
		top: 50%;
		left: 27px;
		width: 10px;
		height: 3px;
		border-left: solid 3px #ffffff;
		border-bottom: solid 3px #ffffff;
		rotate: -45deg;
		-webkit-transform: translateY(-80%);
		        transform: translateY(-80%);
		opacity: 0;
		-webkit-transition: opacity 0.3s;
		transition: opacity 0.3s;
}
#download_form .mktoLogicalField:has(input:checked) label::before {
		background-color: #008C64;
}
#download_form .mktoLogicalField:has(input:checked) label::after {
		opacity: 1;
}
@media (hover: hover) and (pointer: fine) {
		#download_form .mktoLogicalField:hover label {
				cursor: pointer;
				background-color: #008C64;
				color: #ffffff;
		}
		#download_form .mktoLogicalField:hover label::before {
				border-color: #ffffff;
		}
}
#download_form .mktoButtonRow {
		border-top: solid 1px #DBD9CD;
		-webkit-padding-before: 40px;
		        padding-block-start: 40px;
		width: 100%;
}
#download_form .mktoButtonWrap {
		display: contents;
}
#download_form .mktoButton {
		position: relative;
		background-color: #B6B6B6;
		pointer-events: none;
		color: #fff;
		border-radius: 6px;
		border-color: #B6B6B6;
		font-size: 2rem;
		font-family: "Noto Serif JP";
		max-width: 320px;
		display: block;
		padding: 20px 80px;
		width: 100%;
		font-weight: 400;
		margin-inline: auto;
		-webkit-transition: background-color 0.3s, color 0.3s;
		transition: background-color 0.3s, color 0.3s;
}
#download_form .mktoButton::before {
		content: "";
		position: absolute;
		top: 50%;
		right: 20px;
		border-top: solid 1px #ffffff;
		border-right: solid 1px #ffffff;
		width: 6px;
		height: 6px;
		rotate: 45deg;
		translate: 0 -50%;
		-webkit-transition: border-color 0.3s, translate 0.3s;
		transition: border-color 0.3s, translate 0.3s;
}

#download_thanks {
		-webkit-margin-before: 60px;
		        margin-block-start: 60px;
		-webkit-padding-after: 80px;
		        padding-block-end: 80px;
}

.thanks_title {
		font-size: 2.5rem;
		line-height: 1.8;
		text-align: center;
}
@media screen and (min-width: 768px) {
		.thanks_title {
				font-size: 3rem;
		}
		.thanks_title br {
				display: none;
		}
}
@media screen and (min-width: 992px) {
		.thanks_title {
				font-size: 3.5rem;
		}
}

.download_thanks_text {
		font-size: 1.6rem;
		line-height: 1.8;
		-webkit-margin-before: 25px;
		        margin-block-start: 25px;
		text-align: center;
		letter-spacing: 0.02em;
}

.download_thanks_block {
		-webkit-margin-before: 40px;
		        margin-block-start: 40px;
		max-width: 320px;
		margin-inline: auto;
}
@media screen and (min-width: 768px) {
		.download_thanks_block {
				-webkit-margin-before: 60px;
				        margin-block-start: 60px;
		}
}

.download_thanks_title {
		font-size: 1.6rem;
		line-height: 1.8;
		text-align: center;
}

.download_thanks_thumbnail {
		-webkit-margin-before: 20px;
		        margin-block-start: 20px;
		margin-inline: auto;
		border: solid 1px #DBD9CD;
}
.download_thanks_thumbnail img {
		display: block;
}

.download_button {
		-webkit-margin-before: 20px;
		        margin-block-start: 20px;
		margin-inline: auto;
		display: block;
		width: 100%;
		background-color: #222222;
		padding-block: 20px;
		position: relative;
		border-radius: 6px;
		padding-inline: 30px;
		border: solid 1px #222222;
		-webkit-transition: background-color 0.3s;
		transition: background-color 0.3s;
}
.download_button span {
		position: relative;
		display: block;
		color: #fff;
		font-size: 2rem;
		line-height: 1.8;
		letter-spacing: 0.02em;
		-webkit-transition: color 0.3s;
		transition: color 0.3s;
		text-align: center;
}
.download_button span::before {
		content: "";
		position: absolute;
		top: 50%;
		right: 0;
		width: 12px;
		height: 14px;
		-webkit-mask-image: url("../img/common/download_icon.svg");
		        mask-image: url("../img/common/download_icon.svg");
		-webkit-mask-size: cover;
		        mask-size: cover;
		translate: 0 -50%;
		background-color: #ffffff;
		-webkit-transition: background-color 0.3s, translate 0.3s;
		transition: background-color 0.3s, translate 0.3s;
}
@media (hover: hover) and (pointer: fine) {
		.download_button:hover {
				background-color: transparent;
		}
		.download_button:hover span {
				color: #222222;
		}
		.download_button:hover span::before {
				background-color: #222222;
				translate: 0 calc(-50% + 3px);
		}
}

.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%;
		}
}

.archive_link {
		margin-inline: auto;
}
.archive_link::before, .archive_link::after {
		display: none;
}