@charset "utf-8";

article {
	width: 90%;
	max-width: 994px;
	margin: 0 auto;
	padding-bottom: 95px;
}

article .headline {
	margin-top: -14px;
	color: #063788;
}
article .headline .text1 {
	font-size: 22px;
	display: block;
	line-height: 1.5;
}
article .headline .text2 {
	margin-top: 0.3em;
	font-size: 30px;
	font-weight: bold;
	display: block;
	line-height: 1.5;
}
article .headline .text3 {
	margin-top: 0.1em;
	font-size: 24px;
	font-weight: bold;
	display: block;
	line-height: 1.5;
}

article .main-pic {
	margin-top: 42px;
}

article .article-inner p {
	font-size: 18px;
	line-height: 1.66;
}
article .article-inner p + p {
	margin-top: 1em;
}
article .article-inner p.mt {
	margin-top: 45px;
}

@media print, screen and (min-width:741px) {
	article .article-inner {
		margin: 69px calc(84 / 994 * 100%) 0;
	}
}

@media screen and (max-width:740px) {
	article {
		padding-bottom: 55px;
	}
	article .headline {
		margin-top: -6px;
	}
	article .headline .text1 {
		font-size: 20px;
	}
	article .headline .text2 {
		margin-top: 0.5em;
		font-size: 24px;
	}
	article .headline .text3 {
		margin-top: 0.7em;
		font-size: 17px;
	}

	article .main-pic {
		margin-top: 32px;
	}
	
	article .article-inner p {
		font-size: 16px;
		line-height: 1.62;
	}
	article .article-inner p.mt {
		margin-top: 28px;
	}
}

/* -------------------------------------------------
	article .col2
------------------------------------------------- */

@media print, screen and (min-width:741px) {
	article .col2 {
		display: flex;
		justify-content: space-between;
	}
	article .col2.reverse {
		flex-direction: row-reverse;
	}
	article .col2 + .col2 {
		margin-top: 16px;
	}
	article .col2:not(.reverse) + .col2.reverse {
		margin-top: 76px;
	}
	article .col2 .text {
		width: calc(470 / 826 * 100%);
	}
	article .col2 .pic {
		width: calc(322 / 826 * 100%);
	}
}

@media screen and (min-width:1015px) { /* 画面サイズ大きい時の余白調整 */
	article .col2.margin-fix {
		margin-top: -3px;
	}
	article .col2.margin-fix .text {
		padding-top: 28px;
	}
}

@media screen and (max-width:740px) {
	article .col2 {
		margin-top: 28px;
	}
	article .col2 .pic {
		margin-top: 28px;
	}
}

/* -------------------------------------------------
	article .large-pic
------------------------------------------------- */

article .large-pic {
	margin: 50px 0;
	display: block;
}

@media screen and (max-width:740px) {
	article .large-pic {
		margin: 28px 0;
	}
}