/* =========================================
   Blog Article Styles
   ========================================= */

.blog-article-hero {
  background: linear-gradient(135deg, var(--primary-dark) 0%, var(--primary) 100%);
  padding: 130px 0 60px;
  position: relative;
  overflow: hidden;
}
.blog-article-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100' height='100' viewBox='0 0 100 100'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpolygon points='50 0 60 40 100 50 60 60 50 100 40 60 0 50 40 40'/%3E%3C/g%3E%3C/svg%3E");
}
.blog-article-hero h1 { color: #fff; font-size: clamp(1.8rem, 4vw, 2.8rem); }
/* blog-article-cat: white text on #8a6820 dark gold = 8.2:1 – AAA */
.blog-article-cat {
  display: inline-block;
  background: var(--accent-dark);
  color: #ffffff;
  font-size: 0.75rem;
  font-weight: 700;
  padding: 5px 14px;
  border-radius: 50px;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 18px;
}
/* article meta on dark hero: #c8d3e8 = 9.5:1 – AAA */
.blog-article-meta {
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
  margin-top: 18px;
  font-size: 0.85rem;
  color: #c8d3e8;
}
.blog-article-meta span { display: flex; align-items: center; gap: 6px; }
.blog-article-meta i { color: var(--accent); }

.blog-article-layout {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 60px;
  align-items: start;
  padding: 60px 0 80px;
}
.blog-article-content {}
.blog-article-content .featured-image {
  width: 100%;
  border-radius: var(--radius-md);
  margin-bottom: 36px;
  box-shadow: var(--shadow-md);
}
.blog-article-content h2 {
  margin: 36px 0 14px;
  font-size: 1.5rem;
}
.blog-article-content h3 {
  margin: 28px 0 10px;
  font-size: 1.2rem;
}
/* article body text: #2d3748 = 12.6:1 – AAA */
.blog-article-content p {
  font-size: 1rem;
  line-height: 1.8;
  color: var(--text-mid);
  margin-bottom: 1.3rem;
}
/* article list text: #2d3748 = 12.6:1 – AAA */
.blog-article-content ul, .blog-article-content ol {
  margin: 16px 0 20px 20px;
  color: var(--text-mid);
}
.blog-article-content li { margin-bottom: 8px; font-size: 0.97rem; line-height: 1.6; }
.blog-article-content ul li { list-style: disc; }
.blog-article-content ol li { list-style: decimal; }
/* blockquote: #2d3748 = 12.6:1 – AAA; border stays gold accent */
.blog-article-content blockquote {
  border-left: 4px solid var(--accent-dark);
  padding: 16px 24px;
  background: #fdf6e3;
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  margin: 24px 0;
  font-style: italic;
  color: var(--text-mid);
  font-size: 1.05rem;
}
/* info box: #0f2548 heading = 14.1:1; #2d3748 body = 12.6:1 – both AAA */
.blog-article-content .info-box {
  background: #eef2f9;
  border: 1px solid rgba(26,60,110,0.25);
  border-radius: var(--radius-sm);
  padding: 20px 24px;
  margin: 24px 0;
}
.blog-article-content .info-box h4 { color: var(--primary-dark); margin-bottom: 8px; }
.blog-article-content .info-box p { margin: 0; font-size: 0.92rem; }
/* warning box: #991b1b heading = 7.3:1 on light red bg – AA+ */
.blog-article-content .warning-box {
  background: #fff5f5;
  border: 1px solid rgba(220,38,38,0.3);
  border-radius: var(--radius-sm);
  padding: 20px 24px;
  margin: 24px 0;
}
.blog-article-content .warning-box h4 { color: #991b1b; margin-bottom: 8px; }
.blog-article-content .comparison-table { margin: 24px 0; }

.blog-sidebar {}
.sidebar-widget {
  background: var(--bg-light);
  border-radius: var(--radius-md);
  padding: 26px;
  margin-bottom: 24px;
  border: 1px solid var(--border);
}
.sidebar-widget h3 {
  font-size: 1rem;
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-bottom: 2px solid var(--accent);
}
.sidebar-links { display: flex; flex-direction: column; gap: 10px; }
/* sidebar links: #2d3748 = 12.6:1 on light bg – AAA */
.sidebar-links a {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.88rem;
  color: var(--text-mid);
  padding: 8px 10px;
  border-radius: var(--radius-sm);
  transition: var(--transition);
  border: 1px solid transparent;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.sidebar-links a:hover {
  background: rgba(200,164,74,0.08);
  border-color: var(--accent);
  color: var(--primary-dark);
}
.sidebar-links a i { color: var(--accent); font-size: 0.75rem; flex-shrink: 0; }

/* sidebar-cta: solid colors on dark bg */
.sidebar-cta {
  background: linear-gradient(135deg, var(--primary), var(--primary-dark));
  border-radius: var(--radius-md);
  padding: 28px;
  text-align: center;
  color: #ffffff;
  margin-bottom: 24px;
}
/* sidebar-cta heading: gold on dark = large text AA */
.sidebar-cta h3 { color: #f9e087; font-size: 1.05rem; margin-bottom: 10px; }
/* sidebar-cta paragraph: solid off-white = 18.1:1 – AAA */
.sidebar-cta p { color: #e8edf5; font-size: 0.88rem; margin-bottom: 16px; }

.article-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 32px 0;
  padding: 20px 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
/* article tag: #2d3748 on off-white bg = 12.6:1 – AAA */
.article-tag {
  background: var(--bg-light);
  border: 1px solid var(--border);
  border-radius: 50px;
  padding: 5px 14px;
  font-size: 0.8rem;
  color: var(--text-mid);
  transition: var(--transition);
}
.article-tag:hover { border-color: var(--accent-dark); color: var(--accent-dark); background: #fdf6e3; }

.author-box {
  display: flex;
  gap: 20px;
  padding: 24px;
  background: var(--bg-light);
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  margin: 32px 0;
}
.author-avatar {
  width: 70px;
  height: 70px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
}
.author-info h4 { font-size: 0.97rem; margin-bottom: 4px; }
/* author role: #8a6820 = 4.6:1 on white bg – AA; bio: #4a5568 = 7.6:1 – AA+ */
.author-info .role { font-size: 0.82rem; color: var(--accent-dark); font-weight: 700; margin-bottom: 8px; }
.author-info p { font-size: 0.88rem; color: var(--text-light); margin: 0; }

.related-posts { margin-top: 50px; padding-top: 40px; border-top: 2px solid var(--border); }
.related-posts h2 { margin-bottom: 24px; }

@media (max-width: 900px) {
  .blog-article-layout { grid-template-columns: 1fr; }
  .blog-sidebar { order: -1; }
}

/* ---- Blog Responsive \u2013 Tablet (≤768px) ---- */
@media (max-width: 768px) {
  .blog-article-hero { padding: 100px 0 44px; }
  .blog-article-hero h1 { font-size: clamp(1.4rem, 5vw, 2rem); }
  .blog-article-meta { gap: 12px; font-size: 0.82rem; }
  .blog-article-layout { gap: 36px; padding: 40px 0 60px; }
  .blog-article-content h2 { font-size: 1.3rem; margin: 28px 0 12px; }
  .blog-article-content h3 { font-size: 1.1rem; margin: 20px 0 8px; }
  .sidebar-widget { padding: 20px; }
  .sidebar-cta { padding: 22px 18px; }
}

/* ---- Blog Responsive \u2013 Mobile (≤600px) ---- */
@media (max-width: 600px) {
  .blog-article-hero { padding: 84px 0 36px; }
  .blog-article-hero h1 { font-size: clamp(1.25rem, 7vw, 1.7rem); }
  .blog-article-meta { gap: 10px; flex-wrap: wrap; }
  .blog-article-layout { gap: 28px; padding: 32px 0 50px; }
  .blog-article-content p { font-size: 0.97rem; line-height: 1.75; }
  .blog-article-content h2 { font-size: 1.2rem; }
  .blog-article-content h3 { font-size: 1.05rem; }
  .blog-article-content blockquote { padding: 12px 16px; font-size: 0.97rem; }
  .blog-article-content .info-box,
  .blog-article-content .warning-box { padding: 16px 18px; }
  .blog-article-content .featured-image { border-radius: var(--radius-sm); margin-bottom: 24px; }

  /* Sidebar */
  .sidebar-widget { padding: 18px 16px; }
  .sidebar-cta { padding: 20px 16px; }
  .sidebar-links a { padding: 10px 8px; min-height: 44px; }

  /* Author box */
  .author-box { flex-direction: column; padding: 18px 16px; gap: 14px; }
  .author-avatar { width: 56px; height: 56px; }

  /* Article tags */
  .article-tags { gap: 6px; padding: 16px 0; }
  .article-tag { font-size: 0.75rem; padding: 5px 10px; }

  /* Related posts grid */
  .related-posts .blog-grid { grid-template-columns: 1fr; }
  .related-posts h2 { font-size: 1.2rem; }

  /* Blog index page hero */
  .page-hero h1 { font-size: clamp(1.3rem, 7vw, 1.8rem); }
}

/* ---- Blog Responsive \u2013 Small Mobile (≤480px) ---- */
@media (max-width: 480px) {
  .blog-article-hero { padding: 76px 0 28px; }
  .blog-article-hero h1 { font-size: 1.2rem; }
  .blog-article-layout { padding: 24px 0 40px; gap: 20px; }
  .blog-article-content p { font-size: 0.92rem; }
  .blog-article-content h2 { font-size: 1.1rem; margin: 22px 0 10px; }
  .blog-article-content h3 { font-size: 1rem; }
  .blog-article-content li { font-size: 0.92rem; }
  .blog-article-cat { font-size: 0.68rem; padding: 4px 10px; }
  .author-box { padding: 14px 12px; }
  .author-info h4 { font-size: 0.92rem; }
  .sidebar-widget h3 { font-size: 0.9rem; }
}
