
/* =========================
   BLOG / ARTICLE 
   ========================= */

/* Base générale */
main.blog-main,
.fest-blog-category-view,
.fest-article
{
	box-sizing: border-box;
	margin-top: 30px;
	margin-right: auto;
}

main.blog-main {
	padding-top: 95px;
	padding-bottom: 40px;
	min-height: 600px;
}

div.sous-titre-page
{
	margin-top: 10px;
	margin-bottom: 50px;
}

/* =========================
   TITRES / INTRO
   ========================= */


.category-desc p:last-child {
	margin-bottom: 0;
}

/* =========================
   FIL D’ARIANE
   ========================= */

.filAriane {
	margin-bottom: 15px;
}

/* =========================
   ARTICLES EN VEDETTE
   ========================= */

.fest-blog-leading {
	margin-bottom: 40px;
}

.fest-blog-leading .fest-blog-card {
	display: block;
	margin: 0 auto;
	padding: 0 0 30px 0;
}

.fest-blog-leading .fest-blog-card-title {
	font-size: 2rem;
	line-height: 1.15;
	margin: 0 0 5px 0;
}

.fest-blog-leading .fest-blog-card-intro {
	font-size: 1.08rem;
	line-height: 1.75;
}

/* =========================
   GRILLE BLOG
   ========================= */

.fest-blog-grid {
	display: grid;
	gap: 20px 50px;
	margin-bottom: 40px;
	align-items: start;
}

.fest-blog-grid-cols-1 {
	grid-template-columns: 1fr;
}

.fest-blog-grid-cols-2 {
	grid-template-columns: 1fr 1fr;
}

.fest-blog-grid-cols-3 {
	grid-template-columns: 1fr 1fr 1fr;
}

.fest-blog-grid-cols-4 {
	grid-template-columns: 1fr 1fr 1fr 1fr;
}

/* =========================
   CARTE ARTICLE BLOG
   ========================= */

.fest-blog-card
{
	display: flex;
	flex-direction: column;
	height: 100%;
	overflow: hidden;
	margin: 10px;
	padding-bottom: 40px;
	border-bottom: 1px #CCC solid;
}

.fest-blog-card-content {
	padding: 22px 22px 20px 22px;
	display: flex;
	flex-direction: column;
	flex: 1;
}

.fest-blog-card-title {
	margin: 0 0 5px 0;
}

.fest-blog-card-title a {
	color: #04568f;
}

.fest-blog-card-title a:hover {
	
}

.fest-blog-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 8px 16px;
	font-size: 0.92rem;
	line-height: 1.4;
	color: #777;
	margin-bottom: 14px;
}

.fest-blog-meta span,
.fest-blog-meta time {
	display: inline-block;
}

.fest-blog-meta-category a {
	color: #04568f;
	font-weight: 600;
	text-decoration: none;
}

.fest-blog-meta-category a:hover {
	text-decoration: underline;
}

.fest-blog-card-intro {
	font-size: 1rem;
	line-height: 1.7;
	color: #4f4f4f;
	flex: 1;
}

.fest-blog-card-intro p:first-child {
	margin-top: 0;
}

.fest-blog-card-intro p:last-child {
	margin-bottom: 0;
}

.fest-blog-readmore {
	margin-top: 18px;
	margin-bottom: 0;
}

.fest-blog-readmore a {
	display: inline-block;
	padding: 10px 16px;
	border-radius: 8px;
	background: #04568f;
	color: #fff !important;
	text-decoration: none;
	font-weight: 600;
	font-size: 0.95rem;
	line-height: 1.2;
}

.fest-blog-readmore a:hover {
	background-color:#00781f; 
	text-decoration: none;
}

.fest-blog-readmore a:active { position:relative; top:1px; }

/* =========================
   LIENS DE BAS DE BLOG
   ========================= */

.fest-blog-links {
	max-width: 900px;
	margin: 0 auto 35px auto;
	padding-top: 10px;
}

.fest-blog-links ul {
	margin: 0;
	padding-left: 20px;
}

.fest-blog-links li {
	margin-bottom: 8px;
}

/* =========================
   ARTICLE COMPLET
   ========================= */

.fest-article {
	padding-top: 0px;
	padding-bottom: 50px;
}

.fest-article-inner,
.fest-article-header,
.fest-article-content,
.fest-article-footer {

}

.fest-article-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 8px 16px;
	font-size: 0.95rem;
	line-height: 1.4;
	color: #777;
	margin-bottom: 24px;
}

.fest-article-meta span,
.fest-article-meta time {
	display: inline-block;
}

.fest-article-category {
	color: #04568f;
	font-weight: 600;
}

.fest-article-content {
	font-size: 16px;
	line-height: 26px;
}

.fest-article-content > *:first-child
{
	margin-top: 40px;
	font-weight: bold;
	font-size: 18px;
}

.fest-article-content > *:last-child {
	margin-bottom: 0;
}

.fest-article-content p {
	margin-top: 0;
	margin-bottom: 1.2em;
}

.fest-article-content h2,
.fest-article-content h3,
.fest-article-content h4 {
	margin-top: 60px;
	margin-bottom: 20px;
}

div.visuels {
	margin-top: 10px;
	margin-bottom: 40px;
}

div.visuels img { 
	padding:1px;
	margin-top: 30px;
	margin-right: 30px;
	border: solid 1px #b4b4b4;
	transition: transform 0.25s ease; 
}
div.visuels img:hover { transform: scale(1.02); }
@media (max-width: 500px) { div.visuels img { width: 100%; } }

.fest-article-content ul,
.fest-article-content ol {
	margin-top: 0;
	margin-bottom: 1.3em;
	padding-left: 1.5em;
}

.fest-article-content li {
	margin-bottom: 0.45em;
}

.fest-article-content blockquote {
	margin: 1.8em 0;
	padding: 0.9em 1.2em;
	border-left: 4px solid #04568f;
	background: #f6f9fc;
	color: #555;
	font-style: italic;
}

.fest-article-content hr {
	border: 0;
	border-top: 1px solid #ddd;
	margin: 2.2em 0;
}

/* =========================
   TAGS BOUTON
   ========================= */
aside.linkTags { margin-top: 10 px; margin-bottom: 40px; }

/* =========================
   IMAGES D'INTRODUCTION
   ========================= */
.fest-blog-card-image {
	display: block;
	height: 200px;
	width: 200px;
	overflow: hidden;
	background: #f2f2f2;
	margin-bottom: 20px;
	padding: 1px;
	border: solid 1px #b4b4b4;
}

.fest-blog-leading .fest-blog-card-image {
	display: block;
	height: 320px;
	width: 320px;
	overflow: hidden;
	background: #f2f2f2;
	margin-bottom: 20px;
	padding: 1px;
	border: solid 1px #b4b4b4;
}

.fest-blog-card-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.25s ease;
}

.fest-blog-card-image img:hover {
	transform: scale(1.03);
}

.fest-blog-card-image-caption {
	padding: 10px 16px 0 16px;
	font-size: 0.9rem;
	line-height: 1.4;
	color: #777;
}

/* =========================
   IMAGES D'ARTICLES
   ========================= */

figure.fest-article-image
{
	float: left;
	max-width: 400px;
	margin: 0 40px 28px 0;
	padding: 1px;
	border: solid 1px #b4b4b4;
}

.fest-article-image img {
	width: 100%;
}

.fest-article-image figcaption {
	font-size: 0.92rem;
	line-height: 1.5;
	color: #777;
	margin-top: 10px;
	text-align: center;
}


/* =========================
   TABLEAUX
   ========================= */

.fest-article-content table {
	width: 100%;
	border-collapse: collapse;
	margin: 1.6em 0;
	font-size: 0.98rem;
}

.fest-article-content th,
.fest-article-content td {
	padding: 12px 14px;
	border: 1px solid #ddd;
	text-align: left;
	vertical-align: top;
}

.fest-article-content th {
	background: #f5f7f9;
	font-weight: 700;
}


/* =========================
   BLOCS ANNEXES
   ========================= */

.fest-article-footer {
	margin-top: 35px;
	padding-top: 20px;
	border-top: 1px solid #e5e5e5;
}

.fest-article-tags,
.fest-article-related {
	margin-top: 20px;
}

.fest-article-tags a,
.fest-article-related a {
	display: inline-block;
	margin: 0 8px 8px 0;
	padding: 8px 12px;
	background: #f3f5f7;
	border-radius: 999px;
	text-decoration: none;
	color: #464646;
	font-size: 0.92rem;
}

.fest-article-tags a:hover,
.fest-article-related a:hover {
	background: #e7edf2;
	text-decoration: none;
}

/* =========================
   ÉLÉMENTS JOOMLA COURANTS
   ========================= */

.icons,
.article-info,
.com-content-article__info,
.com-content-category-blog__navigation {
	font-size: 0.95rem;
}

dl.article-info {
	margin: 0 0 20px 0;
}

dl.article-info dd {
	display: inline-block;
	margin: 0 14px 8px 0;
	color: #777;
}

/* Messages / états */
.alert,
.system-message,
.message {
	max-width: 900px;
	margin: 20px auto;
	padding: 14px 16px;
	border-radius: 10px;
	background: #f5f7f9;
	border: 1px solid #dfe5ea;
}

/* =========================
   CLEARFIX
   ========================= */

.fest-article-content::after,
.fest-blog-card-intro::after {
	content: "";
	display: block;
	clear: both;
}

/* =========================
   PUB
   ========================= */

div.megabanner { margin-top: 50px; margin-bottom: 50px;}

/* =========================
   RESPONSIVE
   ========================= */

@media (max-width: 1100px) {
	.fest-blog-grid-cols-4 {
		grid-template-columns: 1fr 1fr;
	}

	.fest-blog-grid-cols-3 {
		grid-template-columns: 1fr 1fr;
	}
}

@media (max-width: 900px) {

	.fest-blog-grid,
	.fest-blog-grid-cols-2,
	.fest-blog-grid-cols-3,
	.fest-blog-grid-cols-4 {
		grid-template-columns: 1fr;
		gap: 24px;
	}

	.fest-blog-card-title {
		font-size: 26px;
	}

	.fest-blog-leading .fest-blog-card-title {
		font-size: 1.7rem;
	}

	.img-left,
	.float-start,
	.img-right,
	.float-end {
		float: none;
		display: block;
		max-width: 100%;
		margin: 1.2em 0;
	}
}

@media (max-width: 850px) {
	.pagination-wrap nav.pagination {
		font-size: 24px;
	}

	.pagination-wrap nav.pagination span.label {
		display: none;
	}
}

@media (max-width: 640px) {
	main.blog-main,

	.page-header h1 {
		font-size: 1.7rem;
	}

	.fest-article h1 {
		font-size: 1.8rem;
	}

	.fest-blog-card-content {
		padding: 18px 16px 18px 16px;
	}

	.fest-blog-meta,
	.fest-article-meta {
		font-size: 0.9rem;
		gap: 6px 12px;
	}

	.fest-article-content {
		font-size: 1rem;
		line-height: 1.75;
	}

	.fest-blog-readmore a {
		width: 100%;
		text-align: center;
		box-sizing: border-box;
	}
}
