/* =========================================================
   🎨 IRON TV PRO — main.css
   Light Warm UI (Orange/Peach) — 2026
   ========================================================= */

:root{
  --bg: #fff7ed;          /* very light orange */
  --bg-2: #ffffff;
  --text: #24324a;        /* لا أسود */
  --muted: #5b6b86;

  --primary: #fb923c;     /* orange */
  --secondary: #f97316;   /* deep orange */
  --accent: #fde68a;      /* soft amber */

  --light: #fff1e6;
  --card: #ffffff;

  --radius: 1.15rem;
  --shadow: 0 10px 28px rgba(36, 50, 74, 0.10);
  --border: rgba(249, 115, 22, 0.18);
  --ring: rgba(251, 146, 60, 0.18);
}

*{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%, #fffdfb 100%);
  color: var(--text);
  line-height: 1.65;
}

img{max-width:100%;height:auto;display:block;}
a{color:var(--secondary);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.88);
  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:#000;} 
.logo{width:40px;}

.menu{display:flex; gap:1rem; align-items:center;}
.menu a{
  color: var(--text);
  font-weight: 700;
  padding: .45rem .7rem;
  border-radius: .8rem;
}
.menu a:hover{
  background: rgba(249, 115, 22, 0.10);
}

/* 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.70);
  border-radius: 999px;
}

/* ---------- Hero ---------- */
.hero{
  background:
    radial-gradient(800px 300px at 50% 10%, rgba(251,146,60,0.22), transparent 60%),
    radial-gradient(800px 300px at 50% 40%, rgba(249,115,22,0.18), transparent 60%),
    linear-gradient(135deg, #fff3e8, #ffffff);
  text-align:center;
  padding: 6.2rem 1rem 5.5rem;
}

.badge-top{
  display:inline-block;
  background: linear-gradient(135deg, rgba(251,146,60,0.18), rgba(249,115,22,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(--secondary); font-weight:800;}
.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: 900;
  text-decoration:none;
  transition: transform .18s ease, box-shadow .18s ease, opacity .18s ease;
  box-shadow: 0 10px 18px rgba(249, 115, 22, 0.16);
}
.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(249, 115, 22, 0.22);}

.btn--ghost{
  background: rgba(255,255,255,0.92);
  border: 2px solid rgba(249, 115, 22, 0.35);
  color: var(--secondary);
  box-shadow: none;
}
.btn--ghost:hover{
  background: rgba(249, 115, 22, 0.08);
}

/* ---------- Cards ---------- */
.card{
  background: var(--card);
  border-radius: var(--radius);
  padding: 2rem;
  text-align:center;
  box-shadow: var(--shadow);
  border: 1px solid rgba(249,115,22,0.12);
}
.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: 950;
}

/* ---------- Tabs / Pricing ---------- */
.tabs{display:flex; justify-content:center; margin-bottom:2rem; gap:1rem; flex-wrap:wrap;}
.tab-btn{
  background: rgba(249, 115, 22, 0.10);
  border: 1px solid rgba(249,115,22,0.16);
  padding: .65rem 1.2rem;
  border-radius: 999px;
  cursor:pointer;
  font-weight: 900;
  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(249,115,22,0.12);
  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:900; color:var(--muted);}
.p-price{font-size:1.9rem; font-weight:950; 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(253,230,138,0.95);
  box-shadow: 0 18px 40px rgba(249,115,22,0.12);
}
.badge{
  position:absolute; top: 12px; right: 12px;
  background: rgba(253,230,138,0.95);
  color: var(--text);
  padding: .35rem .6rem;
  border-radius: .75rem;
  font-size: .82rem;
  font-weight: 950;
}

/* ---------- 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(249,115,22,0.14); 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(249,115,22,0.12);
  flex: 1; min-width: 250px;
}
.testi blockquote{margin:.6rem 0; color:var(--muted);}

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

/* ---------- 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(249,115,22,0.16);
  border-radius: var(--radius);
  padding: 1rem;
  background: var(--card);
  box-shadow: 0 10px 20px rgba(36, 50, 74, 0.06);
}
.faq summary{font-weight: 950; 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:900;}

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

/* ---------- 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 ---------- */
.sticky-bar{
  position: fixed;
  bottom: 0; left: 0;
  width: 100%;
  background: #ffffff;
  box-shadow: 0 10px 26px rgba(249,115,22,.18);
  padding: .85rem 1rem;
  z-index: 999;

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

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

.sticky-text{
  color: var(--text);
  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%;
  }

  .whatsapp-float{
    bottom: 90px;
  }
}

/* ---------- Shimmer ---------- */
.shimmer{
  position: relative;
  display:inline-block;
  background: linear-gradient(135deg, var(--secondary), var(--primary));
  -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.55) 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%);}
}

/* ---------- Responsive ---------- */
@media (max-width: 768px){
  .menu{
    display:none;
    flex-direction:column;
    gap: .6rem;
    background: rgba(255,255,255,0.96);
    backdrop-filter: blur(10px);
    padding: 1rem;
    position:absolute;
    top: 64px;
    right: 10px;
    border-radius: 1rem;
    box-shadow: var(--shadow);
    border: 1px solid rgba(249,115,22,0.16);
    min-width: 220px;
  }
  .menu.show{display:flex;}
  .hamburger{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;}

  .footer nav{flex-direction: column; gap: .5rem;}
}

/* FIX: Hero title/badge overflow */
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-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(255,122,0,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(255,122,0,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(255,122,0,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: #fff1e8;
}

.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, #ff5a00, #ffb000);
  box-shadow: 0 10px 22px rgba(255,122,0,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: #ff7a00;
  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(255,122,0,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(255,122,0,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(255,122,0,0.18);
  border-radius: 14px;
  padding: 12px 14px;
  outline: none;
  background: #fff;
}

.search-bar input:focus, .newsletter input:focus{
  border-color: rgba(255,122,0,0.45);
  box-shadow: 0 0 0 4px rgba(255,122,0,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(255,122,0,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(255,122,0,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: #fff1e8;
}

/* 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(255,90,0,0.95), rgba(255,176,0,0.95));
  box-shadow: 0 12px 20px rgba(255,122,0,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: #ff7a00;
  text-decoration:none;
  padding-top: 6px;
}

.post-link:hover{
  color: #e65f00;
}

/* 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(255,122,0,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(255,122,0,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(255,122,0,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(255,122,0,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: #fff1e8;
}

.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(255,90,0,0.95), rgba(255,176,0,0.95));
  box-shadow: 0 12px 20px rgba(255,122,0,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: #ff7a00;
  text-decoration:none;
  padding-top: 6px;
}

.post-link:hover{
  color: #e65f00;
}

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