/* =============================================
   KM Single Post
   ============================================= */

.km-sp {
	margin: 0 auto;
	font-family: Lato, sans-serif;
}

/* =============================================
   Meta (catégorie + date)
   ============================================= */

.km-sp__meta {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 24px;
	font-size: 13px;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	color: #999;
}

.km-sp__meta-cat {
	color: #BE9E66;
	text-decoration: none;
	font-weight: 600;
	transition: color 0.2s ease;
}

.km-sp__meta-cat:hover {
	color: #a5874f;
}

.km-sp__meta-sep {
	color: #ccc;
}

/* =============================================
   Image mise en avant
   ============================================= */

.km-sp__featured-img {
	margin: 0 0 32px;
}

.km-sp__featured-img img {
	display: block;
	width: 100%;
	height: auto;
	border-radius: 10px;
	object-fit: cover;
}

/* =============================================
   Sommaire (TOC)
   ============================================= */

.km-sp__toc {
	background: #F9F7F4;
	border-left: 3px solid #BE9E66;
	border-radius: 0 8px 8px 0;
	padding: 24px 28px;
	margin-bottom: 32px;
}

.km-sp__toc-toggle {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	background: none;
	border: none;
	cursor: pointer;
	padding: 0;
}

.km-sp__toc-title {
	font-family: 'Arca Majora 3', Lato, sans-serif;
	font-size: 15px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	color: #262626;
	margin: 0 0 16px;
}

.km-sp__toc-toggle .km-sp__toc-title {
	margin: 0;
}

.km-sp__toc-chevron {
	color: #494949;
	transition: transform 0.3s ease;
	flex-shrink: 0;
}

.km-sp__toc-toggle[aria-expanded="false"] .km-sp__toc-chevron {
	transform: rotate(-90deg);
}

.km-sp__toc-list {
	list-style: none;
	margin: 16px 0 0;
	padding: 0;
	counter-reset: toc;
}

.km-sp__toc--collapsible .km-sp__toc-list--hidden {
	display: none;
}

.km-sp__toc-item {
	counter-increment: toc;
	padding: 0;
	margin: 0;
}

.km-sp__toc-item--l0 {
	padding-left: 0;
}

.km-sp__toc-item--l1 {
	padding-left: 20px;
}

.km-sp__toc-item--l2 {
	padding-left: 40px;
}

.km-sp__toc-item--l3 {
	padding-left: 60px;
}

.km-sp__toc-link {
	display: flex;
	align-items: baseline;
	gap: 10px;
	padding: 6px 0;
	font-size: 14px;
	font-weight: 500;
	line-height: 1.5;
	color: #494949;
	text-decoration: none;
	transition: color 0.2s ease;
}

.km-sp__toc-link::before {
	content: counter(toc) ".";
	font-size: 13px;
	font-weight: 700;
	color: #BE9E66;
	flex-shrink: 0;
}

.km-sp__toc-link:hover,
.km-sp__toc-link--active {
	color: #BE9E66;
}

/* =============================================
   Contenu de l'article
   ============================================= */

.km-sp__content {
	font-size: 16px;
	line-height: 1.8;
	color: #494949;
}

.km-sp__content h2 {
	font-family: 'Arca Majora 3', Lato, sans-serif;
	font-size: 32px;
	font-weight: 700;
	line-height: 1.3;
	color: #262626;
	margin: 48px 0 16px;
	scroll-margin-top: 80px;
}

.km-sp__content h3 {
	font-family: 'Arca Majora 3', Lato, sans-serif;
	font-size: 20px;
	font-weight: 700;
	line-height: 1.35;
	color: #262626;
	margin: 36px 0 12px;
	text-transform: uppercase;
	scroll-margin-top: 80px;
}

.km-sp__content h4 {
	font-family: Lato, sans-serif;
	font-size: 18px;
	font-weight: 700;
	line-height: 1.4;
	color: #262626;
	margin: 28px 0 10px;
	scroll-margin-top: 80px;
}

.km-sp__content h5,
.km-sp__content h6 {
	font-family: Lato, sans-serif;
	font-size: 16px;
	font-weight: 700;
	line-height: 1.4;
	color: #262626;
	margin: 24px 0 8px;
	scroll-margin-top: 80px;
}

.km-sp__content p {
	margin: 0 0 16px;
}

.km-sp__content a {
	color: #BE9E66;
	text-transform: none;
	text-decoration: underline;
	text-underline-offset: 2px;
	transition: color 0.2s ease;
}

.km-sp__content a:hover {
	color: #a5874f;
}

.km-sp__content img {
	max-width: 100%;
	height: auto;
	border-radius: 8px;
	margin: 16px 0;
}

.km-sp__content ul,
.km-sp__content ol {
	margin: 0 0 16px;
	padding-left: 24px;
}

.km-sp__content li {
	margin-bottom: 6px;
	line-height: 1.7;
}

.km-sp__content blockquote {
	border-left: 3px solid #BE9E66;
	margin: 24px 0;
	padding: 16px 24px;
	background: #F9F7F4;
	border-radius: 0 8px 8px 0;
	font-style: italic;
	color: #666;
}

.km-sp__content blockquote p:last-child {
	margin-bottom: 0;
}

.km-sp__content table {
	width: 100%;
	border-collapse: collapse;
	margin: 24px 0;
	font-size: 14px;
}

.km-sp__content th,
.km-sp__content td {
	padding: 10px 14px;
	border: 1px solid #e0e0e0;
	text-align: left;
}

.km-sp__content th {
	background: #F9F7F4;
	font-weight: 700;
	color: #262626;
}

.km-sp__content figure {
	margin: 24px 0;
}

.km-sp__content figcaption {
	font-size: 13px;
	color: #999;
	text-align: center;
	margin-top: 8px;
}

/* Premier heading sans marge haute */
.km-sp__content>h2:first-child,
.km-sp__content>h3:first-child,
.km-sp__content>h4:first-child {
	margin-top: 0;
}

/* =============================================
   Responsive
   ============================================= */

@media (max-width: 768px) {
	.km-sp__toc {
		padding: 18px 20px;
	}

	.km-sp__toc-link {
		font-size: 13px;
	}

	.km-sp__content {
		font-size: 15px;
	}

	.km-sp__content h2 {
		font-size: 20px;
		margin: 36px 0 12px;
	}

	.km-sp__content h3 {
		font-size: 18px;
		margin: 28px 0 10px;
	}
}