/* =========================================================
   🎨 IRON TV PRO — main.css
   Light UI / Modern Responsive — 2026
   ========================================================= */

:root{
  --bg: #f7fbff;
  --bg-2: #ffffff;
  --text: #24324a;      /* بدون أسود */
  --muted: #5b6b86;

  --primary: #2563eb;   /* أزرق */
  --secondary: #06b6d4; /* سماوي */
  --accent: #fbbf24;    /* ذهبي فاتح */

  --light: #eef6ff;
  --card: #ffffff;

  --radius: 1.15rem;
  --shadow: 0 10px 28px rgba(36, 50, 74, 0.10);
  --border: rgba(37, 99, 235, 0.12);
}

*{margin:0;padding:0;box-sizing:border-box;}

html{scroll-behavior:smooth;}
body{
  font-family: "Inter", system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, sans-serif;
  background: linear-gradient(180deg, var(--bg) 0%, var(--bg-2) 55%, #f8fafc 100%);
  color: var(--text);
  line-height: 1.65;
}

img{max-width:100%;height:auto;display:block;}
a{color:var(--primary);text-decoration:none;}
a:hover{opacity:.92;}

.h1{font-size:2.55rem; margin-bottom:1rem; letter-spacing:-.02em;}
.h2{font-size:2.05rem; margin-bottom:1rem; letter-spacing:-.02em;}
.sub{color:var(--muted); margin:.5rem 0 2rem;}

.container{width:90%; max-width:1200px; margin:0 auto;}
.section{padding:5rem 0;}
.section.alt{background: linear-gradient(180deg, #ffffff 0%, var(--light) 100%);}
.grid-3{display:grid; grid-template-columns:repeat(auto-fit, minmax(250px,1fr)); gap:2rem;}

/* ---------- Header ---------- */
.header{
  position:sticky; top:0; z-index:1000;
  background: rgba(255,255,255,0.86);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border);
}

.nav{display:flex; justify-content:space-between; align-items:center; padding:1rem 0;}
.brand{display:flex; align-items:center; gap:.6rem; font-weight:800; color:var(--primary);}
.logo{width:40px;}

.menu{display:flex; gap:1rem; align-items:center;}
.menu a{
  color: var(--text);
  font-weight: 600;
  padding: .45rem .7rem;
  border-radius: .8rem;
}
.menu a:hover{
  background: rgba(37, 99, 235, 0.08);
}

/* Hamburger */
.hamburger{
  display:none;
  flex-direction:column;
  gap:.35rem;
  background:none;
  border:none;
  cursor:pointer;
}
.hamburger span{
  width:26px;
  height:3px;
  background: rgba(36, 50, 74, 0.75);
  border-radius: 999px;
}

/* ---------- Hero ---------- */
.hero{
  background:
    radial-gradient(800px 300px at 50% 10%, rgba(6,182,212,0.18), transparent 60%),
    radial-gradient(800px 300px at 50% 40%, rgba(37,99,235,0.15), transparent 60%),
    linear-gradient(135deg, #f2f7ff, #ffffff);
  text-align:center;
  padding: 6.2rem 1rem 5.5rem;
}

.badge-top{
  display:inline-block;
  background: linear-gradient(135deg, rgba(37,99,235,0.14), rgba(6,182,212,0.14));
  color: var(--text);
  border: 1px solid var(--border);
  padding: .45rem .9rem;
  border-radius: 999px;
  font-size: .95rem;
  margin-bottom: 1.1rem;
}

.lead{font-size:1.18rem; color:var(--muted); margin-bottom: .9rem;}
.clients{font-size:1rem; margin-bottom:1.6rem; color:var(--primary); font-weight:700;}
.seo-intro{
  max-width: 920px;
  margin: 0 auto 2rem;
  color: var(--muted);
}
.hero__content .cta{display:flex; justify-content:center; gap:1rem; flex-wrap:wrap;}

/* ---------- Buttons ---------- */
.btn{
  display:inline-block;
  padding: .85rem 1.55rem;
  border-radius: 999px;
  font-weight: 800;
  text-decoration:none;
  transition: transform .18s ease, box-shadow .18s ease, opacity .18s ease;
  box-shadow: 0 10px 18px rgba(37, 99, 235, 0.12);
}
.btn:active{transform: translateY(1px);}

.btn--primary{
  background: linear-gradient(135deg, var(--primary), var(--secondary));
  color: #ffffff;
}
.btn--primary:hover{opacity:.95; box-shadow: 0 14px 26px rgba(37, 99, 235, 0.18);}

.btn--ghost{
  background: rgba(255,255,255,0.9);
  border: 2px solid rgba(37, 99, 235, 0.35);
  color: var(--primary);
  box-shadow: none;
}
.btn--ghost:hover{
  background: rgba(37, 99, 235, 0.08);
}

/* ---------- Cards ---------- */
.card{
  background: var(--card);
  border-radius: var(--radius);
  padding: 2rem;
  text-align:center;
  box-shadow: var(--shadow);
  border: 1px solid rgba(37, 99, 235, 0.10);
}
.card .icon{font-size:2rem; margin-bottom:1rem;}
.card h3{margin-bottom:.35rem;}
.card p{color:var(--muted);}

/* ---------- Steps ---------- */
.steps{display:flex; gap:2rem; justify-content:center; flex-wrap:wrap; margin:2rem 0;}
.step{flex:1; min-width:200px; text-align:center;}
.step__num{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width: 44px; height: 44px;
  background: linear-gradient(135deg, var(--primary), var(--secondary));
  color:#fff;
  border-radius: 50%;
  margin-bottom: .6rem;
  font-weight: 900;
}

/* ---------- Tabs / Pricing ---------- */
.tabs{display:flex; justify-content:center; margin-bottom:2rem; gap:1rem; flex-wrap:wrap;}
.tab-btn{
  background: rgba(37, 99, 235, 0.08);
  border: 1px solid rgba(37,99,235,0.14);
  padding: .65rem 1.2rem;
  border-radius: 999px;
  cursor:pointer;
  font-weight: 800;
  color: var(--text);
}
.tab-btn.active{
  background: linear-gradient(135deg, var(--primary), var(--secondary));
  color:#fff;
  border-color: transparent;
}

.tab-content{display:none; transition: opacity .25s ease;}
.tab-content.active{display:block; opacity:1;}

.pricing{display:grid; gap:2rem; grid-template-columns: repeat(auto-fit, minmax(250px,1fr));}
.p-card{
  background: var(--card);
  border-radius: var(--radius);
  padding: 2rem;
  text-align:center;
  box-shadow: var(--shadow);
  position:relative;
  border: 1px solid rgba(37,99,235,0.10);
  transition: transform .25s ease, box-shadow .25s ease;
}
.p-card:hover{
  transform: translateY(-6px);
  box-shadow: 0 16px 34px rgba(36, 50, 74, 0.14);
}
.p-name{font-weight:800; color:var(--muted);}
.p-price{font-size:1.9rem; font-weight:900; margin: 1rem 0;}
.p-feats{list-style: disc; text-align:left; margin: 1rem 0 1.2rem 1.25rem; color: var(--muted);}
.p-feats li{margin:.35rem 0;}

.p-card--recommended{
  border: 2px solid rgba(251,191,36,0.75);
  box-shadow: 0 18px 40px rgba(251,191,36,0.10);
}
.badge{
  position:absolute; top: 12px; right: 12px;
  background: rgba(251,191,36,0.85);
  color: var(--text);
  padding: .35rem .6rem;
  border-radius: .75rem;
  font-size: .82rem;
  font-weight: 900;
}

/* ---------- Stats ---------- */
.stat{text-align:center;}
.stat h3{font-size:2.2rem; margin-bottom:.45rem;}
.stat p{color:var(--muted);}

/* ---------- Comparatif ---------- */
.comparatif{width:100%; border-collapse:collapse; margin-top:2rem; overflow:hidden; border-radius: var(--radius);}
.comparatif th, .comparatif td{border:1px solid rgba(37,99,235,0.12); padding:1rem; text-align:center;}
.comparatif th{
  background: linear-gradient(135deg, var(--primary), var(--secondary));
  color:#fff;
}

/* ---------- Avis ---------- */
.testis{display:flex; gap:2rem; flex-wrap:wrap; justify-content:center;}
.testi{
  background: var(--card);
  border-radius: var(--radius);
  padding: 1.5rem;
  box-shadow: var(--shadow);
  border: 1px solid rgba(37,99,235,0.10);
  flex: 1; min-width: 250px;
}
.testi blockquote{margin:.6rem 0; color:var(--muted);}

/* ---------- Garanties ---------- */
#garanties .card h3{margin-bottom:.5rem; color: var(--primary);}

/* ---------- Revendeur teaser ---------- */
#revendeur-teaser{text-align:center;}
#revendeur-teaser p{margin: 1rem 0; color: var(--muted);}

/* ---------- FAQ ---------- */
.faq{
  margin-bottom: 1rem;
  border: 1px solid rgba(37,99,235,0.14);
  border-radius: var(--radius);
  padding: 1rem;
  background: var(--card);
  box-shadow: 0 10px 20px rgba(36, 50, 74, 0.06);
}
.faq summary{font-weight: 900; cursor: pointer;}
.faq p{margin-top:.6rem; color: var(--muted);}

/* ---------- Contact ---------- */
.contact-list{list-style:none;}
.contact-list li{margin-bottom:.85rem;}
.contact-list a{font-weight:800;}


/* ---------- Footer ---------- */
.footer{
  background: linear-gradient(180deg, var(--light) 0%, #ffffff 100%);
  padding: 2rem 0;
  text-align:center;
  border-top: 1px solid rgba(37,99,235,0.10);
}
.footer nav{
  margin-top: 1rem;
  display:flex;
  gap:1rem;
  justify-content:center;
  flex-wrap:wrap;
}
.footer nav a{
  color: var(--text);
  background: rgba(37,99,235,0.06);
  padding: .45rem .8rem;
  border-radius: 999px;
  font-weight: 800;
}

/* ---------- WhatsApp Floating ---------- */
.whatsapp-float{
  position:fixed; bottom: 20px; right: 20px;
  background: #25d366; color:#fff;
  padding: 1rem;
  border-radius: 50%;
  font-size: 1.55rem;
  box-shadow: var(--shadow);
  z-index: 1000;
}

/* =========================
   Sticky bar (FIX)
   ========================= */
.sticky-bar{
  position: fixed;
  bottom: 0; left: 0;
  width: 100%;
  background: var(--white, #fff);
  box-shadow: 0 10px 26px rgba(109,40,217,.12);
  padding: .85rem 1rem;
  z-index: 999;

  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: .75rem;
}

.sticky-bar a{
  font-weight: 700;
  text-decoration: none;
}

.sticky-text{
  color: var(--text, #1f1b2e);
  line-height: 1.2;
}

.sticky-cta{
  min-width: 140px;
}

/* ✅ Mobile: النص فوق الزر */
@media (max-width: 768px){
  .sticky-bar{
    flex-direction: column;
    align-items: stretch;
    text-align: center;
  }

  .sticky-bar a{
    width: 100%;
  }

  /* اختياري: باش زر واتساب العائم ما يغطيش الـ sticky */
  .whatsapp-float{
    bottom: 90px;
  }
}


/* ---------- Shimmer ---------- */
.shimmer{
  position: relative;
  display:inline-block;
  background: linear-gradient(135deg, var(--primary), var(--secondary));
  -webkit-background-clip:text;
  background-clip:text;
  color: transparent;
  overflow:hidden;
}
.shimmer::before{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(120deg, transparent 0%, rgba(255,255,255,0.5) 50%, transparent 100%);
  transform: translateX(-100%);
  animation: shimmer-move 3s infinite;
  pointer-events:none;
}
@keyframes shimmer-move{
  0%{transform:translateX(-100%);}
  50%{transform:translateX(100%);}
  100%{transform:translateX(100%);}
}

/* pulse class from JS */
.promo-popup.pulsing{
  animation: pulse 1.2s ease-in-out;
}
@keyframes pulse{
  0%{transform: scale(1);}
  50%{transform: scale(1.02);}
  100%{transform: scale(1);}
}

/* ---------- Responsive ---------- */
@media (max-width: 768px){
  .menu{
    display:none;
    flex-direction:column;
    gap: .6rem;
    background: rgba(255,255,255,0.95);
    backdrop-filter: blur(10px);
    padding: 1rem;
    position:absolute;
    top: 64px;
    right: 10px;
    border-radius: 1rem;
    box-shadow: var(--shadow);
    border: 1px solid rgba(37,99,235,0.12);
    min-width: 220px;
  }
  .menu.show{display:flex;}
  .hamburger{display:flex;}

  .sticky-bar{display:flex;}
}

@media (max-width: 480px){
  html, body{font-size: 15px; overflow-x:hidden;}

  .hero{padding: 4.4rem 1rem 4.2rem;}
  .h1{font-size: 1.85rem; line-height: 1.25;}
  .lead{font-size: 1rem;}

  .cta{display:flex; flex-direction:column; gap: .9rem;}
  .btn{width: 100%; text-align:center;}

  .grid-3{grid-template-columns: 1fr; gap: 1.2rem;}
  .card{padding: 1.35rem;}

  .steps{flex-direction: column; gap: 1.2rem;}

  .comparatif{font-size: .88rem;}
  .comparatif th, .comparatif td{padding: .65rem;}

  .testis{flex-direction: column; gap: 1rem;}
  .contact-list li{font-size: .98rem;}

  .promo-popup{bottom: 10px; right: 10px; width: 270px;}
  .footer nav{flex-direction: column; gap: .5rem;}
}
/* ===============================
   FIX: Hero title/badge overflow
   (cuts text left/right)
   =============================== */

/* منع أي سحب أفقي */
html, body { overflow-x: hidden; }

/* خليه يتصرف كبلوك داخل الكونتينر */
.hero__content .h1.shimmer{
  display: block;          /* مهم جداً */
  width: 100%;
  max-width: 100%;
  white-space: normal;     /* يسمح بالالتفاف */
  overflow-wrap: anywhere; /* يكسر لو كان طويل */
  word-break: normal;
  margin-left: auto;
  margin-right: auto;
}

/* نفس الشيء للـBadge حتى لا يطلع خارج الشاشة */
.badge-top{
  max-width: 100%;
  white-space: normal;
  text-align: center;
  line-height: 1.35;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  gap: .4rem;
  padding-left: 1rem;
  padding-right: 1rem;
}




















/* =========================================================
   BLOG PAGE — clean cards like reference (3 per row)
   Put this AFTER main.css (or paste at bottom of main.css)
   ========================================================= */

.blog-page .blog-controls-section{
  padding-top: 2.2rem;
  padding-bottom: 2.2rem;
}

.blog-page .blog-controls{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 1rem;
  flex-wrap: wrap;
  padding: 1rem 1.1rem;
  border-radius: 16px;
  background: rgba(255,255,255,0.9);
  border: 1px solid rgba(37,99,235,0.12);
  box-shadow: 0 10px 22px rgba(36, 50, 74, 0.06);
}

.blog-page .blog-filters{
  display:flex;
  gap: .75rem;
  flex-wrap: wrap;
}

.blog-page .blog-filters select{
  appearance: none;
  border: 1px solid rgba(37,99,235,0.16);
  background: #fff;
  padding: .75rem 1rem;
  border-radius: 999px;
  font-weight: 800;
  color: var(--text);
  outline: none;
  min-width: 220px;
}

.blog-page .results-count{
  font-weight: 900;
  color: var(--muted);
}

/* ✅ GRID: always 3 cards per row on desktop */
.blog-page .articles-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 26px;
  margin-top: 1.5rem;
}

/* Tablet: 2 per row */
@media (max-width: 1024px){
  .blog-page .articles-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* Mobile: 1 per row */
@media (max-width: 640px){
  .blog-page .articles-grid{
    grid-template-columns: 1fr;
    gap: 18px;
  }
}

/* Card */
.blog-page .post-card{
  background: #fff;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(37,99,235,0.12);
  box-shadow: 0 16px 34px rgba(36, 50, 74, 0.10);
  transition: transform .18s ease, box-shadow .18s ease;
  display:flex;
  flex-direction: column;
  min-height: 100%;
}

.blog-page .post-card:hover{
  transform: translateY(-4px);
  box-shadow: 0 20px 46px rgba(36, 50, 74, 0.14);
}

/* Media with fixed ratio (fix huge images) */
.blog-page .post-card__media{
  position: relative;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: #eef2ff;
}

.blog-page .post-card__media img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.02);
}

/* Tag badge (top-left) */
.blog-page .post-tag{
  position:absolute;
  top: 14px;
  left: 14px;
  padding: .42rem .75rem;
  border-radius: 999px;
  font-weight: 900;
  font-size: .92rem;
  color: #fff;
  background: linear-gradient(135deg, #7c3aed, #2563eb);
  box-shadow: 0 10px 22px rgba(37, 99, 235, 0.18);
}

/* Content */
.blog-page .post-card__body{
  padding: 16px 18px 18px;
  display:flex;
  flex-direction: column;
  gap: 10px;
}

.blog-page .post-meta{
  display:flex;
  align-items:center;
  gap: 12px;
  color: rgba(36, 50, 74, 0.70);
  font-weight: 800;
  font-size: .95rem;
}

.blog-page .post-meta span{
  display:inline-flex;
  align-items:center;
  gap: 8px;
}

.blog-page .post-title{
  font-size: 1.2rem;
  letter-spacing: -.01em;
  color: var(--text);
  line-height: 1.25;
  margin: 0;
}

.blog-page .post-excerpt{
  color: rgba(36, 50, 74, 0.78);
  line-height: 1.6;
  margin: 0;

  /* ✅ clamp to avoid ugly long text */
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Link like reference site (not big button) */
.blog-page .post-link{
  margin-top: 4px;
  font-weight: 900;
  color: #6d28d9;
  display:inline-flex;
  align-items:center;
  gap: 10px;
  padding: 8px 0;
  width: fit-content;
}

.blog-page .post-link:hover{
  opacity: .9;
  transform: translateX(1px);
}

.blog-page .post-link .arrow{
  font-size: 1.1rem;
}

/* Empty state */
.blog-page .posts-empty{
  background: rgba(255,255,255,0.9);
  border: 1px solid rgba(37,99,235,0.12);
  border-radius: 16px;
  padding: 18px;
  color: var(--muted);
  font-weight: 900;
}

/* Pagination spacing */
.blog-page .pagination{
  margin-top: 26px;
  display:flex;
  gap: 12px;
  justify-content:center;
  flex-wrap: wrap;
}







/* ===== Fix spacing between Search + Newsletter buttons ===== */
.blog-page .blog-top{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px 26px;              /* ✅ مسافة بين الفورمين */
  align-items: start;
}

.blog-page .search-bar,
.blog-page .newsletter{
  display: grid;
  grid-template-columns: 1fr auto; /* input + button */
  gap: 12px;                        /* ✅ مسافة داخل الفورم */
  width: 100%;
}

.blog-page .search-bar input,
.blog-page .newsletter input{
  width: 100%;
  min-width: 0;
}

/* خفّف حجم الأزرار هنا باش مايبانوش مزحومين */
.blog-page .blog-top .btn{
  padding: .70rem 1.25rem;
  box-shadow: none; /* اختياري: كيولي أنظف */
}

/* Mobile: خليه صف واحد تحت واحد */
@media (max-width: 768px){
  .blog-page .blog-top{
    grid-template-columns: 1fr;
    gap: 14px;
  }
}





/* =========================================================
   BLOG — Cards (3 per row) + Search/Newsletter spacing
   ضع هذا في آخر main.css
   ========================================================= */

.sr-only{
  position:absolute !important;
  width:1px;height:1px;
  padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);
  white-space:nowrap;border:0;
}

/* Search + Newsletter (فاصل واضح بين الزرين) */
.blog-top{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px 26px;
  align-items: start;
  margin-top: 8px;
}

.search-bar, .newsletter{
  display:flex;
  gap: 12px;
  align-items:center;
  background: rgba(255,255,255,0.95);
  border: 1px solid rgba(37,99,235,0.14);
  border-radius: 18px;
  padding: 14px;
  box-shadow: 0 12px 24px rgba(36, 50, 74, 0.08);
}

.search-bar input, .newsletter input{
  flex:1;
  min-width: 0;
  border: 1px solid rgba(37,99,235,0.18);
  border-radius: 14px;
  padding: 12px 14px;
  outline: none;
  background: #fff;
}

.search-bar input:focus, .newsletter input:focus{
  border-color: rgba(37,99,235,0.45);
  box-shadow: 0 0 0 4px rgba(37,99,235,0.10);
}

/* Filters */
.blog-controls{
  margin-top: 16px;
  display:flex;
  justify-content: space-between;
  align-items:center;
  gap: 14px;
  flex-wrap: wrap;
}

.blog-filters{
  display:flex;
  gap: 12px;
  flex-wrap: wrap;
}

.blog-filters select{
  border: 1px solid rgba(37,99,235,0.18);
  background: #fff;
  border-radius: 14px;
  padding: 10px 12px;
  font-weight: 800;
  color: var(--text);
  outline: none;
}

.results-count{
  font-weight: 900;
  color: rgba(36,50,74,0.75);
}

/* ✅ GRID: 3 per row (حل مشكل 5 في السطر) */
.articles-grid{
  display:grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 26px !important;
  margin-top: 22px;
  align-items: stretch;
}

/* Tablet */
@media (max-width: 980px){
  .articles-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
  .blog-top{ grid-template-columns: 1fr; }
}

/* Mobile */
@media (max-width: 620px){
  .articles-grid{ grid-template-columns: 1fr !important; }
}

/* Card style مثل الموقع الثاني */
.post-card{
  background: #fff;
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid rgba(37,99,235,0.12);
  box-shadow: 0 16px 34px rgba(36, 50, 74, 0.10);
  transition: transform .25s ease, box-shadow .25s ease;
}

.post-card:hover{
  transform: translateY(-6px);
  box-shadow: 0 22px 44px rgba(36, 50, 74, 0.14);
}

.post-media{
  position: relative;
  display:block;
  text-decoration:none;
  color: inherit;
}

.post-cover{
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  background: #eef2ff;
}

/* Tag pill */
.post-tag{
  position:absolute;
  top: 14px;
  left: 14px;
  padding: 8px 12px;
  border-radius: 999px;
  font-weight: 900;
  font-size: .9rem;
  color: #fff;
  background: linear-gradient(135deg, rgba(124,58,237,0.95), rgba(37,99,235,0.95));
  box-shadow: 0 12px 20px rgba(124,58,237,0.18);
  border: 1px solid rgba(255,255,255,0.25);
}

.post-body{
  padding: 16px 18px 18px;
  display:flex;
  flex-direction:column;
  gap: 10px;
  min-height: 210px;
}

.post-meta{
  display:flex;
  gap: 14px;
  flex-wrap: wrap;
  font-weight: 800;
  color: rgba(36,50,74,0.65);
  font-size: .95rem;
}

.post-title{
  margin: 2px 0 0;
  font-size: 1.18rem;
  line-height: 1.25;
  font-weight: 950;
  color: #0f172a;
}

.post-title a{
  color: inherit;
  text-decoration:none;
}

.post-title a:hover{
  color: var(--primary);
}

.post-excerpt{
  color: rgba(36,50,74,0.72);
  line-height: 1.65;

  /* يمنع الزحمة: 3 أسطر فقط */
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.post-link{
  margin-top: auto;
  display:inline-flex;
  align-items:center;
  gap: 10px;
  font-weight: 950;
  color: #6d28d9;
  text-decoration:none;
  padding-top: 6px;
}

.post-link:hover{
  color: #4c1d95;
}

/* Pagination spacing */
.pagination{
  display:flex;
  justify-content:center;
  gap: 14px;
  margin-top: 28px;
}

/* لو عندك ستايل قديم يسبب ازدحام للأزرار داخل الكروت */
.article-card { width: auto !important; }




/* =========================================================
   BLOG — 3 cards per row + clean UI
   ألصقه في آخر main.css
   ========================================================= */

/* Top controls spacing (Rechercher / S’inscrire) */
.blog-page .blog-top{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px 28px;           /* ✅ مسافة واضحة */
  align-items: start;
}

.blog-page .search-bar,
.blog-page .newsletter{
  display:flex;
  gap: 12px;
  align-items:center;
  flex-wrap: nowrap;        /* ✅ يمنع تداخل الزر */
  background: rgba(255,255,255,0.96);
  border: 1px solid rgba(37,99,235,0.14);
  border-radius: 18px;
  padding: 14px;
  box-shadow: 0 12px 24px rgba(36, 50, 74, 0.08);
}

.blog-page .search-bar input,
.blog-page .newsletter input{
  flex: 1;
  min-width: 0;
  border: 1px solid rgba(37,99,235,0.18);
  border-radius: 14px;
  padding: 12px 14px;
  outline: none;
  background: #fff;
}

.blog-page .search-bar button,
.blog-page .newsletter button{
  white-space: nowrap;
}

/* Filters */
.blog-page .blog-controls{
  margin-top: 18px;
  display:flex;
  justify-content: space-between;
  align-items:center;
  gap: 14px;
  flex-wrap: wrap;
}

.blog-page .blog-filters{
  display:flex;
  gap: 12px;
  flex-wrap: wrap;
}

.blog-page .blog-filters select{
  border: 1px solid rgba(37,99,235,0.18);
  background: #fff;
  border-radius: 14px;
  padding: 10px 12px;
  font-weight: 800;
  color: var(--text);
  outline: none;
}

.blog-page .results-count{
  font-weight: 900;
  color: rgba(36,50,74,0.75);
}

/* ✅ FIX: 3 per row (حتى لو الشاشة كبيرة) */
.articles-grid{
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 26px !important;
  margin-top: 22px;
  align-items: stretch;
}

/* Tablet: 2 */
@media (max-width: 980px){
  .articles-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
  .blog-page .blog-top{
    grid-template-columns: 1fr;
  }
}

/* Mobile: 1 */
@media (max-width: 620px){
  .articles-grid{
    grid-template-columns: 1fr !important;
  }
}

/* Card style (like your reference site) */
.post-card{
  background: #fff;
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid rgba(37,99,235,0.12);
  box-shadow: 0 16px 34px rgba(36, 50, 74, 0.10);
  transition: transform .25s ease, box-shadow .25s ease;
}

.post-card:hover{
  transform: translateY(-6px);
  box-shadow: 0 22px 44px rgba(36, 50, 74, 0.14);
}

.post-media{
  position: relative;
  display:block;
  text-decoration:none;
  color: inherit;
}

.post-cover{
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  background: #eef2ff;
}

.post-tag{
  position:absolute;
  top: 14px;
  left: 14px;
  padding: 8px 12px;
  border-radius: 999px;
  font-weight: 900;
  font-size: .9rem;
  color: #fff;
  background: linear-gradient(135deg, rgba(124,58,237,0.95), rgba(37,99,235,0.95));
  box-shadow: 0 12px 20px rgba(124,58,237,0.18);
  border: 1px solid rgba(255,255,255,0.25);
}

.post-body{
  padding: 16px 18px 18px;
  display:flex;
  flex-direction:column;
  gap: 10px;
  min-height: 210px;
}

.post-meta{
  display:flex;
  gap: 14px;
  flex-wrap: wrap;
  font-weight: 800;
  color: rgba(36,50,74,0.65);
  font-size: .95rem;
}

.post-title{
  margin: 2px 0 0;
  font-size: 1.18rem;
  line-height: 1.25;
  font-weight: 950;
  color: #0f172a;
}

.post-title a{
  color: inherit;
  text-decoration:none;
}

.post-title a:hover{
  color: var(--primary);
}

.post-excerpt{
  color: rgba(36,50,74,0.72);
  line-height: 1.65;
  display: -webkit-box;
  -webkit-line-clamp: 3;     /* ✅ 3 أسطر فقط */
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.post-link{
  margin-top: auto;
  display:inline-flex;
  align-items:center;
  gap: 10px;
  font-weight: 950;
  color: #6d28d9;
  text-decoration:none;
  padding-top: 6px;
}

.post-link:hover{
  color: #4c1d95;
}

.pagination{
  display:flex;
  justify-content:center;
  gap: 14px;
  margin-top: 28px;
}