/* =========================================================
   blog.css — المثالية كلين
   ========================================================= */

/* =========================================================
   Blog Layout — Article + Sidebar
   ========================================================= */
.blog-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: 40px;
  padding-top: 56px;
  padding-bottom: 80px;
}

/* =========================================================
   Article
   ========================================================= */
.blog-article {
  min-width: 0;
}

.article-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  margin-bottom: 32px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--border);
}

.article-meta span {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.84rem;
  color: var(--text-subtle);
  font-family: var(--font-display);
}

.article-meta i {
  color: var(--primary);
  font-size: 1rem;
}

/* Article Body */
.article-body { line-height: 1.9; }

.article-intro {
  font-size: 1.08rem;
  color: var(--text-muted);
  line-height: 1.9;
  margin-bottom: 32px;
  padding: 20px 22px;
  background: var(--eyebrow-bg);
  border-right: 4px solid var(--primary);
  border-radius: 0 var(--radius) var(--radius) 0;
}

.article-body h2 {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(1.2rem, 2.5vw, 1.55rem);
  color: var(--text);
  margin: 40px 0 16px;
  padding-bottom: 10px;
  border-bottom: 2px solid var(--border);
}

.article-body h3 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.1rem;
  color: var(--primary);
  margin: 28px 0 12px;
}

.article-body p {
  color: var(--text-muted);
  margin-bottom: 18px;
  font-size: 0.97rem;
}

.article-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: 24px;
}

.article-list li {
  display: flex;
  gap: 10px;
  font-size: 0.94rem;
  color: var(--text-muted);
  line-height: 1.7;
  padding: 12px 16px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
}

.article-list li::before {
  content: '';
  width: 7px;
  height: 7px;
  min-width: 7px;
  border-radius: 50%;
  background: var(--primary);
  margin-top: 8px;
  flex-shrink: 0;
}

.article-list li strong {
  color: var(--text);
  font-weight: 700;
}

/* Service Highlights Grid */
.service-highlight-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  margin: 24px 0 32px;
}

.service-highlight {
  padding: 20px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--card-shadow);
  text-align: center;
  transition: border-color var(--transition), transform var(--transition);
}

.service-highlight:hover {
  border-color: var(--border-hover);
  transform: translateY(-3px);
}

.service-highlight i {
  font-size: 2rem;
  color: var(--primary);
  margin-bottom: 10px;
  display: block;
}

.service-highlight h4 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 0.9rem;
  color: var(--text);
  margin-bottom: 7px;
}

.service-highlight p {
  font-size: 0.82rem;
  color: var(--text-muted);
  line-height: 1.6;
  margin: 0;
}

/* Schedule Table */
.schedule-table {
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  margin: 24px 0 32px;
  box-shadow: var(--card-shadow);
}

.schedule-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  padding: 14px 20px;
  border-bottom: 1px solid var(--border);
  font-size: 0.9rem;
  color: var(--text-muted);
  gap: 10px;
  align-items: center;
}

.schedule-row:last-child { border-bottom: none; }

.schedule-row.header {
  background: var(--primary);
  color: #fff;
  font-family: var(--font-display);
  font-weight: 700;
}

.schedule-row:not(.header):nth-child(even) {
  background: var(--eyebrow-bg);
}

/* =========================================================
   Article FAQ
   ========================================================= */
.article-faq {
  margin-top: 48px;
  padding-top: 32px;
  border-top: 2px solid var(--border);
}

.article-faq h2 {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 1.4rem;
  color: var(--text);
  margin-bottom: 24px;
}

/* =========================================================
   Article CTA
   ========================================================= */
.article-cta {
  margin-top: 48px;
  padding: 36px 28px;
  background: var(--cta-bg);
  border: 1px solid var(--cta-border);
  border-radius: var(--radius-lg);
  text-align: center;
}

.article-cta h3 {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 1.3rem;
  color: var(--text);
  margin-bottom: 8px;
}

.article-cta p {
  color: var(--text-muted);
  font-size: 0.95rem;
  margin-bottom: 22px;
}

/* =========================================================
   Related Posts
   ========================================================= */
.related-posts {
  margin-top: 48px;
  padding-top: 32px;
  border-top: 2px solid var(--border);
}

.related-posts h3 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.1rem;
  color: var(--text);
  margin-bottom: 18px;
}

.related-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}

.related-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: 18px 12px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  text-decoration: none;
  text-align: center;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 0.84rem;
  color: var(--text-muted);
  transition: all var(--transition);
  box-shadow: var(--card-shadow);
}

.related-card:hover {
  border-color: var(--primary);
  color: var(--primary);
  transform: translateY(-3px);
  box-shadow: var(--card-hover-shadow);
}

.related-card i {
  font-size: 1.4rem;
  color: var(--primary);
}

/* =========================================================
   Sidebar
   ========================================================= */
.blog-sidebar {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.sidebar-widget {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 22px;
  box-shadow: var(--card-shadow);
}

.sidebar-widget h4 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 0.95rem;
  color: var(--text);
  margin-bottom: 16px;
  padding-bottom: 10px;
  border-bottom: 2px solid var(--border);
}

.sidebar-contact-btn {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  border-radius: var(--radius);
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 0.9rem;
  text-decoration: none;
  margin-bottom: 10px;
  transition: all var(--transition);
}

.sidebar-contact-btn:last-child { margin-bottom: 0; }

.sidebar-contact-btn.phone {
  background: var(--btn-primary-bg);
  color: #fff;
}

.sidebar-contact-btn.phone:hover {
  background: var(--btn-primary-hover);
  transform: translateY(-2px);
}

.sidebar-contact-btn.wa {
  background: #25D366;
  color: #fff;
}

.sidebar-contact-btn.wa:hover {
  background: #1da851;
  transform: translateY(-2px);
}

.sidebar-areas {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.sidebar-areas li a {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 9px 12px;
  border-radius: var(--radius);
  font-size: 0.88rem;
  color: var(--text-muted);
  text-decoration: none;
  transition: all var(--transition);
  border: 1px solid transparent;
}

.sidebar-areas li a:hover,
.sidebar-areas li a.active {
  color: var(--primary);
  background: var(--eyebrow-bg);
  border-color: var(--border);
}

.sidebar-areas li a i {
  font-size: 1rem;
  color: var(--primary);
}

/* =========================================================
   Blog Index Page
   ========================================================= */
.blog-index-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 28px;
  padding: 56px 0 80px;
}

.blog-index-card {
  display: flex;
  flex-direction: column;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  text-decoration: none;
  box-shadow: var(--card-shadow);
  transition: all var(--transition);
}

.blog-index-card:hover {
  border-color: var(--border-hover);
  transform: translateY(-5px);
  box-shadow: var(--card-hover-shadow);
}

.blog-card-icon {
  height: 180px;
  background: var(--eyebrow-bg);
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2.8rem;
  color: var(--primary);
  overflow: hidden;
  position: relative;
}

.blog-card-icon img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.blog-card-icon .fallback-icon {
  position: absolute;
  font-size: 2.8rem;
  color: var(--primary);
}

.blog-card-body { padding: 22px; flex: 1; }

.blog-card-tag {
  display: inline-block;
  font-size: 0.72rem;
  font-weight: 700;
  font-family: var(--font-display);
  color: var(--eyebrow-color);
  background: var(--eyebrow-bg);
  border: 1px solid var(--eyebrow-border);
  border-radius: 50px;
  padding: 3px 10px;
  margin-bottom: 10px;
  letter-spacing: 0.08em;
}

.blog-card-body h2 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.05rem;
  color: var(--text);
  margin-bottom: 8px;
  line-height: 1.4;
}

.blog-card-body p {
  font-size: 0.88rem;
  color: var(--text-muted);
  line-height: 1.7;
  margin-bottom: 16px;
}

.blog-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: 14px;
  border-top: 1px solid var(--border);
}

.blog-card-date {
  font-size: 0.78rem;
  color: var(--text-subtle);
  display: flex;
  align-items: center;
  gap: 5px;
}

.blog-card-read {
  font-family: var(--font-display);
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--primary);
  display: flex;
  align-items: center;
  gap: 5px;
}

/* =========================================================
   Homepage Blog Section
   ========================================================= */
.home-blog-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
  margin-bottom: 36px;
}

.home-blog-card {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 18px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  text-decoration: none;
  box-shadow: var(--card-shadow);
  transition: all var(--transition);
}

.home-blog-card:hover {
  border-color: var(--border-hover);
  transform: translateX(-4px);
  box-shadow: var(--card-hover-shadow);
}

.home-blog-icon {
  width: 52px;
  height: 52px;
  min-width: 52px;
  border-radius: 13px;
  background: var(--eyebrow-bg);
  border: 1px solid var(--eyebrow-border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  color: var(--primary);
}

.home-blog-text h3 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 0.93rem;
  color: var(--text);
  margin-bottom: 4px;
  line-height: 1.45;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: 2.7em;
}

.home-blog-text p {
  font-size: 0.82rem;
  color: var(--text-muted);
  line-height: 1.5;
}

/* =========================================================
   Responsive — 768px
   ========================================================= */
@media (min-width: 768px) {
  .blog-layout {
    grid-template-columns: 1fr 280px;
  }

  .service-highlight-grid {
    grid-template-columns: repeat(4, 1fr);
  }

  .blog-index-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .home-blog-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .blog-layout {
    grid-template-columns: 1fr 300px;
  }

  .blog-index-grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .home-blog-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
