/* =============================================================================
   BST MOVERS — BLOG & SINGLE POST STYLES
   Depends on: front-page.css (nav, footer, topbar, buttons)
   Used by: page-blog.php, single.php
   ============================================================================= */

/* ── BLOG PAGE HERO ── */
.blog-hero {
  background: rgb(152, 27, 37);
  border-bottom: 1px solid var(--border2);
  padding: 48px 48px 40px;
  margin-top: 145px;
}
.blog-hero-inner { max-width: 1100px; margin: 0 auto; }
.blog-hero h1 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: clamp(28px, 4vw, 44px);
  font-weight: 800;
  color: var(--white);
  letter-spacing: -.025em;
  margin-bottom: 8px;
}
.blog-hero p { font-size: 15px; color: rgba(255,255,255,.6); }

/* ── BLOG GRID ── */
.blog-body {
  background: rgb(173, 31, 42);
  padding: 56px 48px 80px;
}
.blog-body-inner { max-width: 1100px; margin: 0 auto; }

.blog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-bottom: 56px;
}

/* ── ARTICLE CARD ── */
.blog-card {
  background: rgb(152, 27, 37);
  border: 1px solid var(--border2);
  border-radius: 16px;
  overflow: hidden;
  transition: all .3s ease;
  text-decoration: none;
  display: flex;
  flex-direction: column;
}
.blog-card:hover {
  border-color: rgba(255,154,170,.4);
  transform: translateY(-4px);
  box-shadow: 0 16px 40px rgba(0,0,0,.3);
}
.blog-card-thumb {
  width: 100%;
  aspect-ratio: 16/9;
  object-fit: cover;
  display: block;
}
.blog-card-thumb-placeholder {
  width: 100%;
  aspect-ratio: 16/9;
  background: rgba(213,38,53,.2);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 40px;
}
.blog-card-body { padding: 20px 22px 24px; flex: 1; display: flex; flex-direction: column; }
.blog-card-cat {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #ff9aaa;
  margin-bottom: 10px;
  font-family: 'Plus Jakarta Sans', sans-serif;
}
.blog-card-title {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 16px;
  font-weight: 700;
  color: var(--white);
  line-height: 1.35;
  margin-bottom: 10px;
  letter-spacing: -.01em;
}
.blog-card-excerpt {
  font-size: 13px;
  color: rgba(232,243,255,.6);
  line-height: 1.65;
  flex: 1;
  margin-bottom: 16px;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.blog-card-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 12px;
  color: rgba(255,255,255,.4);
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 600;
  border-top: 1px solid var(--border2);
  padding-top: 12px;
}
.blog-card-read { color: #ff9aaa; font-weight: 700; }

/* ── PAGINATION ── */
.blog-pagination {
  display: flex;
  justify-content: center;
  gap: 8px;
  flex-wrap: wrap;
}
.blog-pagination a,
.blog-pagination span {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 10px;
  font-size: 14px;
  font-weight: 700;
  font-family: 'Plus Jakarta Sans', sans-serif;
  text-decoration: none;
  transition: all .2s;
  border: 1px solid var(--border2);
  color: rgba(255,255,255,.6);
}
.blog-pagination a:hover { background: rgba(255,255,255,.1); color: #fff; border-color: rgba(255,154,170,.4); }
.blog-pagination .current { background: var(--red); color: #fff; border-color: var(--red); }

/* ── NO POSTS ── */
.blog-empty {
  text-align: center;
  padding: 80px 20px;
  color: rgba(255,255,255,.5);
  font-size: 15px;
}
.blog-empty strong { display: block; font-size: 20px; color: var(--white); margin-bottom: 8px; font-family: 'Plus Jakarta Sans', sans-serif; }

/* ═══════════════════════════════════════════════════════════
   SINGLE POST
   ══════════════════════════════════════════════════════════= */

/* ── SINGLE HERO ── */
.single-hero {
  margin-top: 145px;
  background: #ffcccc;
  border-bottom: 1px solid #e0e0e0;
  padding: 48px 48px 40px;
}
.single-hero-inner { max-width: 1100px; margin: 0 auto; }
.single-cat {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--red);
  margin-bottom: 16px;
  font-family: 'Plus Jakarta Sans', sans-serif;
}
.single-hero h1 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: clamp(26px, 4vw, 40px);
  font-weight: 800;
  color: #1a1a1a;
  line-height: 1.2;
  letter-spacing: -.025em;
  margin-bottom: 20px;
}
.single-meta {
  display: flex;
  align-items: center;
  gap: 20px;
  font-size: 13px;
  color: #888;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 600;
  flex-wrap: wrap;
}
.single-meta span { display: flex; align-items: center; gap: 6px; }

/* ── FEATURED IMAGE ── */
.single-featured {
  background: #ffcccc;
  padding: 0 48px;
}
.single-featured img {
  max-width: 1100px;
  width: 100%;
  margin: 0 auto;
  display: block;
  border-radius: 16px 16px 16px 16px;
  max-height: 420px;
  object-fit: cover;
}

/* ── SINGLE CONTENT ── */
.single-body {
  background: #ffb3b3;
  padding: 48px 48px 80px;
}
.single-body-inner {
  max-width: 1100px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: 48px;
  align-items: start;
}

/* Article content */
.single-content { color: #333; font-size: 15px; line-height: 1.85; font-family: 'Nunito', sans-serif; }
.single-content h2 { font-family: 'Plus Jakarta Sans', sans-serif; font-size: 22px; font-weight: 800; color: #1a1a1a; margin: 36px 0 12px; letter-spacing: -.02em; }
.single-content h3 { font-family: 'Plus Jakarta Sans', sans-serif; font-size: 17px; font-weight: 700; color: #1a1a1a; margin: 24px 0 8px; }
.single-content p { margin-bottom: 16px; }
.single-content ul,
.single-content ol { padding-left: 22px; margin-bottom: 16px; }
.single-content li { margin-bottom: 8px; }
.single-content strong { color: #1a1a1a; font-weight: 700; }
.single-content a { color: var(--red); text-decoration: underline; }
.single-content a:hover { color: #a00; }
.single-content img { max-width: 100%; border-radius: 10px; margin: 20px 0; }
.single-content blockquote {
  border-left: 3px solid var(--red);
  padding: 14px 18px;
  margin: 24px 0;
  background: rgba(213,38,53,.07);
  border-radius: 0 10px 10px 0;
  font-style: italic;
  color: #555;
}
.single-content hr { border: none; border-top: 1px solid #ddd; margin: 32px 0; }

/* Sidebar */
.single-sidebar { position: sticky; top: 200px; }
.sidebar-card {
  background: #fff;
  border: 1px solid #e0e0e0;
  border-radius: 14px;
  padding: 22px;
  margin-bottom: 16px;
}
.sidebar-card-title {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #888;
  margin-bottom: 16px;
}
.sidebar-post {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  padding: 10px 0;
  border-bottom: 1px solid #eee;
  text-decoration: none;
  transition: all .2s;
}
.sidebar-post:last-child { border-bottom: none; padding-bottom: 0; }
.sidebar-post:hover .sidebar-post-title { color: var(--red); }
.sidebar-post-img { width: 52px; height: 52px; border-radius: 8px; object-fit: cover; flex-shrink: 0; background: rgba(213,38,53,.1); }
.sidebar-post-title { font-size: 13px; font-weight: 600; color: #1a1a1a; line-height: 1.4; font-family: 'Plus Jakarta Sans', sans-serif; }
.sidebar-post-date { font-size: 11px; color: #888; margin-top: 4px; }

/* CTA sidebar */
.sidebar-cta {
  background: rgba(213,38,53,.07);
  border: 1px solid rgba(213,38,53,.2);
  border-radius: 14px;
  padding: 22px;
  text-align: center;
}
.sidebar-cta p { font-size: 13px; color: #555; line-height: 1.6; margin-bottom: 14px; font-family: 'Nunito', sans-serif; }

/* ── POST NAV ── */
.single-post-nav {
  max-width: 1100px;
  margin: 0 auto;
  padding: 32px 48px 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  border-top: 1px solid #ddd;
}
.post-nav-item {
  background: #fff;
  border: 1px solid #e0e0e0;
  border-radius: 12px;
  padding: 16px 18px;
  text-decoration: none;
  transition: all .2s;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.post-nav-item:hover { border-color: rgba(213,38,53,.3); background: rgba(213,38,53,.04); }
.post-nav-item.next { text-align: right; }
.post-nav-label { font-size: 11px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: #888; font-family: 'Plus Jakarta Sans', sans-serif; }
.post-nav-title { font-size: 13px; font-weight: 600; color: #1a1a1a; line-height: 1.4; font-family: 'Plus Jakarta Sans', sans-serif; }

/* ── RESPONSIVE ── */
@media (max-width: 900px) {
  .blog-hero { padding: 36px 20px 30px; margin-top: 120px; }
  .blog-body { padding: 36px 20px 60px; }
  .blog-grid { grid-template-columns: repeat(2, 1fr); }
  .single-hero { margin-top: 120px; padding: 36px 20px 28px; }
  .single-featured { padding: 0 20px; }
  .single-body { padding: 36px 20px 60px; }
  .single-body-inner { grid-template-columns: 1fr; max-width: 100%; }
  .single-sidebar { position: static; }
  .single-post-nav { padding: 24px 20px 0; }
}
@media (max-width: 600px) {
  .blog-grid { grid-template-columns: 1fr; }
  .single-post-nav { grid-template-columns: 1fr; }
  .post-nav-item.next { text-align: left; }
}