/* ==========================================================================
   RepX Theme — Blog Styles
   Styles for blog hub, single posts, archives, search, sidebar
   ========================================================================== */

/* ==========================================================================
   BLOG HUB — Hero, Search, Grid Header
   ========================================================================== */

/* ── Blog Hub Hero ────────────────────────────────────────────────────── */
/* Layout (text-align, padding, overflow) handled by .about-hero in homepage.css.
   Headline/subtitle max-width also handled by .about-hero rules.
   .blog-hub-hero is kept as a hook for blog-specific overrides if needed. */

/* ── Blog Hub Search ──────────────────────────────────────────────────── */
.blog-hub-search {
  max-width: 32rem;
  margin: var(--space-xl) auto 0;
}

.blog-hub-search__form {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: var(--radius-pill);
  padding: 0.375rem 0.375rem 0.375rem 1.25rem;
  transition: all var(--transition-fast);
}

.blog-hub-search__form:focus-within {
  background: rgba(255, 255, 255, 0.15);
  border-color: rgba(255, 255, 255, 0.4);
  box-shadow: 0 0 0 3px rgba(63, 153, 213, 0.2);
}

.blog-hub-search__icon {
  color: rgba(255, 255, 255, 0.5);
  font-size: 0.875rem;
  flex-shrink: 0;
}

.blog-hub-search__input {
  flex: 1;
  background: transparent;
  border: none;
  outline: none;
  font-size: var(--fs-body);
  font-family: var(--font-inter);
  color: var(--color-white);
  min-width: 0;
}

.blog-hub-search__input::placeholder {
  color: rgba(255, 255, 255, 0.5);
}

.blog-hub-search__btn {
  flex-shrink: 0;
  padding: 0.5rem 1.25rem;
  font-size: var(--fs-caption);
  border-radius: var(--radius-pill);
}

/* ── Blog Grid Header ─────────────────────────────────────────────────── */
.blog-grid__header {
  margin-bottom: var(--space-xl);
}

.blog-grid__title {
  font-size: var(--fs-h3);
  font-weight: var(--fw-bold);
  color: var(--color-text-heading);
}

/* ── Blog Category Filters ─────────────────────────────────────────────── */
.blog-filters {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
  align-items: center;
}

.blog-filters__item {
  display: inline-flex;
  align-items: center;
  padding: 0.5rem 1.25rem;
  font-size: var(--fs-caption);
  font-weight: var(--fw-medium);
  color: var(--color-text-body);
  background: var(--color-bg-light);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-pill);
  text-decoration: none;
  transition: all var(--transition-fast);
}

.blog-filters__item:hover {
  border-color: var(--color-primary-teal);
  color: var(--color-primary-teal);
}

.blog-filters__item--active {
  background: var(--color-primary-teal);
  border-color: var(--color-primary-teal);
  color: var(--color-white);
}

.blog-filters__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.25rem;
  height: 1.25rem;
  padding: 0 0.375rem;
  font-size: var(--fs-small);
  font-weight: var(--fw-semibold);
  background: rgba(0, 0, 0, 0.06);
  border-radius: var(--radius-pill);
  margin-left: var(--space-xs);
}

.blog-filters__item--active .blog-filters__count {
  background: rgba(255, 255, 255, 0.25);
  color: var(--color-white);
}

/* ── Blog Featured Post ────────────────────────────────────────────────── */
.blog-featured {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-xl);
  align-items: center;
  background: var(--color-bg-light);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.blog-featured__image {
  display: block;
  overflow: hidden;
}

.blog-featured__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.blog-featured__image:hover img {
  transform: scale(1.03);
}

.blog-featured__content {
  padding: var(--space-xl);
}

.blog-featured__title {
  font-size: var(--fs-h3);
  font-weight: var(--fw-bold);
  line-height: var(--lh-snug);
  margin: var(--space-sm) 0 var(--space-md);
}

.blog-featured__title a {
  color: var(--color-text-heading);
  text-decoration: none;
}

.blog-featured__title a:hover {
  color: var(--color-primary-teal);
}

.blog-featured__excerpt {
  color: var(--color-text-secondary);
  font-size: var(--fs-body);
  line-height: var(--lh-relaxed);
  margin-bottom: var(--space-md);
}

.blog-featured__meta {
  font-size: var(--fs-caption);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-lg);
}

/* Featured label ("Featured Article") */
.blog-featured__label {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  font-size: var(--fs-small);
  font-weight: var(--fw-semibold);
  color: var(--color-accent-orange);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: var(--space-sm);
}

.blog-featured__label i {
  font-size: 0.625rem;
}

/* Featured image placeholder when no thumbnail */
.blog-featured__image--placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--color-bg-muted), var(--color-bg-light));
  color: var(--color-border-muted);
  font-size: 3rem;
  min-height: 280px;
}

/* Gradient accent top border on featured card */
.blog-featured {
  border-top: 3px solid transparent;
  border-image: linear-gradient(90deg, var(--color-primary-violet), var(--color-primary-teal)) 1;
}

/* ── Post Card: Category Icon Header ─────────────────────────────────── */
.post-card__icon-header {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 72px;
  background: var(--color-bg-light);
  border-bottom: 1px solid var(--color-border);
  position: relative;
  overflow: hidden;
}

/* Category color tint overlay */
.post-card__icon-header::after {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--cat-color);
  opacity: 0.06;
  pointer-events: none;
}

/* Left accent stripe */
.post-card__icon-header::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 3px;
  background: var(--cat-color);
  z-index: 1;
}

.post-card__icon-header i {
  font-size: 1.5rem;
  color: var(--cat-color);
  opacity: 0.7;
  transition: opacity var(--transition-base), transform var(--transition-base);
  position: relative;
  z-index: 1;
}

.post-card:hover .post-card__icon-header i {
  opacity: 1;
  transform: scale(1.1);
}

/* Thumbnail in icon header */
.post-card__icon-header--has-thumb {
  height: 180px;
  background: var(--color-bg-light);
}

.post-card__icon-header--has-thumb::before,
.post-card__icon-header--has-thumb::after {
  display: none;
}

.post-card__thumb-link {
  display: block;
  width: 100%;
  height: 100%;
}

.post-card__thumb {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* ── Post Card Enhancements ────────────────────────────────────────────── */

.post-card__category {
  display: inline-block;
  font-size: var(--fs-small);
  text-decoration: none;
  margin-bottom: var(--space-xs);
}

.post-card__footer {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  margin-top: auto;
  padding-top: var(--space-md);
  font-size: var(--fs-small);
  color: var(--color-text-secondary);
}

.post-card__sep {
  color: var(--color-border-muted);
}

.post-card__reading-time {
  white-space: nowrap;
}

/* ── Post Card Base (container) ───────────────────────────────────────── */
.post-card {
  display: flex;
  flex-direction: column;
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: all var(--transition-base);
}

.post-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-card);
  border-color: transparent;
}

.post-card__body {
  flex: 1;
  display: flex;
  flex-direction: column;
  padding: var(--space-lg);
}

.post-card__title {
  font-size: var(--fs-h4);
  font-weight: var(--fw-semibold);
  line-height: var(--lh-snug);
  margin: var(--space-xs) 0 var(--space-sm);
}

.post-card__title a {
  color: var(--color-text-heading);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.post-card__title a:hover {
  color: var(--color-primary-violet);
}

.post-card__excerpt {
  font-size: var(--fs-caption);
  color: var(--color-text-secondary);
  line-height: var(--lh-relaxed);
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* ── Post Card Author ─────────────────────────────────────────────────── */
.post-card__avatar {
  border-radius: 50%;
  width: 24px;
  height: 24px;
  flex-shrink: 0;
}

.post-card__author {
  font-weight: var(--fw-medium);
  color: var(--color-text-heading);
  white-space: nowrap;
}


/* ==========================================================================
   SINGLE POST — New Clean Layout (Stripe-inspired)
   ========================================================================== */

/* ── Breadcrumbs ──────────────────────────────────────────────────────── */
.single-post__breadcrumbs {
  background: var(--color-bg-light);
  padding: var(--space-md) 0;
  border-bottom: 1px solid var(--color-border);
}

.breadcrumb {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0;
  list-style: none;
  margin: 0;
  padding: 0;
  font-size: var(--fs-caption);
}

.breadcrumb__item {
  display: inline-flex;
  align-items: center;
  color: var(--color-text-secondary);
}

.breadcrumb__item + .breadcrumb__item::before {
  content: '/';
  margin: 0 0.5rem;
  color: var(--color-border-muted);
}

.breadcrumb__item a {
  color: var(--color-text-secondary);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.breadcrumb__item a:hover {
  color: var(--color-primary-violet);
}

.breadcrumb__item--current {
  color: var(--color-text-heading);
  font-weight: var(--fw-medium);
  max-width: 30ch;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* ── Post Header (Clean white) ────────────────────────────────────────── */
.single-post__header {
  padding: var(--space-3xl) 0 var(--space-xl);
  background: var(--color-white);
}

.single-post__header-inner {
  max-width: var(--max-width-text);
}

.single-post__category {
  /* Override badge--industry white-on-white for post header */
  color: var(--color-text-secondary);
  background-color: rgba(10, 37, 64, 0.06);
  border-color: rgba(10, 37, 64, 0.15);
  /* Match template badge sizing for consistent alignment */
  padding: 0.2em 0.65em;
  margin-bottom: 0; /* Reset badge--industry spacing — container handles gap */
}

.single-post__title {
  font-size: var(--fs-h1);
  font-weight: var(--fw-bold);
  color: var(--color-text-heading);
  line-height: var(--lh-tight);
  margin: 0 0 var(--space-lg);
  max-width: 48rem;
}

.single-post__excerpt {
  font-size: var(--fs-body-lg);
  color: var(--color-text-secondary);
  line-height: var(--lh-relaxed);
  max-width: 40rem;
  margin: 0 0 var(--space-xl);
}

/* Author meta in header */
.single-post__meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-lg);
  flex-wrap: wrap;
}

.single-post__author-brief {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.single-post__avatar {
  border-radius: 50%;
  width: 44px;
  height: 44px;
  flex-shrink: 0;
}

.single-post__meta-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.single-post__author-name {
  display: block;
  font-weight: var(--fw-semibold);
  color: var(--color-text-heading);
  font-size: var(--fs-caption);
}

.single-post__meta-details {
  font-size: var(--fs-small);
  color: var(--color-text-secondary);
}

.post-meta__sep {
  margin: 0 0.35rem;
  color: var(--color-border-muted);
}

/* ── Share Buttons ────────────────────────────────────────────────────── */
.single-post__share {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
}

.single-post__share-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1px solid var(--color-border);
  background: var(--color-white);
  color: var(--color-text-secondary);
  font-size: 0.875rem;
  text-decoration: none;
  transition: all var(--transition-fast);
  cursor: pointer;
  padding: 0;
}

.single-post__share-btn:hover {
  border-color: var(--color-primary-violet);
  color: var(--color-primary-violet);
  background: rgba(63, 153, 213, 0.06);
}

/* Copy link success state */
.single-post__share-btn.is-copied {
  border-color: var(--color-success);
  color: var(--color-success);
  background: rgba(5, 150, 105, 0.06);
}

/* ── Featured Image ───────────────────────────────────────────────────── */
.single-post__featured-image {
  margin-bottom: var(--space-3xl);
}

.single-post__hero-img {
  width: 100%;
  height: auto;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
}

/* ── Content + Sidebar Layout ─────────────────────────────────────────── */
.single-post__content-section {
  padding-top: 0;
}

.single-post__layout {
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: var(--space-4xl);
  align-items: start;
}

.single-post__main {
  min-width: 0;          /* prevent grid track from expanding beyond 1fr */
  overflow-x: hidden;   /* clip any child (e.g. stat-grid) that overflows the column */
  /* Note: overflow-x:hidden implicitly sets overflow-y:auto per spec — that is fine
     because .single-post__sidebar carries its own sticky + overflow-y handling. */
}

/* ── Prose (article body typography) ──────────────────────────────────── */
.prose {
  font-size: var(--fs-body);
  line-height: var(--lh-loose);
  color: var(--color-text-body);
}

.prose h2 {
  font-size: var(--fs-h2);
  font-weight: var(--fw-bold);
  color: var(--color-text-heading);
  line-height: var(--lh-snug);
  margin: var(--space-3xl) 0 var(--space-lg);
  scroll-margin-top: 100px;
}

.prose h3 {
  font-size: var(--fs-h3);
  font-weight: var(--fw-semibold);
  color: var(--color-text-heading);
  line-height: var(--lh-snug);
  margin: var(--space-xl) 0 var(--space-md);
}

.prose h4 {
  font-size: var(--fs-h4);
  font-weight: var(--fw-semibold);
  color: var(--color-text-heading);
  margin: var(--space-lg) 0 var(--space-sm);
}

.prose p {
  margin: 0 0 var(--space-paragraph);
}

.prose a {
  color: var(--color-primary-violet);
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: color var(--transition-fast);
}

.prose a:hover {
  color: var(--color-primary-navy);
}

.prose ul,
.prose ol {
  margin: 0 0 var(--space-paragraph);
  padding-left: 1.5rem;
}

.prose li {
  margin-bottom: var(--space-sm);
}

.prose li::marker {
  color: var(--color-primary-violet);
}

.prose blockquote {
  margin: var(--space-xl) 0;
  padding: var(--space-lg) var(--space-xl);
  border-left: 4px solid var(--color-primary-violet);
  background: var(--color-bg-light);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  font-size: var(--fs-body-lg);
  color: var(--color-text-heading);
  font-style: italic;
  line-height: var(--lh-relaxed);
}

.prose blockquote p:last-child {
  margin-bottom: 0;
}

.prose img {
  max-width: 100%;
  height: auto;
  border-radius: var(--radius-md);
  margin: var(--space-xl) 0;
}

.prose figure {
  margin: var(--space-xl) 0;
}

.prose figcaption {
  font-size: var(--fs-small);
  color: var(--color-text-secondary);
  text-align: center;
  margin-top: var(--space-sm);
}

.prose pre {
  margin: var(--space-xl) 0;
  padding: var(--space-lg);
  background: var(--color-primary-navy);
  color: #d8cfbe;
  border-radius: var(--radius-md);
  overflow-x: auto;
  font-size: var(--fs-caption);
  line-height: var(--lh-relaxed);
}

.prose code {
  font-family: 'SFMono-Regular', Consolas, 'Liberation Mono', Menlo, monospace;
  font-size: 0.875em;
  padding: 0.15em 0.4em;
  background: var(--color-bg-muted);
  border-radius: var(--radius-sm);
  color: var(--color-accent-pink);
}

.prose pre code {
  padding: 0;
  background: none;
  color: inherit;
  font-size: inherit;
}

.prose table {
  width: 100%;
  border-collapse: collapse;
  margin: var(--space-xl) 0;
  font-size: var(--fs-caption);
}

.prose th,
.prose td {
  padding: var(--space-sm) var(--space-md);
  border-bottom: 1px solid var(--color-border);
  text-align: left;
}

.prose th {
  font-weight: var(--fw-semibold);
  color: var(--color-text-heading);
  background: var(--color-bg-light);
}

.prose hr {
  border: none;
  border-top: 1px solid var(--color-border);
  margin: var(--space-3xl) 0;
}

/* ── Tags ─────────────────────────────────────────────────────────────── */
.single-post__tags {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-sm);
  margin-top: var(--space-xl);
  padding-top: var(--space-xl);
  border-top: 1px solid var(--color-border);
}

.single-post__tags-label {
  font-size: var(--fs-caption);
  font-weight: var(--fw-semibold);
  color: var(--color-text-heading);
}

.single-post__tag {
  display: inline-block;
  padding: 0.375rem 0.875rem;
  font-size: var(--fs-small);
  color: var(--color-text-body);
  background: var(--color-bg-light);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-pill);
  text-decoration: none;
  transition: all var(--transition-fast);
}

.single-post__tag:hover {
  border-color: var(--color-primary-violet);
  color: var(--color-primary-violet);
}

/* ── Share Bottom Bar ─────────────────────────────────────────────────── */
.single-post__share-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-md);
  margin-top: var(--space-xl);
  padding: var(--space-lg);
  background: var(--color-bg-light);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
}

.single-post__share-label {
  font-size: var(--fs-caption);
  font-weight: var(--fw-semibold);
  color: var(--color-text-heading);
}

/* ── Author Byline (robust box) ──────────────────────────────────────── */
.author-byline {
  display: flex;
  gap: var(--space-xl);
  margin-top: var(--space-3xl);
  padding: var(--space-xl) var(--space-2xl);
  background: var(--color-bg-light);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  border-left: 4px solid var(--color-primary-violet);
}

.author-byline__avatar-wrap {
  flex-shrink: 0;
}

.author-byline__avatar {
  border-radius: 50%;
  width: 96px;
  height: 96px;
  object-fit: cover;
}

.author-byline__content {
  flex: 1;
  min-width: 0;
}

.author-byline__label {
  display: block;
  font-size: var(--fs-small);
  font-weight: var(--fw-medium);
  color: var(--color-text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: var(--space-xs);
}

.author-byline__name {
  font-size: var(--fs-h3);
  font-weight: var(--fw-bold);
  color: var(--color-text-heading);
  margin: 0 0 var(--space-xs);
}

.author-byline__name a {
  color: inherit;
  text-decoration: none;
  transition: color var(--transition-fast);
}

.author-byline__name a:hover {
  color: var(--color-primary-violet);
}

.author-byline__title {
  display: block;
  font-size: var(--fs-caption);
  color: var(--color-primary-violet);
  font-weight: var(--fw-medium);
  margin-bottom: var(--space-sm);
}

.author-byline__bio {
  font-size: var(--fs-caption);
  color: var(--color-text-body);
  line-height: var(--lh-relaxed);
  margin: 0 0 var(--space-md);
}

.author-byline__links {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-md);
}

.author-byline__link {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-size: var(--fs-small);
  font-weight: var(--fw-medium);
  color: var(--color-text-secondary);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.author-byline__link:hover {
  color: var(--color-primary-violet);
}

.author-byline__link i {
  font-size: 0.8rem;
}

/* ── Sidebar ──────────────────────────────────────────────────────────── */
.single-post__sidebar {
  position: sticky;
  top: calc(var(--space-xl) + 80px); /* account for sticky header */
  display: flex;
  flex-direction: column;
  gap: var(--space-xl);
  max-height: calc(100vh - 120px);
  overflow-y: auto;
}

.admin-bar .single-post__sidebar {
  top: calc(var(--space-xl) + 112px);
}

.sidebar-widget {
  background: var(--color-bg-light);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
}

.sidebar-widget__title {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: var(--fs-caption);
  font-weight: var(--fw-bold);
  color: var(--color-text-heading);
  margin: 0 0 var(--space-md);
  padding-bottom: var(--space-sm);
  border-bottom: 2px solid var(--color-primary-violet);
}

.sidebar-widget__title i {
  color: var(--color-primary-violet);
  font-size: 0.8rem;
}

/* Table of Contents */
.sidebar-toc__nav {
  /* Container for TOC links */
}

.sidebar-toc__list {
  list-style: none;
  margin: 0;
  padding: 0;
  counter-reset: toc-counter;
}

.sidebar-toc__item {
  counter-increment: toc-counter;
}

.sidebar-toc__link {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  padding: var(--space-sm) 0;
  font-size: var(--fs-small);
  color: var(--color-text-body);
  text-decoration: none;
  line-height: var(--lh-snug);
  border-left: 2px solid transparent;
  padding-left: var(--space-sm);
  transition: all var(--transition-fast);
}

.sidebar-toc__link::before {
  content: counter(toc-counter) '.';
  flex-shrink: 0;
  font-weight: var(--fw-semibold);
  color: var(--color-text-secondary);
  min-width: 1.25rem;
}

.sidebar-toc__link:hover {
  color: var(--color-primary-violet);
  border-left-color: var(--color-primary-violet);
}

.sidebar-toc__link.is-active {
  color: var(--color-primary-violet);
  font-weight: var(--fw-medium);
  border-left-color: var(--color-primary-violet);
  background: rgba(63, 153, 213, 0.04);
}

.sidebar-toc__link.is-active::before {
  color: var(--color-primary-violet);
}

/* Hidden when no headings */
.sidebar-toc.is-hidden {
  display: none;
}

/* Sidebar CTA — animated gradient with navy fallback */
.sidebar-cta {
  text-align: center;
  background: linear-gradient(135deg, var(--color-primary-navy), #463747);
  border-color: transparent;
  color: var(--color-white);
  position: relative;
  overflow: hidden;
}

.sidebar-cta__canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  border-radius: inherit;
}

.sidebar-cta__content {
  position: relative;
  z-index: 1;
}

.sidebar-cta__title,
.sidebar-cta__text {
  text-shadow: 0 1px 4px rgba(0, 0, 0, 0.35);
}

.sidebar-cta__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: rgba(63, 153, 213, 0.2);
  color: var(--color-primary-teal);
  font-size: 1.25rem;
  margin-bottom: var(--space-md);
}

.sidebar-cta__title {
  font-size: var(--fs-body);
  font-weight: var(--fw-bold);
  color: var(--color-white);
  margin: 0 0 var(--space-sm);
}

.sidebar-cta__text {
  font-size: var(--fs-small);
  color: rgba(255, 255, 255, 0.8);
  line-height: var(--lh-relaxed);
  margin: 0 0 var(--space-lg);
}

.sidebar-cta__btn {
  display: flex; /* override inline-flex from .btn — needed for width:100% to flex correctly */
  align-items: center;
  width: 100%;
  justify-content: center;
  font-size: var(--fs-caption);
  padding: 0.75rem 1.25rem;
}

.sidebar-cta__note {
  font-size: var(--fs-small);
  color: rgba(255, 255, 255, 0.6);
  margin: var(--space-sm) 0 0;
}

/* Legacy sidebar widget post links (blog hub) */
.sidebar-widget__post-link {
  display: block;
  padding: var(--space-sm) 0;
  font-size: var(--fs-caption);
  color: var(--color-text-body);
  text-decoration: none;
  border-bottom: 1px solid var(--color-border);
  transition: color var(--transition-fast);
  line-height: var(--lh-snug);
}

.sidebar-widget__post-link:last-child {
  border-bottom: none;
}

.sidebar-widget__post-link:hover {
  color: var(--color-primary-teal);
}

/* ── Related Posts ────────────────────────────────────────────────────── */
.related-posts__header {
  text-align: center;
  margin-bottom: var(--space-component);
}

.related-posts__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: var(--space-lg);
}

.related-card {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: all var(--transition-base);
}

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

.related-card__image {
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: var(--color-bg-muted);
}

.related-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.related-card:hover .related-card__image img {
  transform: scale(1.05);
}

.related-card__body {
  flex: 1;
  display: flex;
  flex-direction: column;
  padding: var(--space-md);
}

.related-card__category {
  font-size: var(--fs-small);
  font-weight: var(--fw-semibold);
  color: var(--color-primary-violet);
  text-transform: uppercase;
  letter-spacing: 0.03em;
  margin-bottom: var(--space-xs);
}

.related-card__title {
  font-size: var(--fs-caption);
  font-weight: var(--fw-semibold);
  color: var(--color-text-heading);
  line-height: var(--lh-snug);
  margin: 0 0 var(--space-sm);
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.related-card__meta {
  margin-top: auto;
  font-size: var(--fs-small);
  color: var(--color-text-secondary);
}

/* ── Post Navigation (enhanced) ────────────────────────────────────────── */
.post-navigation {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-xl);
}

.post-navigation__prev,
.post-navigation__next {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
}

.post-navigation__next {
  text-align: right;
}

.post-navigation__label {
  font-size: var(--fs-small);
  font-weight: var(--fw-semibold);
  color: var(--color-text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.post-navigation__prev a,
.post-navigation__next a {
  font-size: var(--fs-body);
  font-weight: var(--fw-medium);
  color: var(--color-text-heading);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.post-navigation__prev a:hover,
.post-navigation__next a:hover {
  color: var(--color-primary-teal);
}


/* ==========================================================================
   BLOG MODULES — A through H
   ========================================================================== */

/* ── Module A: Key Takeaways / TL;DR ───────────────────────────────────── */
.blog-takeaways {
  margin-bottom: var(--space-xl);
  padding: var(--space-xl);
  background: var(--color-bg-light);
  border: 1px solid var(--color-border);
  border-left: 4px solid var(--color-primary-violet);
  border-radius: var(--radius-lg);
}

.blog-takeaways__audience {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: var(--fs-small);
  font-weight: var(--fw-medium);
  color: var(--color-text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: var(--space-md);
}

.blog-takeaways__audience i {
  color: var(--color-primary-violet);
  font-size: 0.75rem;
}

.blog-takeaways__heading {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: var(--fs-body);
  font-weight: var(--fw-bold);
  color: var(--color-text-heading);
  margin: 0 0 var(--space-md);
}

.blog-takeaways__heading i {
  color: var(--color-primary-violet);
  font-size: 0.9rem;
}

.blog-takeaways__list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.blog-takeaways__list li {
  position: relative;
  padding-left: 1.5rem;
  margin-bottom: var(--space-sm);
  font-size: var(--fs-caption);
  line-height: var(--lh-relaxed);
  color: var(--color-text-body);
}

.blog-takeaways__list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.55em;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--color-primary-violet);
}

.blog-takeaways__list li:last-child {
  margin-bottom: 0;
}

.blog-takeaways__tldr {
  margin-top: var(--space-md);
  padding-top: var(--space-md);
  border-top: 1px solid var(--color-border);
}

.blog-takeaways__tldr-label {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  font-size: var(--fs-small);
  font-weight: var(--fw-bold);
  color: var(--color-primary-violet);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: var(--space-xs);
}

.blog-takeaways__tldr-label i {
  font-size: 0.7rem;
}

.blog-takeaways__tldr p {
  margin: 0;
  font-size: var(--fs-caption);
  line-height: var(--lh-relaxed);
  color: var(--color-text-body);
}

/* ---- Blog Takeaways: Accordion Mode ---- */
.blog-takeaways--accordion {
  padding: 0;
}

.blog-takeaways--accordion .blog-takeaways__trigger {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: var(--space-lg) var(--space-xl);
  font-family: var(--font-inter);
  font-size: var(--fs-body);
  font-weight: var(--fw-bold);
  color: var(--color-text-heading);
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  gap: var(--space-md);
}

.blog-takeaways--accordion .blog-takeaways__trigger:hover {
  background-color: rgba(63, 153, 213, 0.04);
}

.blog-takeaways--accordion .blog-takeaways__trigger:focus-visible {
  outline: 2px solid var(--color-primary-violet);
  outline-offset: -2px;
}

.blog-takeaways--accordion .blog-takeaways__trigger-text {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.blog-takeaways--accordion .blog-takeaways__trigger-text i {
  color: var(--color-primary-violet);
  font-size: 0.9rem;
}

.blog-takeaways--accordion .accordion__icon {
  font-size: 0.75rem;
  color: var(--color-text-secondary);
  transition: transform var(--transition-base);
}

.blog-takeaways--accordion .accordion__item.is-open .accordion__icon {
  transform: rotate(180deg);
}

.blog-takeaways--accordion .blog-takeaways__body {
  max-height: 0;
  overflow: hidden;
  transition: max-height var(--transition-slow);
  padding: 0 var(--space-xl);
}

.blog-takeaways--accordion .accordion__item.is-open .blog-takeaways__body {
  max-height: 2000px;
  padding-bottom: var(--space-xl);
}

/* ── Module B: Callout Blocks (shortcodes) ─────────────────────────────── */
.blog-callout {
  display: flex;
  gap: var(--space-md);
  margin: var(--space-xl) 0;
  padding: var(--space-lg);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
}

.blog-callout__icon {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: var(--radius-md);
  font-size: 1rem;
}

.blog-callout__body {
  flex: 1;
  min-width: 0;
}

.blog-callout__title {
  display: block;
  font-size: var(--fs-caption);
  font-weight: var(--fw-bold);
  margin-bottom: var(--space-xs);
}

.blog-callout__text {
  font-size: var(--fs-caption);
  line-height: var(--lh-relaxed);
  color: var(--color-text-body);
}

.blog-callout__text p:last-child {
  margin-bottom: 0;
}

/* Tip — violet */
.blog-callout--tip {
  background: rgba(63, 153, 213, 0.04);
  border-color: rgba(63, 153, 213, 0.2);
}

.blog-callout--tip .blog-callout__icon {
  background: rgba(63, 153, 213, 0.1);
  color: var(--color-primary-violet);
}

.blog-callout--tip .blog-callout__title {
  color: var(--color-primary-violet);
}

/* Important — orange */
.blog-callout--important {
  background: rgba(255, 138, 61, 0.04);
  border-color: rgba(255, 138, 61, 0.2);
}

.blog-callout--important .blog-callout__icon {
  background: rgba(255, 138, 61, 0.1);
  color: var(--color-accent-orange);
}

.blog-callout--important .blog-callout__title {
  color: var(--color-accent-orange);
}

/* Example — teal */
.blog-callout--example {
  background: rgba(0, 212, 255, 0.04);
  border-color: rgba(0, 212, 255, 0.2);
}

.blog-callout--example .blog-callout__icon {
  background: rgba(0, 212, 255, 0.1);
  color: var(--color-primary-teal);
}

.blog-callout--example .blog-callout__title {
  color: #3f6d82; /* darker teal for text readability */
}

/* ── Module C: Mid-Article CTA (shortcode) ─────────────────────────────── */
.blog-mid-cta {
  margin: var(--space-xl) 0;
  padding: var(--space-xl);
  background: linear-gradient(135deg, var(--color-primary-navy), #463747);
  border-radius: var(--radius-lg);
  color: var(--color-white);
}

.blog-mid-cta__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-xl);
}

.blog-mid-cta__content {
  flex: 1;
  min-width: 0;
}

.blog-mid-cta__title {
  font-size: var(--fs-h3);
  font-weight: var(--fw-bold);
  color: var(--color-white);
  margin: 0 0 var(--space-xs);
}

.blog-mid-cta__text {
  font-size: var(--fs-caption);
  color: rgba(255, 255, 255, 0.8);
  line-height: var(--lh-relaxed);
  margin: 0;
}

.blog-mid-cta__btn {
  display: inline-flex; /* explicit — don't rely on .btn inheritance inside .prose */
  align-items: center;
  flex-shrink: 0;
  white-space: nowrap;
}

/* Ensure CTA text stays white inside .prose (overrides inherited dark color) */
.prose .blog-mid-cta {
  color: var(--color-white);
}

.prose .blog-mid-cta__title {
  color: var(--color-white);
}

.prose .blog-mid-cta__text {
  color: rgba(255, 255, 255, 0.8);
}

/* CTA button: override .prose a styles that make button text invisible */
.blog-mid-cta .btn--primary {
  color: var(--color-white);
  text-decoration: none;
}

.blog-mid-cta .btn--primary:hover {
  background-color: var(--color-white);
  border-color: var(--color-white);
  color: var(--color-primary-navy);
  text-decoration: none;
  box-shadow: 0 4px 12px rgba(255, 255, 255, 0.2);
}

/* ── Module D: Related Resources (Further Reading) ─────────────────────── */
.blog-related-resources {
  margin-top: var(--space-xl);
  padding: var(--space-lg);
  background: var(--color-bg-light);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
}

.blog-related-resources__heading {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: var(--fs-caption);
  font-weight: var(--fw-bold);
  color: var(--color-text-heading);
  margin: 0 0 var(--space-md);
}

.blog-related-resources__heading i {
  color: var(--color-primary-violet);
  font-size: 0.85rem;
}

.blog-related-resources__list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.blog-related-resources__item {
  border-bottom: 1px solid var(--color-border);
}

.blog-related-resources__item:last-child {
  border-bottom: none;
}

.blog-related-resources__link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-md);
  padding: var(--space-sm) 0;
  text-decoration: none;
  transition: all var(--transition-fast);
}

.blog-related-resources__link:hover {
  padding-left: var(--space-sm);
}

.blog-related-resources__title {
  font-size: var(--fs-caption);
  font-weight: var(--fw-medium);
  color: var(--color-text-heading);
  transition: color var(--transition-fast);
}

.blog-related-resources__link:hover .blog-related-resources__title {
  color: var(--color-primary-violet);
}

.blog-related-resources__meta {
  flex-shrink: 0;
  font-size: var(--fs-small);
  color: var(--color-text-secondary);
  white-space: nowrap;
}

.blog-related-resources__category {
  font-weight: var(--fw-medium);
  color: var(--color-primary-violet);
}

/* ── Module E: Blog FAQ Accordion ──────────────────────────────────────── */
.blog-faq {
  margin-top: var(--space-3xl);
  padding-top: var(--space-xl);
  border-top: 1px solid var(--color-border);
}

.blog-faq__inner {
  /* Contains the heading and accordion */
}

.blog-faq__heading {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: var(--fs-h3);
  font-weight: var(--fw-bold);
  color: var(--color-text-heading);
  margin: 0 0 var(--space-lg);
}

.blog-faq__heading i {
  color: var(--color-primary-violet);
}

/* ── Module F: Step-by-Step ────────────────────────────────────────────── */
.blog-steps {
  margin-top: var(--space-3xl);
  padding-top: var(--space-xl);
  border-top: 1px solid var(--color-border);
}

.blog-steps__inner {
  /* Contains the heading and list */
}

.blog-steps__heading {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: var(--fs-h3);
  font-weight: var(--fw-bold);
  color: var(--color-text-heading);
  margin: 0 0 var(--space-xl);
}

.blog-steps__heading i {
  color: var(--color-primary-violet);
}

.blog-steps__list {
  list-style: none;
  padding: 0;
  margin: 0;
  counter-reset: none;
}

.blog-steps__item {
  display: flex;
  gap: var(--space-lg);
  padding: var(--space-lg) 0;
  border-bottom: 1px solid var(--color-border);
}

.blog-steps__item:last-child {
  border-bottom: none;
}

.blog-steps__number {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--color-primary-violet);
  color: var(--color-white);
  font-size: var(--fs-body);
  font-weight: var(--fw-bold);
  line-height: 1;
}

.blog-steps__content {
  flex: 1;
  min-width: 0;
}

.blog-steps__step-title {
  font-size: var(--fs-body);
  font-weight: var(--fw-semibold);
  color: var(--color-text-heading);
  margin: 0 0 var(--space-xs);
  line-height: var(--lh-snug);
  padding-top: var(--space-xs);
}

.blog-steps__step-text {
  font-size: var(--fs-caption);
  color: var(--color-text-body);
  line-height: var(--lh-relaxed);
  margin: 0;
}

/* Collapsible steps — <details>/<summary> wrapper */
.blog-steps__collapsible {
  border: none;
  outline: none;
}

.blog-steps__summary {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: var(--fs-h3);
  font-weight: var(--fw-bold);
  color: var(--color-text-heading);
  margin: 0 0 var(--space-xl);
  cursor: pointer;
  list-style: none; /* hide default marker */
  user-select: none;
}

/* Hide the default browser triangle */
.blog-steps__summary::-webkit-details-marker { display: none; }
.blog-steps__summary::marker { display: none; }

.blog-steps__summary-icon {
  color: var(--color-primary-violet);
  flex-shrink: 0;
}

.blog-steps__summary-title {
  flex: 1;
}

.blog-steps__summary-meta {
  font-size: var(--fs-caption);
  font-weight: var(--fw-medium);
  color: var(--color-text-muted);
  background: var(--color-surface-subtle, #e9e1d2);
  padding: 2px 8px;
  border-radius: var(--radius-full, 999px);
  white-space: nowrap;
}

.blog-steps__toggle-icon {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  border: 1.5px solid var(--color-border);
  color: var(--color-text-muted);
  font-size: 11px;
  transition: transform var(--transition-base), border-color var(--transition-base);
}

.blog-steps__toggle-icon::after {
  content: '▼';
}

.blog-steps__collapsible[open] .blog-steps__toggle-icon {
  transform: rotate(180deg);
  border-color: var(--color-primary-violet);
  color: var(--color-primary-violet);
}

/* Animate open/close */
.blog-steps__collapsible .blog-steps__list {
  animation: stepsReveal var(--transition-slow, 300ms) ease;
}

@keyframes stepsReveal {
  from { opacity: 0; transform: translateY(-8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── Module G: Last Updated Badge ──────────────────────────────────────── */
.blog-last-updated {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  color: var(--color-primary-violet);
  font-weight: var(--fw-medium);
}

.blog-last-updated i {
  font-size: 0.65rem;
}

/* ── Module H: Reading Progress Bar ────────────────────────────────────── */
/* Sits directly below the fixed site-header (65px tall on desktop).      */
.reading-progress {
  position: fixed;
  top: 65px;              /* header height */
  left: 0;
  width: 100%;
  height: 3px;
  z-index: 1001;          /* above header (z-index 1000) to avoid box-shadow overlap */
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.3s ease;
}

.reading-progress.is-visible {
  opacity: 1;
}

.reading-progress__bar {
  height: 100%;
  width: 0;
  background: linear-gradient(90deg,
    var(--color-primary-violet) 0%,
    var(--color-primary-teal) 40%,
    var(--color-accent-pink) 70%,
    var(--color-accent-orange) 100%
  );
  transition: width 0.1s linear;
  will-change: width;
}

/* Account for WP admin bar — pushes header down 32px */
.admin-bar .reading-progress {
  top: calc(65px + 32px);  /* header + admin bar */
}

@media (max-width: 782px) {
  .admin-bar .reading-progress {
    top: calc(65px + 46px); /* header + mobile admin bar */
  }
}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */

@media (max-width: 960px) {
  .single-post__layout {
    grid-template-columns: 1fr;
  }

  .single-post__sidebar {
    position: static;
    flex-direction: row;
    flex-wrap: wrap;
    max-height: none;
    overflow-y: visible;
  }

  .single-post__sidebar > * {
    flex: 1 1 280px;
  }

  /* On tablet, move sidebar order: CTA first, TOC second */
  .sidebar-toc {
    order: 2;
  }
  .sidebar-cta {
    order: 1;
  }

  .blog-featured {
    grid-template-columns: 1fr;
  }

  .blog-featured__content {
    padding: var(--space-lg);
  }

  .author-byline {
    padding: var(--space-lg);
  }
}

@media (max-width: 768px) {
  .single-post__title {
    font-size: clamp(1.75rem, 5vw, 2.5rem);
  }

  .single-post__meta {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-md);
  }

  .single-post__share-bottom {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-sm);
  }

  .related-posts__grid {
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: var(--space-md);
  }
}

@media (max-width: 639px) {
  .blog-filters {
    overflow-x: auto;
    flex-wrap: nowrap;
    -webkit-overflow-scrolling: touch;
    padding-bottom: var(--space-sm);
  }

  .blog-filters__item {
    white-space: nowrap;
  }

  /* Blog hub search: stack on mobile */
  .blog-hub-search__form {
    flex-direction: column;
    border-radius: var(--radius-lg);
    padding: var(--space-sm);
    gap: var(--space-sm);
  }

  .blog-hub-search__icon {
    display: none;
  }

  .blog-hub-search__input {
    text-align: center;
    padding: var(--space-sm);
  }

  .blog-hub-search__btn {
    width: 100%;
    justify-content: center;
  }

  .single-post__header {
    padding: var(--space-xl) 0 var(--space-lg);
  }

  .author-byline {
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: var(--space-lg);
    gap: var(--space-md);
  }

  .author-byline__links {
    justify-content: center;
  }

  .post-navigation {
    grid-template-columns: 1fr;
    gap: var(--space-lg);
  }

  .post-navigation__next {
    text-align: left;
  }

  .related-posts__grid {
    grid-template-columns: 1fr 1fr;
  }

  .breadcrumb__item--current {
    max-width: 20ch;
  }
}

@media (max-width: 400px) {
  .related-posts__grid {
    grid-template-columns: 1fr;
  }
}

/* ── Module responsive rules ───────────────────────────────────────────── */
@media (max-width: 768px) {
  .blog-mid-cta__inner {
    flex-direction: column;
    text-align: center;
  }

  .blog-mid-cta__btn {
    width: 100%;
    justify-content: center;
  }

  .blog-callout {
    flex-direction: column;
    gap: var(--space-sm);
  }

  .blog-related-resources__link {
    flex-direction: column;
    gap: var(--space-xs);
    align-items: flex-start;
  }

  .blog-steps__item {
    gap: var(--space-md);
  }

  .blog-steps__number {
    width: 32px;
    height: 32px;
    font-size: var(--fs-caption);
  }
}

/* ==========================================================================
   BLOG TEMPLATE SYSTEM — Template-Specific Styles
   5 template variants: How-To, Thought Leadership, Statistics, Roundup, Listicle
   ========================================================================== */

/* ---- Template Badge (header, all templates) ---- */
.single-post__badges {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  flex-wrap: wrap;
  margin-bottom: var(--space-md);
}

.badge--template {
  font-size: var(--fs-small);
  font-weight: var(--fw-semibold);
  letter-spacing: 0.03em;
  text-transform: uppercase;
  padding: 0.2em 0.65em;
  border-radius: var(--radius-pill);
  border: 1px solid;
}

.badge--template-how-to {
  color: var(--color-success);
  border-color: var(--color-success);
  background: rgba(5, 150, 105, 0.08);
}

.badge--template-thought-leadership {
  color: var(--color-primary-violet);
  border-color: var(--color-primary-violet);
  background: rgba(63, 153, 213, 0.08);
}

.badge--template-statistics {
  color: var(--color-primary-teal);
  border-color: var(--color-primary-teal);
  background: rgba(0, 212, 255, 0.08);
}

.badge--template-roundup {
  color: var(--color-accent-orange);
  border-color: var(--color-accent-orange);
  background: rgba(255, 138, 61, 0.08);
}

.badge--template-listicle {
  color: var(--color-accent-pink);
  border-color: var(--color-accent-pink);
  background: rgba(255, 77, 157, 0.08);
}

/* ---- Thought Leadership: Wider prose ---- */
.single-post--thought-leadership .prose--wide {
  max-width: none;
}

.single-post--thought-leadership .prose--wide blockquote {
  font-size: var(--fs-body-lg);
  font-weight: var(--fw-medium);
  color: var(--color-primary-navy);
  border-left: 4px solid var(--color-primary-violet);
  padding: var(--space-lg) var(--space-xl);
  margin: var(--space-2xl) 0;
  background: rgba(63, 153, 213, 0.04);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  line-height: var(--lh-relaxed);
}

.single-post--thought-leadership .prose--wide blockquote p:last-child {
  margin-bottom: 0;
}

/* ---- Pull Quote Shortcode ---- */
.blog-pull-quote {
  position: relative;
  padding: var(--space-2xl) var(--space-xl);
  margin: var(--space-3xl) 0;
  border-top: 3px solid var(--color-primary-violet);
  border-bottom: 3px solid var(--color-primary-violet);
  text-align: center;
}

.blog-pull-quote::before {
  content: '\201C';
  position: absolute;
  top: -0.3em;
  left: 50%;
  transform: translateX(-50%);
  font-size: 5rem;
  line-height: 1;
  color: var(--color-primary-violet);
  opacity: 0.15;
  font-family: Georgia, serif;
}

.blog-pull-quote__text {
  font-size: clamp(1.25rem, 3vw, 1.5rem);
  font-weight: var(--fw-medium);
  color: var(--color-primary-navy);
  line-height: var(--lh-relaxed);
  font-style: italic;
  margin-bottom: var(--space-md);
}

.blog-pull-quote__attribution {
  font-size: var(--fs-caption);
  color: var(--color-text-secondary);
  font-style: normal;
}

.blog-pull-quote__attribution strong {
  color: var(--color-primary-navy);
  font-weight: var(--fw-semibold);
}

/* ---- Stat Callout Shortcode ---- */
.blog-stat-callout {
  display: flex;
  align-items: center;
  gap: var(--space-lg);
  padding: var(--space-xl);
  margin: var(--space-2xl) 0;
  background: linear-gradient(135deg, rgba(0, 212, 255, 0.06) 0%, rgba(63, 153, 213, 0.06) 100%);
  border-left: 4px solid var(--color-primary-teal);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
}

.blog-stat-callout__value {
  font-size: clamp(2rem, 5vw, 2.75rem);
  font-weight: var(--fw-bold);
  color: var(--color-primary-navy);
  line-height: 1;
  white-space: nowrap;
}

.blog-stat-callout__body {
  flex: 1;
}

.blog-stat-callout__label {
  font-size: var(--fs-body);
  color: var(--color-text-body);
  line-height: var(--lh-relaxed);
}

.blog-stat-callout__source {
  font-size: var(--fs-small);
  color: var(--color-text-secondary);
  margin-top: var(--space-xs);
}

.blog-stat-callout__source a {
  color: var(--color-primary-violet);
  text-decoration: underline;
}

/* ---- Tweetable Stat Shortcode ---- */
.blog-tweetable-stat {
  display: flex;
  align-items: center;
  gap: var(--space-lg);
  padding: var(--space-lg) var(--space-xl);
  margin: var(--space-xl) 0;
  background: var(--color-bg-light);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  transition: box-shadow var(--transition-base);
  text-decoration: none;
  color: inherit;
}

.blog-tweetable-stat:hover {
  box-shadow: var(--shadow-md);
}

.blog-tweetable-stat__content {
  flex: 1;
}

.blog-tweetable-stat__value {
  font-size: var(--fs-h3);
  font-weight: var(--fw-bold);
  color: var(--color-primary-navy);
}

.blog-tweetable-stat__label {
  font-size: var(--fs-caption);
  color: var(--color-text-secondary);
  margin-top: 2px;
}

.blog-tweetable-stat__icon {
  color: var(--color-text-secondary);
  font-size: 1.25rem;
  opacity: 0.6;
  transition: opacity var(--transition-base);
}

.blog-tweetable-stat:hover .blog-tweetable-stat__icon {
  opacity: 1;
  color: #3a99db;
}

/* ==========================================================================
   STATISTICS TEMPLATE
   ========================================================================== */

/* ---- Stat Highlight Carousel ---- */
.stat-highlight-carousel {
  position: relative;
  margin-bottom: var(--space-2xl);
}

.stat-highlight-carousel__track {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-lg);
}

.stat-highlight-carousel__slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 0.6s ease;
  pointer-events: none;
}

.stat-highlight-carousel__slide.is-active {
  position: relative;
  opacity: 1;
  pointer-events: auto;
}

.stat-highlight-carousel__dots {
  display: flex;
  justify-content: center;
  gap: var(--space-sm);
  margin-top: var(--space-md);
}

.stat-highlight-carousel__dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  border: 2px solid var(--color-border-muted);
  background: transparent;
  cursor: pointer;
  padding: 0;
  transition: background-color var(--transition-fast), border-color var(--transition-fast);
}

.stat-highlight-carousel__dot:hover {
  border-color: var(--color-primary-violet);
}

.stat-highlight-carousel__dot.is-active {
  background: var(--color-primary-violet);
  border-color: var(--color-primary-violet);
}

/* ---- Stat Highlight (hero stat) ---- */
.stat-highlight {
  text-align: center;
  padding: var(--space-3xl) var(--space-xl);
  margin-bottom: var(--space-2xl);
  background: linear-gradient(135deg, var(--color-primary-navy) 0%, #463747 100%);
  border-radius: var(--radius-lg);
  color: var(--color-white);
}

/* When inside carousel, remove bottom margin (carousel handles it) */
.stat-highlight-carousel .stat-highlight {
  margin-bottom: 0;
}

.stat-highlight__value {
  font-size: clamp(3rem, 10vw, 5rem);
  font-weight: var(--fw-extrabold);
  line-height: 1;
  margin-bottom: var(--space-sm);
  background: linear-gradient(135deg, var(--color-primary-teal), var(--color-primary-violet));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.stat-highlight__label {
  font-size: var(--fs-body-lg);
  font-weight: var(--fw-medium);
  opacity: 0.9;
  max-width: 40ch;
  margin: 0 auto var(--space-md);
}

.stat-highlight__source {
  font-size: var(--fs-small);
  opacity: 0.6;
}

.stat-highlight__source a {
  color: var(--color-primary-teal);
  text-decoration: underline;
}

/* ---- Stat Grid ---- */
.stat-grid {
  display: grid;
  /*
   * Use min(260px, 100%) so that auto-fill always measures against the
   * actual rendered width of the parent column (not an intrinsic/viewport
   * estimate). This prevents the grid from creating more columns than fit
   * when nested inside a CSS Grid track with min-width:0.
   */
  grid-template-columns: repeat(auto-fill, minmax(min(260px, 100%), 1fr));
  gap: var(--space-lg);
  margin-bottom: var(--space-2xl);
  width: 100%;     /* always fill the parent column, never exceed it */
  box-sizing: border-box;
}

/* ---- Stat Card ---- */
.stat-card {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-xl);
  text-align: center;
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.stat-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

.stat-card__value {
  font-size: clamp(1.75rem, 5vw, 2.5rem);
  font-weight: var(--fw-bold);
  color: var(--color-primary-navy);
  line-height: 1;
  margin-bottom: var(--space-sm);
}

.stat-card__label {
  font-size: var(--fs-body);
  color: var(--color-text-body);
  line-height: var(--lh-relaxed);
  margin-bottom: var(--space-md);
}

.stat-card__meta {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-sm);
  font-size: var(--fs-small);
  color: var(--color-text-secondary);
}

.stat-card__source a {
  color: var(--color-primary-violet);
  text-decoration: underline;
}

.stat-card__year {
  padding: 0.1em 0.5em;
  background: var(--color-bg-light);
  border-radius: var(--radius-sm);
  font-weight: var(--fw-medium);
}

/* ---- Stat Sources Footer ---- */
.stat-sources {
  margin-top: var(--space-3xl);
  padding-top: var(--space-xl);
  border-top: 1px solid var(--color-border);
}

.stat-sources__title {
  font-size: var(--fs-h4);
  font-weight: var(--fw-semibold);
  color: var(--color-primary-navy);
  margin-bottom: var(--space-md);
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.stat-sources__list {
  padding-left: var(--space-xl);
}

.stat-sources__list li {
  font-size: var(--fs-caption);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-sm);
  line-height: var(--lh-relaxed);
}

.stat-sources__list a {
  color: var(--color-primary-violet);
  text-decoration: underline;
}

/* ---- Stat Methodology Note ---- */
.stat-methodology {
  display: flex;
  align-items: flex-start;
  gap: var(--space-sm);
  padding: var(--space-md) var(--space-lg);
  margin: var(--space-xl) 0;
  background: var(--color-bg-light);
  border-radius: var(--radius-md);
  font-size: var(--fs-caption);
  color: var(--color-text-secondary);
  line-height: var(--lh-relaxed);
}

.stat-methodology i {
  color: var(--color-primary-teal);
  margin-top: 2px;
  flex-shrink: 0;
}

/* ---- Stat Card Detail Button ---- */
.stat-card__detail-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.3em;
  padding: 0.25em 0.65em;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-pill);
  background: var(--color-bg-light);
  font-family: var(--font-inter);
  font-size: var(--fs-small);
  font-weight: var(--fw-medium);
  color: var(--color-primary-violet);
  cursor: pointer;
  transition: background-color var(--transition-fast),
              border-color var(--transition-fast),
              color var(--transition-fast);
}

.stat-card__detail-btn:hover {
  background: var(--color-primary-violet);
  border-color: var(--color-primary-violet);
  color: var(--color-white);
}

.stat-card__detail-btn:focus-visible {
  outline: 2px solid var(--color-primary-violet);
  outline-offset: 2px;
}

.stat-card__detail-btn i {
  font-size: 0.7rem;
}

/* ==========================================================================
   Stat Detail Modal
   ========================================================================== */
.stat-modal {
  position: fixed;
  inset: 0;
  z-index: var(--z-modal);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-lg);
}

.stat-modal[hidden] {
  display: none;
}

.stat-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(10, 37, 64, 0.6);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  animation: stat-modal-fade-in 200ms ease forwards;
  cursor: pointer;
}

.stat-modal__dialog {
  position: relative;
  background: var(--color-white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xl);
  max-width: 480px;
  width: 100%;
  padding: var(--space-3xl) var(--space-xl) var(--space-xl);
  animation: stat-modal-slide-up 300ms ease forwards;
  z-index: 1;
}

.stat-modal__close {
  position: absolute;
  top: var(--space-md);
  right: var(--space-md);
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: none;
  background: var(--color-bg-light);
  border-radius: 50%;
  color: var(--color-text-secondary);
  cursor: pointer;
  font-size: 1rem;
  transition: background-color var(--transition-fast), color var(--transition-fast);
}

.stat-modal__close:hover {
  background: var(--color-border);
  color: var(--color-text-heading);
}

.stat-modal__close:focus-visible {
  outline: 2px solid var(--color-primary-violet);
  outline-offset: 2px;
}

.stat-modal__body {
  text-align: center;
}

.stat-modal__value {
  font-size: clamp(2rem, 6vw, 3rem);
  font-weight: var(--fw-extrabold);
  line-height: 1;
  margin-bottom: var(--space-md);
  background: linear-gradient(135deg, var(--color-primary-teal), var(--color-primary-violet));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.stat-modal__label {
  font-size: var(--fs-body-lg);
  font-weight: var(--fw-medium);
  color: var(--color-text-body);
  line-height: var(--lh-relaxed);
  margin: 0 auto var(--space-xl);
  max-width: 38ch;
}

.stat-modal__source {
  padding-top: var(--space-md);
  border-top: 1px solid var(--color-border);
  font-size: var(--fs-small);
  color: var(--color-text-secondary);
}

.stat-modal__detail {
  display: block;
  margin-top: var(--space-md);
  font-size: var(--fs-caption);
  font-weight: normal;
  color: var(--color-text-secondary);
  line-height: var(--lh-relaxed);
  text-align: left;
}

.stat-modal__source:empty {
  display: none;
}

.stat-modal__source a {
  color: var(--color-primary-violet);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.stat-modal__source a:hover {
  color: var(--color-primary-navy);
}

/* ---- Stat Modal Share Button ---- */
.stat-modal__share {
  margin-top: var(--space-lg);
}

.stat-modal__share-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.4em;
  padding: 0.5em 1.25em;
  border-radius: var(--radius-pill);
  border: 1px solid var(--color-border);
  background: var(--color-bg-light);
  font-family: var(--font-inter);
  font-size: var(--fs-small);
  font-weight: var(--fw-medium);
  color: var(--color-text-body);
  text-decoration: none;
  transition: background-color var(--transition-fast),
              border-color var(--transition-fast),
              color var(--transition-fast);
}

.stat-modal__share-btn:hover {
  background: #000;
  border-color: #000;
  color: var(--color-white);
}

.stat-modal__share-btn i {
  font-size: 0.85rem;
}

/* ---- Stat Card Highlight (hash-scroll) ---- */
.stat-card--highlight {
  outline: 3px solid var(--color-primary-violet);
  outline-offset: 4px;
  animation: stat-highlight-pulse 2s ease forwards;
}

@keyframes stat-highlight-pulse {
  0%   { outline-color: var(--color-primary-violet); }
  50%  { outline-color: var(--color-primary-teal); }
  100% { outline-color: transparent; }
}

@keyframes stat-modal-fade-in {
  from { opacity: 0; }
  to   { opacity: 1; }
}

@keyframes stat-modal-slide-up {
  from {
    opacity: 0;
    transform: translateY(16px) scale(0.98);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@media (prefers-reduced-motion: reduce) {
  .stat-modal__backdrop,
  .stat-modal__dialog {
    animation: none;
  }
}

/* ==========================================================================
   ROUNDUP TEMPLATE
   ========================================================================== */

/* ---- Roundup Criteria Note ---- */
.roundup-criteria {
  display: flex;
  gap: var(--space-lg);
  padding: var(--space-xl);
  margin-bottom: var(--space-2xl);
  background: rgba(255, 138, 61, 0.06);
  border-left: 4px solid var(--color-accent-orange);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
}

.roundup-criteria__icon {
  color: var(--color-accent-orange);
  font-size: 1.25rem;
  flex-shrink: 0;
  margin-top: 2px;
}

.roundup-criteria__title {
  font-size: var(--fs-body);
  color: var(--color-primary-navy);
  margin-bottom: var(--space-xs);
}

.roundup-criteria__content p {
  font-size: var(--fs-caption);
  color: var(--color-text-secondary);
  line-height: var(--lh-relaxed);
  margin: 0;
}

/* ---- Roundup Grid ---- */
.roundup-grid {
  display: grid;
  gap: var(--space-lg);
  margin-bottom: var(--space-2xl);
}

/* ---- Roundup Card ---- */
.roundup-card {
  display: flex;
  gap: var(--space-lg);
  padding: var(--space-xl);
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  transition: box-shadow var(--transition-base);
}

.roundup-card:hover {
  box-shadow: var(--shadow-md);
}

.roundup-card__number {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--color-accent-orange);
  color: var(--color-white);
  font-size: var(--fs-body-lg);
  font-weight: var(--fw-bold);
  flex-shrink: 0;
}

.roundup-card__body {
  flex: 1;
  min-width: 0;
}

.roundup-card__title {
  font-size: var(--fs-h4);
  font-weight: var(--fw-semibold);
  color: var(--color-primary-navy);
  margin-bottom: var(--space-xs);
  line-height: var(--lh-snug);
}

.roundup-card__title a {
  color: inherit;
  text-decoration: none;
  display: inline-flex;
  align-items: baseline;
  gap: var(--space-xs);
}

.roundup-card__title a:hover {
  color: var(--color-primary-violet);
}

.roundup-card__title a i {
  font-size: var(--fs-small);
  opacity: 0.5;
}

.roundup-card__category {
  display: inline-block;
  font-size: var(--fs-small);
  font-weight: var(--fw-medium);
  color: var(--color-accent-orange);
  background: rgba(255, 138, 61, 0.1);
  padding: 0.1em 0.5em;
  border-radius: var(--radius-sm);
  margin-bottom: var(--space-sm);
}

.roundup-card__desc {
  font-size: var(--fs-caption);
  color: var(--color-text-secondary);
  line-height: var(--lh-relaxed);
  margin: 0;
}

/* ==========================================================================
   LISTICLE TEMPLATE
   ========================================================================== */

/* ---- Listicle Intro ---- */
.listicle-intro {
  font-size: var(--fs-body-lg);
  color: var(--color-text-body);
  line-height: var(--lh-loose);
  margin-bottom: var(--space-2xl);
  padding-bottom: var(--space-xl);
  border-bottom: 1px solid var(--color-border);
}

.listicle-intro p:last-child {
  margin-bottom: 0;
}

/* ---- Listicle Items ---- */
.listicle-items {
  margin-bottom: var(--space-2xl);
}

.listicle-item {
  display: flex;
  gap: var(--space-xl);
  padding: var(--space-xl);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-md);
}

.listicle-item--alt {
  background: var(--color-bg-light);
}

.listicle-item__number {
  flex-shrink: 0;
}

.listicle-item__number span {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--color-accent-pink), var(--color-primary-violet));
  color: var(--color-white);
  font-size: var(--fs-body-lg);
  font-weight: var(--fw-bold);
}

.listicle-item__content {
  flex: 1;
  min-width: 0;
}

.listicle-item__title {
  font-size: var(--fs-h3);
  font-weight: var(--fw-semibold);
  color: var(--color-primary-navy);
  margin-bottom: var(--space-sm);
  line-height: var(--lh-snug);
}

.listicle-item__body {
  font-size: var(--fs-body);
  color: var(--color-text-body);
  line-height: var(--lh-relaxed);
}

.listicle-item__body p:last-child {
  margin-bottom: 0;
}

/* ==========================================================================
   BLOG PAGINATION
   Styles for the_posts_pagination() — .navigation.pagination
   ========================================================================== */

.navigation.pagination {
  margin: var(--space-3xl) 0 var(--space-xl);
  display: flex;
  justify-content: center;
}

.navigation.pagination .nav-links {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  flex-wrap: wrap;
  justify-content: center;
}

/* All page number items */
.navigation.pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.5rem;
  height: 2.5rem;
  padding: 0 var(--space-sm);
  border-radius: 0.5rem;
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  color: var(--color-text-body);
  background: transparent;
  border: 1.5px solid transparent;
  text-decoration: none;
  transition: all var(--transition-base);
  line-height: 1;
}

/* Hover state for linked items */
.navigation.pagination a.page-numbers:hover {
  color: var(--color-primary-violet);
  background: color-mix(in srgb, var(--color-primary-violet) 8%, transparent);
  border-color: color-mix(in srgb, var(--color-primary-violet) 25%, transparent);
}

/* Active / current page */
.navigation.pagination .page-numbers.current {
  color: #fff;
  background: var(--color-primary-violet);
  border-color: var(--color-primary-violet);
  font-weight: var(--fw-semibold);
  box-shadow: 0 2px 8px color-mix(in srgb, var(--color-primary-violet) 35%, transparent);
}

/* Dots (ellipsis) */
.navigation.pagination .page-numbers.dots {
  color: var(--color-text-secondary);
  border-color: transparent;
  cursor: default;
  min-width: 1.5rem;
  padding: 0;
}

/* Prev / Next — pill style with arrow */
.navigation.pagination .prev.page-numbers,
.navigation.pagination .next.page-numbers {
  padding: 0 var(--space-md);
  gap: var(--space-xs);
  color: var(--color-primary-navy);
  border-color: var(--color-border);
  background: var(--color-surface-card);
  font-weight: var(--fw-medium);
  box-shadow: var(--shadow-sm);
}

.navigation.pagination .prev.page-numbers:hover,
.navigation.pagination .next.page-numbers:hover {
  color: var(--color-primary-violet);
  border-color: var(--color-primary-violet);
  background: color-mix(in srgb, var(--color-primary-violet) 5%, white);
  box-shadow: var(--shadow-md);
  transform: translateY(-1px);
}

/* ── Responsive ─────────────────────────────────────────────────────────── */
@media (max-width: 639px) {
  .blog-takeaways {
    padding: var(--space-lg);
  }

  /* On mobile: hide numbered pages, keep only prev/next */
  .navigation.pagination .page-numbers:not(.prev):not(.next):not(.current):not(.dots) {
    display: none;
  }

  .navigation.pagination .page-numbers.dots {
    display: none;
  }

  .navigation.pagination .nav-links {
    gap: var(--space-sm);
  }

  .navigation.pagination .prev.page-numbers,
  .navigation.pagination .next.page-numbers {
    padding: 0 var(--space-lg);
    height: 2.75rem;
    font-size: var(--fs-body);
  }
}
