/* ============================================================
   kiji_sousyokudoubutsu - 共通スタイル（フロント＋エディター）
   ============================================================ */

/* ============================================================
   スペックバー
   3列固定 / 4個以上は3つずつ折り返し
   ============================================================ */
.ksd-specs-bar-wrap {
	display: grid !important;
	grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
	gap: 12px !important;
	width: 100% !important;
	margin: 0 0 1.5em 0 !important;
	box-sizing: border-box;
}

.ksd-specs-item {
	display: flex !important;
	flex-direction: column;
	align-items: center;
	justify-content: flex-start;
	padding: 18px 10px !important;
	border-style: solid;
	border-width: 1px;
	border-radius: 10px;
	text-align: center;
	box-sizing: border-box;
	min-width: 0;
}

.ksd-specs-item .ksd-svg-icon {
	display: flex !important;
	align-items: center;
	justify-content: center;
	width: 100%;
	margin: 0 0 8px 0;
	line-height: 1;
	text-align: center;
}

.ksd-specs-item .ksd-svg-icon svg {
	display: block;
	margin: 0 auto;
}

.ksd-specs-label {
	display: block;
	width: 100%;
	font-size: 13px;
	font-weight: bold;
	line-height: 1.6;
	white-space: pre-line;
	text-align: center;
	word-break: break-word;
}

/* ============================================================
   特徴カード
   添付イメージ寄せの見た目に調整
   ============================================================ */
.ksd-feature-card-wrap {
	padding: 28px 36px;
	border: 1px solid #d9d9d9;
	border-radius: 22px;
	margin: 0 0 24px 0;
	box-sizing: border-box;
	overflow: hidden;
	background: #fff;
}

.ksd-feature-card-inner {
	display: flex;
	align-items: stretch !important;
	gap: 12px !important;
	min-width: 0;
}

.ksd-feature-card-wrap.ksd-image-right .ksd-feature-card-inner {
	flex-direction: row;
}

.ksd-feature-card-wrap.ksd-image-left .ksd-feature-card-inner {
	flex-direction: row-reverse;
}

.ksd-feature-text {
	flex: 1 1 auto;
	min-width: 0;
}

.ksd-feature-title {
	display: block;
	font-weight: 700;
	font-size: 24px;
	line-height: 1.4;
	margin: 0 0 20px 0 !important;
	color: #222;
}

.ksd-check-list {
	list-style: none !important;
	margin: 0 !important;
	padding: 0 !important;
}

.ksd-check-list li {
	display: grid;
	grid-template-columns: 28px 1fr;
	column-gap: 14px;
	align-items: start;
	margin: 0 0 12px 0;
	padding: 0;
	font-size: 18px;
	font-weight: 700;
	line-height: 1.5;
	color: #222;
}

.ksd-check-list li:last-child {
	margin-bottom: 0;
}

.ksd-check-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	line-height: 1;
	margin-top: 2px;
	padding: 0;
	flex-shrink: 0;
	border: none !important;
	background: transparent !important;
	box-shadow: none !important;
}

.ksd-check-icon svg {
	display: block;
	width: 28px;
	height: 28px;
	margin: 0 auto;
	border: none !important;
	box-shadow: none !important;
}

.ksd-feature-image {
	flex: 0 0 220px;
	width: 220px;
	max-width: 220px;
	border: none !important;
	background: transparent !important;
	box-shadow: none !important;
	outline: none !important;
}

.ksd-feature-image img {
	display: block;
	width: 100%;
	max-width: 220px;
	height: auto;
	margin: 0 auto;
	border: none !important;
	border-radius: 0 !important;
	background: transparent !important;
	box-shadow: none !important;
	outline: none !important;
}

/* 旧table系の崩れ防止 */
.ksd-feature-card-wrap table,
.ksd-feature-card-wrap tbody,
.ksd-feature-card-wrap tr,
.ksd-feature-card-wrap td {
	border: none !important;
	box-shadow: none !important;
	background: transparent;
}

/* スマホ */
@media (max-width: 640px) {
	.ksd-feature-card-wrap {
		padding: 20px 18px;
		border-radius: 16px;
	}

	.ksd-feature-card-inner {
		gap: 16px;
	}

	.ksd-feature-title {
		font-size: 20px;
		margin-bottom: 14px !important;
	}

	.ksd-check-list li {
		grid-template-columns: 24px 1fr;
		column-gap: 10px;
		font-size: 16px;
		margin-bottom: 10px;
	}

	.ksd-check-icon {
		width: 24px;
		height: 24px;
	}

	.ksd-check-icon svg {
		width: 24px;
		height: 24px;
	}

	.ksd-feature-image {
		flex: 0 0 140px;
		width: 140px;
		max-width: 140px;
	}

	.ksd-feature-image img {
		max-width: 140px;
	}
}

/* ============================================================
   アイコン付きテキスト
   ============================================================ */
.ksd-icon-text-wrap {
	padding: 18px 20px;
	border-style: solid;
	border-width: 1px;
	border-radius: 10px;
	margin: 0 0 1.5em 0;
	box-sizing: border-box;
}

.ksd-icon-title-row {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 8px;
	width: 100%;
}

.ksd-icon-title-row .ksd-svg-icon {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	line-height: 1;
}

.ksd-icon-title-row .ksd-svg-icon svg {
	display: block;
	margin: 0 auto;
}

.ksd-icon-text-title {
	font-weight: bold;
	font-size: 15px;
	line-height: 1.4;
}

.ksd-icon-text-body-wrap {
	display: block;
	width: 100%;
}

.ksd-icon-text-body {
	font-size: 14px;
	color: #555;
	line-height: 1.7;
	margin: 0 !important;
	padding: 0;
	display: block;
	width: 100%;
}

/* ============================================================
   レスポンシブ
   スマホでも3列固定
   ============================================================ */
@media (max-width: 640px) {
	.ksd-specs-bar-wrap {
		grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
		gap: 10px !important;
	}

	.ksd-specs-item {
		padding: 14px 6px !important;
	}

	.ksd-specs-label {
		font-size: 12px;
		line-height: 1.5;
	}

	.ksd-feature-card-inner {
		gap: 14px;
	}

	.ksd-feature-image {
		flex: 0 0 110px;
		width: 110px;
		max-width: 110px;
	}
}


/* ============================================================
   PCで3つの装飾全体をスマホ寄りの横幅に固定
   ============================================================ */
.ksd-specs-bar-wrap,
.ksd-feature-card-wrap,
.ksd-icon-text-wrap {
	width: min(100%, 520px) !important;
	max-width: 520px !important;
	margin-left: auto !important;
	margin-right: auto !important;
	box-sizing: border-box !important;
}

/* ============================================================
   スペックバー
   3列を中央基準にして、左寄りに見えないようにする
   ============================================================ */
.ksd-specs-bar-wrap {
	display: grid !important;
	grid-template-columns: repeat(3, 1fr) !important;
	gap: 10px !important;
	justify-content: center !important;
	align-items: stretch !important;
}

.ksd-specs-item {
	display: flex !important;
	flex-direction: column !important;
	align-items: center !important;
	justify-content: flex-start !important;
	text-align: center !important;
	padding: 14px 6px !important;
	min-width: 0 !important;
	width: 100% !important;
	box-sizing: border-box !important;
}

.ksd-specs-item .ksd-svg-icon {
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: 100% !important;
	margin: 0 0 6px 0 !important;
	text-align: center !important;
	line-height: 1 !important;
}

.ksd-specs-item .ksd-svg-icon svg {
	display: block !important;
	margin: 0 auto !important;
	width: 28px !important;
	height: 28px !important;
}

.ksd-specs-label {
	display: block !important;
	width: 100% !important;
	text-align: center !important;
	font-size: 12px !important;
	line-height: 1.5 !important;
	white-space: pre-line !important;
	word-break: break-word !important;
}

/* ============================================================
   特徴カード
   文字と画像を少し小さく
   ============================================================ */
.ksd-feature-card-wrap {
	padding: 20px 20px !important;
	border-radius: 18px !important;
}

.ksd-feature-card-inner {
	gap: 16px !important;
}

.ksd-feature-title {
	font-size: 15px !important;
	line-height: 1.5 !important;
	margin: 0 0 10px 0 !important;
	font-weight: 700 !important;
}

.ksd-check-list li {
	font-size: 13px !important;
	line-height: 1.6 !important;
	font-weight: 700 !important;
	margin: 0 0 8px 0 !important;
	grid-template-columns: 18px 1fr !important;
	column-gap: 8px !important;
}

.ksd-check-icon {
	width: 18px !important;
	height: 18px !important;
	margin-top: 1px !important;
}

.ksd-check-icon svg {
	width: 18px !important;
	height: 18px !important;
}

.ksd-feature-image {
	flex: 0 0 120px !important;
	width: 120px !important;
	max-width: 120px !important;
}

.ksd-feature-image img {
	display: block !important;
	width: 100% !important;
	max-width: 120px !important;
	height: auto !important;
	margin: 0 auto !important;
}

/* ============================================================
   アイコン付きテキスト
   ============================================================ */
.ksd-icon-text-wrap {
	padding: 16px 18px !important;
	border-radius: 18px !important;
}

.ksd-icon-text-title {
	font-size: 14px !important;
	line-height: 1.5 !important;
}

.ksd-icon-text-body {
	font-size: 13px !important;
	line-height: 1.7 !important;
}

/* ============================================================
   スマホでは幅いっぱい
   ============================================================ */
@media (max-width: 640px) {
	.ksd-specs-bar-wrap,
	.ksd-feature-card-wrap,
	.ksd-icon-text-wrap {
		width: 100% !important;
		max-width: 100% !important;
	}
}



/* ============================================================
   feature-card
   テキストを上下中央 / 画像は縦幅基準
   ============================================================ */

.ksd-feature-card-wrap {
	position: relative;
	overflow: visible !important;
	padding: 0px 20px 0px !important;
	border-radius: 18px !important;
}

.ksd-feature-card-inner {
	display: flex;
	align-items: stretch !important;
	gap: 16px !important;
	min-width: 0;
}

/* 画像右 */
.ksd-feature-card-wrap.ksd-image-right .ksd-feature-card-inner {
	flex-direction: row;
}

/* 画像左 */
.ksd-feature-card-wrap.ksd-image-left .ksd-feature-card-inner {
	flex-direction: row-reverse;
}

/* テキスト側を縦中央寄せ */
.ksd-feature-text {
	flex: 1 1 0% !important;
	min-width: 0;
	position: relative;
	z-index: 2;
	display: flex !important;
	flex-direction: column !important;
	justify-content: center !important;
	align-self: stretch !important;
}

/* タイトル */
.ksd-feature-title {
	font-size: 15px !important;
	line-height: 1.5 !important;
	margin: 0 0 10px 0 !important;
	font-weight: 700 !important;
}

/* チェックリスト */
.ksd-check-list {
	list-style: none !important;
	margin: 0 !important;
	padding: 0 !important;
}

.ksd-check-list li {
	font-size: 13px !important;
	line-height: 1.6 !important;
	font-weight: 700 !important;
	margin: 0 0 8px 0 !important;
	display: grid !important;
	grid-template-columns: 18px 1fr !important;
	column-gap: 8px !important;
	align-items: start !important;
}

.ksd-check-list li:last-child {
	margin-bottom: 0 !important;
}

.ksd-check-icon {
	width: 18px !important;
	height: 18px !important;
	margin-top: 1px !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	line-height: 1 !important;
}

.ksd-check-icon svg {
	width: 18px !important;
	height: 18px !important;
	display: block !important;
}

/* 画像側
   余計なスペースを消して、画像サイズぴったりの箱にする */
.ksd-feature-image {
	flex: 0 0 auto !important;
	width: fit-content !important;
	max-width: fit-content !important;
	height: auto !important;
	display: block !important;
	align-self: flex-end !important;
	margin: 0 0 -8px 0 !important;
}

.ksd-feature-image img {
	display: block !important;
	width: auto !important;
	height: 150px !important;
	max-width: none !important;
	margin: 0 !important;
	border: none !important;
	border-radius: 0 !important;
	background: transparent !important;
	box-shadow: none !important;
	outline: none !important;
	object-fit: contain !important;
	vertical-align: bottom !important;
}

/* PCでも全体をスマホ寄りの幅に固定 */
.ksd-specs-bar-wrap,
.ksd-feature-card-wrap,
.ksd-icon-text-wrap {
	width: min(100%, 520px) !important;
	max-width: 520px !important;
	margin-left: auto !important;
	margin-right: auto !important;
	box-sizing: border-box !important;
}

/* スペックバー中央寄せ */
.ksd-specs-bar-wrap {
	display: grid !important;
	grid-template-columns: repeat(3, 1fr) !important;
	gap: 10px !important;
	justify-content: center !important;
	align-items: stretch !important;
}

.ksd-specs-item {
	display: flex !important;
	flex-direction: column !important;
	align-items: center !important;
	justify-content: flex-start !important;
	text-align: center !important;
	padding: 14px 6px !important;
	min-width: 0 !important;
	width: 100% !important;
	box-sizing: border-box !important;
}

.ksd-specs-item .ksd-svg-icon {
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: 100% !important;
	margin: 0 0 6px 0 !important;
	text-align: center !important;
	line-height: 1 !important;
}

.ksd-specs-item .ksd-svg-icon svg {
	display: block !important;
	margin: 0 auto !important;
	width: 28px !important;
	height: 28px !important;
}

.ksd-specs-label {
	display: block !important;
	width: 100% !important;
	text-align: center !important;
	font-size: 12px !important;
	line-height: 1.5 !important;
	white-space: pre-line !important;
	word-break: break-word !important;
}

/* アイコン付きテキスト */
.ksd-icon-text-wrap {
	padding: 16px 18px !important;
	border-radius: 18px !important;
}

.ksd-icon-text-title {
	font-size: 14px !important;
	line-height: 1.5 !important;
}

.ksd-icon-text-body {
	font-size: 13px !important;
	line-height: 1.7 !important;
}

/* スマホ */
@media (max-width: 640px) {
	.ksd-specs-bar-wrap,
	.ksd-feature-card-wrap,
	.ksd-icon-text-wrap {
		width: 100% !important;
		max-width: 100% !important;
	}

	.ksd-feature-card-wrap {
		padding: 0px 18px 0px !important;
	}

	.ksd-feature-image {
		flex: 0 0 110px !important;
		width: 110px !important;
		max-width: 110px !important;
		transform: translateY(14px);
	}

	.ksd-feature-image img {
		max-width: 110px !important;
	}
}



.ksd-feature-body {
	font-size: 13px;
	line-height: 1.8;
	color: #222;
	word-break: break-word;
}

.ksd-feature-body > *:first-child {
	margin-top: 0;
}

.ksd-feature-body > *:last-child {
	margin-bottom: 0;
}

.ksd-feature-body p {
	margin: 0 0 0.8em 0;
}