/* Polices chargees via <link rel="preconnect"+stylesheet> dans head.php (plus rapide que @import, qui bloque le rendu). Ne pas remettre d @import ici. */

/* =========================================================================
   VOSPOSTS — Refonte 2026 — Design system moderne (editorial / magazine)
   Classes prefixees vp- pour cohabiter sans conflit avec l ancien CSS.
   ========================================================================= */

:root{
	/* Couleurs */
	--vp-bg:#ffffff;
	--vp-surface:#f6f5f2;
	--vp-surface-2:#edece7;
	--vp-ink:#18181b;
	--vp-ink-soft:#3d3d44;
	--vp-muted:#71717a;
	--vp-line:#e7e5e0;
	--vp-accent:#e0492f;
	--vp-accent-dark:#c13a22;
	--vp-accent-soft:#fdede8;
	--vp-on-accent:#ffffff;

	/* Rayons */
	--vp-r-sm:8px;
	--vp-r:12px;
	--vp-r-lg:18px;
	--vp-r-full:999px;

	/* Ombres */
	--vp-shadow-sm:0 1px 2px rgba(24,24,27,.06), 0 1px 3px rgba(24,24,27,.04);
	--vp-shadow:0 4px 14px rgba(24,24,27,.08);
	--vp-shadow-lg:0 16px 40px rgba(24,24,27,.14);

	/* Typo */
	--vp-font-display:"Libre Franklin", "Helvetica Neue", Arial, sans-serif;
	--vp-font-sans:"Inter", system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
	--vp-font-serif:"Newsreader", Georgia, "Times New Roman", serif;

	/* Layout */
	--vp-maxw:1180px;
	--vp-gap:28px;
	--vp-header-h:68px;
}

/* ----------------------------- Reset / base ----------------------------- */
*,*::before,*::after{ box-sizing:border-box; }

body.vp-skin{
	margin:0;
	background:var(--vp-bg);
	color:var(--vp-ink);
	font-family:var(--vp-font-sans);
	font-size:16px;
	line-height:1.6;
	-webkit-font-smoothing:antialiased;
	text-rendering:optimizeLegibility;
	overflow-x:hidden;
}

.vp-skin img{ max-width:100%; height:auto; display:block; }
.vp-skin a{ color:inherit; text-decoration:none; }
.vp-skin h1,.vp-skin h2,.vp-skin h3,.vp-skin h4{
	font-family:var(--vp-font-display);
	font-weight:600;
	line-height:1.15;
	color:var(--vp-ink);
	margin:0 0 .5em;
	letter-spacing:-.01em;
}
.vp-skin p{ margin:0 0 1em; }

/* ----------------------------- Layout ----------------------------------- */
.vp-container{ width:100%; max-width:var(--vp-maxw); margin:0 auto; padding:0 22px; }
/* Accessibilite / SEO : contenu lu par les lecteurs d ecran + moteurs, masque visuellement (ex: h1 de l accueil) */
.vp-visually-hidden{ position:absolute !important; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }
.vp-section{ padding:46px 0; }
.vp-section-tight{ padding:28px 0; }

/* ----------------------------- Boutons ---------------------------------- */
.vp-btn{
	display:inline-flex; align-items:center; gap:.5em;
	font-family:var(--vp-font-sans); font-weight:600; font-size:.95rem;
	padding:.62em 1.15em; border-radius:var(--vp-r-full);
	border:1px solid transparent; cursor:pointer; transition:all .18s ease;
	line-height:1; white-space:nowrap;
}
.vp-btn-primary{ background:var(--vp-accent); color:var(--vp-on-accent); }
.vp-btn-primary:hover{ background:var(--vp-accent-dark); transform:translateY(-1px); box-shadow:var(--vp-shadow); }
.vp-btn-ghost{ background:transparent; color:var(--vp-ink); border-color:var(--vp-ink); }
.vp-btn-ghost:hover{ background:var(--vp-ink); color:#fff; border-color:var(--vp-ink); }

/* ----------------------------- Tags / chips ----------------------------- */
.vp-tag{
	display:inline-flex; align-items:center;
	font-family:var(--vp-font-sans); font-weight:600; font-size:.72rem;
	text-transform:uppercase; letter-spacing:.05em;
	color:var(--vp-accent); background:var(--vp-accent-soft);
	padding:.32em .7em; border-radius:var(--vp-r-full);
}
.vp-tag-ink{ color:#fff; background:var(--vp-ink); }

/* ----------------------------- Header ----------------------------------- */
.vp-header{
	position:sticky; top:0; z-index:200;
	background:rgba(255,255,255,.86); backdrop-filter:saturate(180%) blur(10px);
	border-bottom:1px solid var(--vp-line);
}
.vp-header-inner{
	display:flex; align-items:center; gap:20px;
	height:var(--vp-header-h);
}
.vp-logo{ display:flex; align-items:center; flex:0 0 auto; }
.vp-logo img{ height:34px; width:auto; }
.vp-logo .vp-logo-txt{ font-family:var(--vp-font-display); font-weight:700; font-size:1.5rem; letter-spacing:-.02em; color:var(--vp-ink); }

.vp-nav{ display:flex; align-items:center; gap:4px; flex:1 1 auto; }
.vp-nav a{
	font-weight:500; font-size:.95rem; color:var(--vp-ink-soft);
	padding:.5em .8em; border-radius:var(--vp-r-sm); transition:all .15s ease;
}
.vp-nav a:hover{ color:var(--vp-ink); background:var(--vp-surface); }
.vp-nav a.vp-active{ color:var(--vp-accent); }

.vp-header-actions{ display:flex; align-items:center; gap:12px; flex:0 0 auto; }
.vp-header-actions .vp-icon-btn{
	display:inline-flex; align-items:center; justify-content:center;
	width:38px; height:38px; border-radius:var(--vp-r-full);
	color:var(--vp-ink-soft); background:transparent; border:1px solid transparent; cursor:pointer;
}
.vp-header-actions .vp-icon-btn:hover{ background:var(--vp-surface); color:var(--vp-ink); }

.vp-burger{ display:none; width:40px; height:40px; border:1px solid var(--vp-line); border-radius:var(--vp-r-sm); background:#fff; cursor:pointer; align-items:center; justify-content:center; }
.vp-burger span,.vp-burger span::before,.vp-burger span::after{
	content:''; display:block; width:18px; height:2px; background:var(--vp-ink); border-radius:2px; position:relative; transition:.2s;
}
.vp-burger span::before{ position:absolute; top:-6px; }
.vp-burger span::after{ position:absolute; top:6px; }

/* ----------------------------- Hero / une ------------------------------- */
.vp-hero{ display:grid; grid-template-columns:1.6fr 1fr; gap:var(--vp-gap); margin-top:32px; }
.vp-hero-main{ position:relative; border-radius:var(--vp-r-lg); overflow:hidden; min-height:420px; display:flex; align-items:flex-end; box-shadow:var(--vp-shadow); }
.vp-hero-main img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0; }
.vp-hero-main .vp-hero-grad{ position:absolute; inset:0; z-index:1; background:linear-gradient(to top, rgba(10,10,12,.88) 0%, rgba(10,10,12,.35) 45%, rgba(10,10,12,0) 75%); }
.vp-hero-main .vp-hero-body{ position:relative; z-index:2; padding:30px; color:#fff; }
.vp-hero-main .vp-hero-body h2{ color:#fff; font-size:clamp(1.7rem,3vw,2.5rem); margin:.35em 0 .25em; }
.vp-hero-main .vp-hero-body p{ color:rgba(255,255,255,.82); margin:0; font-size:1rem; max-width:48ch; }

.vp-hero-side{ display:flex; flex-direction:column; gap:18px; }
.vp-hero-side .vp-mini{ display:grid; grid-template-columns:96px 1fr; gap:14px; align-items:center; }
.vp-hero-side .vp-mini img{ width:96px; height:72px; object-fit:cover; border-radius:var(--vp-r-sm); }
.vp-hero-side .vp-mini h3{ font-size:1.02rem; margin:.2em 0 0; line-height:1.25; }
.vp-hero-side .vp-mini .vp-meta{ font-size:.78rem; color:var(--vp-muted); }

/* ----------------------------- Grille cartes ---------------------------- */
.vp-section-head{ display:flex; align-items:baseline; justify-content:space-between; gap:16px; margin-bottom:22px; border-bottom:2px solid var(--vp-ink); padding-bottom:10px; }
.vp-section-head h2{ font-size:1.5rem; margin:0; }
.vp-section-head a{ font-size:.85rem; font-weight:600; color:var(--vp-accent); }

.vp-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--vp-gap); }
.vp-card{ display:flex; flex-direction:column; background:var(--vp-bg); border-radius:var(--vp-r); overflow:hidden; transition:transform .2s ease, box-shadow .2s ease; }
.vp-card:hover{ transform:translateY(-3px); }
.vp-card-thumb{ position:relative; aspect-ratio:16/10; overflow:hidden; border-radius:var(--vp-r); background:var(--vp-surface-2); }
.vp-card-thumb img{ width:100%; height:100%; object-fit:cover; transition:transform .35s ease; }
.vp-card:hover .vp-card-thumb img{ transform:scale(1.04); }
.vp-card-thumb .vp-tag{ position:absolute; top:12px; left:12px; z-index:2; }
.vp-card-body{ padding:14px 4px 4px; }
.vp-card-body h3{ font-size:1.18rem; margin:.3em 0 .35em; line-height:1.25; }
.vp-card-body h3 a:hover{ color:var(--vp-accent); }
.vp-card-excerpt{ color:var(--vp-ink-soft); font-size:.92rem; margin:0 0 .7em; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.vp-meta{ display:flex; align-items:center; gap:8px; font-size:.8rem; color:var(--vp-muted); }
.vp-meta .vp-dot{ width:3px; height:3px; border-radius:50%; background:var(--vp-muted); }

/* ----------------------------- Footer ----------------------------------- */
.vp-footer{ background:var(--vp-ink); color:#d8d8de; margin-top:60px; }
.vp-footer a{ color:#d8d8de; }
.vp-footer a:hover{ color:#fff; }
.vp-footer-inner{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:36px; padding:52px 22px 34px; }
.vp-footer h4{ color:#fff; font-family:var(--vp-font-sans); font-size:.8rem; text-transform:uppercase; letter-spacing:.08em; margin:0 0 16px; }
.vp-footer ul{ list-style:none; margin:0; padding:0; line-height:2.1; font-size:.92rem; }
.vp-footer .vp-foot-brand{ font-family:var(--vp-font-display); font-weight:700; font-size:1.8rem; color:#fff; }
.vp-footer .vp-foot-brand span{ color:var(--vp-accent); }
.vp-footer-bottom{ border-top:1px solid rgba(255,255,255,.12); padding:20px 0; display:flex; justify-content:space-between; gap:14px; font-size:.82rem; color:#a1a1aa; flex-wrap:wrap; }

/* ----------------------------- Responsive ------------------------------- */
@media (max-width:980px){
	.vp-hero{ grid-template-columns:1fr; }
	.vp-grid{ grid-template-columns:repeat(2,1fr); }
	.vp-footer-inner{ grid-template-columns:1fr 1fr; gap:28px; }
}
@media (max-width:680px){
	.vp-nav{ display:none; }
	.vp-burger{ display:inline-flex; }
	.vp-grid{ grid-template-columns:1fr; }
	.vp-footer-inner{ grid-template-columns:1fr 1fr; gap:22px; }
	.vp-hero-main{ min-height:320px; }
	.vp-section{ padding:32px 0; }
}

/* ----------------------------- Header actions (refonte) ----------------- */
.vp-search{ display:flex; align-items:center; gap:8px; background:var(--vp-surface); border:1px solid var(--vp-line); border-radius:var(--vp-r-full); padding:7px 14px; transition:border-color .15s ease, background .15s ease; }
.vp-search:focus-within{ background:#fff; border-color:var(--vp-ink); }
.vp-search svg{ width:16px; height:16px; color:var(--vp-muted); flex:0 0 auto; }
.vp-search input{ border:0; outline:0; background:transparent; font-family:var(--vp-font-sans); font-size:.9rem; color:var(--vp-ink); width:150px; }
.vp-search input::placeholder{ color:var(--vp-muted); }

.vp-lang{ display:flex; align-items:center; }
/* Selecteur de langue (widget backoffice_gestion_traduction_front) rendu compact en dropdown */
body.vp-skin .vp-lang .selecteur_langue{ position:relative; }
body.vp-skin .vp-lang .lang_actuelle{ display:flex; align-items:center; gap:6px; cursor:pointer; font-size:.85rem; font-weight:500; padding:7px 11px; border:1px solid var(--vp-line); border-radius:var(--vp-r-full); white-space:nowrap; color:var(--vp-ink); }
body.vp-skin .vp-lang .lang_actuelle:hover{ background:var(--vp-surface); }
body.vp-skin .vp-lang #interne_selecteur_code_lang{ display:none; position:absolute; top:calc(100% + 8px); right:0; background:#fff; border:1px solid var(--vp-line); border-radius:var(--vp-r); box-shadow:var(--vp-shadow-lg); padding:6px; min-width:172px; max-height:60vh; overflow-y:auto; z-index:400; }
body.vp-skin .vp-lang .option_select_code_lang{ display:flex; align-items:center; gap:9px; padding:8px 10px; border-radius:var(--vp-r-sm); cursor:pointer; font-size:.86rem; white-space:nowrap; color:var(--vp-ink); }
body.vp-skin .vp-lang .option_select_code_lang:hover{ background:var(--vp-surface); }
body.vp-skin .vp-lang .drapeau_lang{ width:20px; height:auto; border-radius:2px; flex:0 0 auto; }
body.vp-skin .vp-lang .fleche_dropdown_lang{ font-size:.7rem; color:var(--vp-muted); margin-left:2px; }
.vp-account{ flex:0 0 auto; }
/* Alignement vertical homogene des controles du header */
.vp-header-inner{ align-items:center; }
.vp-header-inner > *{ align-self:center; }
.vp-search, .vp-account, .vp-nav-more-btn, .vp-lang .lang_actuelle{ height:40px; box-sizing:border-box; }

/* Menu mobile (toggle via body.vp-menu-open) */
.vp-mobile-nav{ display:none; flex-direction:column; padding:8px 22px 18px; border-top:1px solid var(--vp-line); background:#fff; }
.vp-mobile-nav a{ padding:13px 4px; font-weight:500; color:var(--vp-ink); border-bottom:1px solid var(--vp-line); }
.vp-mobile-nav a:last-child{ border-bottom:0; }
body.vp-menu-open .vp-mobile-nav{ display:flex; }
/* Recherche integree au menu burger (la recherche du header est masquee en petit mobile) */
.vp-mobile-search{ display:flex; align-items:center; gap:8px; background:var(--vp-surface); border:1px solid var(--vp-line); border-radius:var(--vp-r-full); padding:9px 14px; margin:6px 0 12px; }
.vp-mobile-search svg{ width:16px; height:16px; color:var(--vp-muted); flex:0 0 auto; }
.vp-mobile-search input{ border:0; outline:0; background:transparent; width:100%; font-family:var(--vp-font-sans); font-size:.95rem; color:var(--vp-ink); }
.vp-mobile-search input::placeholder{ color:var(--vp-muted); }
body.vp-menu-open .vp-burger span{ background:transparent; }
body.vp-menu-open .vp-burger span::before{ top:0; transform:rotate(45deg); }
body.vp-menu-open .vp-burger span::after{ top:0; transform:rotate(-45deg); }

.vp-foot-col-brand p{ color:#a9a9b2; font-size:.92rem; max-width:34ch; }

/* Responsive header : nav -> burger plus tot (beaucoup d items) */
@media (max-width:1040px){
	.vp-nav{ display:none; }
	.vp-burger{ display:inline-flex; }
}
@media (max-width:560px){
	.vp-search{ display:none; } /* recherche deplacee dans le menu burger (sinon logo+recherche+langue+burger debordent et le burger sort de l ecran) */
	.vp-account{ display:none; }
	.vp-logo img{ height:28px; }
}

/* ----------------------------- Fil d ariane ---------------------------- */
.vp-breadcrumb{ display:flex; align-items:center; gap:8px; flex-wrap:wrap; font-size:.82rem; color:var(--vp-muted); padding:22px 0 6px; }
.vp-breadcrumb a{ color:var(--vp-muted); }
.vp-breadcrumb a:hover{ color:var(--vp-accent); }
.vp-breadcrumb .vp-bc-sep{ color:var(--vp-line); }
.vp-breadcrumb .vp-bc-current{ color:var(--vp-ink); font-weight:500; }

/* ----------------------------- Page article ---------------------------- */
.vp-article{ display:grid; grid-template-columns:minmax(0,1fr) 320px; gap:48px; align-items:start; padding:10px 0; }
.vp-article-full{ grid-template-columns:1fr; max-width:760px; margin:0 auto; }
.vp-article-main{ min-width:0; }

/* Lecture : typographie soignee du corps de l article (sortie de diffusion_article) */
.vp-article-body{ font-family:var(--vp-font-serif); font-size:1.19rem; line-height:1.8; color:var(--vp-ink); }
.vp-article-body h1,.vp-article-body h2,.vp-article-body h3,.vp-article-body h4{ font-family:var(--vp-font-display); color:var(--vp-ink); }
.vp-article-body h1{ font-size:clamp(1.5rem,2.5vw,2rem); line-height:1.2; margin:.1em 0 .5em; }
.vp-article-body h2{ font-size:1.55rem; margin:1.6em 0 .5em; }
.vp-article-body h3{ font-size:1.25rem; margin:1.4em 0 .4em; }
.vp-skin .vp-article-body p, .vp-skin .vp-article-body li{ font-family:var(--vp-font-serif) !important; font-size:1.13rem; line-height:1.8; color:var(--vp-ink); }
.vp-article-body p{ margin:0 0 1.15em; }
.vp-article-body a{ color:var(--vp-accent); text-decoration:underline; text-underline-offset:2px; }
.vp-article-body img{ border-radius:var(--vp-r); height:auto; margin:18px 0; }
.vp-article-body blockquote{ margin:1.5em 0; padding:8px 0 8px 22px; border-left:4px solid var(--vp-accent); font-family:var(--vp-font-display); font-size:1.3rem; font-style:italic; color:var(--vp-ink); }
.vp-article-body ul,.vp-article-body ol{ margin:0 0 1.15em; padding-left:1.4em; }
.vp-article-body li{ margin:.3em 0; }

/* Sidebar article */
.vp-article-aside{ position:sticky; top:88px; display:flex; flex-direction:column; gap:28px; }
.vp-side-title{ font-family:var(--vp-font-sans); font-size:.8rem; text-transform:uppercase; letter-spacing:.06em; color:var(--vp-ink); padding-bottom:8px; margin:0 0 14px; border-bottom:2px solid var(--vp-ink); }
.vp-ad-block{ background:var(--vp-surface); border:1px solid var(--vp-line); border-radius:var(--vp-r); padding:12px; text-align:center; min-height:120px; }
.vp-ad-label{ display:block; font-size:.66rem; text-transform:uppercase; letter-spacing:.08em; color:var(--vp-muted); margin-bottom:8px; }
.vp-ad-block .adsbygoogle{ display:block; min-height:90px; }

.vp-related{ border-top:1px solid var(--vp-line); margin-top:34px; }

@media (max-width:980px){
	.vp-article{ grid-template-columns:1fr; gap:30px; }
	.vp-article-aside{ position:static; max-width:560px; }
}

/* ----------------------------- Pages liste (categorie / auteur / recherche) --- */
.vp-listing{ padding-top:6px; }
.vp-listing-title{ font-size:clamp(1.6rem,3vw,2.2rem); margin:18px 0 18px; }
.vp-listing-head{ margin:18px 0 28px; }
.vp-listing-head .vp-listing-title{ margin:0 0 .3em; }
.vp-listing-desc{ color:var(--vp-ink-soft); font-size:1.02rem; line-height:1.6; max-width:70ch; margin:0; }
.vp-listing .entour_presentation_cat_article{ margin:18px 0 28px; }
.vp-listing .titre_cat_article{ font-family:var(--vp-font-display); font-size:clamp(1.9rem,3.6vw,2.7rem); color:var(--vp-ink); margin:0 0 .3em; line-height:1.1; }
.vp-listing .img_cat_article_tt_largeur{ border-radius:var(--vp-r-lg); margin-bottom:20px; box-shadow:var(--vp-shadow); }
.vp-listing .encadre_desc_cat_article{ color:var(--vp-ink-soft); font-size:1.02rem; line-height:1.6; max-width:70ch; }

/* Conteneurs de liste -> grille de cartes (uniquement les conteneurs qui portent DIRECTEMENT les cartes) */
.vp-listing .interne_autour_des_block_article,
.vp-listing .zone_liste_article,
.vp-listing .liste_article_dans_cat{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--vp-gap); align-items:stretch; }
.vp-listing .autour_des_block_article{ display:block; } /* simple wrapper : ne pas le grilliser (sinon la grille interne est ecrasee a 1/3 de largeur) */
.vp-listing .interne_autour_des_block_article > a,
.vp-listing .zone_liste_article > a,
.vp-listing .liste_article_dans_cat > a{ display:flex; text-decoration:none; }
/* La pagination (center / p) est un enfant direct de la grille -> span toute la largeur + centree (sinon "perdue a gauche") */
.vp-listing .zone_liste_article > center,
.vp-listing .zone_liste_article > p,
.vp-listing .interne_autour_des_block_article > center,
.vp-listing .interne_autour_des_block_article > p,
.vp-listing .liste_article_dans_cat > center{ grid-column:1 / -1; text-align:center; margin:22px 0 0; }

/* Carte article (mini_block_article) facon vp-card */
.vp-listing .cadre_mini_article{ display:flex; flex-direction:column; width:100%; background:#fff; border:1px solid var(--vp-line); border-radius:var(--vp-r); overflow:hidden; transition:transform .2s ease, box-shadow .2s ease; }
.vp-listing a:hover .cadre_mini_article{ transform:translateY(-3px); box-shadow:var(--vp-shadow); }
.vp-listing .cadre_mini_article .image_dans_mini_article{ position:relative; aspect-ratio:16/10; overflow:hidden; background:var(--vp-surface-2); }
.vp-listing .cadre_mini_article .image_dans_mini_article img{ width:100%; height:100%; object-fit:cover; }
.vp-listing .cadre_mini_article .effet_survol_article{ display:none; }
.vp-listing .cadre_mini_article .titre_mini_article{ font-family:var(--vp-font-display); font-size:1.16rem; line-height:1.25; font-weight:600; color:var(--vp-ink); padding:14px 16px 0; }
.vp-listing .cadre_mini_article .titre_mini_article table,
.vp-listing .cadre_mini_article .titre_mini_article tr,
.vp-listing .cadre_mini_article .titre_mini_article td{ width:auto !important; height:auto !important; display:block; text-align:left !important; }
.vp-listing .cadre_mini_article .texte_mini_article{ color:var(--vp-ink-soft); font-size:.92rem; line-height:1.55; padding:8px 16px 0; flex:1 1 auto; }
.vp-listing .cadre_mini_article .lire_la_suite{ color:var(--vp-accent); font-weight:600; font-size:.85rem; padding:10px 16px 0; }
.vp-listing .cadre_mini_article .date_mni_article{ color:var(--vp-muted); font-size:.8rem; padding:10px 16px 14px; }
.vp-listing .cadre_mini_article .liste_tags{ height:auto; background:none; padding:0 16px 14px; display:flex; flex-wrap:wrap; gap:6px; }
.vp-listing .cadre_mini_article .un_tag_article{ background:var(--vp-surface); color:var(--vp-muted); font-size:.7rem; padding:3px 8px; border-radius:var(--vp-r-full); margin:0; }

/* Pagination */
.vp-listing .element_pagination, .vp-listing .element_pagination_select{ display:inline-flex; align-items:center; justify-content:center; min-width:38px; height:38px; padding:0 10px; margin:4px; border:1px solid var(--vp-line); border-radius:var(--vp-r-sm); cursor:pointer; font-weight:600; font-size:.92rem; color:var(--vp-ink); }
.vp-listing .element_pagination:hover{ border-color:var(--vp-ink); background:var(--vp-surface); }
.vp-listing .element_pagination_select{ background:var(--vp-accent); color:#fff; border-color:var(--vp-accent); }

@media (max-width:980px){
	.vp-listing .interne_autour_des_block_article,
	.vp-listing .zone_liste_article,
	.vp-listing .liste_article_dans_cat,
	.vp-listing .autour_des_block_article{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:600px){
	.vp-listing .interne_autour_des_block_article,
	.vp-listing .zone_liste_article,
	.vp-listing .liste_article_dans_cat,
	.vp-listing .autour_des_block_article{ grid-template-columns:1fr; }
}

/* ----------------------------- Loader (#chargement) -------------------- */
#chargement{ position:fixed; inset:0; z-index:9998; background:rgba(255,255,255,.55); }
#chargement .vp-spinner{ position:absolute; top:50%; left:50%; width:42px; height:42px; margin:-21px 0 0 -21px; border:3px solid var(--vp-line); border-top-color:var(--vp-accent); border-radius:50%; animation:vp-spin .8s linear infinite; }
@keyframes vp-spin{ to{ transform:rotate(360deg); } }

/* ----------------------------- Bouton fonce (signup) ------------------- */
.vp-btn-dark{ background:var(--vp-ink); color:#fff; border-color:var(--vp-ink); }
.vp-btn-dark:hover{ background:#000; color:#fff; transform:translateY(-1px); box-shadow:var(--vp-shadow); }
/* Couleur de texte des boutons : prime sur .vp-skin a{color:inherit} (sinon texte noir invisible) */
.vp-skin a.vp-btn-primary{ color:var(--vp-on-accent); }
.vp-skin a.vp-btn-dark{ color:#fff; }
.vp-skin a.vp-btn-ghost{ color:var(--vp-ink); }
.vp-skin a.vp-btn-ghost:hover{ color:#fff; }

/* ----------------------------- Sous-menu "Plus" de la nav -------------- */
.vp-nav-more{ position:relative; }
.vp-nav-more-btn{ display:inline-flex; align-items:center; gap:5px; font-family:var(--vp-font-sans); font-weight:500; font-size:.95rem; color:var(--vp-ink-soft); background:none; border:0; padding:.5em .8em; border-radius:var(--vp-r-sm); cursor:pointer; }
.vp-nav-more-btn:hover{ color:var(--vp-ink); background:var(--vp-surface); }
.vp-nav-more-btn .vp-caret{ font-size:.65rem; }
.vp-nav-more-panel{ display:none; position:absolute; top:calc(100% + 10px); left:0; background:#fff; border:1px solid var(--vp-line); border-radius:var(--vp-r); box-shadow:var(--vp-shadow-lg); padding:7px; min-width:210px; z-index:300; }
.vp-nav-more.open .vp-nav-more-panel{ display:block; }
.vp-nav-more-panel a{ display:block; padding:9px 12px; border-radius:var(--vp-r-sm); font-size:.92rem; font-weight:500; color:var(--vp-ink-soft); }
.vp-nav-more-panel a:hover{ background:var(--vp-surface); color:var(--vp-ink); }

/* ----------------------------- Articles similaires (grille cartes) ----- */
.vp-related-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--vp-gap); }
@media (max-width:980px){ .vp-related-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:600px){ .vp-related-grid{ grid-template-columns:1fr; } }

/* Masque le menu flottant au scroll (widget_menu_header_float, fond noir) : mon header est deja sticky/blanc */
#barre_menu_float_header, #menu_float_header{ display:none !important; }

/* ----------------------------- Formulaires front (contact, login, signup...) --- */
.vp-skin main input[type="text"],
.vp-skin main input[type="email"],
.vp-skin main input[type="password"],
.vp-skin main input[type="tel"],
.vp-skin main input[type="number"],
.vp-skin .contenu_text_article input[type="text"],
.vp-skin .champ_form_contact,
.vp-skin .champs_de_form,
.vp-skin main textarea,
.vp-skin main select{
	width:100%; max-width:520px; box-sizing:border-box;
	font-family:var(--vp-font-sans); font-size:.98rem; color:var(--vp-ink);
	background:#fff; border:1px solid var(--vp-line); border-radius:var(--vp-r-sm);
	padding:.7em .9em; margin:6px 0 14px; transition:border-color .15s ease, box-shadow .15s ease;
}
.vp-skin main textarea{ min-height:150px; resize:vertical; line-height:1.6; }
.vp-skin .champs_de_form{ max-width:200px; } /* code captcha : champ court */
.vp-skin main input[type="text"]:focus,
.vp-skin main input[type="email"]:focus,
.vp-skin main input[type="password"]:focus,
.vp-skin .champ_form_contact:focus,
.vp-skin .champs_de_form:focus,
.vp-skin main textarea:focus,
.vp-skin main select:focus{
	outline:none; border-color:var(--vp-accent); box-shadow:0 0 0 3px var(--vp-accent-soft);
}
.vp-skin main label, .vp-skin .contenu_text_article label{ font-family:var(--vp-font-sans); font-weight:600; font-size:.9rem; color:var(--vp-ink-soft); }

/* Boutons de validation (div.btn_validation, input submit) facon vp-btn-primary */
.vp-skin .btn_validation,
.vp-skin main input[type="submit"],
.vp-skin main button[type="submit"]{
	display:inline-flex; align-items:center; justify-content:center;
	font-family:var(--vp-font-sans); font-weight:600; font-size:.98rem; line-height:1;
	background:var(--vp-accent); color:var(--vp-on-accent); border:1px solid var(--vp-accent);
	padding:.75em 1.6em; border-radius:var(--vp-r-full); cursor:pointer; text-align:center;
	transition:background .15s ease, transform .15s ease, box-shadow .15s ease;
}
.vp-skin .btn_validation:hover,
.vp-skin main input[type="submit"]:hover,
.vp-skin main button[type="submit"]:hover{
	background:var(--vp-accent-dark); transform:translateY(-1px); box-shadow:var(--vp-shadow);
}

/* ===================== ROUND 3 (retours Steeve) ===================== */

/* En-tete de categorie : aligne a GAUCHE comme le reste des listings (l ancien theme le centrait -> incoherent) */
.vp-skin .vp-listing .entour_presentation_cat_article{ text-align:left; margin:18px 0 26px; }
.vp-skin .vp-listing .zone_liste_article{ text-align:left; }
.vp-skin .vp-listing .encadre_titre_desc_cat_article{ margin:0; }
.vp-skin .vp-listing .titre_cat_article{ text-align:left; }
.vp-skin .vp-listing .encadre_desc_cat_article{ text-align:left; margin:0; }
.vp-skin .vp-listing .img_cat_article_tt_largeur{ border-radius:var(--vp-r-lg); margin-bottom:20px; box-shadow:var(--vp-shadow); }

/* Widget "Nos derniers articles" : on RE-AFFICHE les vignettes (l ancien theme les masquait) en mini-cartes horizontales */
.vp-skin .mini_liste_article_widget .ligne_mini_liste_article_widget{ margin-bottom:14px !important; padding-bottom:14px; border-bottom:1px solid var(--vp-line); }
.vp-skin .mini_liste_article_widget .ligne_mini_liste_article_widget:last-child{ margin-bottom:0 !important; padding-bottom:0; border-bottom:0; }
.vp-skin .lien_mini_liste_article_widget{
	display:grid; grid-template-columns:84px 1fr; grid-template-areas:"img title" "img date";
	gap:2px 12px; align-items:center; text-decoration:none; color:inherit;
}
.vp-skin .img_mini_liste_article_widget{
	display:block !important; grid-area:img; width:84px; height:60px; border-radius:var(--vp-r-sm);
	overflow:hidden; background:var(--vp-surface-2) center/cover no-repeat;
}
.vp-skin .img_mini_liste_article_widget img{ width:100%; height:100%; object-fit:cover; display:block; }
.vp-skin .titre_mini_article_widget{ grid-area:title; margin:0 !important; font-family:var(--vp-font-display); font-size:.95rem !important; font-weight:600; line-height:1.25; color:var(--vp-ink); }
.vp-skin .lien_mini_liste_article_widget:hover .titre_mini_article_widget{ color:var(--vp-accent); }
.vp-skin .txt_mini_liste_article_widget{ display:none !important; } /* pas d extrait : on garde la mini-carte compacte */
.vp-skin .txt_mini_date_article_widget{ grid-area:date; font-size:.78rem; color:var(--vp-muted); font-style:normal; }

/* Header : la barre de recherche etait 8px trop haute (marge bas par defaut du <form>) -> centrage parfait */
.vp-skin .vp-header .vp-search{ margin:0; }

/* --- Pied de fiche article : partage social, tags, boutons, commentaires (relooking moderne) --- */
/* Boutons de partage social : espaces, arrondis, effet hover (au lieu de rectangles colles) ; on garde la couleur de marque (inline) */
.vp-skin .partage_social_dans_article_redac{ margin:26px 0; }
.vp-skin .partage_social_dans_article_redac [class^="autour_btn_r_sociaux"]{ display:flex; flex-wrap:wrap; gap:8px; align-items:stretch; }
.vp-skin .partage_social_dans_article_redac .encadre_un_btn_r_social{ position:static !important; border-radius:var(--vp-r-sm); overflow:hidden; cursor:pointer; transition:transform .15s ease, box-shadow .15s ease, opacity .15s ease; }
.vp-skin .partage_social_dans_article_redac .encadre_un_btn_r_social:hover{ transform:translateY(-2px); box-shadow:var(--vp-shadow); opacity:.96; }
.vp-skin .partage_social_dans_article_redac .interne_btn_social{ padding:0 6px; }
.vp-skin .partage_social_dans_article_redac .entour_titre_r_social{ font-family:var(--vp-font-sans); font-weight:600; font-size:.85rem; }

/* Tags : petits chips discrets (etaient trop voyants) */
.vp-skin .titre_tags{ font-family:var(--vp-font-sans); font-weight:700; font-size:.78rem; text-transform:uppercase; letter-spacing:.06em; color:var(--vp-muted); margin:28px 0 10px; }
.vp-skin .le_tag_dans_article{ display:inline-block; background:var(--vp-surface); color:var(--vp-ink-soft); font-size:.8rem; font-weight:500; line-height:1.4; padding:4px 12px; margin:0 7px 8px 0; border:1px solid var(--vp-line); border-radius:var(--vp-r-full); text-decoration:none; transition:all .15s ease; }
.vp-skin a.le_tag_dans_article:hover, .vp-skin .le_tag_dans_article:hover{ background:var(--vp-accent-soft); color:var(--vp-accent); border-color:transparent; }

/* Boutons "Envoyer a un ami" / "Signaler cet article" : ghost discrets (etaient des barres grises pleine largeur) */
.vp-skin .btn_envois_article_amis,
.vp-skin .btn_signaler_article{
	display:inline-flex; align-items:center; justify-content:center; gap:6px;
	width:auto; margin:8px 8px 0 0; padding:9px 18px; box-sizing:border-box;
	background:transparent; color:var(--vp-ink-soft); border:1px solid var(--vp-line); border-radius:var(--vp-r-full);
	font-family:var(--vp-font-sans); font-weight:600; font-size:.85rem; cursor:pointer; transition:all .15s ease;
}
.vp-skin .btn_envois_article_amis:hover,
.vp-skin .btn_signaler_article:hover{ border-color:var(--vp-ink); background:var(--vp-surface); color:var(--vp-ink); }

/* Systeme de commentaire : titre/declencheur en titre propre */
.vp-skin .titre_commentaire{ font-family:var(--vp-font-display); font-weight:700; font-size:1.15rem; color:var(--vp-ink); margin:30px 0 14px; cursor:pointer; display:inline-flex; align-items:center; gap:8px; }
.vp-skin .titre_commentaire:hover{ color:var(--vp-accent); }
.vp-skin .section_commentaire_article{ margin-top:10px; }

/* --- Page enregistrement / connexion (module compte, partage partout -> CSS uniquement) --- */
.vp-skin .input_login{
	width:100%; max-width:520px; box-sizing:border-box;
	font-family:var(--vp-font-sans); font-size:.98rem; color:var(--vp-ink);
	background:#fff; border:1px solid var(--vp-line); border-radius:var(--vp-r-sm);
	padding:.7em .9em; margin:6px 0 6px; transition:border-color .15s ease, box-shadow .15s ease;
}
.vp-skin .input_login:focus{ outline:none; border-color:var(--vp-accent); box-shadow:0 0 0 3px var(--vp-accent-soft); }
.vp-skin .champ_formulaire{ margin-bottom:14px; }
/* Boutons du module compte (Annuler / Enregistrer / Connexion) : etaient gris -> pills accent */
.vp-skin .btn_bleu{
	display:inline-flex; align-items:center; justify-content:center;
	background:var(--vp-accent); color:#fff; border:1px solid var(--vp-accent);
	border-radius:var(--vp-r-full); padding:11px 26px; margin:6px 8px 0 0;
	font-family:var(--vp-font-sans); font-weight:600; font-size:.95rem; line-height:1; cursor:pointer;
	transition:background .15s ease, transform .15s ease, box-shadow .15s ease; text-decoration:none;
}
.vp-skin .btn_bleu:hover{ background:var(--vp-accent-dark); transform:translateY(-1px); box-shadow:var(--vp-shadow); color:#fff; }

/* --- CTA "venez poster" sur l accueil (l idee meme du blog : que les visiteurs contribuent) --- */
.vp-cta{ margin:54px 0 8px; }
.vp-cta-inner{ background:linear-gradient(135deg, var(--vp-ink) 0%, #2b2b32 100%); color:#fff; border-radius:var(--vp-r-lg); padding:48px 36px; text-align:center; box-shadow:var(--vp-shadow); }
.vp-cta-inner h2{ font-family:var(--vp-font-display); font-size:clamp(1.5rem,3vw,2.1rem); line-height:1.15; margin:0 0 .45em; color:#fff; }
.vp-cta-inner p{ color:rgba(255,255,255,.82); max-width:580px; margin:0 auto 1.7em; font-size:1.04rem; line-height:1.6; }
.vp-cta-actions{ display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }
.vp-cta .vp-btn-ghost{ border-color:rgba(255,255,255,.45); color:#fff; }
.vp-cta .vp-btn-ghost:hover{ background:#fff; color:var(--vp-ink); border-color:#fff; }
.vp-skin .vp-cta a.vp-btn-ghost{ color:#fff; }
.vp-skin .vp-cta a.vp-btn-ghost:hover{ color:var(--vp-ink); }

/* --- Bandeau cookies (widget) : integre au theme, plus discret, et corrige le texte illisible (cream sur blanc) --- */
.vp-skin #barre_cookies{ max-width:680px; }
.vp-skin #interieur_barre_cookies{ background:rgba(255,255,255,.97); border:1px solid var(--vp-line); border-radius:var(--vp-r); box-shadow:var(--vp-shadow-lg); padding:12px 14px; font-family:var(--vp-font-sans); backdrop-filter:saturate(180%) blur(10px); }
.vp-skin .barre_cookies_texte{ color:var(--vp-ink-soft) !important; font-size:.86rem; text-align:left; }
.vp-skin .barre_cookies_icone{ font-size:20px; }
.vp-skin .btn_accept_cookies{ background:var(--vp-surface); color:var(--vp-ink); width:32px; height:32px; line-height:30px; }
.vp-skin .btn_accept_cookies:hover{ background:var(--vp-surface-2); transform:scale(1.05); }
