/* =============================================================================
   Blog Wine Line — styles dédiés aux articles
   Chargés conditionnellement sur les single posts (voir functions.php).

   Réutilise les tokens et patterns du SKILL :
     - Couleurs : --wl-color-*
     - Typo : --wl-font-headings (Playfair) + --wl-font-body (Inter)
     - Sections : .wl-section, .wl-section--white, --ivory, --dark
     - Patterns : .wl-feature, .wl-section-header, .wl-eyebrow, etc.
   ============================================================================= */

/* =============================================================================
   1. RESET PARENT (Hello Elementor) — neutralise les styles génériques
   du parent qui peuvent s'appliquer dans nos zones blog/article.
   Scopé strictement à nos wrappers pour ne pas casser les autres pages.
   ============================================================================= */

/* Liens : le parent met du rose corail #c36, on hérite la couleur du contexte */
.wl-blog-page a,
.wl-blog-archive-main a,
.wl-article a,
.wl-article-main a,
.wl-related a,
.wl-blog-page a:active,
.wl-blog-page a:hover,
.wl-article a:active,
.wl-article a:hover {
	color: inherit;
}

/* Boutons natifs : neutralise les border #c36, hover bg #c36 du parent */
.wl-blog-page button,
.wl-blog-page [type="button"],
.wl-blog-page [type="submit"],
.wl-blog-archive-main button,
.wl-article button,
.wl-article-main button {
	background: transparent;
	border: 0;
	color: inherit;
	padding: 0;
	white-space: normal;
	transition: none;
}

.wl-blog-page button:hover,
.wl-blog-page button:focus,
.wl-blog-page [type="submit"]:hover,
.wl-blog-page [type="submit"]:focus,
.wl-article button:hover,
.wl-article button:focus {
	background: transparent;
	color: inherit;
	text-decoration: none;
}

/* Inputs : neutralise border #666 et padding par défaut */
.wl-blog-page input[type="search"],
.wl-blog-page input[type="text"],
.wl-blog-page input[type="number"],
.wl-blog-page input[type="email"],
.wl-blog-page input[type="tel"],
.wl-blog-page select,
.wl-blog-page textarea,
.wl-article input[type="search"],
.wl-article input[type="text"],
.wl-article input[type="number"],
.wl-article input[type="email"],
.wl-article select,
.wl-article textarea {
	border: 0;
	padding: 0;
	background: transparent;
	width: auto;
	transition: none;
}

/* Tables : neutralise striping/hover/borders/padding du parent */
.wl-article-body table tbody > tr:nth-child(odd) > td,
.wl-article-body table tbody > tr:nth-child(odd) > th,
.wl-article-body table tbody tr:hover > td,
.wl-article-body table tbody tr:hover > th,
.wl-article-content table tbody > tr:nth-child(odd) > td,
.wl-article-content table tbody > tr:nth-child(odd) > th,
.wl-article-content table tbody tr:hover > td,
.wl-article-content table tbody tr:hover > th {
	background: inherit;
}

.wl-article-body table td,
.wl-article-body table th,
.wl-article-content table td,
.wl-article-content table th {
	border: 0;  /* on définit nos propres borders plus bas */
	padding: 0;
	line-height: inherit;
}

.wl-article-body table,
.wl-article-content table {
	font-size: inherit;
	margin-block-end: 0;
}

/* Image post : neutralise le max-height 500px du parent qui crop les cards */
.wl-card .wp-post-image,
.wl-article-cover .wp-post-image {
	max-height: none;
	object-fit: cover;
}

/* Pagination native WP : neutralise .pagination du parent qui est en flex justify-between */
.wl-blog-page .pagination,
.wl-blog-archive-main .pagination {
	display: block;
	justify-content: initial;
	margin: 0;
}

/* =============================================================================
   2. STYLES BLOG WINE LINE
   ============================================================================= */

/* Anti-scroll horizontal global sur les pages article (cf. seo-content.css) */
html, body {
	overflow-x: clip;
}

/* Override la contrainte 1140px du thème parent Hello Elementor sur nos templates.
   La règle parent : @media (min-width: 1200px) { body:not(.elementor-page-) .site-main { max-width: 1140px } }
   Ici on libère pour que nos hero / fullbleed s'étendent correctement. */
body .site-main.wl-blog-page,
body .site-main.wl-blog-archive-main,
body .site-main.wl-article-main,
body .site-main.wl-article {
	max-width: none !important;
	padding: 0 !important;
}

.wl-article {
	max-width: 100%;
	margin: 0;
	padding: 0;
	line-height: 1.7;
	color: var(--wl-color-text);
	overflow-x: clip;
}

/* -----------------------------------------------------------------------------
   Hero article (header)
   ----------------------------------------------------------------------------- */
.wl-article-hero {
	max-width: 820px;
	margin: 0 auto;
	padding: 3rem 1.5rem 2rem;
	text-align: center;
}

.wl-article-hero .wl-eyebrow {
	margin-bottom: 1rem;
	color: var(--wl-color-secondary-dk);
}

.wl-article-hero h1,
.wl-article h1.wl-article-title {
	font-family: var(--wl-font-headings) !important;
	font-size: clamp(2rem, 4.5vw, 3.4rem) !important;
	font-weight: 500 !important;
	line-height: 1.1 !important;
	letter-spacing: -0.02em !important;
	color: var(--wl-color-primary) !important;
	margin: 0 0 1.5rem !important;
}

.wl-article-hero h1 em,
.wl-article-title em {
	font-style: italic;
	color: var(--wl-color-secondary-dk);
}

.wl-article-meta {
	font-size: 0.85rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--wl-color-text);
	opacity: 0.6;
}

.wl-article-meta span {
	margin: 0 0.5rem;
}

/* -----------------------------------------------------------------------------
   Lead (intro paragraph after hero)
   ----------------------------------------------------------------------------- */
.wl-article-lead {
	max-width: 720px;
	margin: 0 auto 3rem;
	padding: 0 1.5rem;
	font-size: 1.15rem;
	line-height: 1.65;
	color: var(--wl-color-text);
	font-weight: 300;
}

/* -----------------------------------------------------------------------------
   Wrapper du corps de l'article
   ----------------------------------------------------------------------------- */
.wl-article-body {
	max-width: 760px;
	margin: 0 auto;
	padding: 0 1.5rem;
}

.wl-article-body h2 {
	font-family: var(--wl-font-headings) !important;
	font-size: clamp(1.6rem, 3vw, 2.2rem) !important;
	font-weight: 500 !important;
	line-height: 1.2 !important;
	letter-spacing: -0.01em !important;
	color: var(--wl-color-primary) !important;
	margin: 3.5rem 0 1.25rem !important;
}

.wl-article-body h2 em {
	font-style: italic;
	color: var(--wl-color-secondary-dk);
}

.wl-article-body h3 {
	font-family: var(--wl-font-body) !important;
	font-size: 1.25rem !important;
	font-weight: 600 !important;
	line-height: 1.35 !important;
	color: var(--wl-color-primary) !important;
	margin: 2rem 0 0.75rem !important;
}

.wl-article-body h4 {
	font-family: var(--wl-font-body) !important;
	font-size: 1.05rem !important;
	font-weight: 600 !important;
	margin: 1.5rem 0 0.5rem !important;
	color: var(--wl-color-primary) !important;
}

.wl-article-body p {
	margin: 0 0 1.25rem;
	font-size: 1.05rem;
	line-height: 1.75;
}

.wl-article-body strong {
	color: var(--wl-color-primary);
	font-weight: 600;
}

.wl-article-body em {
	font-style: italic;
}

.wl-article-body ul,
.wl-article-body ol {
	margin: 0 0 1.5rem;
	padding-left: 1.5rem;
}

.wl-article-body li {
	margin-bottom: 0.5rem;
	line-height: 1.65;
}

.wl-article-body ul li::marker {
	color: var(--wl-color-secondary-dk);
}

.wl-article-body a {
	color: var(--wl-color-primary);
	text-decoration: none;
	border-bottom: 1px solid var(--wl-color-secondary);
	padding-bottom: 1px;
	transition: border-color 0.2s ease, color 0.2s ease;
}

.wl-article-body a:hover {
	color: var(--wl-color-secondary-dk);
	border-bottom-color: var(--wl-color-secondary-dk);
}

/* -----------------------------------------------------------------------------
   Tableaux
   ----------------------------------------------------------------------------- */
.wl-article-body table {
	width: 100%;
	border-collapse: collapse;
	margin: 2rem 0;
	font-size: 0.95rem;
	background: var(--wl-color-white);
	box-shadow: var(--wl-shadow-md);
	border-radius: var(--wl-radius-md);
	overflow: hidden;
}

.wl-article-body thead th {
	background: var(--wl-color-primary);
	color: var(--wl-color-white);
	font-family: var(--wl-font-headings);
	font-weight: 500;
	text-align: left;
	padding: 0.85rem 1rem;
	border: 0;
}

.wl-article-body tbody th,
.wl-article-body tbody td {
	padding: 0.75rem 1rem;
	border-bottom: 1px solid var(--wl-color-border);
	text-align: left;
	vertical-align: top;
}

.wl-article-body tbody tr:last-child th,
.wl-article-body tbody tr:last-child td {
	border-bottom: 0;
}

.wl-article-body tbody tr:nth-child(even) {
	background: var(--wl-color-bg-soft);
}

.wl-article-body tbody th {
	font-weight: 500;
	color: var(--wl-color-primary);
}

@media (max-width: 600px) {
	.wl-article-body table { font-size: 0.85rem; }
	.wl-article-body th,
	.wl-article-body td { padding: 0.55rem 0.65rem; }
}

/* -----------------------------------------------------------------------------
   Image placeholders et figures
   ----------------------------------------------------------------------------- */
.wl-article-body figure {
	margin: 2rem 0;
}

.wl-article-body figure img {
	display: block;
	width: 100%;
	height: auto;
	border-radius: var(--wl-radius-md);
	box-shadow: var(--wl-shadow-md);
}

.wl-article-body figcaption {
	margin-top: 0.75rem;
	font-size: 0.85rem;
	color: var(--wl-color-text);
	opacity: 0.7;
	font-style: italic;
	text-align: center;
}

.wl-image-placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 2.5rem 0;
	padding: 2.5rem 2rem;
	min-height: 220px;
	background: var(--wl-color-bg-soft);
	border: 1px dashed var(--wl-color-border);
	border-radius: var(--wl-radius-md);
	text-align: center;
}

.wl-image-placeholder p {
	margin: 0 !important;
	font-size: 0.9rem !important;
	color: var(--wl-color-text);
	opacity: 0.7;
	font-style: italic;
	max-width: 480px;
}

/* -----------------------------------------------------------------------------
   Callouts / encarts (conseil, à retenir, attention)
   ----------------------------------------------------------------------------- */
.wl-callout {
	margin: 2rem 0;
	padding: 1.5rem 1.75rem;
	background: var(--wl-color-bg-soft);
	border-left: 3px solid var(--wl-color-secondary);
	border-radius: 0 var(--wl-radius-md) var(--wl-radius-md) 0;
}

.wl-callout p:last-child {
	margin-bottom: 0 !important;
}

.wl-callout-title {
	display: block;
	font-family: var(--wl-font-body);
	font-size: 0.8rem;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--wl-color-secondary-dk);
	margin-bottom: 0.5rem;
}

.wl-callout--warning {
	border-left-color: #b35a00;
	background: #fdf4ec;
}

.wl-callout--warning .wl-callout-title {
	color: #8a4400;
}

/* -----------------------------------------------------------------------------
   Calculator interactif (article 2)
   ----------------------------------------------------------------------------- */
.wl-calculator {
	margin: 2.5rem 0;
	padding: 2rem;
	background: var(--wl-color-primary);
	color: var(--wl-color-white);
	border-radius: var(--wl-radius-lg);
	box-shadow: var(--wl-shadow-md);
}

.wl-calculator-title {
	display: block;
	font-family: var(--wl-font-headings);
	font-size: 1.5rem;
	font-weight: 500;
	margin-bottom: 0.5rem;
	color: var(--wl-color-white);
}

.wl-calculator-subtitle {
	display: block;
	font-size: 0.9rem;
	opacity: 0.75;
	margin-bottom: 1.5rem;
}

.wl-calculator-form {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1rem;
	margin-bottom: 1.5rem;
}

.wl-calculator-field {
	display: flex;
	flex-direction: column;
	gap: 0.4rem;
}

.wl-calculator-field label {
	font-size: 0.78rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	font-weight: 500;
	color: rgba(255, 255, 255, 0.85);
}

.wl-calculator-field input,
.wl-calculator-field select {
	padding: 0.7rem 0.9rem;
	font-family: inherit;
	font-size: 1rem;
	color: var(--wl-color-primary);
	background: var(--wl-color-white);
	border: 0;
	border-radius: var(--wl-radius-sm);
	appearance: none;
	-webkit-appearance: none;
}

.wl-calculator-field select {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23101010' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 0.85rem center;
	background-size: 1rem;
	padding-right: 2.25rem;
}

.wl-calculator-result {
	display: grid;
	grid-template-columns: 1fr;
	gap: 0.5rem;
	padding: 1.25rem 1.5rem;
	background: rgba(255, 255, 255, 0.06);
	border-radius: var(--wl-radius-md);
	border: 1px solid rgba(194, 178, 128, 0.25);
}

.wl-calculator-result-label {
	font-size: 0.8rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--wl-color-secondary);
	margin: 0;
}

.wl-calculator-result-value {
	font-family: var(--wl-font-headings);
	font-size: 2rem;
	font-weight: 500;
	margin: 0;
	color: var(--wl-color-white);
	line-height: 1.1;
}

.wl-calculator-result-detail {
	font-size: 0.9rem;
	opacity: 0.75;
	margin: 0;
}

@media (max-width: 600px) {
	.wl-calculator-form {
		grid-template-columns: 1fr;
	}
	.wl-calculator-result-value {
		font-size: 1.6rem;
	}
}

/* -----------------------------------------------------------------------------
   Bloc CTA produit (mid-article et fin d'article)
   ----------------------------------------------------------------------------- */
.wl-article-cta {
	margin: 3rem 0;
	padding: 2rem;
	background: var(--wl-color-bg-soft);
	border-radius: var(--wl-radius-lg);
	text-align: center;
	border: 1px solid var(--wl-color-border);
}

.wl-article-cta .wl-eyebrow {
	display: block;
	margin-bottom: 0.75rem;
}

.wl-article-cta-title {
	font-family: var(--wl-font-headings);
	font-size: 1.5rem;
	font-weight: 500;
	margin: 0 0 1rem;
	color: var(--wl-color-primary);
	line-height: 1.25;
}

.wl-article-cta-title em {
	font-style: italic;
	color: var(--wl-color-secondary-dk);
}

.wl-article-cta p {
	max-width: 540px;
	margin: 0 auto 1.5rem !important;
	font-size: 1rem;
}

.wl-article-cta-btn {
	display: inline-block;
	padding: 0.85rem 1.75rem;
	background: var(--wl-color-primary);
	color: var(--wl-color-white) !important;
	text-decoration: none !important;
	font-size: 0.85rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	font-weight: 500;
	border: 0 !important;
	border-bottom: 0 !important;
	border-radius: var(--wl-radius-sm);
	transition: background 0.2s ease, transform 0.2s ease;
}

.wl-article-cta-btn:hover {
	background: var(--wl-color-secondary-dk) !important;
	color: var(--wl-color-white) !important;
	transform: translateY(-1px);
}

/* -----------------------------------------------------------------------------
   Checklist en résumé
   ----------------------------------------------------------------------------- */
.wl-checklist {
	list-style: none !important;
	padding-left: 0 !important;
	margin: 1.5rem 0 !important;
}

.wl-checklist li {
	position: relative;
	padding-left: 2rem;
	margin-bottom: 0.65rem;
	line-height: 1.6;
}

.wl-checklist li::before {
	content: "✓";
	position: absolute;
	left: 0;
	top: 0;
	width: 1.4rem;
	height: 1.4rem;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--wl-color-secondary-dk);
	font-weight: 700;
}

/* -----------------------------------------------------------------------------
   Citation / pull-quote
   ----------------------------------------------------------------------------- */
.wl-article-body blockquote {
	margin: 2.5rem 0;
	padding: 1.5rem 2rem;
	border-left: 3px solid var(--wl-color-secondary);
	background: var(--wl-color-bg-soft);
	font-family: var(--wl-font-headings);
	font-size: 1.2rem;
	font-style: italic;
	line-height: 1.4;
	color: var(--wl-color-primary);
}

.wl-article-body blockquote p:last-child {
	margin-bottom: 0;
}

/* =============================================================================
   ARCHIVE BLOG — hero, hubs triptyque, séparateur
   Utilisé par [wineline_blog_above] / [wineline_blog_below]
   ============================================================================= */

.wl-blog-archive,
.wl-blog-archive-below {
	max-width: 100%;
	margin: 0;
	padding: 0;
}

/* Hero archive */
.wl-blog-archive-hero {
	max-width: 820px;
	margin: 0 auto;
	padding: 4rem 1.5rem 2rem;
	text-align: center;
}

.wl-blog-archive-hero .wl-eyebrow {
	margin-bottom: 1rem;
	color: var(--wl-color-secondary-dk);
}

.wl-blog-archive-title {
	font-family: var(--wl-font-headings) !important;
	font-size: clamp(2rem, 4.5vw, 3.4rem) !important;
	font-weight: 500 !important;
	line-height: 1.1 !important;
	letter-spacing: -0.02em !important;
	color: var(--wl-color-primary) !important;
	margin: 0 0 1.5rem !important;
}

.wl-blog-archive-title em {
	font-style: italic;
	color: var(--wl-color-secondary-dk);
}

.wl-blog-archive-lead {
	max-width: 640px;
	margin: 0 auto !important;
	font-size: 1.1rem;
	line-height: 1.65;
	color: var(--wl-color-text);
	opacity: 0.9;
	font-weight: 300;
}

/* -----------------------------------------------------------------------------
   Triptyque dynamique des hubs (s'adapte au nombre de catégories WP)
   ----------------------------------------------------------------------------- */
.wl-blog-hubs {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 2rem;
	max-width: 1100px;
	margin: 4rem auto;
	padding: 0 1.5rem;
}

/* Affinage par nombre de cards : on plafonne pour éviter les cards trop larges
   quand il n'y a que 1 ou 2 catégories */
.wl-blog-hubs--count-1 { grid-template-columns: minmax(280px, 480px); justify-content: center; }
.wl-blog-hubs--count-2 { grid-template-columns: repeat(2, minmax(280px, 1fr)); max-width: 820px; }
.wl-blog-hubs--count-3 { grid-template-columns: repeat(3, 1fr); }
.wl-blog-hubs--count-4 { grid-template-columns: repeat(4, 1fr); }
.wl-blog-hubs--count-5,
.wl-blog-hubs--count-6 { grid-template-columns: repeat(3, 1fr); }

.wl-blog-hub {
	display: block;
	padding: 2rem;
	background: var(--wl-color-bg-soft);
	border: 1px solid var(--wl-color-border);
	border-radius: var(--wl-radius-lg);
	text-decoration: none !important;
	color: var(--wl-color-primary) !important;
	transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}

.wl-blog-hub:hover {
	transform: translateY(-3px);
	box-shadow: var(--wl-shadow-md);
	border-color: var(--wl-color-secondary);
}

.wl-blog-hub-num {
	display: block;
	font-family: var(--wl-font-headings);
	font-size: 1rem;
	font-style: italic;
	color: var(--wl-color-secondary-dk);
	letter-spacing: 0.05em;
	margin-bottom: 0.5rem;
}

.wl-blog-hub h3 {
	font-family: var(--wl-font-headings) !important;
	font-size: 1.4rem !important;
	font-weight: 500 !important;
	margin: 0 0 0.75rem !important;
	color: var(--wl-color-primary) !important;
	letter-spacing: -0.005em;
}

.wl-blog-hub p {
	margin: 0 0 1.25rem !important;
	color: var(--wl-color-text);
	font-size: 0.95rem;
	line-height: 1.55;
}

.wl-blog-hub-link {
	display: inline-block;
	font-size: 0.8rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	font-weight: 500;
	color: var(--wl-color-secondary-dk);
	border-bottom: 1px solid var(--wl-color-secondary-dk);
	padding-bottom: 2px;
}

/* Variante compacte (en bas d'archive cat/tag) */
.wl-blog-hubs--compact {
	max-width: 1100px;
	margin: 3rem auto 2rem;
	padding: 0 1.5rem;
}

.wl-blog-hubs-title {
	font-family: var(--wl-font-headings);
	font-size: 1.5rem;
	font-weight: 500;
	margin: 0 0 1.5rem !important;
	color: var(--wl-color-primary);
	text-align: center;
}

.wl-blog-hubs-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 1.5rem;
}

.wl-blog-hubs--compact.wl-blog-hubs--count-1 .wl-blog-hubs-grid { grid-template-columns: minmax(280px, 460px); justify-content: center; }
.wl-blog-hubs--compact.wl-blog-hubs--count-2 .wl-blog-hubs-grid { grid-template-columns: repeat(2, minmax(260px, 1fr)); }
.wl-blog-hubs--compact.wl-blog-hubs--count-3 .wl-blog-hubs-grid { grid-template-columns: repeat(3, 1fr); }
.wl-blog-hubs--compact.wl-blog-hubs--count-4 .wl-blog-hubs-grid { grid-template-columns: repeat(4, 1fr); }

.wl-blog-hubs--compact .wl-blog-hub {
	padding: 1.5rem;
}

.wl-blog-hubs--compact .wl-blog-hub h3 {
	font-size: 1.2rem !important;
}

@media (max-width: 768px) {
	.wl-blog-hubs,
	.wl-blog-hubs-grid {
		grid-template-columns: 1fr;
		gap: 1.25rem;
	}
}

/* -----------------------------------------------------------------------------
   Séparateur "Tous les articles"
   ----------------------------------------------------------------------------- */
.wl-blog-archive-divider {
	max-width: 1100px;
	margin: 3rem auto 2rem;
	padding: 0 1.5rem;
	text-align: center;
	position: relative;
}

.wl-blog-archive-divider::before {
	content: "";
	position: absolute;
	top: 50%;
	left: 1.5rem;
	right: 1.5rem;
	height: 1px;
	background: var(--wl-color-border);
}

.wl-blog-archive-divider-label {
	display: inline-block;
	position: relative;
	background: var(--wl-color-white);
	padding: 0 1.5rem;
	font-size: 0.8rem;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: var(--wl-color-secondary-dk);
	font-weight: 500;
}

/* =============================================================================
   ARCHIVE BLOG — boucle d'articles (cards) + pagination
   Utilisé par archive.php / home.php
   ============================================================================= */

.wl-blog-archive-main {
	background: var(--wl-color-white);
}

.wl-blog-loop {
	padding: 0 0 4rem;
}

.wl-blog-loop-inner {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 1.5rem;
}

/* Grid de cards */
.wl-cards-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 2.5rem 2rem;
	margin: 0 0 3rem;
}

@media (max-width: 1024px) {
	.wl-cards-grid { grid-template-columns: repeat(2, 1fr); gap: 2rem 1.5rem; }
}

@media (max-width: 600px) {
	.wl-cards-grid { grid-template-columns: 1fr; gap: 2rem; }
}

/* Card */
.wl-card {
	background: transparent;
}

.wl-card-link {
	display: block;
	text-decoration: none !important;
	color: inherit !important;
	border: 0 !important;
}

.wl-card-media {
	overflow: hidden;
	border-radius: var(--wl-radius-md);
	margin-bottom: 1.25rem;
	aspect-ratio: 4 / 3;
	background: var(--wl-color-bg-soft);
}

.wl-card-image,
.wl-card-media img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.6s ease;
}

.wl-card-link:hover .wl-card-image {
	transform: scale(1.04);
}

/* Placeholder visuel quand pas de featured image */
.wl-card-image-placeholder {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--wl-color-bg-soft);
	font-family: var(--wl-font-headings);
	font-style: italic;
	font-size: 1.1rem;
	color: var(--wl-color-secondary-dk);
	letter-spacing: 0.05em;
}

.wl-card-body {
	padding: 0;
}

.wl-card-eyebrow {
	display: block;
	font-size: 0.7rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--wl-color-secondary-dk);
	font-weight: 500;
	margin-bottom: 0.5rem;
}

.wl-card-title {
	font-family: var(--wl-font-headings) !important;
	font-size: 1.4rem !important;
	font-weight: 500 !important;
	line-height: 1.2 !important;
	letter-spacing: -0.005em !important;
	color: var(--wl-color-primary) !important;
	margin: 0 0 0.75rem !important;
	transition: color 0.2s ease;
}

.wl-card-link:hover .wl-card-title {
	color: var(--wl-color-secondary-dk) !important;
}

.wl-card-excerpt {
	font-size: 0.95rem;
	line-height: 1.6;
	color: var(--wl-color-text);
	opacity: 0.85;
	margin: 0 0 1rem !important;
}

.wl-card-cta {
	display: inline-block;
	font-size: 0.78rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	font-weight: 500;
	color: var(--wl-color-secondary-dk);
	border-bottom: 1px solid var(--wl-color-secondary);
	padding-bottom: 1px;
	transition: border-color 0.2s ease;
}

.wl-card-link:hover .wl-card-cta {
	border-bottom-color: var(--wl-color-secondary-dk);
}

/* -----------------------------------------------------------------------------
   Pagination
   ----------------------------------------------------------------------------- */
.wl-pagination {
	margin-top: 3rem;
	text-align: center;
}

.wl-pagination-list {
	list-style: none !important;
	margin: 0 !important;
	padding: 0 !important;
	display: inline-flex;
	gap: 0.5rem;
	flex-wrap: wrap;
	justify-content: center;
}

.wl-pagination-list li { margin: 0 !important; }

.wl-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 40px;
	padding: 0 0.85rem;
	font-size: 0.9rem;
	font-weight: 500;
	color: var(--wl-color-primary);
	text-decoration: none !important;
	border: 1px solid var(--wl-color-border);
	border-radius: var(--wl-radius-sm);
	background: var(--wl-color-white);
	transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.wl-pagination .page-numbers:hover,
.wl-pagination .page-numbers:focus {
	border-color: var(--wl-color-secondary);
	color: var(--wl-color-secondary-dk);
}

.wl-pagination .page-numbers.current {
	background: var(--wl-color-primary);
	color: var(--wl-color-white);
	border-color: var(--wl-color-primary);
}

.wl-pagination .page-numbers.dots {
	border: 0;
	background: transparent;
}

/* -----------------------------------------------------------------------------
   État vide (no posts found)
   ----------------------------------------------------------------------------- */
.wl-blog-empty {
	text-align: center;
	max-width: 480px;
	margin: 4rem auto;
	padding: 2.5rem 1.5rem;
}

.wl-blog-empty .wl-eyebrow {
	display: block;
	margin-bottom: 1rem;
}

.wl-blog-empty p {
	margin: 0 0 1.5rem;
	font-size: 1.05rem;
	color: var(--wl-color-text);
	opacity: 0.8;
}

/* =============================================================================
   PAGE BLOG — barre de filtres (search + pills catégories)
   ============================================================================= */

.wl-blog-filter-bar {
	background: var(--wl-color-bg-soft);
	border-top: 1px solid var(--wl-color-border);
	border-bottom: 1px solid var(--wl-color-border);
	padding: 1.5rem 1.5rem;
	margin: 2rem 0 3rem;
}

.wl-blog-filter-inner {
	max-width: 1200px;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	gap: 1.5rem;
	align-items: center;
	justify-content: space-between;
}

/* Search form */
.wl-blog-search {
	position: relative;
	flex: 1;
	min-width: 240px;
	max-width: 360px;
	display: flex;
	align-items: center;
	background: var(--wl-color-white);
	border: 1px solid var(--wl-color-border);
	border-radius: var(--wl-radius-sm);
	transition: border-color 0.2s ease;
}

.wl-blog-search:focus-within {
	border-color: var(--wl-color-secondary);
}

.wl-blog-search input[type="search"] {
	flex: 1;
	padding: 0.7rem 0.9rem;
	font-family: inherit;
	font-size: 0.95rem;
	color: var(--wl-color-primary);
	background: transparent;
	border: 0;
	outline: none;
	min-width: 0;
}

.wl-blog-search input[type="search"]::placeholder {
	color: var(--wl-color-text);
	opacity: 0.5;
}

.wl-blog-search-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 42px;
	height: 100%;
	background: transparent;
	border: 0;
	color: var(--wl-color-secondary-dk);
	cursor: pointer;
	transition: color 0.2s ease;
}

.wl-blog-search-btn:hover { color: var(--wl-color-primary); }

/* Pills catégories */
.wl-blog-filter-pills {
	list-style: none !important;
	margin: 0 !important;
	padding: 0 !important;
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}

.wl-blog-filter-pills li { margin: 0 !important; }

.wl-pill {
	display: inline-block;
	padding: 0.5rem 1rem;
	font-size: 0.85rem;
	font-weight: 500;
	letter-spacing: 0.02em;
	color: var(--wl-color-primary) !important;
	background: var(--wl-color-white);
	border: 1px solid var(--wl-color-border);
	border-radius: 999px;
	text-decoration: none !important;
	border-bottom: 1px solid var(--wl-color-border) !important;
	transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.wl-pill:hover {
	background: var(--wl-color-bg-soft);
	border-color: var(--wl-color-secondary) !important;
	color: var(--wl-color-secondary-dk) !important;
}

.wl-pill.is-active {
	background: var(--wl-color-primary);
	color: var(--wl-color-white) !important;
	border-color: var(--wl-color-primary) !important;
}

@media (max-width: 768px) {
	.wl-blog-filter-inner { flex-direction: column; align-items: stretch; gap: 1rem; }
	.wl-blog-search { max-width: 100%; }
	.wl-blog-filter-pills { justify-content: flex-start; }
}

/* Loading state lors du fetch Ajax */
.wl-blog-loop.is-loading .wl-blog-loop-inner {
	opacity: 0.5;
	pointer-events: none;
	transition: opacity 0.2s ease;
}

/* =============================================================================
   SINGLE ARTICLE — cover, share, related
   ============================================================================= */

/* Cover image */
.wl-article-cover {
	max-width: 1100px;
	margin: 0 auto 3rem;
	padding: 0 1.5rem;
}

.wl-article-cover img {
	display: block;
	width: 100%;
	height: auto;
	max-height: 560px;
	object-fit: cover;
	border-radius: var(--wl-radius-lg);
	box-shadow: var(--wl-shadow-md);
}

/* Wrapper du contenu rendu par the_content() */
.wl-article-content {
	max-width: 760px;
	margin: 0 auto;
	padding: 0 1.5rem;
}

/* the_content() peut générer des <p> wrapper, on s'assure qu'ils héritent du style article */
.wl-article-content > .wl-article-body {
	max-width: 100%;
	margin: 0;
	padding: 0;
}

/* -----------------------------------------------------------------------------
   Share buttons (en bas de l'article)
   ----------------------------------------------------------------------------- */
.wl-share {
	max-width: 760px;
	margin: 3rem auto 1rem;
	padding: 0 1.5rem;
}

.wl-share-inner {
	display: flex;
	align-items: center;
	gap: 1rem;
	padding: 1.25rem 0;
	border-top: 1px solid var(--wl-color-border);
	border-bottom: 1px solid var(--wl-color-border);
}

.wl-share-label {
	font-size: 0.78rem;
	font-weight: 500;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: var(--wl-color-secondary-dk);
}

.wl-share-list {
	list-style: none !important;
	margin: 0 !important;
	padding: 0 !important;
	display: flex;
	gap: 0.5rem;
	flex-wrap: wrap;
}

.wl-share-list li { margin: 0 !important; }

.wl-share-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 38px;
	height: 38px;
	background: var(--wl-color-bg-soft);
	color: var(--wl-color-primary) !important;
	text-decoration: none !important;
	border: 1px solid var(--wl-color-border);
	border-radius: 50%;
	cursor: pointer;
	transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease, transform 0.15s ease;
}

.wl-share-link:hover {
	background: var(--wl-color-primary);
	color: var(--wl-color-white) !important;
	border-color: var(--wl-color-primary);
	transform: translateY(-2px);
}

.wl-share-copy.is-copied {
	background: var(--wl-color-secondary-dk);
	color: var(--wl-color-white) !important;
	border-color: var(--wl-color-secondary-dk);
}

.wl-share-copy.is-copied::after {
	content: "Copié";
	margin-left: 0.5rem;
	font-size: 0.75rem;
	font-weight: 500;
}

/* -----------------------------------------------------------------------------
   Related articles
   ----------------------------------------------------------------------------- */
.wl-related {
	background: var(--wl-color-bg-soft);
	padding: 4rem 0 3rem;
	margin: 4rem 0 0;
}

.wl-related-inner {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 1.5rem;
}

.wl-related-header {
	text-align: center;
	margin-bottom: 3rem;
}

.wl-related-header .wl-eyebrow {
	display: block;
	margin-bottom: 0.75rem;
}

.wl-related-title {
	font-family: var(--wl-font-headings) !important;
	font-size: clamp(1.75rem, 3vw, 2.4rem) !important;
	font-weight: 500 !important;
	margin: 0 !important;
	color: var(--wl-color-primary) !important;
	letter-spacing: -0.01em;
}

.wl-related-title em {
	font-style: italic;
	color: var(--wl-color-secondary-dk);
}

/* -----------------------------------------------------------------------------
   Mention légale (fin d'article alcool)
   ----------------------------------------------------------------------------- */
.wl-article-legal {
	margin: 3rem auto 2rem;
	padding: 1rem 1.5rem;
	max-width: 760px;
	font-size: 0.85rem;
	font-style: italic;
	text-align: center;
	color: var(--wl-color-text);
	opacity: 0.6;
	border-top: 1px solid var(--wl-color-border);
	padding-top: 1.5rem;
}
