hr.blog-divider {
	background: linear-gradient(to right,#fac6cf,transparent);
	border: 0;
	height: 1px;
	margin: 26px 0 18px;
}

main.article-main {
	padding: 52px 0 72px;
}

.article-bottom-nav {
	align-items: center;
	border-top: 1px solid #f4d1da;
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	justify-content: space-between;
	margin-top: 32px;
	padding-top: 18px;
}

.article-bottom-nav a {
	color: #50045d;
	font-size: 0.95rem;
	font-weight: 600;
}

.article-bottom-nav a:hover {
	color: #e11a63;
}

.article-footer-meta {
	align-items: center;
	color: var(--muted);
	display: flex;
	flex-wrap: wrap;
	font-size: 0.9rem;
	gap: 10px 18px;
}

.article-footer-meta .pill {
	border-width: 2px;
	font-size: 0.8rem;
	padding: 6px 10px;
}

.article-header {
	padding-bottom: 12px;
	/*padding-top: 24px;*/
}

.article-header .tag {
	margin-top: 0;
}

.article-layout {
	align-items: flex-start;
	display: grid;
	gap: 32px;
	grid-template-columns: minmax(0,3fr) minmax(0,1fr);
}

.blog-article {
	background: rgba(255,255,255,0.96);
	border-radius: 22px;
	border: 1px solid rgba(255,255,255,0.7);
	box-shadow: 0 18px 40px rgba(0,0,0,0.06);
	order: 1;
	padding: clamp(22px,3vw,32px);
}

.blog-article .article-subtitle {
	color: var(--muted);
	font-size: 1rem;
	margin: 0 0 18px;
}

.blog-article h1 {
	color: #50045d;
	font-size: clamp(2rem,3.2vw,2.6rem);
	line-height: 1.1;
	margin: 0 0 10px;
}

.blog-article h2 {
	color: #50045d;
	font-size: 1.4rem;
	margin: 26px 0 10px;
}

.blog-article h3 {
	color: #e11a63;
	font-size: 1.15rem;
	margin: 20px 0 8px;
}

.blog-article li + li {
	margin-top: 6px;
}

.blog-article ol, .blog-article ul {
	color: var(--text);
	line-height: 1.8;
	margin: 0 0 18px;
	padding-left: 1.2rem;
}

.blog-article p {
	color: var(--text);
	line-height: 1.8;
	margin: 0 0 16px;
}

.blog-aside {
	align-self: flex-start;
	display: flex;
	flex-direction: column;
	gap: 18px;
	order: 2;
	position: sticky;
	top: calc(var(--header-h,72px) + 24px);
}

.blog-aside .btn {
	font-size: 0.95rem;
	justify-content: center;
	width: 100%;
}

.blog-aside small {
	color: var(--muted);
	display: block;
	font-size: 0.8rem;
	margin-top: 8px;
}

.blog-callout {
	background: linear-gradient(135deg,#fce4ec,#fff);
	border-left: 5px solid #e11a63;
	border-radius: 16px;
	color: #50045d;
	font-size: 0.98rem;
	margin: 24px 0 10px;
	padding: 14px 16px;
}

.blog-callout strong {
	color: #e11a63;
	display: block;
	margin-bottom: 4px;
}

.blog-card {
	background: #ffffff;
	border-radius: 18px;
	border: 1px solid #f4d1da;
	box-shadow: 0 10px 26px rgba(225,26,99,0.08);
	padding: 16px 18px;
}

.blog-card h3 {
	color: #e11a63;
	font-size: 1rem;
	margin: 0 0 10px;
}

.blog-card p {
	color: var(--muted);
	font-size: 0.95rem;
	margin: 0 0 10px;
}

.blog-lead {
	color: var(--muted);
	font-size: 1.05rem;
	font-weight: 500;
	line-height: 1.8;
	margin-bottom: 22px;
	margin-top: 42px !important;
}

.blog-meta {
	color: var(--muted);
	display: flex;
	flex-wrap: wrap;
	font-size: 0.9rem;
	gap: 10px 16px;
	margin-bottom: 20px;
	align-items: center;
}

.blog-meta .dot {
	background: #fac6cf;
	height: 8px;
	width: 8px;
	border-radius: 50%;
    flex-shrink: 0; /* empêche le point de se déformer */
    display: inline-block; 
    margin: 0 4px; /* optionnel : petit espacement */
    align-self: center; /* force la centering du point même avec emojis */	
}

.blog-meta span {
    align-items: center;
    display: inline-flex;
    gap: 6px;
    white-space: normal;      /* autorise le retour à la ligne */
    overflow-wrap: anywhere;  /* casse si c’est vraiment très long */
}

.blog-quote {
	background: #faedef;
	border-radius: 16px;
	border: 1px solid #fac6cf;
	color: #50045d;
	font-style: italic;
	margin: 22px 0;
	padding: 16px 18px;
	position: relative;
}

.blog-quote strong {
	color: #e11a63;
}

.blog-quote::before {
	content: "“";
	font-size: 40px;
	left: 14px;
	line-height: 1;
	opacity: 0.12;
	position: absolute;
	top: 6px;
}

.blog-toc {
	font-size: 0.93rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

/*
.blog-toc a {
	align-items: center;
	display: inline-flex;
	gap: 8px;
	padding: 4px 0;
}
*/

.blog-toc a {
    display: flex;                 /* aligne la dot et le texte */
    align-items: flex-start;       /* la dot reste en haut, sans s'étirer */
    gap: 8px;
	padding: 4px 0;
}

/*
.blog-toc a::before {
	background: #fac6cf;
	border-radius: 999px;
	content: "";
	height: 6px;
	width: 6px;
}
*/

.blog-toc a::before {
    content: "";
    display: inline-block;         /* IMPORTANT : empêche l'étirement */
    width: 8px;                    /* ou ta valeur */
    height: 8px;
    border-radius: 50%;
    background: #fac6cf;
    flex-shrink: 0;                /* NE PAS rétrécir */
    margin-top: 6px;               /* ajuste l’alignement avec le texte */
}

.blog-toc a:hover {
	color: #e11a63;
}

.blog-toc li + li {
	margin-top: 8px;
}

.fab {
	bottom: 18px;
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	justify-content: flex-end;
	position: fixed;
	right: 18px;
	z-index: 40;
}

.fab .btn {
	box-shadow: 0 10px 24px rgba(0,0,0,.35);
}

.reading-progress {
	background: rgba(250,198,207,0.4);
	height: 3px;
	left: 0;
	position: fixed;
	right: 0;
	top: var(--header-h,72px);
	z-index: 900;
}

.reading-progress__bar {
	background: #e11a63;
	height: 100%;
	transform-origin: left;
	transition: width 0.08s ease-out;
	width: 0;
}

@media (max-width: 680px) {
	.article-bottom-nav {
		align-items: flex-start;
		flex-direction: column;
	}

	.blog-article {
		border-radius: 18px;
		padding: 18px 16px;
	}

	.blog-meta {
		align-items: flex-start;
		flex-direction: column;
	}
}

@media (max-width: 960px) {
    .article-layout {
        grid-template-columns: 1fr; /* une seule colonne */
    }

    .blog-article {
        order: 1; /* article en haut */
    }

    .blog-aside {
        order: 2; /* aside en bas */
    }	

	.blog-meta .dot {
		display: none;
	}
}

@media (max-width: 768px) {
	#fabBtnCoach, #fabBtnBackTbd {
		width: 60px !important;
		height: 60px !important;
		border-radius: 50%;
		border: none;
		text-align: center !important;
		cursor: pointer;
		display: flex;        /* pour centrer le texte */
		align-items: center;
		justify-content: center;
	}

	#fabBtnSpanCoach, #fabBtnSpanCoach {
		display: none;
	}

	#danscetarticle, #continuerdansmonespace {
		display: none !important;
	}
}
