/* Updated: 2026-06-17 */
/* ==========================================================================
   CONSOURCE — BLOG STYLESHEET
   v2.2.0 — March 2026

   SCOPE:
   - Single post pages  → selectors prefixed .single-post
   - Blog index page    → unscoped component classes (.blog-*)

   CHANGES v2.2.0:
   - Preserved original blog index styling as source of truth
   - Added classes required by cleaned [consource_blog_page] shortcode
   - Replaced former inline-style dependencies with CSS classes
   - Kept single-post layout/styling intact
   - Light cleanup only; no visual redesign
   ========================================================================== */


/* ==========================================================================
   DIVI OVERRIDES
   ========================================================================== */

.single-post .et_pb_gutters3 .et_pb_column_3_5,
.single-post .et_pb_gutters3.et_pb_row .et_pb_column_3_5 {
  width: 100% !important;
  flex: 2.5 !important;
}

.single-post .et_pb_gutters3 .et_pb_column_2_5,
.single-post .et_pb_gutters3.et_pb_row .et_pb_column_2_5 {
  width: 100% !important;
  flex: 1 !important;
}


/* ==========================================================================
   BLOG HEADER — FULL WIDTH IMAGE WITH OVERLAY TITLE
   ========================================================================== */

.single-post .et_pb_section.blog-header-section {
  background: var(--white) !important;
  padding: 0 !important;
  position: relative !important;
  border-bottom: none !important;
}

.single-post .et_pb_image.blog-featured-image {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  position: relative !important;
  overflow: hidden !important;
}

.single-post .et_pb_image.blog-featured-image .et_pb_image_wrap {
  width: 100% !important;
  position: relative !important;
  display: block !important;
}

.single-post .et_pb_image.blog-featured-image img {
  width: 100% !important;
  height: 520px !important;
  object-fit: cover !important;
  display: block !important;
  border: none !important;
  border-radius: 0 !important;
  margin: 0 !important;
}

/* Category eyebrow — sits above the title.
   If image / categories / title are all in the same Divi column,
   flex order moves categories above the title without touching the template. */
.single-post .et_pb_section.blog-header-section .et_pb_column {
  display: flex !important;
  flex-direction: column !important;
}
.single-post .et_pb_image.blog-featured-image    { order: 0 !important; }
.single-post .et_pb_text.blog-categories         { order: 1 !important; }
.single-post .et_pb_post_title.blog-title        { order: 2 !important; }

.single-post .et_pb_text.blog-categories {
  background: var(--white) !important;
  padding: 28px 24px 0 !important;
  text-align: center !important;
  position: static !important;
}

.single-post .et_pb_text.blog-categories::before {
  display: none !important;
}

.single-post .et_pb_text.blog-categories .et_pb_text_inner {
  display: flex !important;
  gap: 10px !important;
  justify-content: center !important;
  flex-wrap: wrap !important;
}

.single-post .et_pb_text.blog-categories .category-badge {
  display: inline-flex !important;
  align-items: center !important;
  background: var(--brand-primary-soft, rgba(0,171,187,0.10)) !important;
  color: var(--brand-primary) !important;
  border: 1px solid var(--brand-primary) !important;
  padding: 5px 14px !important;
  border-radius: 999px !important;
  font-family: var(--font-family-body) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.08em !important;
  text-decoration: none !important;
  transition: background 0.2s ease, color 0.2s ease !important;
}

.single-post .et_pb_text.blog-categories .category-badge a {
  color: inherit !important;
  text-decoration: none !important;
}

.single-post .et_pb_text.blog-categories .category-badge:hover {
  background: var(--brand-primary) !important;
  color: var(--white) !important;
}

/* Title — clean below category, no image overlap */
.single-post .et_pb_post_title.blog-title {
  position: relative !important;
  z-index: 1 !important;
  margin: 0 auto !important;
  width: 90% !important;
  max-width: 800px !important;
  background: none !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 16px 32px 32px !important;
  box-shadow: none !important;
  text-align: center !important;
}

.single-post .et_pb_post_title.blog-title h1.entry-title {
  font-family: var(--font-family-heading) !important;
  font-size: clamp(1.5rem, 4vw, 2.5rem) !important;
  font-weight: 700 !important;
  color: var(--color-foreground) !important;
  margin: 0 !important;
  line-height: 1.2 !important;
  text-align: center !important;
}


/* ==========================================================================
   MAIN CONTENT LAYOUT — 2-COLUMN WITH DIVI OVERRIDES
   ========================================================================== */

.single-post .et_pb_section_1_tb_body {
  background: var(--white) !important;
  padding: 60px 24px !important;
}

.single-post .et_pb_row_1_tb_body {
  display: flex !important;
  flex-wrap: nowrap !important;
  gap: 48px !important;
  align-items: start !important;
  max-width: 1200px !important;
  margin: 0 auto !important;
  width: 100% !important;
}

.single-post .et_pb_column.blog-article-content {
  background: var(--white) !important;
  padding: 0 !important;
  flex: 0 0 calc(70% - 24px) !important;
  width: calc(70% - 24px) !important;
  max-width: none !important;
}

.single-post .et_pb_column.blog-sidebar {
  display: flex !important;
  flex-direction: column !important;
  gap: 16px !important;
  position: sticky !important;
  top: 120px !important;
  flex: 0 0 calc(30% - 24px) !important;
  width: calc(30% - 24px) !important;
  max-width: none !important;
}


/* ==========================================================================
   SIDEBAR
   ========================================================================== */

/* Module order: share → author → book a demo → newsletter */
.single-post .blog-sidebar .et_pb_code_0_tb_body { order: 1 !important; } /* share */
.single-post .blog-sidebar .et_pb_code_1_tb_body { order: 2 !important; } /* author box */
.single-post .blog-sidebar .et_pb_code_2_tb_body { order: 3 !important; } /* book a demo */
.single-post .blog-sidebar .et_pb_code_3_tb_body { order: 4 !important; } /* newsletter */

/* Section title */
.single-post .blog-sidebar .blog-sidebar-title {
  font-family: var(--font-family-heading) !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  color: var(--color-muted-foreground) !important;
  margin: 0 0 16px 0 !important;
  text-align: left !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  position: relative !important;
  padding-left: 16px !important;
}

.single-post .blog-sidebar .blog-sidebar-title::before {
  content: '' !important;
  position: absolute !important;
  left: 0 !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 4px !important;
  height: 16px !important;
  background: var(--brand-primary) !important;
}

/* Social share */
.single-post .blog-sidebar .blog-social-share {
  display: flex !important;
  justify-content: flex-start !important;
  gap: 16px !important;
  margin: 0 !important;
  padding: 0 !important;
}

.single-post .blog-sidebar .blog-social-button {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 32px !important;
  height: 32px !important;
  border-radius: 50% !important;
  background: var(--white) !important;
  border: 2px solid !important;
  text-decoration: none !important;
  transition: all 0.3s ease !important;
  font-size: 14px !important;
  cursor: pointer !important;
}

.single-post .blog-sidebar .blog-social-button:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 4px 12px var(--shadow-20) !important;
}

.single-post .blog-sidebar .blog-social-button.linkedin {
  border-color: var(--brand-primary) !important;
  color: var(--brand-primary) !important;
}
.single-post .blog-sidebar .blog-social-button.linkedin:hover {
  background: var(--brand-primary) !important;
  color: var(--white) !important;
}

.single-post .blog-sidebar .blog-social-button.twitter {
  border-color: var(--brand-secondary) !important;
  color: var(--brand-secondary) !important;
}
.single-post .blog-sidebar .blog-social-button.twitter:hover {
  background: var(--brand-secondary) !important;
  color: var(--white) !important;
}

.single-post .blog-sidebar .blog-social-button.email {
  border-color: var(--brand-primary) !important;
  color: var(--brand-primary) !important;
}
.single-post .blog-sidebar .blog-social-button.email:hover {
  background: var(--brand-primary) !important;
  color: var(--white) !important;
}

/* Suppress wpautop-injected empty <p> tags near the share widget.
   Note: [data-consource-share] > p was removed — it caught button wrappers too. */
[data-consource-share] p:empty,
[data-consource-share] + p:empty,
.et_pb_text_inner:has([data-consource-share]) > p:empty {
  display: none !important;
  margin: 0 !important;
  padding: 0 !important;
  line-height: 0 !important;
}

/* Demo CTA */
.single-post .blog-sidebar .blog-demo-cta {
  text-align: left !important;
  padding: 20px 0 !important;
  border-top: 1px solid var(--color-border) !important;
}

.single-post .blog-sidebar .blog-demo-cta-text {
  font-family: var(--font-family-body) !important;
  font-size: 13px !important;
  color: var(--color-muted-foreground) !important;
  line-height: 1.4 !important;
  margin: 0 0 14px 0 !important;
}

.single-post .blog-sidebar .blog-demo-button {
  width: 100% !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  padding: 10px 16px !important;
  border-radius: 0 !important;
  background: var(--brand-secondary) !important;
  color: var(--white) !important;
  border: 2px solid var(--brand-secondary) !important;
  font-family: var(--font-family-body) !important;
  font-weight: 600 !important;
  font-size: 13px !important;
  cursor: pointer !important;
  transition: all 0.3s ease !important;
}

.single-post .blog-sidebar .blog-demo-button:hover {
  background: var(--brand-secondary-2) !important;
  border-color: var(--brand-secondary-2) !important;
  transform: translateY(-2px) !important;
}

/* Newsletter widget */
.single-post .blog-sidebar .blog-newsletter-widget {
  text-align: left !important;
  padding: 20px 0 !important;
  border-top: 1px solid var(--color-border) !important;
}

.single-post .blog-sidebar .blog-newsletter-text {
  font-family: var(--font-family-body) !important;
  font-size: 13px !important;
  color: var(--color-muted-foreground) !important;
  line-height: 1.4 !important;
  margin: 0 0 14px 0 !important;
}

.single-post .blog-sidebar .blog-newsletter-form {
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
  margin-bottom: 8px !important;
}

.single-post .blog-sidebar .blog-newsletter-input {
  width: 100% !important;
  padding: 8px 10px !important;
  border: 2px solid var(--color-border) !important;
  border-radius: 0 !important;
  font-family: var(--font-family-body) !important;
  font-size: 13px !important;
  background: var(--white) !important;
  color: var(--color-foreground) !important;
}

.single-post .blog-sidebar .blog-newsletter-input:focus {
  outline: none !important;
  border-color: var(--brand-primary) !important;
  box-shadow: none !important;
}

.single-post .blog-sidebar .blog-newsletter-button {
  width: 100% !important;
  padding: 8px 10px !important;
  border: 2px solid var(--brand-primary) !important;
  border-radius: 0 !important;
  background: var(--brand-primary) !important;
  color: var(--white) !important;
  font-family: var(--font-family-body) !important;
  font-weight: 600 !important;
  font-size: 13px !important;
  cursor: pointer !important;
  transition: all 0.3s ease !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
}

.single-post .blog-sidebar .blog-newsletter-button:hover {
  background: var(--brand-teal-secondary) !important;
  border-color: var(--brand-teal-secondary) !important;
}

.single-post .blog-sidebar .blog-newsletter-privacy {
  font-family: var(--font-family-body) !important;
  font-size: 11px !important;
  color: var(--color-muted-foreground) !important;
  margin: 8px 0 0 0 !important;
}


/* ==========================================================================
   ARTICLE CONTENT TYPOGRAPHY
   ========================================================================== */

.single-post .et_pb_column.blog-article-content .et_pb_post_content {
  padding: 0 !important;
}

/* Headings */
.single-post .blog-article-content .et_pb_text_inner h1,
.single-post .blog-article-content .et_pb_text_inner h2,
.single-post .blog-article-content .et_pb_text_inner h3,
.single-post .blog-article-content .et_pb_text_inner h4,
.single-post .blog-article-content .et_pb_text_inner h5,
.single-post .blog-article-content .et_pb_text_inner h6 {
  font-family: var(--font-family-heading) !important;
  color: var(--brand-primary) !important;
  font-weight: 600 !important;
  line-height: 1.3 !important;
  margin: 1.5rem 0 0 0 !important;
}

.single-post .blog-article-content .et_pb_text_inner h2 {
  font-size: clamp(1.5rem, 3vw, 2rem) !important;
  color: var(--brand-primary) !important;
  border-bottom: 2px solid var(--brand-teal-secondary) !important;
  padding-bottom: 0.75rem !important;
  margin-bottom:0.75em!important;
}

.single-post .blog-article-content .et_pb_text_inner h3 {
  font-size: clamp(1.25rem, 2.5vw, 1.5rem) !important;
  color: var(--brand-teal-secondary) !important;
  position: relative !important;
  padding-left: 20px !important;
}

.single-post .blog-article-content .et_pb_text_inner h3::before {
  content: '' !important;
  position: absolute !important;
  left: 0 !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 4px !important;
  height: 24px !important;
  background: var(--brand-teal-secondary) !important;
  border-radius: 2px !important;
}

.single-post .blog-article-content .et_pb_text_inner h4 {
  font-size: 1.125rem !important;
  color: var(--brand-teal-accent) !important;
}

/* Paragraphs */
.single-post .blog-article-content .et_pb_text_inner p {
  font-family: var(--font-family-body) !important;
  font-size: 16px !important;
  font-weight: 400 !important;
  line-height: 1.8 !important;
  color: var(--color-foreground) !important;
  margin: 0 !important;
}

/* Lists */
.single-post .blog-article-content .et_pb_text_inner ul,
.single-post .blog-article-content .et_pb_text_inner ol {
  font-family: var(--font-family-body) !important;
  font-size: 18px !important;
  line-height: 1.8 !important;
  color: var(--color-foreground) !important;
  padding-left: 2.5rem !important;
}

.single-post .blog-article-content .et_pb_text_inner ul li::marker {
  color: var(--brand-primary) !important;
}

.single-post .blog-article-content .et_pb_text_inner ol li::marker {
  color: var(--brand-primary) !important;
  font-weight: 600 !important;
}

/* Links */
.single-post .blog-article-content .et_pb_text_inner a {
  color: var(--brand-secondary) !important;
  text-decoration: underline !important;
  text-decoration-color: var(--brand-secondary-transparent) !important;
  text-underline-offset: 3px !important;
  text-decoration-thickness: 2px !important;
  transition: all 0.3s ease !important;
  font-weight: 500 !important;
}

.single-post .blog-article-content .et_pb_text_inner a:hover {
  color: var(--brand-secondary-2) !important;
  text-decoration-color: var(--brand-secondary) !important;
  text-decoration-thickness: 3px !important;
}

/* Strong / em */
.single-post .blog-article-content .et_pb_text_inner strong,
.single-post .blog-article-content .et_pb_text_inner b {
  color: var(--brand-primary) !important;
  font-weight: 600 !important;
}

.single-post .blog-article-content .et_pb_text_inner em,
.single-post .blog-article-content .et_pb_text_inner i {
  color: var(--brand-secondary) !important;
  font-style: italic !important;
}


/* ==========================================================================
   AUTHOR BOX — visibility only (all styles live in the author-box plugin)
   ========================================================================== */

.author-box,
.consource-author-section {
  display: none !important;
}

body.single-post .author-box {
  display: flex !important;
}

body.single-post .screen-reader-text {
  position: absolute !important;
  left: -9999px !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
}

/* Legacy compat */
.single-post .blog-sidebar .consource-author-section {
  background: var(--white) !important;
  border: 2px solid var(--brand-secondary) !important;
  border-radius: 0 !important;
  padding: 24px !important;
  margin: 0 !important;
  display: flex !important;
  align-items: flex-start !important;
  gap: 20px !important;
  position: relative !important;
  box-shadow: none !important;
}

.single-post .blog-sidebar .consource-author-section::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  width: 4px !important;
  height: 100% !important;
  background: var(--brand-secondary) !important;
}

.single-post .blog-sidebar .consource-author-photo {
  width: 80px !important;
  height: 80px !important;
  border-radius: 0 !important;
  object-fit: cover !important;
  border: 2px solid var(--brand-secondary) !important;
  flex-shrink: 0 !important;
  background: var(--surface-100) !important;
}

.single-post .blog-sidebar .consource-author-content {
  flex: 1 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
}

.single-post .blog-sidebar .consource-author-name {
  font-family: var(--font-family-heading) !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  color: var(--brand-primary) !important;
  margin: 0 0 4px 0 !important;
  line-height: 1.2 !important;
}

.single-post .blog-sidebar .consource-author-title {
  font-family: var(--font-family-body) !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  color: var(--brand-secondary) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  margin: 0 0 8px 0 !important;
}

.single-post .blog-sidebar .consource-author-bio {
  font-family: var(--font-family-body) !important;
  font-size: 12px !important;
  color: var(--color-muted-foreground) !important;
  line-height: 1.5 !important;
  margin: 0 0 12px 0 !important;
}

.single-post .blog-sidebar .consource-author-social {
  display: flex !important;
  gap: 8px !important;
  align-items: center !important;
}

.single-post .blog-sidebar .consource-author-social-link {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 28px !important;
  height: 28px !important;
  border-radius: 50% !important;
  background: none !important;
  border: 1.5px solid !important;
  text-decoration: none !important;
  transition: all 0.3s ease !important;
  font-size: 12px !important;
}

.single-post .blog-sidebar .consource-author-social-link:hover {
  transform: translateY(-1px) !important;
}

.single-post .blog-sidebar .consource-author-social-link.email {
  border-color: var(--brand-secondary) !important;
  color: var(--brand-secondary) !important;
}
.single-post .blog-sidebar .consource-author-social-link.email:hover {
  background: var(--brand-secondary) !important;
  color: var(--white) !important;
}

.single-post .blog-sidebar .consource-author-social-link.linkedin {
  border-color: var(--brand-primary) !important;
  color: var(--brand-primary) !important;
}
.single-post .blog-sidebar .consource-author-social-link.linkedin:hover {
  background: var(--brand-primary) !important;
  color: var(--white) !important;
}


/* ==========================================================================
   DOWNLOAD WIDGET
   ========================================================================== */

.single-post .blog-single-download {
  background: var(--white) !important;
  border: 2px solid var(--brand-primary) !important;
  border-radius: 12px !important;
  padding: 32px !important;
  margin: 48px 0 !important;
  position: relative !important;
  overflow: hidden !important;
  box-shadow: 0 4px 16px var(--shadow-10) !important;
}

.single-post .blog-single-download::before {
  content: '' !important;
  position: absolute !important;
  top: -20px !important;
  right: -20px !important;
  width: 80px !important;
  height: 80px !important;
  background: var(--brand-primary-transparent) !important;
  border-radius: 50% !important;
  z-index: 1 !important;
}

.single-post .blog-single-download > * {
  position: relative !important;
  z-index: 10 !important;
}

.single-post .blog-single-download h3,
.single-post .blog-single-download h4,
.single-post .blog-single-download h5,
.single-post .blog-single-download h6 {
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
}

.single-post .blog-single-download p {
  margin: 0 !important;
  padding: 0 !important;
  font-size: inherit !important;
  line-height: inherit !important;
}

.single-post .blog-download-header {
  text-align: center !important;
  margin-bottom: 28px !important;
}

.single-post .blog-download-main-title {
  font-family: var(--font-family-heading) !important;
  font-size: 28px !important;
  font-weight: 600 !important;
  color: var(--color-foreground) !important;
  margin-bottom: 12px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 12px !important;
}

.single-post .blog-download-title-icon {
  color: var(--brand-primary) !important;
  font-size: 32px !important;
}

.single-post .blog-download-subtitle {
  font-family: var(--font-family-body) !important;
  color: var(--color-muted-foreground) !important;
  font-size: 16px !important;
  line-height: 1.5 !important;
  max-width: 500px !important;
  margin: 0 auto !important;
}

.single-post .blog-download-item {
  display: flex !important;
  align-items: center !important;
  gap: 20px !important;
  padding: 24px !important;
  background: var(--brand-primary-transparent) !important;
  border: 1px solid var(--brand-primary) !important;
  border-radius: 12px !important;
  transition: all 0.3s ease !important;
  cursor: pointer !important;
  position: relative !important;
  margin-bottom: 20px !important;
}

.single-post .blog-download-item:hover {
  background: var(--brand-primary) !important;
  color: var(--white) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 6px 20px var(--shadow-20) !important;
}

.single-post .blog-download-icon {
  color: var(--brand-primary) !important;
  font-size: 32px !important;
  flex-shrink: 0 !important;
  transition: color 0.3s ease !important;
}
.single-post .blog-download-item:hover .blog-download-icon {
  color: var(--white) !important;
}

.single-post .blog-download-content {
  flex: 1 !important;
}

.single-post .blog-download-title {
  font-family: var(--font-family-heading) !important;
  font-size: 20px !important;
  font-weight: 600 !important;
  color: var(--color-foreground) !important;
  margin-bottom: 8px !important;
  transition: color 0.3s ease !important;
}
.single-post .blog-download-item:hover .blog-download-title {
  color: var(--white) !important;
}

.single-post .blog-download-description {
  font-family: var(--font-family-body) !important;
  color: var(--color-muted-foreground) !important;
  font-size: 15px !important;
  line-height: 1.4 !important;
  margin: 0 !important;
  transition: color 0.3s ease !important;
}
.single-post .blog-download-item:hover .blog-download-description {
  color: rgba(255, 255, 255, 0.9) !important;
}

.single-post .blog-download-arrow {
  color: var(--surface-400) !important;
  font-size: 18px !important;
  flex-shrink: 0 !important;
  transition: all 0.3s ease !important;
}
.single-post .blog-download-item:hover .blog-download-arrow {
  color: var(--white) !important;
  transform: translateX(4px) !important;
}

.single-post .blog-download-form {
  background: var(--surface-50) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 8px !important;
  padding: 24px !important;
  margin-top: 16px !important;
  display: none !important;
  transition: all 0.3s ease !important;
}

.single-post .blog-download-form.active {
  display: block !important;
  animation: slideDown 0.3s ease !important;
}

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

.single-post .blog-download-form-title {
  font-family: var(--font-family-heading) !important;
  font-size: 18px !important;
  font-weight: 600 !important;
  color: var(--color-foreground) !important;
  margin-bottom: 16px !important;
  text-align: center !important;
}


/* ==========================================================================
   FLUENT FORMS — DOWNLOAD WIDGET
   ========================================================================== */

.single-post .blog-download-form .fluentform,
.single-post .blog-download-form .fluent_form_wrapper,
.single-post .blog-download-form .ff-form-wrap {
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
  box-shadow: none !important;
}

.single-post .blog-download-form .ff-el-group,
.single-post .blog-download-form .ff-field-container {
  margin-bottom: 16px !important;
}

.single-post .blog-download-form .ff-el-input--label,
.single-post .blog-download-form .ff-field-label {
  font-family: var(--font-family-body) !important;
  font-weight: 600 !important;
  font-size: 14px !important;
  color: var(--color-foreground) !important;
  margin-bottom: 6px !important;
  display: block !important;
}

.single-post .blog-download-form .ff-el-form-control,
.single-post .blog-download-form .ff-field input[type="text"],
.single-post .blog-download-form .ff-field input[type="email"],
.single-post .blog-download-form .ff-field input[type="tel"],
.single-post .blog-download-form .ff-field textarea,
.single-post .blog-download-form .ff-field select {
  width: 100% !important;
  padding: 12px 16px !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 6px !important;
  font-family: var(--font-family-body) !important;
  font-size: 16px !important;
  margin-bottom: 12px !important;
  transition: border-color 0.3s ease !important;
  background-color: var(--white) !important;
  color: var(--color-foreground) !important;
  box-shadow: none !important;
}

.single-post .blog-download-form .ff-el-form-control:focus,
.single-post .blog-download-form .ff-field input:focus,
.single-post .blog-download-form .ff-field textarea:focus,
.single-post .blog-download-form .ff-field select:focus {
  outline: none !important;
  border-color: var(--brand-primary) !important;
  box-shadow: 0 0 0 3px var(--brand-primary-transparent) !important;
}

.single-post .blog-download-form .ff-btn-submit,
.single-post .blog-download-form .ff-btn-primary,
.single-post .blog-download-form .wpf_submit_btn,
.single-post .blog-download-form .ff-submit-btn-wrapper button,
.single-post .blog-download-form .ff-submit-btn-wrapper input[type="submit"] {
  background: var(--brand-primary) !important;
  color: var(--white) !important;
  border: none !important;
  padding: 14px 28px !important;
  border-radius: 6px !important;
  font-family: var(--font-family-body) !important;
  font-weight: 600 !important;
  font-size: 16px !important;
  cursor: pointer !important;
  transition: all 0.3s ease !important;
  width: 100% !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  box-shadow: 0 2px 8px var(--shadow-10) !important;
}

.single-post .blog-download-form .ff-btn-submit:hover,
.single-post .blog-download-form .ff-btn-primary:hover,
.single-post .blog-download-form .wpf_submit_btn:hover,
.single-post .blog-download-form .ff-submit-btn-wrapper button:hover,
.single-post .blog-download-form .ff-submit-btn-wrapper input[type="submit"]:hover {
  background: var(--brand-teal-secondary) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 4px 12px var(--shadow-20) !important;
}

.single-post .author-bio-section,
.single-post .et_pb_post_title .author.vcard {
  display: none !important;
}


/* ==========================================================================
   BLOG INDEX PAGE — COMPONENT CLASSES
   ========================================================================== */
.breadcrumb-section {display:none;}
/* Breadcrumb
.breadcrumb-section {
  background-color: var(--surface-50);
  padding: 12px 0;
  border-bottom: 1px solid var(--color-border);
}

.breadcrumb-link {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--color-muted-foreground);
  text-decoration: none;
  transition: color 0.3s ease;
  font-family: var(--font-family-body);
  font-size: 0.875rem;
}

.breadcrumb-link:hover {
  color: var(--color-foreground);
}*/

/* Blog page header */
.blog-header-section {
  background-color: var(--white);
  padding: 48px 0 32px 0;
  border-bottom: 1px solid var(--color-border);
}

.blog-header-content {
  text-align: center;
  margin-bottom: 32px;
}

.blog-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background-color: var(--brand-primary-transparent);
  border: 2px solid var(--brand-primary);
  color: var(--brand-primary);
  padding: 8px 16px;
  border-radius: 4px;
  font-family: var(--font-family-body);
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 24px;
}

.blog-main-title  { margin-bottom: 16px; }
.blog-description { max-width: 600px; margin: 0 auto; }

/* Category filter */
.blog-categories-filter {
  display: flex;
  justify-content: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 24px;
}

.blog-category-btn {
  padding: 8px 16px;
  border: 1px solid var(--color-border);
  background-color: var(--white);
  color: var(--color-muted-foreground);
  font-family: var(--font-family-body);
  font-size: 14px;
  font-weight: 400;
  cursor: pointer;
  transition: all 0.3s ease;
  border-radius: 4px;
  position: relative;
  text-decoration: none;
}

.blog-category-btn:hover {
  border-color: var(--surface-300);
  color: var(--color-foreground);
}

.blog-category-btn.active {
  border: 2px solid var(--brand-primary);
  background-color: var(--brand-primary-transparent);
  color: var(--brand-primary);
  font-weight: 600;
}

.blog-category-count {
  position: absolute;
  top: -8px;
  right: -8px;
  width: 20px;
  height: 20px;
  background-color: var(--brand-secondary);
  color: var(--white);
  border-radius: 50%;
  font-size: 10px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Filter bar */
.blog-filter-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 32px;
  background-color: var(--surface-50);
  border: 1px solid var(--color-border);
  border-radius: 8px;
  flex-wrap: wrap;
  gap: 16px;
}

.blog-filter-left,
.blog-filter-right {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.blog-filter-label {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--brand-primary);
  font-family: var(--font-family-body);
  font-size: 14px;
  font-weight: 600;
}

.blog-sort-container {
  display: flex;
  align-items: center;
  gap: 8px;
}

.blog-sort-container label {
  font-family: var(--font-family-body);
  font-size: 13px;
  color: var(--color-muted-foreground);
  font-weight: 500;
}

.blog-select-wrapper {
  position: relative;
}

.blog-sort-select {
  appearance: none;
  padding: 6px 28px 6px 12px;
  border: 1px solid var(--color-border);
  background-color: var(--white);
  font-family: var(--font-family-body);
  font-size: 13px;
  color: var(--color-foreground);
  cursor: pointer;
  min-width: 140px;
  border-radius: 4px;
}

.blog-select-wrapper i {
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--color-muted-foreground);
  font-size: 10px;
  pointer-events: none;
}

.blog-clear-filter {
  padding: 6px 12px;
  background-color: var(--white);
  color: var(--color-muted-foreground);
  border: 1px solid var(--color-border);
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.3s ease;
  border-radius: 4px;
  display: none;
  align-items: center;
  gap: 4px;
  font-family: var(--font-family-body);
  text-decoration: none;
}

.blog-clear-filter.show {
  display: flex;
}

.blog-clear-filter:hover {
  background-color: var(--surface-100);
  color: var(--color-foreground);
}

.blog-article-count {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--color-muted-foreground);
  font-family: var(--font-family-body);
}

.blog-article-count i {
  color: var(--brand-secondary);
  font-size: 14px;
}

.blog-search-link {
  padding: 6px 12px;
  background-color: var(--brand-primary);
  color: var(--white);
  border: none;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: background-color 0.3s ease;
  border-radius: 4px;
  display: flex;
  align-items: center;
  gap: 6px;
  text-decoration: none;
  font-family: var(--font-family-body);
}

.blog-search-link:hover {
  background-color: var(--brand-teal-secondary);
  color: var(--white);
  text-decoration: none;
}

/* Blog index sidebar */
.blog-sidebar-section {
  background: var(--white);
  border: 1px solid var(--color-border);
  border-radius: 8px;
  padding: 24px;
}

.blog-sidebar-title {
  font-family: var(--font-family-heading);
  font-size: 18px;
  font-weight: 600;
  color: var(--color-foreground);
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.blog-sidebar-title i {
  color: var(--brand-secondary);
  font-size: 16px;
}

/* Most read list */
.blog-most-read-list {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.blog-most-read-item {
  display: flex;
  gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid var(--color-border);
  transition: all 0.3s ease;
}

.blog-most-read-item:last-child {
  border-bottom: none;
}

.blog-most-read-item:hover {
  background-color: var(--surface-50);
  margin: 0 -12px;
  padding: 12px;
  border-radius: 8px;
}

.blog-most-read-image {
  width: 60px;
  height: 60px;
  border-radius: 4px;
  overflow: hidden;
  flex-shrink: 0;
}

.blog-most-read-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.blog-most-read-content h4 {
  font-family: var(--font-family-heading);
  font-size: 14px;
  font-weight: 600;
  line-height: 1.3;
  margin-bottom: 4px;
}

.blog-most-read-content h4 a {
  color: var(--color-foreground);
  text-decoration: none;
}

.blog-most-read-content h4 a:hover {
  color: var(--brand-primary);
}

.blog-most-read-meta {
  font-size: 11px;
  color: var(--color-muted-foreground);
  display: flex;
  gap: 8px;
}

.blog-empty-popular {
  color: var(--color-muted-foreground);
  text-align: center;
  padding: 20px;
  margin: 0;
  font-family: var(--font-family-body);
  font-size: 14px;
}

/* Section headers */
.blog-section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 32px;
}

.blog-section-header-spaced {
  margin-bottom: 32px;
}

.blog-section-title {
  font-family: var(--font-family-heading);
  font-size: 24px;
  font-weight: 600;
  color: var(--color-foreground);
  margin: 0;
  display: flex;
  align-items: center;
  gap: 12px;
}

.blog-section-title i {
  color: var(--brand-primary);
  font-size: 20px;
}

.blog-section-meta {
  font-family: var(--font-family-body);
  font-size: 13px;
  color: var(--color-muted-foreground);
  display: flex;
  align-items: center;
  gap: 6px;
}

.blog-section-meta i {
  color: var(--brand-secondary);
  font-size: 12px;
}

/* Layout */
.blog-main-grid-section {
  background-color: var(--white);
  padding: 48px 0;
}

.blog-two-column-layout {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 48px;
  align-items: start;
}

.blog-articles-column {
  display: flex;
  flex-direction: column;
  gap: 48px;
}

.blog-sidebar-column {
  position: sticky;
  top: 120px;
}

/* Grids */
.blog-large-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-bottom: 48px;
}

.blog-medium-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
  margin-bottom: 48px;
}

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

.blog-grid-spaced {
  margin-bottom: 48px;
}

.blog-load-more-section {
  text-align: center;
}

/* Featured article */
.blog-featured-article {
  background-color: var(--white);
  border: 1px solid var(--color-border);
  overflow: hidden;
  margin-bottom: 48px;
}

.blog-featured-banner {
  background-color: var(--brand-secondary);
  color: var(--white);
  padding: 12px 24px 8px;
  text-align: center;
}

.blog-featured-banner-label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  opacity: 0.9;
  font-family: var(--font-family-body);
}

.blog-featured-image img {
  width: 100%;
  height: 280px;
  object-fit: cover;
  display: block;
}

.blog-featured-content {
  padding: 32px;
  border-left: 4px solid var(--brand-secondary);
  cursor: pointer;
  transition: all 0.3s ease;
}

.blog-featured-content:hover {
  background-color: var(--surface-50);
}

.blog-featured-meta {
  display: flex;
  gap: 12px;
  align-items: center;
  margin-bottom: 20px;
  flex-wrap: wrap;
}

.blog-category-tag {
  background-color: var(--brand-primary-transparent);
  color: var(--brand-primary);
  padding: 4px 12px;
  border-radius: 12px;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.blog-meta-items {
  display: flex;
  align-items: center;
  gap: 16px;
  font-size: 12px;
  color: var(--color-muted-foreground);
}

.blog-featured-title {
  font-family: var(--font-family-heading);
  font-size: 28px;
  font-weight: 600;
  color: var(--color-foreground);
  margin-bottom: 16px;
  line-height: 1.3;
}

.blog-featured-title a {
  color: inherit;
  text-decoration: none;
}

.blog-featured-excerpt {
  font-family: var(--font-family-body);
  font-size: 16px;
  color: var(--color-muted-foreground);
  line-height: 1.6;
  margin-bottom: 24px;
}

.blog-read-more {
  font-family: var(--font-family-body);
  font-size: 14px;
  font-weight: 600;
  color: var(--brand-primary);
  display: flex;
  align-items: center;
  gap: 6px;
  text-decoration: none;
}

/* Large cards */
.blog-large-article {
  background-color: var(--white);
  border: 1px solid var(--color-border);
  border-radius: 8px;
  overflow: hidden;
  cursor: pointer;
  transition: all 0.3s ease;
}

.blog-large-article:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 24px var(--shadow-20);
}

.blog-large-image {
  height: 200px;
  overflow: hidden;
}

.blog-large-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
}

.blog-large-article:hover .blog-large-image img {
  transform: scale(1.05);
}

.blog-large-content {
  padding: 24px;
}

.blog-large-meta {
  display: flex;
  gap: 8px;
  align-items: center;
  margin-bottom: 16px;
  flex-wrap: wrap;
}

.blog-category-small {
  background-color: var(--brand-secondary-transparent);
  color: var(--brand-secondary);
  padding: 3px 8px;
  border-radius: 10px;
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
}

.blog-meta-small {
  font-size: 11px;
  color: var(--color-muted-foreground);
  display: flex;
  align-items: center;
  gap: 8px;
}

.blog-large-title {
  font-family: var(--font-family-heading);
  font-size: 20px;
  font-weight: 600;
  color: var(--color-foreground);
  margin-bottom: 12px;
  line-height: 1.3;
}

.blog-large-title a {
  color: inherit;
  text-decoration: none;
}

.blog-large-excerpt {
  font-family: var(--font-family-body);
  font-size: 14px;
  color: var(--color-muted-foreground);
  line-height: 1.5;
  margin-bottom: 16px;
}

.blog-large-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.blog-read-more-small {
  font-size: 12px;
  color: var(--brand-primary);
  font-weight: 600;
  text-decoration: none;
}

.blog-views-small {
  font-size: 11px;
  color: var(--color-muted-foreground);
}

/* Medium cards */
.blog-medium-article {
  background-color: var(--white);
  border: 1px solid var(--color-border);
  border-radius: 6px;
  overflow: hidden;
  cursor: pointer;
  transition: all 0.3s ease;
}

.blog-medium-article:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 16px var(--shadow-10);
}

.blog-medium-image {
  height: 160px;
  overflow: hidden;
}

.blog-medium-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.blog-medium-content {
  padding: 20px;
}

.blog-medium-meta {
  display: flex;
  gap: 8px;
  align-items: center;
  margin-bottom: 12px;
  flex-wrap: wrap;
}

.blog-category-tiny {
  background-color: var(--brand-primary-transparent);
  color: var(--brand-primary);
  padding: 2px 6px;
  border-radius: 8px;
  font-size: 9px;
  font-weight: 600;
  text-transform: uppercase;
  margin-bottom: 12px;
  display: inline-block;
}

.blog-medium-title {
  font-family: var(--font-family-heading);
  font-size: 16px;
  font-weight: 600;
  color: var(--color-foreground);
  margin-bottom: 10px;
  line-height: 1.3;
}

.blog-medium-title a {
  color: inherit;
  text-decoration: none;
}

.blog-medium-excerpt {
  font-family: var(--font-family-body);
  font-size: 13px;
  color: var(--color-muted-foreground);
  line-height: 1.4;
  margin-bottom: 14px;
}

.blog-medium-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 10px;
  color: var(--color-muted-foreground);
}

/* Compact cards */
.blog-compact-card {
  background: var(--white);
  border: 1px solid var(--color-border);
  border-radius: 8px;
  overflow: hidden;
  transition: all 0.3s ease;
}

.blog-compact-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px var(--shadow-20);
}

.blog-compact-card .blog-compact-image {
  overflow: hidden;
}

.blog-compact-card .blog-compact-image img {
  width: 100%;
  height: 140px;
  object-fit: cover;
  transition: transform 0.3s ease;
}

.blog-compact-card:hover .blog-compact-image img {
  transform: scale(1.03);
}

.blog-compact-card .blog-compact-content {
  padding: 16px;
}

.blog-compact-card .blog-compact-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 8px;
}

.blog-compact-card .blog-compact-title {
  font-family: var(--font-family-heading);
  font-size: 14px;
  font-weight: 600;
  line-height: 1.3;
  margin-bottom: 12px;
}

.blog-compact-card .blog-compact-title a {
  color: var(--color-foreground);
  text-decoration: none;
}

.blog-compact-card .blog-compact-title a:hover {
  color: var(--brand-primary);
}

.blog-compact-card .blog-compact-footer {
  display: flex;
  justify-content: space-between;
  font-size: 11px;
  color: var(--color-muted-foreground);
}

/* Pagination */
.blog-pagination {
  text-align: center;
  margin-top: 32px;
}

.blog-pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  margin: 0 4px;
  border: 1px solid var(--color-border);
  background: var(--white);
  color: var(--color-foreground);
  text-decoration: none;
  transition: all 0.3s ease;
  border-radius: 4px;
  font-family: var(--font-family-body);
  font-size: 14px;
}

.blog-pagination .page-numbers:hover,
.blog-pagination .page-numbers.current {
  background: var(--brand-primary);
  color: var(--white);
  border-color: var(--brand-primary);
}

.blog-pagination .page-numbers.dots {
  border: none;
  background: none;
  color: var(--color-muted-foreground);
}

/* No posts */
.blog-no-posts {
  text-align: center;
  padding: 80px 40px;
  color: var(--color-muted-foreground);
}

.blog-no-posts i {
  font-size: 48px;
  color: var(--brand-primary);
  margin-bottom: 24px;
  opacity: 0.5;
}

.blog-no-posts h3 {
  font-family: var(--font-family-heading);
  font-size: 24px;
  color: var(--color-foreground);
  margin-bottom: 16px;
}

.blog-no-posts p {
  font-family: var(--font-family-body);
  font-size: 16px;
  margin-bottom: 24px;
}

.blog-no-results-state {
  text-align: center;
  padding: 40px;
  color: var(--color-muted-foreground);
  font-family: var(--font-family-body);
  font-size: 15px;
}

/* Newsletter section */
.blog-newsletter-section {
  background-color: var(--surface-50);
  border-top: 1px solid var(--surface-200);
  padding: 64px 0;
}

.blog-newsletter-content {
  text-align: center;
  max-width: 600px;
  margin: 0 auto;
}

.blog-newsletter-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background-color: var(--brand-primary-soft);
  border: 1px solid var(--brand-primary);
  color: var(--brand-primary);
  padding: 8px 16px;
  border-radius: 20px;
  font-family: var(--font-family-body);
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 24px;
}

.blog-newsletter-section h2 {
  color: var(--text-color);
  margin-bottom: 16px;
}

.blog-newsletter-section .text-lead {
  color: var(--text-muted);
  margin-bottom: 32px;
}

.blog-newsletter-form {
  display: flex;
  gap: 12px;
  max-width: 400px;
  margin: 0 auto 16px auto;
  flex-wrap: wrap;
  justify-content: center;
}

.blog-newsletter-input {
  flex: 1;
  min-width: 250px;
  padding: 14px 16px;
  border: 1px solid var(--surface-300);
  background-color: var(--surface-0);
  border-radius: 6px;
  font-family: var(--font-family-body);
  font-size: 14px;
  color: var(--text-color);
}

.blog-newsletter-privacy {
  color: var(--text-muted);
  font-family: var(--font-family-body);
  font-size: 12px;
}

.blog-newsletter-privacy a {
  color: var(--brand-primary);
  text-decoration: underline;
}

/* Loading states */
.blog-loading-categories,
.blog-loading-most-read,
.blog-loading-section {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 20px;
  color: var(--color-muted-foreground);
  font-family: var(--font-family-body);
  font-size: 14px;
}

.blog-loading-section {
  flex-direction: column;
  text-align: center;
  border: 2px dashed var(--color-border);
  border-radius: 8px;
  min-height: 200px;
}

.blog-loading-section i {
  font-size: 48px;
  color: var(--brand-primary);
  margin-bottom: 16px;
}

.blog-sort-form {
  display: inline-block;
}


/* ==========================================================================
   ACCESSIBILITY
   ========================================================================== */

.single-post .sr-only {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0,0,0,0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}


/* ==========================================================================
   RESPONSIVE — SINGLE POST
   ========================================================================== */

@media (max-width: 768px) {
  .single-post .et_pb_image.blog-featured-image img {
    height: 250px !important;
  }

  .single-post .et_pb_post_title.blog-title {
    width: 95% !important;
    padding: 12px 16px 24px !important;
  }

  .single-post .et_pb_post_title.blog-title h1.entry-title {
    font-size: clamp(1.25rem, 5vw, 1.75rem) !important;
  }

  .single-post .et_pb_text.blog-categories {
    padding: 20px 16px 0 !important;
  }

  .single-post .et_pb_row_1_tb_body {
    flex-direction: column !important;
    gap: 32px !important;
  }

  .single-post .et_pb_column.blog-article-content {
    flex: none !important;
    width: 100% !important;
  }

  .single-post .et_pb_column.blog-sidebar {
    position: static !important;
    top: auto !important;
    flex: none !important;
    width: 100% !important;
  }

  .single-post .blog-article-content .et_pb_text_inner p {
    font-size: 16px !important;
  }

  .single-post .blog-article-content .et_pb_text_inner h3::before {
    display: none !important;
  }

  .single-post .blog-article-content .et_pb_text_inner h3 {
    padding-left: 0 !important;
  }

  .single-post .blog-sidebar .consource-author-section {
    flex-direction: column !important;
    text-align: center !important;
    gap: 20px !important;
    padding: 24px !important;
  }

  .single-post .blog-sidebar .consource-author-photo {
    width: 100px !important;
    height: 100px !important;
    align-self: center !important;
  }

  .single-post .blog-single-download {
    padding: 24px !important;
    margin: 32px 0 !important;
  }

}



/* ==========================================================================
   RESPONSIVE — BLOG INDEX
   ========================================================================== */

@media (max-width: 1024px) {
  .blog-two-column-layout  { grid-template-columns: 1fr; gap: 32px; }
  .blog-sidebar-column     { position: static; order: -1; }
  .blog-large-grid         { grid-template-columns: 1fr; }
  .blog-medium-grid        { grid-template-columns: repeat(2, 1fr); }
  .blog-compact-grid       { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 768px) {
  .blog-filter-bar         { flex-direction: column; align-items: flex-start; }
  .blog-filter-left        { flex-direction: column; align-items: flex-start; gap: 12px; }
  .blog-newsletter-form    { flex-direction: column; align-items: center; }
  .blog-newsletter-input   { min-width: 100%; }
  .blog-large-grid,
  .blog-medium-grid,
  .blog-compact-grid       { grid-template-columns: 1fr; }
  .blog-header-content     { text-align: center; }
  .blog-categories-filter  { justify-content: center; }
  .blog-section-header     { flex-direction: column; align-items: flex-start; gap: 8px; }
}

@media (max-width: 480px) {
  .blog-compact-grid { grid-template-columns: 1fr; }
}


/* ==========================================================================
   PRINT
   ========================================================================== */

@media print {
  .single-post .blog-single-download {
    border: 1px solid #000 !important;
    background: #fff !important;
    box-shadow: none !important;
  }

  .single-post .blog-download-form {
    display: none !important;
  }

  .single-post .blog-social-share {
    display: none !important;
  }

  .single-post .consource-author-section {
    border: 1px solid #ccc !important;
    box-shadow: none !important;
  }
}

/* ==========================================================================
   DIVI PLUS FAQ — ARTICLE PAGE
   Confirmed classes: dipl_faq_item_wrapper (item), dipl_question_wrapper,
   dipl_answer_wrapper. Open state: dipl_active. Icon via ::after pseudo-element.
   ========================================================================== */

/* Each FAQ item card */
.single-post .dipl_faq_item_wrapper {
  border: 1px solid var(--surface-200) !important;
  border-radius: 8px !important;
  overflow: hidden !important;
  background: var(--surface-0) !important;
  transition: box-shadow 0.3s ease !important;
  box-shadow: none !important;
  margin-bottom: 16px !important;
}

.single-post .dipl_faq_item_wrapper:last-child {
  margin-bottom: 0 !important;
}

.single-post .dipl_faq_item_wrapper:hover {
  box-shadow: var(--shadow-md) !important;
}

/* Question row */
.single-post .dipl_question_wrapper {
  width: 100% !important;
  padding: 24px !important;
  background: transparent !important;
  border: none !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 16px !important;
  cursor: pointer !important;
  transition: background 0.3s ease !important;
  text-align: left !important;
  box-sizing: border-box !important;
  position: relative !important;
}

.single-post .dipl_faq_item_wrapper.dipl_active .dipl_question_wrapper {
  background: var(--surface-50) !important;
}

/* Question text — target all likely text elements inside */
.single-post .dipl_question_wrapper,
.single-post .dipl_question_wrapper * {
  font-family: var(--font-body) !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  color: var(--surface-900) !important;
  margin: 0 !important;
  line-height: 1.4 !important;
}

/* + / × icon via pseudo-element */
.single-post .dipl_question_wrapper::after {
  content: '+' !important;
  flex-shrink: 0 !important;
  font-size: 22px !important;
  font-weight: 300 !important;
  line-height: 1 !important;
  color: var(--brand-primary) !important;
  transition: transform 0.3s ease !important;
  display: block !important;
}

.single-post .dipl_faq_item_wrapper.dipl_active .dipl_question_wrapper::after {
  transform: rotate(45deg) !important;
}

/* Answer panel */
.single-post .dipl_answer_wrapper {
  padding: 0 24px 24px 24px !important;
  background: var(--surface-0) !important;
}

.single-post .dipl_answer_wrapper p {
  margin: 0 0 12px 0 !important;
  font-family: var(--font-body) !important;
  font-size: 16px !important;
  font-weight: 400 !important;
  color: var(--surface-700) !important;
  line-height: 1.6 !important;
}

.single-post .dipl_answer_wrapper p:last-child {
  margin-bottom: 0 !important;
}