/* ============================================================
   Saaph.in — Blog styles (navy + saffron, long-form reading)
   Loads after main.css; uses its design tokens.
   ============================================================ */

.blog-shell { max-width: 1080px; margin: 0 auto; padding: 0 var(--space-5); }

/* ---- Blog index ---- */
.blog-hero { text-align: center; padding: var(--space-16) 0 var(--space-10); }
.blog-hero .eyebrow {
  display: inline-block; color: var(--color-primary); font-family: var(--font-heading);
  font-weight: 700; font-size: 13px; letter-spacing: 0.08em; text-transform: uppercase;
  margin-bottom: var(--space-3);
}
.blog-hero h1 {
  font-family: var(--font-heading); font-weight: 800; color: var(--text-primary);
  font-size: clamp(32px, 6vw, 52px); line-height: 1.05; margin: 0 0 var(--space-4);
}
.blog-hero p { color: var(--text-secondary); font-size: 18px; max-width: 640px; margin: 0 auto; }

.blog-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: var(--space-6); padding-bottom: var(--space-20);
}
.blog-card {
  display: flex; flex-direction: column; background: var(--bg-surface);
  border: 1px solid var(--border-default); border-radius: var(--radius-xl);
  padding: var(--space-6); text-decoration: none; transition: transform var(--dur-normal) var(--ease-out), border-color var(--dur-normal);
}
.blog-card:hover { transform: translateY(-4px); border-color: var(--color-primary-border); box-shadow: var(--shadow-card-hover); }
.blog-card-tag {
  align-self: flex-start; font-size: 11px; font-weight: 700; letter-spacing: 0.05em;
  text-transform: uppercase; color: var(--color-primary); background: var(--color-primary-dim);
  border: 1px solid var(--color-primary-border); padding: 4px 10px; border-radius: var(--radius-pill);
  margin-bottom: var(--space-4);
}
.blog-card h2 { font-family: var(--font-heading); font-weight: 700; color: var(--text-primary); font-size: 21px; line-height: 1.25; margin: 0 0 var(--space-3); }
.blog-card p { color: var(--text-secondary); font-size: 14.5px; line-height: 1.55; margin: 0 0 var(--space-4); flex: 1; }
.blog-card-meta { color: var(--text-muted); font-size: 13px; font-weight: 600; }
.blog-card-meta .arrow { color: var(--color-primary); }

/* ---- Article ---- */
.article-wrap { max-width: 760px; margin: 0 auto; padding: 0 var(--space-5); }
.article-breadcrumb { font-size: 13px; color: var(--text-muted); padding: var(--space-8) 0 0; }
.article-breadcrumb a { color: var(--text-secondary); text-decoration: none; }
.article-breadcrumb a:hover { color: var(--color-primary); }

.article-header { padding: var(--space-6) 0 var(--space-6); border-bottom: 1px solid var(--border-subtle); margin-bottom: var(--space-8); }
.article-tag {
  display: inline-block; font-size: 11px; font-weight: 700; letter-spacing: 0.05em; text-transform: uppercase;
  color: var(--color-primary); background: var(--color-primary-dim); border: 1px solid var(--color-primary-border);
  padding: 4px 10px; border-radius: var(--radius-pill); margin-bottom: var(--space-4);
}
.article-header h1 { font-family: var(--font-heading); font-weight: 800; color: var(--text-primary); font-size: clamp(30px, 5.5vw, 46px); line-height: 1.08; margin: 0 0 var(--space-4); }
.article-meta { color: var(--text-muted); font-size: 14px; }
.article-meta strong { color: var(--text-secondary); }

.article-body { color: var(--text-secondary); font-size: 17.5px; line-height: 1.7; }
.article-body h2 { font-family: var(--font-heading); font-weight: 700; color: var(--text-primary); font-size: 28px; line-height: 1.2; margin: var(--space-12) 0 var(--space-4); }
.article-body h3 { font-family: var(--font-heading); font-weight: 700; color: var(--text-primary); font-size: 21px; margin: var(--space-8) 0 var(--space-3); }
.article-body p { margin: 0 0 var(--space-5); }
.article-body a { color: var(--color-primary); text-decoration: underline; text-underline-offset: 2px; }
.article-body ul, .article-body ol { margin: 0 0 var(--space-5); padding-left: var(--space-6); }
.article-body li { margin-bottom: var(--space-3); }
.article-body strong { color: var(--text-primary); }
.article-body img { max-width: 100%; border-radius: var(--radius-lg); border: 1px solid var(--border-default); }

/* Short-answer / TL;DR block (AEO) */
.short-answer {
  background: var(--color-primary-dim); border: 1px solid var(--color-primary-border);
  border-left: 4px solid var(--color-primary); border-radius: var(--radius-md);
  padding: var(--space-5) var(--space-6); margin: 0 0 var(--space-8);
}
.short-answer .label { font-family: var(--font-heading); font-weight: 700; font-size: 13px; letter-spacing: 0.04em; text-transform: uppercase; color: var(--color-primary); margin-bottom: var(--space-2); }
.short-answer p { color: var(--text-primary); font-size: 16px; margin: 0; }

/* Steps */
.step-card {
  display: flex; gap: var(--space-4); padding: var(--space-5) 0; border-top: 1px solid var(--border-subtle);
}
.step-num {
  flex-shrink: 0; width: 34px; height: 34px; border-radius: 50%; background: var(--color-primary);
  color: #fff; font-family: var(--font-heading); font-weight: 800; display: grid; place-items: center; font-size: 16px;
}
.step-card h3 { margin: 2px 0 var(--space-2); }
.step-card p { margin: 0; font-size: 16px; }

/* Tables */
.article-table-wrap { overflow-x: auto; margin: 0 0 var(--space-6); border: 1px solid var(--border-default); border-radius: var(--radius-lg); }
.article-table { width: 100%; border-collapse: collapse; font-size: 15px; min-width: 520px; }
.article-table th { text-align: left; background: var(--bg-raised); color: var(--text-primary); font-family: var(--font-heading); font-weight: 700; padding: 12px 16px; border-bottom: 1px solid var(--border-default); }
.article-table td { padding: 12px 16px; border-bottom: 1px solid var(--border-subtle); color: var(--text-secondary); }
.article-table tr:last-child td { border-bottom: none; }

/* CTA block */
.post-cta {
  background: var(--bg-surface); border: 1px solid var(--color-primary-border);
  border-radius: var(--radius-xl); padding: var(--space-8); text-align: center; margin: var(--space-12) 0;
  box-shadow: var(--shadow-saffron);
}
.post-cta h3 { font-family: var(--font-heading); font-weight: 800; color: var(--text-primary); font-size: 24px; margin: 0 0 var(--space-2); }
.post-cta p { color: var(--text-secondary); margin: 0 0 var(--space-5); font-size: 16px; }

/* FAQ */
.faq-block { margin: var(--space-12) 0; }
.faq-block h2 { margin-bottom: var(--space-5); }
.faq-item { border: 1px solid var(--border-default); border-radius: var(--radius-md); padding: var(--space-5); margin-bottom: var(--space-4); background: var(--bg-surface); }
.faq-item h3 { margin: 0 0 var(--space-2); font-size: 18px; }
.faq-item p { margin: 0; font-size: 16px; }

.article-disclaimer { font-size: 13px; color: var(--text-muted); border-top: 1px solid var(--border-subtle); padding-top: var(--space-5); margin-top: var(--space-10); line-height: 1.6; }

@media (max-width: 600px) {
  .article-body { font-size: 16.5px; }
  .article-body h2 { font-size: 24px; }
}
