/* ── Pompiers Formations — Public CSS ── */
:root {
	--pf-rouge:   #c0392b;
	--pf-rouge-f: #922b21;
	--pf-vert:    #1e8449;
	--pf-gris:    #f5f5f5;
	--pf-texte:   #1a1a1a;
}

/* Sessions list */
.pf-sessions-list {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.pf-session-card {
	background: #fff;
	border: 1px solid #ddd;
	border-left: 5px solid var(--pf-rouge);
	border-radius: 6px;
	padding: 18px 20px;
}

.pf-session-card.pf-complet {
	border-left-color: #aaa;
	opacity: .85;
}

.pf-session-title {
	font-size: 18px;
	margin: 0 0 10px;
}
.pf-session-title a {
	color: var(--pf-texte);
	text-decoration: none;
}
.pf-session-title a:hover {
	color: var(--pf-rouge);
}

.pf-session-meta {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 10px 20px;
	font-size: 14px;
	color: #555;
}
.pf-session-meta .dashicons {
	font-size: 16px;
	vertical-align: middle;
	color: var(--pf-rouge);
}

/* Badges */
.pf-cat-badge {
	display: inline-block;
	background: var(--pf-rouge);
	color: #fff;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 1px;
	text-transform: uppercase;
	padding: 2px 10px;
	border-radius: 20px;
	margin-bottom: 8px;
}

.pf-badge {
	display: inline-block;
	font-size: 12px;
	font-weight: 600;
	padding: 2px 10px;
	border-radius: 20px;
}
.pf-badge-dispo {
	background: rgba(30,132,73,.15);
	color: var(--pf-vert);
	border: 1px solid rgba(30,132,73,.4);
}
.pf-badge-complet {
	background: rgba(0,0,0,.07);
	color: #777;
	border: 1px solid #ccc;
}

/* Formations grid */
.pf-formations-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
	gap: 20px;
}

.pf-formation-card {
	background: #fff;
	border: 1px solid #ddd;
	border-radius: 8px;
	overflow: hidden;
	transition: box-shadow .2s;
}
.pf-formation-card:hover {
	box-shadow: 0 4px 16px rgba(0,0,0,.1);
}

.pf-formation-thumb img {
	width: 100%;
	height: 160px;
	object-fit: cover;
	display: block;
}

.pf-formation-body {
	padding: 16px;
}
.pf-formation-body h3 {
	margin: 8px 0 6px;
	font-size: 17px;
}
.pf-formation-body h3 a {
	color: var(--pf-texte);
	text-decoration: none;
}
.pf-formation-body h3 a:hover {
	color: var(--pf-rouge);
}
.pf-excerpt {
	font-size: 13px;
	color: #666;
	line-height: 1.5;
	margin: 0;
}

/* Utilitaires */
.pf-quiz-wrapper {
	width: 100%;
	margin: 24px 0;
}
.pf-error, .pf-notice {
	padding: 12px 16px;
	border-radius: 4px;
	font-size: 14px;
}
.pf-error  { background: #fdecea; color: #c0392b; border: 1px solid #f5c6c2; }
.pf-notice { background: #f0f0f0; color: #555;    border: 1px solid #ddd;    }
