.es-blog-premium {
  position: relative;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  padding: 90px 6% 105px;
  background:
    radial-gradient(circle at 12% 18%, rgba(33,118,199,.09), transparent 32%),
    radial-gradient(circle at 86% 20%, rgba(229,57,53,.06), transparent 28%),
    linear-gradient(180deg, #f7fbff 0%, #ffffff 100%);
  overflow: hidden;
}

.es-blog-premium,
.es-blog-premium * {
  box-sizing: border-box;
}

.es-blog-premium__container {
  max-width: 1280px;
  margin: 0 auto;
}

.es-blog-premium__header {
  max-width: 820px;
  margin: 0 auto 55px;
  text-align: center;
}

.es-blog-premium__header span {
  display: inline-flex;
  margin-bottom: 16px;
  padding: 9px 16px;
  border-radius: 999px;
  background: rgba(33,118,199,.10);
  color: #2176c7;
  font-size: 13px;
  font-weight: 850;
}

.es-blog-premium__header h1 {
  margin: 0 0 18px;
  color: #1f2d3d;
  font-size: clamp(34px, 4vw, 54px);
  line-height: 1.08;
  font-weight: 900;
  letter-spacing: -1.4px;
}

.es-blog-premium__header p {
  margin: 0;
  color: #647891;
  font-size: 17px;
  line-height: 1.75;
}

.es-blog-premium__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 34px;
}

.es-blog-premium__card {
  position: relative;
  overflow: hidden;
  border-radius: 30px;
  background: #ffffff;
  border: 1px solid #dcebf8;
  box-shadow: 0 22px 58px rgba(18,43,68,.08);
  transition: all .35s ease;
}

.es-blog-premium__card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 50% 0%, rgba(33,118,199,.12), transparent 38%);
  opacity: 0;
  transition: opacity .35s ease;
  pointer-events: none;
}

.es-blog-premium__card:hover {
  transform: translateY(-9px);
  border-color: rgba(33,118,199,.32);
  box-shadow: 0 34px 85px rgba(18,43,68,.15);
}

.es-blog-premium__card:hover::before {
  opacity: 1;
}

.es-blog-premium__image {
  position: relative;
  display: block;
  height: 320px;
  background: linear-gradient(135deg, #eef6fd 0%, #f9fcff 100%);
  overflow: hidden;
}

.es-blog-premium__image img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 42px;
  display: block;
  transition: transform .45s ease;
}

.es-blog-premium__card:hover .es-blog-premium__image img {
  transform: scale(1.07);
}

.es-blog-premium__content {
  position: relative;
  z-index: 2;
  padding: 28px 28px 32px;
}

.es-blog-premium__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
  margin-bottom: 16px;
}

.es-blog-premium__meta span {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 6px 12px;
  border-radius: 999px;
  background: rgba(33,118,199,.08);
  color: #2176c7;
  font-size: 12px;
  font-weight: 850;
}

.es-blog-premium__card h3 {
  margin: 0 0 15px;
  color: #1f2d3d;
  font-size: 22px;
  line-height: 1.28;
  font-weight: 900;
  letter-spacing: -.4px;
}

.es-blog-premium__card h3 a {
  color: inherit;
  text-decoration: none;
}

.es-blog-premium__card h3 a:hover {
  color: #2176c7;
}

.es-blog-premium__card p {
  margin: 0 0 24px;
  color: #647891;
  font-size: 15px;
  line-height: 1.75;
}

.es-blog-premium__link {
  display: inline-flex;
  align-items: center;
  color: #e53935;
  font-size: 14px;
  font-weight: 900;
  text-decoration: none;
}

.es-blog-premium__link::after {
  content: "→";
  margin-left: 8px;
  transition: transform .25s ease;
}

.es-blog-premium__link:hover::after {
  transform: translateX(5px);
}

/* TABLETTE : 2 cartes */
@media (max-width: 1024px) {
  .es-blog-premium {
    padding: 75px 32px 85px;
  }

  .es-blog-premium__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 26px;
  }

  .es-blog-premium__image {
    height: 280px;
  }
}

/* MOBILE : 1 carte */
@media (max-width: 700px) {
  .es-blog-premium {
    padding: 60px 22px 75px;
  }

  .es-blog-premium__header {
    margin-bottom: 38px;
  }

  .es-blog-premium__header h1 {
    font-size: 32px;
    letter-spacing: -.8px;
  }

  .es-blog-premium__header p {
    font-size: 15px;
  }

  .es-blog-premium__grid {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  .es-blog-premium__image {
    height: 240px;
  }

  .es-blog-premium__image img {
    padding: 34px;
  }

  .es-blog-premium__content {
    padding: 24px 22px 28px;
  }

  .es-blog-premium__card h3 {
    font-size: 20px;
  }
}

/* AMÉLIORATION PREMIUM BLOG CARDS */
.es-blog-premium__card {
  min-height: 100%;
}

.es-blog-premium__card::after {
  content: "";
  position: absolute;
  top: 0;
  left: 28px;
  right: 28px;
  height: 4px;
  border-radius: 0 0 20px 20px;
  background: linear-gradient(90deg, #2176c7, #e53935);
  opacity: 0;
  transition: opacity .35s ease;
}

.es-blog-premium__card:hover::after {
  opacity: 1;
}

.es-blog-premium__image::before {
  content: "";
  position: absolute;
  width: 170px;
  height: 170px;
  left: 50%;
  top: 50%;
  border-radius: 50%;
  transform: translate(-50%, -50%);
  background: radial-gradient(circle, rgba(33,118,199,.14), transparent 68%);
  z-index: 0;
}

.es-blog-premium__image img {
  position: relative;
  z-index: 2;
  filter: drop-shadow(0 16px 22px rgba(18,43,68,.12));
}

.es-blog-premium__content {
  display: flex;
  flex-direction: column;
  min-height: 255px;
}

.es-blog-premium__link {
  margin-top: auto;
}

.es-blog-premium__card:hover h3 {
  color: #2176c7;
}

.es-blog-premium__meta span:first-child {
  background: rgba(33,118,199,.10);
}

.es-blog-premium__meta span:last-child {
  background: rgba(229,57,53,.08);
  color: #e53935;
}

@media (max-width: 700px) {
  .es-blog-premium__content {
    min-height: auto;
  }
}


/* ===============================
   BLOG PREMIUM - FINAL UI FIX
=============================== */

/* Image pleine largeur */
.es-blog-premium__image {
  height: 255px;
  padding: 0 !important;
  background: #eef6fd;
}

.es-blog-premium__image img {
  width: 100%;
  height: 100%;
  object-fit: cover !important;
  padding: 0 !important;
  filter: none;
}

/* Overlay premium image */
.es-blog-premium__image::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(18, 43, 68, 0.18),
    rgba(18, 43, 68, 0)
  );
  opacity: 0;
  transition: opacity .35s ease;
  z-index: 2;
}

.es-blog-premium__card:hover .es-blog-premium__image::after {
  opacity: 1;
}

/* Supprimer le glow ancien derrière image */
.es-blog-premium__image::before {
  display: none !important;
}

/* Catégories uniquement */
.es-blog-premium__meta span {
  background: rgba(33,118,199,.09) !important;
  color: #2176c7 !important;
  text-transform: none !important;
}

/* Description normale */
.es-blog-premium__card p {
  text-transform: none !important;
  font-size: 14.5px;
  line-height: 1.72;
  color: #5f748e;
}

/* Titre plus premium */
.es-blog-premium__card h3 {
  font-size: 21px;
  line-height: 1.25;
  letter-spacing: -0.3px;
}

/* Carte plus propre */
.es-blog-premium__card {
  border-radius: 28px;
  background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
}

.es-blog-premium__content {
  padding: 26px 26px 30px;
  min-height: 250px;
}

/* Bouton lire */
.es-blog-premium__link {
  color: #e53935 !important;
  text-transform: none !important;
}

/* Pagination premium */
.es-blog-pagination {
  margin-top: 55px;
  display: flex;
  justify-content: center;
  gap: 8px;
  flex-wrap: wrap;
}

.es-blog-pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 42px;
  height: 42px;
  padding: 0 14px;
  border-radius: 13px;
  border: 1px solid #dbe9f6;
  background: #ffffff;
  color: #2176c7;
  font-size: 14px;
  font-weight: 850;
  text-decoration: none;
  transition: all .25s ease;
}

.es-blog-pagination .page-numbers.current,
.es-blog-pagination .page-numbers:hover {
  background: #2176c7;
  color: #ffffff;
  border-color: #2176c7;
  transform: translateY(-2px);
}

/* Responsive */
@media (max-width: 1024px) {
  .es-blog-premium__image {
    height: 240px;
  }
}

@media (max-width: 700px) {
  .es-blog-premium__image {
    height: 220px;
  }

  .es-blog-premium__content {
    min-height: auto;
    padding: 24px 22px 28px;
  }

  .es-blog-premium__card h3 {
    font-size: 20px;
  }
}