@charset "UTF-8";

/* ====================================
	共通スタイル
 ==================================== */
#sub01 .flex-item:has(img) {
	max-inline-size: 15rem;
	margin-inline: auto;
}
#sub07 .flex-item:has(img) {
	max-inline-size: 15rem;
	margin-inline: auto;
}


/* 補足記事：コラム */
.column-container {
	position: relative;
	background: #f5f5f5;
	padding: 5rem 3rem;
	margin-top: 10rem;
}

.column-icon {
	font-weight: 700;
	color: #fff;
	background-color: #000;
	border-radius: 50px;
	display: inline-block;
	position: absolute;
	top: 0;
	left: 50%;
	transform: translate(-50%, -50%);
	font-size: 1.4rem;
	padding: 0.4em 2.4em;
}

.title-box {
	width: 100%;
	padding-bottom: 0.5em;
	text-align: center;
	margin-left: auto;
	margin-right: auto;
	border-bottom: 2px dotted #000;
}

.column-title {
	font-size: 1.8rem;
	font-weight: 500;
	inline-size: fit-content;
	text-align: center;
	margin-inline: auto;
}

.column-text-container {
	margin-top: 3rem;
	width: 100%;
	display: flex;
	align-items: flex-start;
	gap: 4rem;
}

.column-img {
	flex: 1 1 0;
	min-inline-size: 0;
}

.column-title {
	text-align: center;
	width: 100%;
	max-width: 340px;
	margin: 15px auto;	
}

/* コラム個別スタイル */
#column01 {
	padding-top: 0;
}

a.btn-has-arrow-left {
	color: #fff !important;
}

a:hover.btn-has-arrow-left {
	color: #000 !important;
}


/* ====================================
	ホバーが有効な環境のみ
===================================== */
@media (hover:hover) and (pointer: fine) {}

/* ====================================
	スマートフォン専用スタイル
===================================== */
@media screen and (width < 768px) {

	/* 補足記事：コラム */
	.column-container {
		padding: 3rem 2rem;
		margin-top: 6rem;
	}

	.column-container .column-text-container {
		flex-direction: column;
	}

	.column-text-container {
		margin-top: 3rem;
		gap: 3rem;
	}

	.column-title {
		max-width: 80%;	
	}

}

/* ====================================
	PC&タブレット、印刷専用スタイル
===================================== */
@media print,
screen and (width >=768px) {
	#sub01 .flex-item:has(img) {
		inline-size: 20%;
		margin-left: 7rem;
	}
	#sub05 .flex-item:has(img) {
		margin-left: 4rem;
	}
	#sub07 .flex-item:has(img) {
		inline-size: 18%;
		margin-left: 7rem;
	}
	
	
	/* 補足記事：コラム */
	.column-text-left {
		flex: 1 1 0;
		min-inline-size: 0;
		display: flex;
		align-items: flex-start;
		gap: 0.8rem;
	}

	.column-text {
		line-height: 1.8;
		font-size: 1.6rem;
		flex: 1 1 auto;
		min-inline-size: 0;
	}
	
}

/* ====================================
	タブレット専用スタイル（768px～1080px）
===================================== */
@media screen and (768px <=width < 1080px) {}