/* ============================================================
   AGRILEADER — LeoBlog CSS
   Harmonisé avec theme.css — ne pas redéfinir les variables
   déjà déclarées dans theme.css (:root global)

   Variables héritées de theme.css (ne pas redéclarer) :
     --al-green        #0C8E44
     --al-green-dark   #076b32
     --al-green-light  #e6f5ed
     --al-green-mid    #c8ecd8
     --al-text         #1a2e1a
     --al-muted        #4a6b52
     --al-subtle       #7a9a7e
     --al-border       #daeade
     --al-bg           #f7fbf8
     --al-white        #ffffff
     --al-hover-bg     #edf7f1
     --al-accent       #076b32
     --al-font         'Poppins', system-ui, sans-serif
     --al-ease         cubic-bezier(.25, .46, .45, .94)

   Variables blog-spécifiques (ajoutées ici uniquement) :
     --al-black / --al-dark / --al-radius / --al-shadow...
   ============================================================ */

:root {
  /* Noirs & fonds sombres (héros, badges) — absents de theme.css */
  --al-black:        #111111;
  --al-dark:         #152211;          /* noir teinté vert Agrileader */
  --al-dark-2:       #1f3019;

  /* Rayon et ombres */
  --al-radius:       10px;
  --al-radius-sm:    6px;
  --al-shadow:       0 2px 10px rgba(0, 0, 0, .07);
  --al-shadow-hover: 0 10px 30px rgba(0, 0, 0, .14);

  /* Transition courte — réutilise l'easing de theme.css */
  --al-t:            .22s var(--al-ease);

  /* Glow focus inputs — basé sur le vert réel du thème */
  --al-green-glow:   rgba(12, 142, 68, .20);
}


/* ============================================================
   SÉPARATION SIDEBAR / CONTENU
   #left-column / #right-column — structure PrestaShop 9
   ============================================================ */
#left-column,
#right-column {
  background: var(--al-bg);
  border-radius: var(--al-radius);
  padding: 20px 16px;
  font-family: var(--al-font);
}

#left-column {
  position: relative;
}
#left-column::after {
  content: '';
  position: absolute;
  top: 16px; right: -1px; bottom: 16px;
  width: 2px;
  background: linear-gradient(
    to bottom,
    var(--al-green)  0%,
    var(--al-black)  40%,
    var(--al-border) 100%
  );
  border-radius: 2px;
  pointer-events: none;
  z-index: 1;
}
#right-column {
  position: relative;
}
#right-column::before {
  content: '';
  position: absolute;
  top: 16px; left: -1px; bottom: 16px;
  width: 2px;
  background: linear-gradient(
    to bottom,
    var(--al-green)  0%,
    var(--al-black)  40%,
    var(--al-border) 100%
  );
  border-radius: 2px;
  pointer-events: none;
  z-index: 1;
}

#content-wrapper.left-column  { padding-left:  28px; }
#content-wrapper.right-column { padding-right: 28px; }

/* Blocs widgets sidebar */
#left-column  .block,
#right-column .block,
#left-column  .card,
#right-column .card,
#left-column  [class*="leo"],
#right-column [class*="leo"],
#left-column  #search-blog,
#right-column #search-blog {
  background: var(--al-white);
  border: 1px solid var(--al-border);
  border-radius: var(--al-radius);
  padding: 18px 16px;
  margin-bottom: 20px;
  box-shadow: var(--al-shadow);
}

/* Titres de blocs sidebar */
#left-column  .block-title,
#right-column .block-title,
#left-column  .title_block,
#right-column .title_block {
  font-size: 12px !important;
  font-weight: 700 !important;
  font-family: var(--al-font);
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--al-black) !important;
  margin: 0 0 14px !important;
  padding-bottom: 10px;
  border-bottom: 2px solid var(--al-black);
  position: relative;
}
#left-column  .block-title::after,
#right-column .block-title::after,
#left-column  .title_block::after,
#right-column .title_block::after {
  content: '';
  position: absolute;
  bottom: -2px; left: 0;
  width: 32px; height: 2px;
  background: var(--al-green);
}

#left-column  a,
#right-column a {
  color: var(--al-text);
  text-decoration: none;
  transition: color var(--al-t);
}
#left-column  a:hover,
#right-column a:hover { color: var(--al-green); }

@media (max-width: 991px) {
  #left-column::after,
  #right-column::before { display: none; }
  #left-column,
  #right-column {
    background: transparent;
    border-radius: 0;
    padding: 24px 0 0;
    border-top: 2px solid var(--al-border);
    margin-top: 32px;
  }
  #content-wrapper.left-column,
  #content-wrapper.right-column { padding-left: 15px; padding-right: 15px; }
}


/* ============================================================
   EN-TÊTE DE PAGE BLOG
   ============================================================ */
.blog-page-header {
  margin-bottom: 28px;
  padding: 24px 28px;
  background: var(--al-dark);
  border-radius: var(--al-radius);
  position: relative;
  overflow: hidden;
  font-family: var(--al-font);
}
.blog-page-header::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 4px; height: 100%;
  background: var(--al-green);
}
.blog-page-header::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, var(--al-green) 0%, transparent 60%);
}
.blog-page-header-inner { padding-left: 12px; }
.blog-page-header-label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--al-green);
  margin-bottom: 6px;
}
.blog-page-title {
  font-size: clamp(20px, 3vw, 28px);
  font-weight: 900;
  color: var(--al-white) !important;
  margin: 0;
  letter-spacing: -.01em;
  line-height: 1.2;
}
.blog-rss-link {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  margin-top: 10px;
  font-size: 12px;
  font-weight: 600;
  color: #f8991d !important;
  text-decoration: none;
  opacity: .85;
  transition: opacity var(--al-t);
}
.blog-rss-link:hover { opacity: 1; }


/* ============================================================
   GRILLE ARTICLES
   ============================================================ */
.blog-grid > [class*="col-"] { display: flex; }
.blog-grid > [class*="col-"] .blog-item { width: 100%; }

.blog-section-divider {
  height: 1px;
  background: linear-gradient(90deg, var(--al-green) 0%, var(--al-border) 60%, transparent 100%);
  margin: 8px 0 24px;
}
.blog-pagination {
  margin-top: 32px;
  padding-top: 24px;
  border-top: 1px solid var(--al-border);
}
.blog-detail .page-item,
.blogs-container .page-item { display: inline-block; }

.blog-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 14px;
  padding: 60px 20px;
  color: var(--al-muted);
  text-align: center;
  background: var(--al-bg);
  border-radius: var(--al-radius);
  border: 1px dashed var(--al-border);
}
.blog-empty svg { opacity: .35; }
.blog-empty p { font-size: 15px; margin: 0; }


/* ============================================================
   INFO CATÉGORIE
   ============================================================ */
.blog-category-info { margin-bottom: 28px; }
.blog-category-info-inner {
  background: var(--al-bg);
  border-radius: var(--al-radius);
  padding: 24px;
  border-left: 4px solid var(--al-green);
  font-size: 15px;
  line-height: 1.7;
  color: var(--al-text);
}
.blog-category-info--with-image {
  display: flex;
  gap: 24px;
  align-items: flex-start;
  padding: 0;
  border-left: none;
  background: transparent;
}
.blog-category-image {
  flex: 0 0 260px;
  border-radius: var(--al-radius);
  overflow: hidden;
  background: var(--al-dark);
}
.blog-category-image img { width: 100%; height: auto; display: block; }
.blog-category-text {
  flex: 1;
  background: var(--al-bg);
  border-radius: var(--al-radius);
  padding: 24px;
  border-left: 4px solid var(--al-green);
  font-size: 15px;
  line-height: 1.7;
}
@media (max-width: 767px) {
  .blog-category-info--with-image { flex-direction: column; }
  .blog-category-image { flex: none; width: 100%; }
}


/* ============================================================
   SOUS-CATÉGORIES
   ============================================================ */
.blog-subcategories { margin-bottom: 36px; }
.blog-subcategories-title {
  font-size: 13px;
  font-weight: 700;
  font-family: var(--al-font);
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--al-muted);
  margin-bottom: 16px;
  padding-bottom: 10px;
  border-bottom: 2px solid var(--al-border);
}
.blog-subcat-card {
  background: var(--al-white);
  border: 1px solid var(--al-border);
  border-radius: var(--al-radius);
  overflow: hidden;
  margin-bottom: 20px;
  box-shadow: var(--al-shadow);
  transition: box-shadow var(--al-t), transform var(--al-t);
}
.blog-subcat-card:hover {
  box-shadow: var(--al-shadow-hover);
  transform: translateY(-3px);
}
.blog-subcat-image { aspect-ratio: 16/9; overflow: hidden; background: var(--al-dark); }
.blog-subcat-image img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s var(--al-ease); }
.blog-subcat-card:hover .blog-subcat-image img { transform: scale(1.05); }
.blog-subcat-body { padding: 14px 16px; }
.blog-subcat-body h4 { margin: 0 0 6px; font-size: 15px; font-weight: 700; }
.blog-subcat-body h4 a { color: var(--al-black); text-decoration: none; transition: color var(--al-t); }
.blog-subcat-body h4 a:hover { color: var(--al-green); }
.blog-subcat-desc { font-size: 13px; color: var(--al-muted); line-height: 1.5; }


/* ============================================================
   BLOG ITEM — CARD LISTING
   ============================================================ */
.blog-item { margin-bottom: 24px; display: flex; }

.blog-item-inner {
  background: var(--al-white);
  border-radius: var(--al-radius);
  overflow: hidden;
  box-shadow: var(--al-shadow);
  border: 1px solid var(--al-border);
  display: flex;
  flex-direction: column;
  width: 100%;
  position: relative;
  transition: box-shadow var(--al-t), transform var(--al-t);
  font-family: var(--al-font);
}
/* Barre verte top — glisse au hover */
.blog-item-inner::before {
  content: '';
  display: block;
  height: 3px;
  background: linear-gradient(90deg, var(--al-green), var(--al-green-dark));
  position: absolute;
  top: 0; left: 0; right: 0;
  z-index: 2;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--al-t);
}
.blog-item:hover .blog-item-inner::before { transform: scaleX(1); }
.blog-item:hover .blog-item-inner {
  box-shadow: var(--al-shadow-hover);
  transform: translateY(-4px);
}

/* Image */
.blog-item .blog-image {
  position: relative;
  overflow: hidden;
  aspect-ratio: 32 / 9;   /* plus haute que 16:9 → image mieux valorisée */
  background: var(--al-dark);
  margin: 0;
  flex-shrink: 0;
}
.blog-item .blog-image-link { display: block; width: 100%; height: 100%; }
.blog-item .blog-image img {
  width: 100%; height: 100%;
  object-fit: cover; display: block;
  transition: transform .5s var(--al-ease), filter .5s;
  filter: brightness(.93);
}
.blog-item:hover .blog-image img { transform: scale(1.06); filter: brightness(1); }

.blog-image-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to bottom, transparent 40%, rgba(21,34,17,.55) 100%);
  pointer-events: none;
}

/* Badge catégorie */
.blog-cat-badge {
  position: absolute;
  bottom: 10px; left: 10px;
  z-index: 3;
  display: inline-flex;
  align-items: center;
  background: var(--al-black);
  color: var(--al-white) !important;
  font-size: 10px;
  font-weight: 700;
  font-family: var(--al-font);
  letter-spacing: .07em;
  text-transform: uppercase;
  padding: 4px 9px;
  border-radius: var(--al-radius-sm);
  text-decoration: none !important;
  border-left: 3px solid var(--al-green);
  line-height: 1.6;
  transition: background var(--al-t);
  white-space: nowrap;
}
.blog-cat-badge:hover { background: var(--al-green) !important; }

/* Héro : badge sans position absolue */
.blog-cat-badge--hero {
  position: static;
  display: inline-flex;
  margin-bottom: 12px;
}

/* Contenu card */
.blog-item .blog-info {
  padding: 18px 20px 20px;
  display: flex;
  flex-direction: column;
  flex: 1;
}

/* Meta row (date · auteur · commentaires) */
.blog-item .blog-meta-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0 7px;
  font-size: 11px;
  font-family: var(--al-font);
  color: var(--al-muted);
  margin-bottom: 9px;
}
.blog-item .blog-meta-row > span {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  line-height: 1.5;
}
.blog-item .blog-meta-row svg { color: var(--al-green); flex-shrink: 0; }
.blog-item .blog-meta-sep {
  width: 3px; height: 3px;
  border-radius: 50%;
  background: var(--al-border);
  display: inline-block;
}
.blog-item .blog-author a {
  color: var(--al-text);
  font-weight: 600;
  text-decoration: none;
}
.blog-item .blog-author a:hover { color: var(--al-green); }

/* Titre */
.blog-item .title { margin: 0 0 9px; flex: 1; }
.blog-item .title a {
  font-size: 16px;
  line-height: 1.4;
  font-weight: 800;
  font-family: var(--al-font);
  color: var(--al-black);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-decoration: none;
  transition: color var(--al-t);
}
.blog-item .title a:hover { color: var(--al-green); }

/* Résumé */
.blog-item .blog-shortinfo {
  font-size: 13px;
  line-height: 1.65;
  color: var(--al-muted);
  margin-bottom: 16px;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Footer card */
.blog-item .blog-footer {
  margin-top: auto;
  padding-top: 14px;
  border-top: 1px solid var(--al-border);
}
.blog-item .more {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--al-black);
  color: var(--al-white) !important;
  font-size: 11px;
  font-weight: 700;
  font-family: var(--al-font);
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: 8px 16px;
  border-radius: var(--al-radius-sm);
  text-decoration: none !important;
  transition: background var(--al-t), gap var(--al-t);
}
.blog-item .more:hover { background: var(--al-green); gap: 12px; }
.blog-item .more svg { flex-shrink: 0; }
.blog-item p { margin-bottom: 0; }


/* ============================================================
   BLOG DETAIL — PAGE ARTICLE

   Même ratio 3/2 que la card listing → recadrage identique
   sur la seule image disponible.
   Format recommandé : 1200 × 800 px (ratio 3:2) ≤ 250 ko
   ============================================================ */
.blog-hero {
  position: relative;
  margin-bottom: 36px;
  border-radius: var(--al-radius);
  overflow: hidden;
  background: var(--al-dark);

  /* Même ratio que la card → même crop, même rendu */
  aspect-ratio: 32 / 9;

  /* Plafond : évite un héro trop grand sur grands écrans */
  max-height: 420px;

  /* Le contenu (titre, meta) se positionne en bas */
  display: flex;
  align-items: flex-end;
}

.blog-hero--no-image {
  aspect-ratio: unset;
  height: 160px;
  background: linear-gradient(135deg, var(--al-dark) 0%, var(--al-dark-2) 100%);
}

/* L'image remplit tout le conteneur sans distorsion */
.blog-hero-image {
  position: absolute;
  inset: 0;
}
.blog-hero-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;   /* même comportement que la card */
  object-position: center center; /* point de recadrage — ajuste si besoin */
  display: block;
}

/* Dégradé sombre bas → transparence haut pour lisibilité du texte */
.blog-hero-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(21, 34, 17, .05)  0%,
    rgba(21, 34, 17, .45) 50%,
    rgba(21, 34, 17, .82) 100%
  );
}
.blog-hero-content {
  position: relative;
  z-index: 2;
  padding: 36px 36px 28px;
  width: 100%;
  font-family: var(--al-font);
}

/* Titre article */
.blog-detail .blog-title {
  font-size: clamp(22px, 4vw, 32px);
  font-weight: 900;
  font-family: var(--al-font);
  line-height: 1.2;
  color: var(--al-white);
  margin: 0 0 18px;
  letter-spacing: -.01em;
}

/* Meta héro */
.blog-detail .blog-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px 12px;
  font-size: 13px;
  font-family: var(--al-font);
  color: rgba(255,255,255,.78);
}
.blog-detail .blog-meta > span {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  float: none; /* supprime les anciens floats */
}
.blog-detail .blog-meta svg { color: var(--al-green); }
.blog-detail .blog-meta a { color: rgba(255,255,255,.9); font-weight: 600; text-decoration: none; }
.blog-detail .blog-meta a:hover { color: var(--al-white); }
.blog-detail .blog-meta .blog-meta-sep {
  width: 3px; height: 3px;
  border-radius: 50%;
  background: rgba(255,255,255,.30);
  display: inline-block;
}

/* Contenu article */
.blog-body { max-width: 100%; }
.blog-detail .blog-description {
  font-size: 1.0625rem;
  line-height: 1.8;
  color: var(--al-text);
  margin-bottom: 32px;
}
.blog-detail .blog-description p { margin-bottom: 1.3em; }
.blog-detail .blog-description h2,
.blog-detail .blog-description h3 {
  font-weight: 800;
  font-family: var(--al-font);
  color: var(--al-black);
  margin: 2em 0 .6em;
}
.blog-detail .blog-description h2 { font-size: 22px; }
.blog-detail .blog-description h3 { font-size: 18px; }
.blog-detail .blog-description img { max-width: 100%; height: auto; border-radius: var(--al-radius); margin: 1rem 0; }
.blog-detail .blog-description blockquote {
  border-left: 4px solid var(--al-green);
  background: var(--al-green-light);
  margin: 1.5em 0;
  padding: 16px 22px;
  border-radius: 0 var(--al-radius-sm) var(--al-radius-sm) 0;
  font-style: italic;
  color: var(--al-text);
}
.blog-detail .blog-description a { color: var(--al-green); text-decoration: underline; text-underline-offset: 3px; }
.blog-detail .blog-description ul,
.blog-detail .blog-description ol { padding-left: 1.4em; margin-bottom: 1.2em; }
.blog-detail .blog-description li { margin-bottom: .4em; }

/* Footer article */
.blog-article-footer {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 20px 0;
  border-top: 2px solid var(--al-border);
  margin-bottom: 32px;
}

/* Tags */
.blog-tags {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  margin: 0;
}
.blog-tags-label {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 11px;
  font-weight: 700;
  font-family: var(--al-font);
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--al-muted);
  margin-right: 4px;
}
.blog-tags-label svg { color: var(--al-green); }
.blog-tag-item {
  display: inline-block;
  background: var(--al-bg);
  color: var(--al-text);
  font-size: 12px;
  font-weight: 600;
  font-family: var(--al-font);
  padding: 4px 11px;
  border-radius: 20px;
  text-decoration: none;
  border: 1px solid var(--al-border);
  transition: all var(--al-t);
}
.blog-tag-item:hover { background: var(--al-black); color: var(--al-white); border-color: var(--al-black); }

/* Articles connexes */
.extra-blogs { clear: both; margin-bottom: 32px; }
.extra-blogs .col-lg-6 {
  background: var(--al-bg);
  border-radius: var(--al-radius);
  padding: 20px 22px;
  border-top: 3px solid var(--al-black);
}
.extra-blogs .col-lg-6 + .col-lg-6 { border-top-color: var(--al-green); }
.extra-blogs h4 {
  font-size: 12px; font-weight: 800;
  font-family: var(--al-font);
  text-transform: uppercase; letter-spacing: .07em;
  color: var(--al-muted); margin: 0 0 12px;
}
.extra-blogs ul { margin: 0; padding: 0; list-style: none; }
.extra-blogs ul li { padding: 7px 0; border-bottom: 1px solid var(--al-border); }
.extra-blogs ul li:last-child { border-bottom: none; padding-bottom: 0; }
.extra-blogs ul li a {
  color: var(--al-text); font-size: 13px; font-weight: 500;
  text-decoration: none;
  display: flex; align-items: flex-start; gap: 6px;
  transition: color var(--al-t);
}
.extra-blogs ul li a::before { content: '→'; color: var(--al-green); font-weight: 700; flex-shrink: 0; }
.extra-blogs ul li a:hover { color: var(--al-green); }

/* Vidéo */
.blog-video-code { margin-bottom: 32px; }
.blog-video-code .inner {
  background: var(--al-dark);
  border-radius: var(--al-radius);
  padding: 1rem; text-align: center;
}
.blog-video-code .inner iframe { max-width: 100%; border-radius: var(--al-radius-sm); }


/* ============================================================
   COMMENTAIRES
   ============================================================ */
.blog-comment-block { margin-bottom: 1.5rem; }
.comment-item { padding: .75rem 0; }
.comment-item img { padding: 0 .75rem 0 0; float: left; border-radius: 50%; }
.rtl .comment-item img { padding: 0 0 0 .75rem; float: right; }

.comment-wrap {
  background: var(--al-white);
  border: 1px solid var(--al-border);
  border-radius: var(--al-radius);
  padding: 1.25rem;
  transition: box-shadow var(--al-t);
  overflow: hidden;
}
.comment-wrap:hover { box-shadow: var(--al-shadow); }
.comment-wrap .comment-meta {
  border-bottom: 1px solid var(--al-border);
  font-size: .8125rem;
  display: flex;
  justify-content: space-between;
  padding-bottom: 10px; margin-bottom: 12px;
}
@media (max-width: 575px) {
  .comment-wrap .comment-meta { display: block; }
  .comment-wrap .comment-meta > span { display: block; margin: .25rem 0; }
}
.comment-link { font-weight: 700; padding: 0; }
@media (min-width: 576px) { .comment-link { float: right; } }


/* ============================================================
   MENU BLOG (sidebar)
   ============================================================ */
.blog-menu .collapse-icons[aria-expanded="false"] .remove { display: none; }
.blog-menu .collapse-icons[aria-expanded="true"]  .add    { display: none; }
.blog-menu .collapse-icons[aria-expanded="true"]  .remove { display: block; }
.blog-menu .collapse-icons i { font-size: 0; }
.blog-menu .collapse-icons i::before { font-size: 16px; font-family: "Font Awesome Regular"; }
.blog-menu .collapse-icons .add,
.blog-menu .collapse-icons .remove { color: var(--al-black); }
.blog-menu .collapse-icons .add:hover,
.blog-menu .collapse-icons .remove:hover { color: var(--al-green); }
.blog-menu .collapse-icons .remove { display: none; }
.blog-menu .collapse-icons .remove::before { content: '\f106'; }
.blog-menu .collapse-icons .add::before    { content: '\f107'; }


/* ============================================================
   SHARE BUTTON
   ============================================================ */
.share_button {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 13px;
  font-weight: 600;
  font-family: var(--al-font);
  color: var(--al-muted);
}
.share_button > span i { color: var(--al-green); margin-right: 4px; }
.share_button ul { margin: 0; padding: 0; list-style: none; display: flex; gap: 6px; }
.share_button ul li { display: inline-block; }
.share_button ul li a {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 5px 12px; border-radius: var(--al-radius-sm);
  font-size: 12px; font-weight: 700; text-decoration: none;
  transition: opacity var(--al-t);
}
.share_button ul li a:hover { opacity: .82; }
.share_button ul li.facebook a { background: #e8edf5; color: #3c5a98; }
.share_button ul li.twitter  a { background: #e5f4fd; color: #1da1f2; }
.share_button--detail {
  background: var(--al-bg);
  border: 1px solid var(--al-border);
  border-radius: var(--al-radius);
  padding: 10px 16px;
}


/* ============================================================
   SEARCH BLOG (sidebar)
   ============================================================ */
#search-blog form {
  position: relative;
  display: inline-block;
  width: 100%;
  margin-bottom: 16px;
}
#search-blog form input {
  width: 100%;
  height: 44px;
  background: var(--al-white);
  border-radius: var(--al-radius);
  padding: 0 48px 0 14px;
  font-size: 14px;
  font-family: var(--al-font);
  border: 1.5px solid var(--al-border);
  color: var(--al-text);
  transition: border-color var(--al-t), box-shadow var(--al-t);
}
.rtl #search-blog form input { padding: 0 14px 0 48px; }
#search-blog form input::placeholder { color: var(--al-subtle); opacity: 1; }
#search-blog form input:focus {
  outline: none;
  border-color: var(--al-green);
  box-shadow: 0 0 0 3px var(--al-green-glow);
}
#search-blog form button {
  position: absolute; right: 6px; top: 50%;
  transform: translateY(-50%);
  width: 34px; height: 34px;
  background: none; border: none; cursor: pointer; padding: 0;
}
.rtl #search-blog form button { left: 6px; right: auto; }
#search-blog form button i { font-size: 0; }
#search-blog form button i::before {
  content: '';
  background-image: url("data:image/svg+xml,%3Csvg width='17' height='17' viewBox='0 0 17 17' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M11.344 12.254C10.146 13.273 8.604 13.873 6.915 13.873 3.122 13.873 0 10.764 0 6.927 0 3.127 3.122 0 6.915 0c3.83 0 6.934 3.11 6.934 6.927 0 1.69-.617 3.236-1.615 4.436l3.575 3.564c.254.236.254.636 0 .89-.127.128-.29.182-.455.182-.18 0-.326-.054-.453-.182L11.344 12.254ZM12.579 6.927c0-3.127-2.542-5.673-5.664-5.673-3.104 0-5.663 2.564-5.663 5.673 0 3.127 2.541 5.673 5.663 5.673 3.122 0 5.664-2.546 5.664-5.673Z' fill='%230C8E44' fill-rule='evenodd'/%3E%3C/svg%3E");
  width: 17px; height: 17px;
  display: block;
  position: absolute; inset: 0; margin: auto;
}
#search-blog #blog-nav ul { margin-bottom: 0; }
#search-blog #blog-nav li a {
  display: block;
  font-size: 14px; line-height: 34px;
  font-family: var(--al-font);
  color: var(--al-text); text-decoration: none;
  border-bottom: 1px solid var(--al-border);
  padding: 0 4px;
  transition: color var(--al-t), padding-left var(--al-t);
}
#search-blog #blog-nav li:last-child a { border-bottom: none; }
#search-blog #blog-nav li a::before { content: '›'; margin-right: 6px; color: var(--al-green); font-weight: 700; }
#search-blog #blog-nav li a:hover { color: var(--al-green); padding-left: 8px; }


/* ============================================================
   SIDEBAR — DERNIERS ARTICLES
   ============================================================ */
.blog-lastest-title {
  font-size: 12px; font-weight: 800;
  font-family: var(--al-font);
  text-transform: uppercase; letter-spacing: .07em;
  color: var(--al-black); margin-bottom: 18px;
  padding-bottom: 10px; border-bottom: 2px solid var(--al-black);
  position: relative;
}
.blog-lastest-title::after {
  content: '';
  position: absolute;
  bottom: -2px; left: 0;
  width: 32px; height: 2px;
  background: var(--al-green);
}

ul.lists { margin: 0; padding: 0; list-style: none; }
ul.lists > li { display: flex; gap: 12px; align-items: flex-start; }
ul.lists > li:not(:last-child) {
  margin-bottom: 14px; padding-bottom: 14px;
  border-bottom: 1px solid var(--al-border);
}
ul.lists > li .blog-image { width: 68px; flex-shrink: 0; }
ul.lists > li .blog-image img {
  width: 68px; height: 68px;
  object-fit: cover; border-radius: var(--al-radius-sm); display: block;
  transition: transform var(--al-t);
}
ul.lists > li:hover .blog-image img { transform: scale(1.05); }
ul.lists > li .blog-content { flex: 1; min-width: 0; }
ul.lists > li .post-name a {
  font-size: 13px; font-weight: 700; line-height: 1.4;
  font-family: var(--al-font);
  color: var(--al-black);
  display: -webkit-box;
  -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
  margin-bottom: 4px; text-decoration: none;
  transition: color var(--al-t);
}
ul.lists > li .post-name a:hover { color: var(--al-green); }
ul.lists > li .info { font-size: 11px; line-height: 1.5; color: var(--al-subtle); }

/* RSS */
.blog-lastest-rss { float: right !important; position: relative; top: -2.1875rem; }
.blog-lastest-rss a { color: #f8991d; }
.blog-lastest-rss a:hover { color: var(--al-green); }


/* ============================================================
   TAGS WIDGET (sidebar)
   ============================================================ */
.leo-blog-tags .block_content { display: flex; flex-wrap: wrap; gap: 6px; }
.leo-blog-tags .block_content > a {
  font-size: 12px; font-weight: 600;
  font-family: var(--al-font);
  padding: 4px 11px;
  border: 1.5px solid var(--al-border);
  background: var(--al-white); color: var(--al-muted);
  border-radius: 20px; text-decoration: none;
  transition: all var(--al-t);
}
.leo-blog-tags .block_content > a:hover {
  background: var(--al-green); color: var(--al-white); border-color: var(--al-green);
}


/* ============================================================
   CONTAINER GLOBAL
   ============================================================ */
.blogs-container .product-count {
  margin-bottom: 1rem; padding: .5rem 0;
  font-size: 13px; color: var(--al-muted); font-weight: 500;
  text-align: right;
}
.blogs-container .section-title {
  margin-bottom: 24px; text-transform: uppercase;
  letter-spacing: .06em; font-weight: 800;
  font-family: var(--al-font);
  color: var(--al-black);
}
.blogs-container .childrens .row { display: flex; flex-wrap: wrap; }
@media (max-width: 1199px) { .blogs-container .childrens .row > * { width: calc(100%/3); } }
@media (max-width: 991px)  { .blogs-container .childrens .row > * { width: 50%; } }
@media (max-width: 480px) {
  .blogs-container .childrens .row > * { width: 100%; }
  .blogs-container .childrens .row { gap: 20px 0; }
}
.blogs-container .childrens img,
.blogs-container .category-image img { border-radius: var(--al-radius); }
@media (max-width: 767px) {
  .blogs-container .panel-body .category-image,
  .blogs-container .panel-body .category-info { width: 50%; }
}
@media (max-width: 480px) {
  .blogs-container .panel-body .category-image,
  .blogs-container .panel-body .category-info { width: 100%; }
  .blogs-container .panel-body .category-info { margin-top: 20px; }
}


/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 767px) {
  .blog-page-header { padding: 18px 18px 16px; }
  .blog-page-header-inner { padding-left: 10px; }
  /* Sur mobile le max-height est levé — le ratio 16:9 suffit */
  .blog-hero { max-height: unset; } /* ratio 3/2 gère seul la hauteur sur mobile */
  .blog-hero-content { padding: 18px; }
  .blog-detail .blog-title { font-size: 22px; }
  .blog-body { max-width: 100%; }
  .blog-article-footer { flex-direction: column; align-items: flex-start; }
  .extra-blogs .col-lg-6 { margin-bottom: 14px; }
  .blog-video-code iframe { width: 100%; }
}
@media (max-width: 575px) {
  .blog-item .blog-info { padding: 14px 16px 16px; }
  .blog-item .more { width: 100%; justify-content: center; }
  .share_button { flex-wrap: wrap; }
  .blog-grid > [class*="col-"] { width: 100%; }
}