/*
Theme Name: Savage Opus
Theme URI: https://savagemercies.com
Description: Custom child theme for Savage Mercies implementing the Opus 4.5 design system with maximalist aesthetics, rich typography, and theological content structure.
Author: Savage Mercies
Author URI: https://savagemercies.com
Template: generatepress
Version: 1.3.3
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: savage-opus
Tags: theology, maximalist, custom-design
*/

/**
 * Opus 4.5 Design System
 * Maximalist aesthetic for theological content
 */

:root {
  /* Color Palette - Opus 4.5 */
  --color-crimson: #C1121F;      /* Primary, CTAs, emphasis */
  --color-ivory: #F6F3ED;         /* Background, light sections */
  --color-gold: #D7B25A;          /* Dividers, accents, highlights */
  --color-sky: #4DA3FF;           /* Links, interactive elements */
  --color-graphite: #1E1E1E;      /* Primary text, headers */
  --color-slate: #6B6B6B;         /* Secondary text, metadata */

  /* Typography - Maximalist + Readable */
  --font-display: 'Playfair Display', 'Georgia', serif;
  --font-body: 'Source Serif 4', 'Georgia', serif;
  --font-ui: 'Space Grotesk', system-ui, sans-serif;

  /* Type Scale */
  --text-xs: 0.75rem;      /* 12px */
  --text-sm: 0.875rem;     /* 14px */
  --text-base: 1rem;       /* 16px */
  --text-lg: 1.125rem;     /* 18px */
  --text-xl: 1.25rem;      /* 20px */
  --text-2xl: 1.5rem;      /* 24px */
  --text-3xl: 1.875rem;    /* 30px */
  --text-4xl: 2.25rem;     /* 36px */
  --text-5xl: 3rem;        /* 48px */

  /* Spacing */
  --space-1: 0.25rem;      /* 4px */
  --space-2: 0.5rem;       /* 8px */
  --space-3: 0.75rem;      /* 12px */
  --space-4: 1rem;         /* 16px */
  --space-6: 1.5rem;       /* 24px */
  --space-8: 2rem;         /* 32px */
  --space-12: 3rem;        /* 48px */
  --space-16: 4rem;        /* 64px */

  /* Border Radius */
  --radius-sm: 0.25rem;    /* 4px */
  --radius-md: 0.5rem;     /* 8px */
  --radius-lg: 1rem;       /* 16px */

  /* Shadows */
  --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
  --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
  --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);

  /* Transitions */
  --transition-fast: 150ms ease-in-out;
  --transition-base: 250ms ease-in-out;
  --transition-slow: 350ms ease-in-out;
}

/* Prevent horizontal page scrolling on all devices */
html {
  overflow-x: hidden;
}

/* Base Typography */
body {
  font-family: var(--font-body);
  font-size: var(--text-lg);
  line-height: 1.7;
  color: var(--color-graphite);
  background-color: var(--color-ivory);
  overflow-x: hidden;
}

/* Headings - Maximalist Display Font */
h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
  font-family: var(--font-display);
  font-weight: 700;
  line-height: 1.2;
  color: var(--color-graphite);
  margin-top: var(--space-8);
  margin-bottom: var(--space-4);
}

h1, .h1 {
  font-size: var(--text-5xl);
  letter-spacing: -0.02em;
}

h2, .h2 {
  font-size: var(--text-4xl);
  letter-spacing: -0.01em;
}

h3, .h3 {
  font-size: var(--text-3xl);
}

h4, .h4 {
  font-size: var(--text-2xl);
}

h5, .h5 {
  font-size: var(--text-xl);
}

h6, .h6 {
  font-size: var(--text-lg);
}

/* Links */
a {
  color: var(--color-sky);
  text-decoration: none;
  transition: color var(--transition-fast);
}

a:hover {
  color: var(--color-crimson);
  text-decoration: underline;
}

/* Strong Emphasis */
strong, b {
  font-weight: 700;
  color: var(--color-graphite);
}

em, i {
  font-style: italic;
}

/* Buttons & CTAs */
.btn,
button,
input[type="submit"],
.wp-block-button__link {
  font-family: var(--font-ui);
  font-weight: 600;
  padding: var(--space-3) var(--space-6);
  background-color: var(--color-crimson);
  color: white;
  border: none;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all var(--transition-base);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-size: var(--text-sm);
}

.btn:hover,
button:hover,
input[type="submit"]:hover,
.wp-block-button__link:hover {
  background-color: #A00F1A;
  color: white;
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
  text-decoration: none;
}

/* Content Width (DISABLED - see line 4619 for active styles) */
/*.site-content,
.entry-content {
  max-width: 720px;
  margin: 0 auto;
  padding: var(--space-8) var(--space-4);
}*/

/* Paragraph Spacing */
p {
  margin-bottom: var(--space-6);
  line-height: 1.8;
}

/* Blockquotes - Styled */
blockquote,
.wp-block-quote {
  margin: var(--space-8) 0;
  padding: var(--space-6) var(--space-8);
  border-left: 4px solid var(--color-burgundy, #8B1538);
  background-color: var(--color-cream-light, #FAF7F3);
  font-style: italic;
  position: relative;
}

blockquote p,
.wp-block-quote p {
  margin-bottom: var(--space-4);
}

blockquote cite,
.wp-block-quote cite {
  display: block;
  margin-top: var(--space-4);
  font-family: var(--font-ui);
  font-size: var(--text-sm);
  font-style: normal;
  color: var(--color-slate);
}

/* Lists */
ul, ol {
  margin-bottom: var(--space-6);
  padding-left: var(--space-8);
}

li {
  margin-bottom: var(--space-2);
  line-height: 1.7;
}

/* Code Blocks */
code,
pre {
  font-family: 'Monaco', 'Courier New', monospace;
  font-size: var(--text-sm);
  background-color: rgba(30, 30, 30, 0.05);
  border-radius: var(--radius-sm);
}

code {
  padding: var(--space-1) var(--space-2);
}

pre {
  padding: var(--space-4);
  overflow-x: auto;
  margin-bottom: var(--space-6);
}

pre code {
  background: none;
  padding: 0;
}

/* Horizontal Rule */
hr {
  border: none;
  height: 2px;
  background: linear-gradient(
    to right,
    transparent,
    var(--color-gold) 25%,
    var(--color-gold) 75%,
    transparent
  );
  margin: var(--space-12) 0;
}

/* Images */
img {
  max-width: 100%;
  height: auto;
  border-radius: var(--radius-md);
}

figure {
  margin: var(--space-8) 0;
}

figcaption {
  font-family: var(--font-ui);
  font-size: var(--text-sm);
  color: var(--color-slate);
  margin-top: var(--space-2);
  text-align: center;
  font-style: italic;
}

/* Responsive Typography */
@media (max-width: 768px) {
  :root {
    --text-5xl: 2.25rem;    /* 36px */
    --text-4xl: 1.875rem;   /* 30px */
    --text-3xl: 1.5rem;     /* 24px */
  }

  body {
    font-size: var(--text-base);
  }

  .site-content,
  .entry-content {
    padding: var(--space-6) var(--space-3);
  }
}

/* Print Styles */
@media print {
  body {
    background-color: white;
    color: black;
  }

  a {
    color: black;
    text-decoration: underline;
  }

  .btn,
  button,
  nav,
  header,
  footer {
    display: none;
  }
}

/**
 * Layout Components
 */

.container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 var(--space-4);
}

.container-narrow {
  max-width: 800px;
  margin: 0 auto;
  padding: 0 var(--space-4);
}

/**
 * Site Header
 */

.site-header {
  background-color: #FFFFFF;
  border-bottom: 2px solid var(--color-gold);
  padding: var(--space-4) 0;
  position: sticky;
  top: 0;
  z-index: 1000;
  box-shadow: var(--shadow-sm);
}

.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-8);
}

.site-branding .site-title {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  margin: 0;
}

.site-branding .site-title a {
  color: var(--color-graphite);
  text-decoration: none;
}

.site-branding .site-description {
  font-family: var(--font-ui);
  font-size: var(--text-sm);
  color: var(--color-slate);
  margin: var(--space-1) 0 0 0;
}

.main-navigation ul {
  display: flex;
  gap: var(--space-6);
  list-style: none;
  margin: 0;
  padding: 0;
}

.main-navigation a {
  font-family: var(--font-ui);
  font-weight: 500;
  color: var(--color-graphite);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.main-navigation a:hover {
  color: var(--color-crimson);
}

.button-header {
  font-size: var(--text-sm);
  padding: var(--space-2) var(--space-4);
}

.header-cta {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

.header-login-link {
  font-size: var(--text-sm);
  font-family: var(--font-ui);
  color: var(--color-text-secondary);
  text-decoration: none;
  cursor: pointer;
  transition: color 0.2s;
}

.header-login-link:hover {
  color: var(--color-crimson);
}

/* Header Login Modal */
.header-login-modal {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 10000;
  background: rgba(0, 0, 0, 0.5);
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding-top: 120px;
}

.header-login-modal-content {
  background: var(--color-ivory, #FFFDF5);
  border: 2px solid var(--color-gold);
  border-radius: var(--radius-lg);
  padding: var(--space-8) var(--space-8) var(--space-6);
  width: 100%;
  max-width: 400px;
  text-align: center;
  position: relative;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.15);
}

.header-login-close {
  position: absolute;
  top: var(--space-3);
  right: var(--space-4);
  background: none;
  border: none;
  font-size: 1.5rem;
  color: var(--color-slate);
  cursor: pointer;
  line-height: 1;
}

.header-login-close:hover {
  color: var(--color-graphite);
}

.header-login-modal-content h3 {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  color: var(--color-graphite);
  margin-bottom: var(--space-2);
}

.header-login-modal-content p {
  color: var(--color-slate);
  margin-bottom: var(--space-5);
  font-size: var(--text-sm);
}

.header-login-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.header-login-form .newsletter-input {
  border: 2px solid var(--color-gold);
  background: white;
  width: 100%;
}

.header-login-form .newsletter-button {
  background: var(--color-crimson);
  color: white;
  border: none;
  cursor: pointer;
  width: 100%;
}

.header-login-form .newsletter-button:hover {
  background: #7A1230;
}

.header-login-subscribe {
  font-size: var(--text-sm);
  color: var(--color-slate);
  margin-top: var(--space-3);
  margin-bottom: 0;
}

.header-login-subscribe a {
  color: var(--color-accent);
  text-decoration: underline;
}

.mobile-menu-toggle {
  display: none;
  background: none;
  border: none;
  padding: 0.5rem;
  cursor: pointer;
  width: 36px;
  height: 36px;
  position: relative;
  flex-shrink: 0;
}

.mobile-menu-toggle .hamburger,
.mobile-menu-toggle .hamburger::before,
.mobile-menu-toggle .hamburger::after {
  display: block;
  width: 22px;
  height: 2px;
  background-color: var(--color-ink, #1A1A1A);
  border-radius: 1px;
  position: absolute;
  left: 7px;
  transition: transform 0.3s ease, opacity 0.3s ease;
}

.mobile-menu-toggle .hamburger {
  top: 50%;
  transform: translateY(-50%);
}

.mobile-menu-toggle .hamburger::before {
  content: '';
  top: -7px;
}

.mobile-menu-toggle .hamburger::after {
  content: '';
  top: 7px;
}

@media (max-width: 768px) {
  .main-navigation {
    display: none;
  }

  .main-navigation.active {
    display: block;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: #FFFFFF;
    padding: var(--space-4);
    box-shadow: var(--shadow-lg);
  }

  .main-navigation ul {
    flex-direction: column;
  }

  .mobile-menu-toggle {
    display: block;
    background: none;
    border: none;
    padding: var(--space-2);
    cursor: pointer;
  }
}

/**
 * Homepage
 */

.hero-section {
  background: linear-gradient(135deg, var(--color-crimson) 0%, #8B0E17 100%);
  color: white;
  padding: var(--space-16) 0;
  text-align: center;
}

.hero-title {
  font-size: var(--text-5xl);
  margin: 0 0 var(--space-6) 0;
  color: white;
  line-height: 1.1;
}

.hero-subtitle {
  font-size: var(--text-xl);
  margin: 0 0 var(--space-8) 0;
  color: rgba(255, 255, 255, 0.9);
}

.hero-cta {
  max-width: 500px;
  margin: 0 auto;
}

.newsletter-form {
  margin-bottom: var(--space-3);
}

.newsletter-form-fields {
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
  justify-content: center;
}

.newsletter-input {
  padding: var(--space-3) var(--space-4);
  border: 2px solid transparent;
  border-radius: var(--radius-md);
  font-size: var(--text-base);
  font-family: var(--font-ui);
}

.newsletter-name-input {
  flex: 0 1 140px;
}

.newsletter-email-input {
  flex: 1 1 200px;
}

/* Compact hero for subscribers */
.hero-section.hero-compact {
  padding: var(--space-12) 0 var(--space-8);
  min-height: auto;
}

.hero-continue-btn {
  display: inline-block;
  padding: var(--space-3) var(--space-8);
  background: white;
  color: var(--color-crimson);
  font-weight: 700;
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: transform 0.2s ease, background-color 0.2s ease;
}

.hero-continue-btn:hover {
  background-color: var(--color-ivory);
  transform: translateY(-2px);
  color: var(--color-crimson);
}

.newsletter-button {
  padding: var(--space-3) var(--space-6);
  background-color: white;
  color: var(--color-crimson);
  font-weight: 700;
  border-radius: var(--radius-md);
  white-space: nowrap;
}

.newsletter-button:hover {
  background-color: var(--color-ivory);
  transform: translateY(-2px);
}

.form-privacy {
  font-size: var(--text-sm);
  color: rgba(255, 255, 255, 0.8);
  margin: 0;
}

.latest-posts-section,
.demographics-section,
.lead-magnets-section {
  padding: var(--space-16) 0;
}

.section-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-8);
}

.section-title {
  font-size: var(--text-4xl);
  margin: 0;
}

.section-title.centered {
  text-align: center;
  margin-bottom: var(--space-4);
}

.section-subtitle.centered {
  text-align: center;
  color: var(--color-slate);
  font-size: var(--text-lg);
  margin-bottom: var(--space-12);
}

.posts-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: var(--space-8);
}

.post-card {
  background: var(--color-ivory);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-md);
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}

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

.post-card-image {
  position: relative;
  aspect-ratio: 16/9;
  overflow: hidden;
}

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

.post-card:hover .post-card-image img {
  transform: scale(1.05);
}

.content-type-badge {
  position: absolute;
  top: var(--space-3);
  right: var(--space-3);
  padding: var(--space-1) var(--space-3);
  background: var(--color-ivory);
  color: var(--color-graphite);
  font-family: var(--font-ui);
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  border-radius: var(--radius-sm);
}

.content-type-badge.teaching {
  background: var(--color-gold);
  color: var(--color-graphite);
}

.content-type-badge.current_events {
  background: var(--color-crimson);
  color: white;
}

.content-type-badge.bible_deep_dive {
  background: var(--color-sky);
  color: white;
}

/* Legacy badge classes */
.content-type-badge.news {
  background: var(--color-crimson);
  color: white;
}

.content-type-badge.premium {
  background: var(--color-sky);
  color: white;
}

.post-card-content {
  padding: var(--space-6);
}

.post-meta {
  font-family: var(--font-ui);
  font-size: var(--text-sm);
  color: var(--color-slate);
  margin-bottom: var(--space-3);
}

.meta-separator {
  margin: 0 var(--space-2);
}

.post-card-title {
  font-size: var(--text-xl);
  margin: 0 0 var(--space-3) 0;
  line-height: 1.3;
}

.post-card-title a {
  color: var(--color-graphite);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.post-card-title a:hover {
  color: var(--color-crimson);
}

.post-card-excerpt {
  color: var(--color-slate);
  font-size: var(--text-base);
  margin-bottom: var(--space-4);
  line-height: 1.6;
}

.read-more-link {
  font-family: var(--font-ui);
  font-weight: 600;
  font-size: var(--text-sm);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.demographics-grid,
.lead-magnets-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--space-6);
}

.demographic-card,
.lead-magnet-card {
  background: var(--color-ivory);
  padding: var(--space-6);
  border-radius: var(--radius-lg);
  text-align: center;
  box-shadow: var(--shadow-md);
  transition: all var(--transition-base);
}

.demographic-card:hover,
.lead-magnet-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-xl);
}

.demo-icon {
  font-size: var(--text-5xl);
  margin-bottom: var(--space-4);
}

.demo-title {
  font-size: var(--text-xl);
  margin: 0 0 var(--space-3) 0;
}

.demo-description {
  color: var(--color-slate);
  margin-bottom: var(--space-4);
}

.final-cta-section {
  background: var(--color-graphite);
  color: white;
  padding: var(--space-16) 0;
  text-align: center;
}

.final-cta-content h2 {
  color: white;
  margin-bottom: var(--space-4);
}

.final-cta-content p {
  color: rgba(255, 255, 255, 0.9);
  margin-bottom: var(--space-8);
}

/**
 * Single Post
 */

.post-header {
  padding: var(--space-12) 0;
}

.post-meta-top {
  font-family: var(--font-ui);
  font-size: var(--text-sm);
  color: var(--color-slate);
  margin-bottom: var(--space-6);
}

.post-title {
  font-size: var(--text-5xl);
  margin-bottom: var(--space-4);
}

.post-subtitle {
  font-size: var(--text-xl);
  color: var(--color-slate);
  font-family: var(--font-body);
  font-style: italic;
}

.post-featured-image {
  margin-top: var(--space-8);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.post-layout {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: var(--space-12);
  padding: var(--space-12) 0;
}

@media (max-width: 968px) {
  .post-layout {
    grid-template-columns: 1fr;
  }

  .post-sidebar {
    order: 1;
  }
}

.post-content {
  font-size: var(--text-lg);
  line-height: 1.8;
}

.post-sidebar {
  position: sticky;
  top: 100px;
  height: fit-content;
}

.sidebar-widget {
  background: var(--color-ivory);
  padding: var(--space-6);
  border-radius: var(--radius-lg);
  margin-bottom: var(--space-6);
  box-shadow: var(--shadow-sm);
}

.widget-title {
  font-size: var(--text-xl);
  margin: 0 0 var(--space-4) 0;
}

.scripture-primary,
.scripture-secondary {
  margin-bottom: var(--space-4);
}

.scripture-secondary ul {
  margin: 0;
  padding-left: var(--space-6);
}

.share-button {
  display: block;
  width: 100%;
  margin-bottom: var(--space-2);
  padding: var(--space-2) var(--space-4);
  text-align: center;
  background: var(--color-ivory);
  color: var(--color-graphite);
  border-radius: var(--radius-md);
  font-family: var(--font-ui);
  font-size: var(--text-sm);
  transition: all var(--transition-fast);
}

.share-button:hover {
  background: var(--color-crimson);
  color: white;
  transform: none;
}

/**
 * Site Footer
 */

.site-footer {
  background: var(--color-graphite);
  color: white;
  margin-top: var(--space-16);
}

.footer-newsletter {
  background: var(--color-crimson);
  padding: var(--space-12) 0;
  text-align: center;
}

.footer-newsletter h3 {
  color: white;
  margin-bottom: var(--space-4);
}

.footer-newsletter p {
  color: rgba(255, 255, 255, 0.9);
}

.footer-widgets {
  padding: var(--space-12) 0;
  background: transparent !important; /* Override GeneratePress inline var(--base-3) */
}

.footer-widget p {
  color: rgba(255, 255, 255, 0.8);
}

.footer-widgets-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: var(--space-8);
}

.footer-widget h4 {
  color: white;
  margin-bottom: var(--space-4);
}

.footer-widget ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.footer-widget li {
  margin-bottom: var(--space-2);
}

.footer-widget a {
  color: rgba(255, 255, 255, 0.8);
  text-decoration: none;
}

.footer-widget a:hover {
  color: white;
}

/* Support/Donate CTA (footer & post footer) */
.support-cta {
  text-align: center;
  padding: var(--space-8) var(--space-4);
  margin-top: var(--space-8);
  border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.support-cta p {
  color: rgba(255, 255, 255, 0.8);
  margin-bottom: var(--space-4);
  font-size: var(--text-base);
}

.support-cta .donate-button {
  display: inline-block;
  padding: 0.75rem 2rem;
  background: var(--color-burgundy);
  color: white;
  border-radius: 6px;
  font-weight: 600;
  text-decoration: none;
  transition: background 0.2s ease, transform 0.2s ease;
}

.support-cta .donate-button:hover {
  background: #7A1F2E;
  transform: translateY(-1px);
}

/* Post footer support CTA (light background context) */
.post-support-cta {
  text-align: center;
  padding: var(--space-8) var(--space-4);
  margin-top: var(--space-8);
  border-top: 1px solid var(--color-border);
}

.post-support-cta p {
  color: var(--color-text-light);
  margin-bottom: var(--space-4);
  font-size: var(--text-base);
}

.post-support-cta .donate-button {
  display: inline-block;
  padding: 0.75rem 2rem;
  background: var(--color-burgundy);
  color: white;
  border-radius: 6px;
  font-weight: 600;
  text-decoration: none;
  transition: background 0.2s ease, transform 0.2s ease;
}

.post-support-cta .donate-button:hover {
  background: #7A1F2E;
  transform: translateY(-1px);
}

/* Support Modal — Buy Me a Coffee inspired */
.support-modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 10000;
  background: rgba(0, 0, 0, 0.55);
  backdrop-filter: blur(6px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  opacity: 1;
  transition: opacity 0.25s ease;
}

.support-modal-overlay[aria-hidden="true"] {
  opacity: 0;
  pointer-events: none;
}

.support-modal {
  background: #FFFFFF;
  border-radius: 20px;
  max-width: 440px;
  width: 100%;
  position: relative;
  box-shadow: 0 25px 60px rgba(0, 0, 0, 0.25);
  transform: scale(1);
  transition: transform 0.25s ease;
  overflow: hidden;
}

.support-modal-overlay[aria-hidden="true"] .support-modal {
  transform: scale(0.95);
}

.support-modal-close {
  position: absolute;
  top: 0.75rem;
  right: 0.75rem;
  background: rgba(255, 255, 255, 0.85);
  border: none;
  font-size: 1.5rem;
  color: #6B7280;
  cursor: pointer;
  line-height: 1;
  width: 2rem;
  height: 2rem;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.15s;
  z-index: 2;
}

.support-modal-close:hover {
  background: white;
  color: #1F2937;
}

/* Illustration banner */
.support-modal-banner {
  background: linear-gradient(135deg, #FBBF24 0%, #F59E0B 50%, #D97706 100%);
  padding: 1rem 2rem;
  text-align: center;
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}

.banner-illustration {
  height: 140px;
  width: auto;
  object-fit: contain;
  filter: drop-shadow(0 4px 12px rgba(0, 0, 0, 0.15));
}

/* Body content */
.support-modal-body {
  padding: 1.5rem 2rem 1.75rem;
}

.support-modal-body h3 {
  font-size: 1.6rem;
  font-weight: 800;
  color: var(--color-graphite);
  margin: 0 0 0.6rem;
  text-align: center;
}

.support-modal-body > p:first-of-type {
  font-size: 0.92rem;
  color: #4B5563;
  margin: 0 0 1.25rem;
  line-height: 1.6;
  text-align: center;
}

/* Amount cards — 3 columns */
.support-modal-amounts {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.65rem;
  margin-bottom: 1rem;
}

.amount-pill {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.2rem;
  padding: 1rem 0.5rem;
  border: 2px solid #E5E7EB;
  border-radius: 14px;
  background: #F9FAFB;
  cursor: pointer;
  transition: all 0.15s ease;
}

.amount-pill:hover {
  border-color: #FBBF24;
  background: #FFFBEB;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(251, 191, 36, 0.2);
}

.amount-pill.active {
  border-color: #F59E0B;
  background: #FFFBEB;
  box-shadow: 0 4px 16px rgba(245, 158, 11, 0.25);
  transform: translateY(-2px);
}

.pill-icon {
  width: 48px;
  height: 48px;
  object-fit: contain;
}

.pill-label {
  font-size: 1.25rem;
  font-weight: 800;
  color: var(--color-graphite);
}

.pill-desc {
  font-size: 0.72rem;
  color: #6B7280;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-weight: 600;
}

/* Custom amount — always visible inline row */
.support-modal-custom-row {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 1.25rem;
}

.custom-label {
  font-size: 0.85rem;
  color: #6B7280;
  white-space: nowrap;
  font-weight: 500;
}

.custom-input-wrap {
  display: flex;
  align-items: center;
  border: 2px solid #E5E7EB;
  border-radius: 10px;
  background: #F9FAFB;
  padding: 0 0.75rem;
  flex: 1;
  transition: border-color 0.15s;
}

.custom-input-wrap:focus-within {
  border-color: #F59E0B;
}

.custom-dollar {
  color: #9CA3AF;
  font-weight: 700;
  font-size: 1rem;
}

.custom-input-wrap input {
  border: none;
  background: transparent;
  padding: 0.6rem 0.4rem;
  font-size: 1rem;
  font-weight: 600;
  color: var(--color-graphite);
  width: 100%;
  outline: none;
  -moz-appearance: textfield;
}

.custom-input-wrap input::-webkit-inner-spin-button,
.custom-input-wrap input::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

/* Pay button */
.support-modal-pay {
  display: block;
  width: 100%;
  padding: 1rem;
  background: var(--color-burgundy);
  color: white;
  border: none;
  border-radius: 12px;
  font-size: 1.05rem;
  font-weight: 700;
  cursor: pointer;
  transition: background 0.2s ease, transform 0.15s ease, box-shadow 0.15s ease;
  margin-bottom: 0.75rem;
}

.support-modal-pay:hover {
  background: #7A1F2E;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(139, 21, 56, 0.3);
}

/* Thank you note */
.support-modal-note {
  text-align: center;
  font-size: 0.82rem;
  color: #6B7280;
  margin: 0 0 0.5rem;
  font-style: italic;
}

.support-modal-disclaimer {
  text-align: center;
  font-size: 0.7rem;
  color: #9CA3AF;
  margin: 0;
  line-height: 1.4;
}

@media (max-width: 480px) {
  .support-modal-body {
    padding: 1.25rem 1.25rem 1.5rem;
  }

  .banner-illustration {
    height: 110px;
  }

  .pill-icon {
    width: 40px;
    height: 40px;
  }

  .support-modal-body h3 {
    font-size: 1.35rem;
  }

  .support-modal-custom-row {
    flex-direction: column;
    align-items: stretch;
    gap: 0.35rem;
  }
}

.footer-bottom {
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  padding: var(--space-6) 0;
}

.footer-bottom-content {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: var(--text-sm);
  color: rgba(255, 255, 255, 0.7);
}

@media (max-width: 768px) {
  .footer-bottom-content {
    flex-direction: column;
    gap: var(--space-4);
    text-align: center;
  }
}

/* =================================================================
   PRIORITY 1 DESIGN IMPROVEMENTS (2026-01-31)
   Inspired by: Steven Bartlett, Alex Clark, MilkRoad
   ================================================================= */

/* 1. MASSIVE HERO TYPOGRAPHY (Steven Bartlett-inspired) */
.hero-title {
  font-size: clamp(3.75rem, 10vw, 7.5rem) !important; /* 60px - 120px */
  font-weight: 900 !important;
  line-height: 0.95 !important;
  letter-spacing: -0.03em !important;
  text-shadow: 3px 3px 0 rgba(30, 30, 30, 0.1);
}

.hero-subtitle {
  font-size: clamp(1.25rem, 3vw, 1.875rem); /* 20px - 30px */
  font-weight: 400;
  line-height: 1.4;
  opacity: 0.92;
}

/* 2. SCROLL INDICATOR (Steven Bartlett-inspired) */
.scroll-indicator {
  position: absolute;
  bottom: 40px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
  color: rgba(255, 255, 255, 0.9);
  font-family: var(--font-ui);
  font-size: 0.875rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor: pointer;
  z-index: 10;
  animation: bounce 2s infinite;
}

.scroll-arrow {
  width: 24px;
  height: 24px;
  fill: rgba(255, 255, 255, 0.8);
}

@keyframes bounce {
  0%, 100% {
    transform: translateX(-50%) translateY(0);
  }
  50% {
    transform: translateX(-50%) translateY(10px);
  }
}

/* 3. TICKER ANNOUNCEMENT BAR (MilkRoad-inspired) */
.announcement-bar {
  background: linear-gradient(135deg, var(--color-graphite) 0%, #2a2a2a 100%);
  color: white;
  padding: 0.75rem 1rem;
  text-align: center;
  font-family: var(--font-ui);
  font-size: 0.875rem;
  font-weight: 500;
  position: relative;
  z-index: 100;
  border-bottom: 2px solid var(--color-gold);
}

.announcement-bar-content {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.5rem;
  flex-wrap: wrap;
}

.announcement-bar .ann-icon {
  font-size: 1.125rem;
}

.announcement-bar .cta-link {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background-color: var(--color-crimson);
  color: white;
  padding: 0.5rem 1rem;
  border-radius: 0.5rem;
  font-weight: 600;
  transition: all 0.25s ease-in-out;
  text-decoration: none;
}

.announcement-bar .cta-link:hover {
  background-color: #A00F1A;
  transform: translateX(3px);
  text-decoration: none;
}

.announcement-bar .cta-link::after {
  content: '→';
  transition: transform 0.25s ease-in-out;
}

.announcement-bar .cta-link:hover::after {
  transform: translateX(3px);
}

/* 4. ENHANCED CARD HOVER EFFECTS (All sites) */
.post-card {
  transition: transform 0.25s ease-in-out, box-shadow 0.25s ease-in-out;
}

.post-card:hover {
  transform: translateY(-8px) !important;
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.15) !important;
}

.demographic-card,
.lead-magnet-card {
  transition: transform 0.25s ease-in-out, box-shadow 0.25s ease-in-out;
}

.demographic-card:hover,
.lead-magnet-card:hover {
  transform: translateY(-6px) scale(1.02);
  box-shadow: 0 15px 30px rgba(0, 0, 0, 0.12);
}

/* 5. TESTIMONIALS SECTION (MilkRoad-inspired) */
.testimonials-section {
  background: linear-gradient(135deg, #2a2a2a 0%, var(--color-graphite) 100%);
  color: white;
  padding: 4rem 0;
  position: relative;
  overflow: hidden;
}

.testimonials-section .section-label {
  color: var(--color-gold);
  font-family: var(--font-ui);
  font-size: 0.875rem;
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  text-align: center;
  margin-bottom: 1rem;
}

.testimonials-section .section-title {
  color: white;
  text-align: center;
  margin-bottom: 3rem;
}

.testimonials-carousel {
  display: flex;
  gap: 2rem;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding: 2rem 0;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scrollbar-color: var(--color-gold) rgba(255,255,255,0.1);
}

.testimonial-card {
  flex: 0 0 auto;
  width: clamp(280px, 90vw, 400px);
  background: rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 1rem;
  padding: 2rem;
  scroll-snap-align: center;
  transition: all 0.25s ease-in-out;
}

.testimonial-card:hover {
  background: rgba(255, 255, 255, 0.12);
  border-color: var(--color-gold);
  transform: translateY(-4px);
}

.testimonial-quote {
  font-family: var(--font-body);
  font-size: 1.125rem;
  line-height: 1.6;
  margin-bottom: 1.5rem;
  font-style: italic;
  color: rgba(255, 255, 255, 0.95);
}

.testimonial-quote::before {
  content: '"';
  font-size: 3rem;
  line-height: 0;
  color: var(--color-gold);
  opacity: 0.4;
}

.testimonial-author {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.testimonial-author-name {
  font-family: var(--font-ui);
  font-weight: 600;
  font-size: 1rem;
  color: white;
}

.testimonial-author-role {
  font-size: 0.875rem;
  color: rgba(255, 255, 255, 0.6);
}

/* 6. SOCIAL ICONS (Alex Clark-inspired) */
.social-icons {
  display: flex;
  gap: 1rem;
  align-items: center;
}

.social-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: rgba(77, 163, 255, 0.1);
  color: var(--color-sky);
  transition: all 0.25s ease-in-out;
  text-decoration: none;
}

.social-icon:hover {
  background: var(--color-sky);
  color: white;
  transform: translateY(-3px);
  text-decoration: none;
}

.social-icon svg {
  width: 18px;
  height: 18px;
  fill: currentColor;
}

/* 7. INCREASED SPACING (MilkRoad-inspired) */
.hero-section {
  position: relative;
  padding: 120px 0 140px 0 !important;
  min-height: 80vh;
  display: flex;
  align-items: center;
}

.latest-posts-section,
.demographic-cards-section,
.lead-magnets-section {
  padding: 80px 0 !important;
}

/* 8. WAVE DIVIDERS (Alex Clark-inspired) */
.wave-divider {
  width: 100%;
  height: 60px;
  overflow: hidden;
  line-height: 0;
}

.wave-divider svg {
  width: 100%;
  height: 100%;
  display: block;
}

/* 9. CTA BUTTON RIPPLE EFFECT */
.btn-primary,
.newsletter-button,
.cta-button {
  position: relative;
  overflow: hidden;
}

.btn-primary::before,
.newsletter-button::before,
.cta-button::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.2);
  transform: translate(-50%, -50%);
  transition: width 0.6s, height 0.6s;
}

.btn-primary:hover::before,
.newsletter-button:hover::before,
.cta-button:hover::before {
  width: 300px;
  height: 300px;
}

/* Mobile Responsive Overrides */
@media (max-width: 768px) {
  .hero-title {
    font-size: clamp(2.5rem, 8vw, 4rem) !important; /* 40px - 64px mobile */
    text-shadow: 2px 2px 0 rgba(30, 30, 30, 0.1);
  }

  .hero-subtitle {
    font-size: clamp(1.125rem, 2.5vw, 1.5rem);
  }

  .hero-section {
    padding: 80px 0 100px 0 !important;
    min-height: 60vh;
  }

  .announcement-bar-content {
    flex-direction: column;
    gap: 0.5rem;
  }

  .scroll-indicator {
    bottom: 20px;
  }

  .wave-divider {
    height: 40px;
  }

  .testimonial-card {
    width: clamp(260px, 85vw, 340px);
  }

  .latest-posts-section,
  .demographic-cards-section,
  .lead-magnets-section {
    padding: 48px 0 !important;
  }

  .testimonials-section {
    padding: 3rem 0;
  }

  .testimonials-carousel {
    padding-left: 1rem;
    padding-right: 1rem;
  }
}

/* ================================
   PERSONALIZATION FEATURES
   ================================ */

/* Hero Personalization Label */
.hero-personalization {
    display: inline-block;
    margin-top: 0.5rem;
    padding: 0.5rem 1rem;
    background: rgba(215, 178, 90, 0.15);
    border: 1px solid var(--color-gold);
    border-radius: 4px;
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--color-gold);
    font-style: normal;
    letter-spacing: 0.5px;
    text-transform: uppercase;
}

/* Recommended Section */
.recommended-section {
    margin-bottom: 4rem;
    padding: 3rem 0;
    background: linear-gradient(135deg, rgba(248, 245, 240, 0.5) 0%, rgba(255, 255, 255, 0.3) 100%);
    border-radius: 8px;
}

.recommended-section .section-label {
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--color-gold);
    margin-bottom: 0.5rem;
    text-align: center;
}

.recommended-section .recommended-title {
    font-size: 2rem;
    font-weight: 700;
    color: var(--color-graphite);
    margin-bottom: 2rem;
    text-align: center;
}

.recommended-posts-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 2rem;
    margin-top: 2rem;
}

.recommended-post-card {
    background: var(--color-ivory);
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
    transition: all 0.25s ease;
    border: 2px solid transparent;
}

.recommended-post-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.15);
    border-color: var(--color-gold);
}

.rec-post-image {
    position: relative;
    overflow: hidden;
}

.rec-post-image img {
    width: 100%;
    height: 200px;
    object-fit: cover;
    transition: transform 0.3s ease;
}

.recommended-post-card:hover .rec-post-image img {
    transform: scale(1.05);
}

.rec-post-image .content-type-badge {
    position: absolute;
    top: 1rem;
    right: 1rem;
    padding: 0.35rem 0.75rem;
    font-size: 0.75rem;
    font-weight: 600;
    border-radius: 4px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.rec-post-content {
    padding: 1.5rem;
}

.rec-post-content h4 {
    font-size: 1.25rem;
    font-weight: 700;
    margin-bottom: 0.75rem;
    line-height: 1.4;
}

.rec-post-content h4 a {
    color: var(--color-graphite);
    text-decoration: none;
    transition: color 0.2s ease;
}

.rec-post-content h4 a:hover {
    color: var(--color-crimson);
}

.rec-post-excerpt {
    color: var(--color-stone);
    font-size: 0.9375rem;
    line-height: 1.6;
    margin-bottom: 1rem;
}

.rec-post-content .read-more-link {
    display: inline-block;
    font-weight: 600;
    color: var(--color-crimson);
    text-decoration: none;
    font-size: 0.875rem;
    transition: all 0.2s ease;
}

.rec-post-content .read-more-link:hover {
    color: var(--color-gold);
    transform: translateX(4px);
}

/* Section Divider */
.section-divider {
    width: 100%;
    height: 1px;
    background: linear-gradient(90deg, transparent 0%, var(--color-gold) 50%, transparent 100%);
    margin: 3rem 0;
    opacity: 0.3;
}

/* Related Posts Section */
.related-title {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--color-graphite);
    margin-bottom: 2rem;
}

.related-posts-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 2rem;
    margin-bottom: 3rem;
}

.related-post-card {
    background: var(--color-ivory);
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
    transition: all 0.25s ease;
}

.related-post-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.12);
}

.related-post-image {
    position: relative;
    overflow: hidden;
}

.related-post-image img {
    width: 100%;
    height: 200px;
    object-fit: cover;
    transition: transform 0.3s ease;
}

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

.related-post-image .content-type-badge {
    position: absolute;
    top: 1rem;
    right: 1rem;
    padding: 0.35rem 0.75rem;
    font-size: 0.75rem;
    font-weight: 600;
    border-radius: 4px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.related-post-content {
    padding: 1.5rem;
}

.related-post-content h4 {
    font-size: 1.125rem;
    font-weight: 700;
    margin-bottom: 0.75rem;
    line-height: 1.4;
}

.related-post-content h4 a {
    color: var(--color-graphite);
    text-decoration: none;
    transition: color 0.2s ease;
}

.related-post-content h4 a:hover {
    color: var(--color-crimson);
}

.related-post-excerpt {
    color: var(--color-stone);
    font-size: 0.9375rem;
    line-height: 1.6;
    margin-bottom: 1rem;
}

.related-post-content .read-more-link {
    display: inline-block;
    font-weight: 600;
    color: var(--color-crimson);
    text-decoration: none;
    font-size: 0.875rem;
    transition: all 0.2s ease;
}

.related-post-content .read-more-link:hover {
    color: var(--color-gold);
    transform: translateX(4px);
}

/* Personalized CTA Styling */
.personalized-cta {
    background: linear-gradient(135deg, var(--color-graphite) 0%, #2a2a2a 100%);
    color: white;
    padding: 2rem;
    border-radius: 8px;
    border: 2px solid var(--color-gold);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
}

.personalized-cta .cta-label {
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--color-gold);
    margin-bottom: 0.5rem;
    display: block;
}

.personalized-cta h3 {
    font-size: 1.5rem;
    font-weight: 700;
    margin-bottom: 0.75rem;
    color: white;
}

.personalized-cta p {
    font-size: 0.9375rem;
    line-height: 1.6;
    color: rgba(255, 255, 255, 0.85);
    margin-bottom: 1.5rem;
}

.personalized-cta .button {
    background: var(--color-crimson);
    color: white;
    padding: 0.75rem 1.5rem;
    border-radius: 4px;
    font-weight: 600;
    text-decoration: none;
    display: inline-block;
    transition: all 0.25s ease;
}

.personalized-cta .button:hover {
    background: var(--color-gold);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(215, 178, 90, 0.3);
}

/* Mobile Responsive: Personalization */
@media (max-width: 768px) {
    .hero-personalization {
        font-size: 0.75rem;
        padding: 0.4rem 0.8rem;
    }

    .recommended-section .recommended-title {
        font-size: 1.5rem;
    }

    .recommended-posts-grid {
        grid-template-columns: 1fr;
        gap: 1.5rem;
    }

    .personalized-cta {
        padding: 1.5rem;
    }

    .personalized-cta h3 {
        font-size: 1.25rem;
    }
}

/* ========================================================================
   OPUS 4.5 TYPOGRAPHY SYSTEM - Enhanced Reading Experience
   ======================================================================== */

/* ========================================================================
   1. FONT LOADING - Loaded via Google Fonts API in functions.php
   Fonts: Playfair Display, Source Serif 4, Space Grotesk
   ======================================================================== */

/* ========================================================================
   2. BASE TYPOGRAPHY - Reading Experience Foundation
   ======================================================================== */

/* Update CSS Variables for Typography */
:root {
  /* Font Families */
  --font-display: 'Playfair Display', Georgia, serif;
  --font-body: 'Source Serif 4', Georgia, serif;
  --font-ui: 'Space Grotesk', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

  /* Font Sizes - Fluid Typography */
  --text-xs: clamp(0.75rem, 0.7rem + 0.25vw, 0.875rem);     /* 12-14px */
  --text-sm: clamp(0.875rem, 0.8rem + 0.35vw, 1rem);        /* 14-16px */
  --text-base: clamp(1rem, 0.95rem + 0.25vw, 1.125rem);     /* 16-18px */
  --text-lg: clamp(1.125rem, 1.05rem + 0.35vw, 1.25rem);    /* 18-20px */
  --text-xl: clamp(1.25rem, 1.15rem + 0.5vw, 1.5rem);       /* 20-24px */
  --text-2xl: clamp(1.5rem, 1.35rem + 0.75vw, 2rem);        /* 24-32px */
  --text-3xl: clamp(2rem, 1.75rem + 1.25vw, 2.5rem);        /* 32-40px */
  --text-4xl: clamp(2.5rem, 2rem + 2.5vw, 3.5rem);          /* 40-56px */
  --text-5xl: clamp(3rem, 2.25rem + 3.75vw, 4.5rem);        /* 48-72px */

  /* Line Heights */
  --leading-tight: 1.2;
  --leading-snug: 1.375;
  --leading-normal: 1.5;
  --leading-relaxed: 1.625;
  --leading-loose: 1.75;

  /* Letter Spacing */
  --tracking-tight: -0.02em;
  --tracking-normal: 0;
  --tracking-wide: 0.025em;
  --tracking-wider: 0.05em;

  /* Reading Width (optimal for readability) */
  --prose-width: 70ch;      /* ~70 characters per line */
  --prose-width-narrow: 60ch;
  --prose-width-wide: 80ch;
}

/* ========================================================================
   3. POST CONTENT TYPOGRAPHY - Beautiful Reading Experience
   ======================================================================== */

/* Main Post Content Area */
.post-content,
.entry-content {
  font-family: var(--font-body);
  font-size: var(--text-lg);
  line-height: var(--leading-relaxed);
  color: var(--color-text-primary);
  max-width: var(--prose-width);
}

/* Paragraphs - Optimal Reading */
.post-content p,
.entry-content p {
  margin-bottom: 1.5em;
  line-height: var(--leading-relaxed);
  font-size: var(--text-lg);
  color: var(--color-text-primary);
  max-width: var(--prose-width);
  hyphens: auto;
  -webkit-hyphens: auto;
  -moz-hyphens: auto;
}

/* First Paragraph - Slightly Larger */
.post-content > p:first-of-type,
.entry-content > p:first-of-type {
  font-size: var(--text-xl);
  line-height: var(--leading-relaxed);
  color: var(--color-text-secondary);
}

/* Drop Cap for First Letter (Optional - Maximalist Touch) */
.post-content > p:first-of-type::first-letter {
  font-family: var(--font-display);
  font-size: 3.5em;
  line-height: 0.9;
  float: left;
  margin: 0.1em 0.1em 0 0;
  color: var(--color-burgundy);
  font-weight: 700;
}

/* ========================================================================
   4. HEADING HIERARCHY - Theological Gravitas
   ======================================================================== */

/* All Headings - Base Styles */
.post-content h1,
.post-content h2,
.post-content h3,
.post-content h4,
.post-content h5,
.post-content h6,
.entry-content h1,
.entry-content h2,
.entry-content h3,
.entry-content h4,
.entry-content h5,
.entry-content h6 {
  font-family: var(--font-display);
  font-weight: 700;
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  color: var(--color-text-primary);
  margin-top: 2em;
  margin-bottom: 0.75em;
  clear: both;
}

/* Post Title (h1 in header) */
.post-title {
  font-family: var(--font-display);
  font-size: var(--text-5xl);
  font-weight: 900;
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  color: var(--color-text-primary);
  margin-bottom: 0.5em;
  max-width: 20ch;
}

/* Content Headings */
.post-content h2,
.entry-content h2 {
  font-size: var(--text-3xl);
  font-weight: 700;
  line-height: var(--leading-snug);
  margin-top: 2.5em;
  margin-bottom: 1em;
  padding-bottom: 0.25em;
  border-bottom: 2px solid var(--color-burgundy-light);
}

.post-content h3,
.entry-content h3 {
  font-size: var(--text-2xl);
  font-weight: 700;
  line-height: var(--leading-snug);
  margin-top: 2em;
  margin-bottom: 0.75em;
  color: var(--color-text-secondary);
}

.post-content h4,
.entry-content h4 {
  font-size: var(--text-xl);
  font-weight: 600;
  line-height: var(--leading-normal);
  margin-top: 1.75em;
  margin-bottom: 0.5em;
  color: var(--color-text-secondary);
}

.post-content h5,
.entry-content h5 {
  font-size: var(--text-lg);
  font-weight: 600;
  line-height: var(--leading-normal);
  margin-top: 1.5em;
  margin-bottom: 0.5em;
  font-family: var(--font-ui);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
}

.post-content h6,
.entry-content h6 {
  font-size: var(--text-base);
  font-weight: 600;
  line-height: var(--leading-normal);
  margin-top: 1.5em;
  margin-bottom: 0.5em;
  font-family: var(--font-ui);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--color-text-tertiary);
}

/* ========================================================================
   5. TEXT FORMATTING - Emphasis & Meaning
   ======================================================================== */

/* Emphasis */
.post-content em,
.post-content i,
.entry-content em,
.entry-content i {
  font-style: italic;
  color: var(--color-text-secondary);
}

/* Strong Emphasis */
.post-content strong,
.post-content b,
.entry-content strong,
.entry-content b {
  font-weight: 700;
  color: var(--color-text-primary);
}

/* Blockquotes - Scripture & Quotes */
.post-content blockquote,
.entry-content blockquote {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  line-height: var(--leading-relaxed);
  font-style: italic;
  margin: 2.5em 0;
  padding: 1.5em 2em;
  border-left: 4px solid var(--color-burgundy);
  background: var(--color-cream-light);
  color: var(--color-text-secondary);
  position: relative;
}

.post-content blockquote::before {
  content: '"';
  font-family: var(--font-display);
  font-size: 4em;
  color: var(--color-burgundy-light);
  position: absolute;
  top: -0.2em;
  left: 0.1em;
  opacity: 0.3;
  line-height: 1;
}

.post-content blockquote p {
  margin-bottom: 0.75em;
}

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

/* Code & Pre */
.post-content code,
.entry-content code {
  font-family: 'Monaco', 'Courier New', monospace;
  font-size: 0.9em;
  background: var(--color-cream);
  padding: 0.2em 0.4em;
  border-radius: 4px;
  color: var(--color-burgundy);
}

.post-content pre,
.entry-content pre {
  font-family: 'Monaco', 'Courier New', monospace;
  font-size: var(--text-sm);
  line-height: var(--leading-normal);
  background: var(--color-charcoal);
  color: var(--color-cream);
  padding: 1.5em;
  border-radius: 8px;
  overflow-x: auto;
  margin: 2em 0;
}

.post-content pre code {
  background: transparent;
  padding: 0;
  color: inherit;
}

/* ========================================================================
   6. LISTS - Structured Content
   ======================================================================== */

.post-content ul,
.post-content ol,
.entry-content ul,
.entry-content ol {
  margin: 1.5em 0;
  padding-left: 2em;
  line-height: var(--leading-relaxed);
}

.post-content ul {
  list-style-type: disc;
}

.post-content ol {
  list-style-type: decimal;
}

.post-content li,
.entry-content li {
  margin-bottom: 0.75em;
  font-size: var(--text-lg);
  line-height: var(--leading-relaxed);
  padding-left: 0.5em;
}

.post-content li:last-child {
  margin-bottom: 0;
}

/* Nested Lists */
.post-content ul ul,
.post-content ol ol,
.post-content ul ol,
.post-content ol ul {
  margin-top: 0.75em;
  margin-bottom: 0.75em;
}

/* ========================================================================
   7. LINKS - Clear & Accessible
   ======================================================================== */

.post-content a,
.entry-content a {
  color: var(--color-burgundy);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 2px;
  transition: all 0.2s ease;
}

.post-content a:hover,
.entry-content a:hover {
  color: var(--color-burgundy-dark);
  text-decoration-thickness: 2px;
}

/* ========================================================================
   8. METADATA & UI TEXT - Clean & Unobtrusive
   ======================================================================== */

.post-meta-top,
.post-meta,
.entry-meta {
  font-family: var(--font-ui);
  font-size: var(--text-sm);
  font-weight: 500;
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--color-text-tertiary);
  margin-bottom: 1em;
}

.post-subtitle {
  font-family: var(--font-body);
  font-size: var(--text-xl);
  line-height: var(--leading-relaxed);
  color: var(--color-text-secondary);
  margin-top: 1em;
  margin-bottom: 2em;
  font-style: italic;
  max-width: 50ch;
}

/* ========================================================================
   9. RESPONSIVE TYPOGRAPHY - Mobile Optimization
   ======================================================================== */

@media (max-width: 768px) {
  :root {
    /* Slightly smaller sizes on mobile for better fit */
    --prose-width: 100%;
  }

  .post-content,
  .entry-content {
    font-size: var(--text-base);
  }

  .post-content p,
  .entry-content p {
    font-size: var(--text-base);
    margin-bottom: 1.25em;
  }

  .post-content > p:first-of-type,
  .entry-content > p:first-of-type {
    font-size: var(--text-lg);
  }

  /* Remove drop cap on mobile */
  .post-content > p:first-of-type::first-letter {
    font-size: inherit;
    float: none;
    margin: 0;
    color: inherit;
    font-weight: inherit;
  }

  .post-title {
    font-size: var(--text-4xl);
    max-width: 100%;
  }

  .post-content h2,
  .entry-content h2 {
    font-size: var(--text-2xl);
    margin-top: 2em;
  }

  .post-content h3,
  .entry-content h3 {
    font-size: var(--text-xl);
    margin-top: 1.75em;
  }

  .post-content blockquote,
  .entry-content blockquote {
    font-size: var(--text-lg);
    padding: 1em 1.5em;
    margin: 2em 0;
  }

  .post-content ul,
  .post-content ol {
    padding-left: 1.5em;
  }

  .post-content li {
    font-size: var(--text-base);
  }
}

/* ========================================================================
   10. PRINT STYLES - Beautiful Printed Articles
   ======================================================================== */

@media print {
  .post-content,
  .entry-content {
    font-size: 11pt;
    line-height: 1.6;
    color: #000;
  }

  .post-content h1 { font-size: 24pt; }
  .post-content h2 { font-size: 18pt; page-break-after: avoid; }
  .post-content h3 { font-size: 14pt; page-break-after: avoid; }
  .post-content h4 { font-size: 12pt; page-break-after: avoid; }

  .post-content a {
    color: #000;
    text-decoration: underline;
  }

  .post-content blockquote {
    page-break-inside: avoid;
  }
}
/* ========================================================================
   EXTENDED COLOR SYSTEM - Light Mode Variables
   Dark mode overrides handled by dark-mode.css
   ======================================================================== */

:root {
  /* Base Colors - Light Mode */
  --color-bg-primary: #FFFFFF;
  --color-bg-secondary: #F9FAFB;
  --color-bg-tertiary: #F3F4F6;

  /* Text Colors - Light Mode */
  --color-text-primary: #111827;
  --color-text-secondary: #374151;
  --color-text-tertiary: #6B7280;

  /* Accent Colors - Burgundy */
  --color-burgundy: #8B1538;
  --color-burgundy-dark: #6B0F2B;
  --color-burgundy-light: #C41E3A;

  /* Cream/Beige */
  --color-cream: #F8F4EF;
  --color-cream-light: #FAF7F3;
  --color-cream-dark: #E8E4DF;

  /* Charcoal */
  --color-charcoal: #1F2937;
  --color-charcoal-light: #374151;

  /* Borders */
  --color-border: #E5E7EB;
  --color-border-light: #F3F4F6;
}

/* ========================================================================
   APPLY EXTENDED COLORS TO ELEMENTS
   ======================================================================== */

/* Cards & Widgets */
.sidebar-widget,
.recommended-post-card,
.related-post-card {
  background-color: var(--color-bg-tertiary);
  border: 1px solid var(--color-border);
}

/* Meta text */
.post-meta,
.entry-meta,
.post-meta-top {
  color: var(--color-text-tertiary);
}

/* Code Blocks */
.post-content pre {
  background-color: var(--color-bg-tertiary);
  color: var(--color-text-primary);
  border: 1px solid var(--color-border);
}

.post-content code {
  background-color: var(--color-cream);
  color: var(--color-burgundy);
}

/* Blockquotes */
.post-content blockquote {
  background-color: var(--color-cream-light);
  border-left-color: var(--color-burgundy);
  color: var(--color-text-secondary);
}

/* ========================================================================
   LOGO SWITCHER - Light Mode Defaults
   Dark mode switching handled by dark-mode.css
   ======================================================================== */

/* Hide dark logo by default (light mode) */
.custom-logo-dark {
  display: none;
}

/* Show light logo by default */
.custom-logo-light {
  display: block;
}

/* Ensure both logos have same dimensions */
.custom-logo-light,
.custom-logo-dark {
  height: auto;
  max-height: 60px;
  width: auto;
}

/* Logo size - see CRITICAL FIXES section for current 80px size */

/* Dark mode text visibility fixes - handled by dark-mode.css */

/* Homepage dark mode visibility fixes - handled by dark-mode.css */

/* ========================================================================
   CRITICAL FIXES - Footer, Navigation, Logo
   ======================================================================== */

/* Logo - Proportional Size */
.custom-logo-light,
.custom-logo-dark,
.site-header .header-image,
.site-branding img,
.custom-logo {
  max-height: 80px !important;
  height: auto !important;
  width: auto !important;
}

/* Navigation - Fix Z-Index to Appear Above Everything */
.site-header,
.main-navigation,
#site-navigation {
  z-index: 9999 !important;
  position: sticky !important;
}

.main-navigation ul {
  z-index: 9999 !important;
}

/* Ensure Subscribe Bar Doesn't Overlap Navigation */
.newsletter-widget,
.subscribe-bar,
.hero-cta,
.announcement-bar {
  z-index: 100 !important;
}

/* Footer dark mode complete fix - handled by dark-mode.css */

/* Force Footer Visibility (Both Modes) */
.site-footer {
  padding: 3rem 0 !important;
}

.footer-widgets .widget {
  margin-bottom: 2rem !important;
}

.footer-widgets .widget-title {
  margin-bottom: 1rem !important;
  font-size: 1.125rem !important;
  font-weight: 700 !important;
}

.footer-widgets ul li {
  margin-bottom: 0.5rem !important;
}

.footer-widgets a {
  transition: color 0.2s ease !important;
}

/* Footer dark mode ultra-specific overrides - handled by dark-mode.css */

/* ========================================================================
   NAVIGATION & SUBSCRIBE BAR - COMPLETE FIX
   ======================================================================== */

/* ========================================================================
   1. NAVIGATION MENU - FORCE VISIBILITY IN ALL MODES
   ======================================================================== */

/* Light Mode Navigation - Force Dark Text */
.main-navigation .main-nav ul li a,
.main-navigation a,
.main-navigation .menu a,
#primary-menu li a {
  color: #111827 !important;
  font-weight: 500 !important;
  font-size: 1rem !important;
  padding: 0.75rem 1rem !important;
  text-decoration: none !important;
  transition: color 0.2s ease !important;
}

.main-navigation .main-nav ul li a:hover,
.main-navigation a:hover,
#primary-menu li a:hover {
  color: #8B1538 !important;
}

/* Dark mode navigation - handled by dark-mode.css */

/* Navigation Container - Better Spacing */
.main-navigation {
  padding: 0.5rem 0 !important;
  margin: 0 !important;
  clear: both !important;
}

.main-navigation ul {
  display: flex !important;
  gap: 0.5rem !important;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

.main-navigation li {
  margin: 0 !important;
}

/* Site Header - Better Layout */
.site-header {
  padding: 1.5rem 0 !important;
  position: sticky !important;
  top: 0 !important;
  z-index: 9999 !important;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1) !important;
}

.header-inner {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  gap: 2rem !important;
}

/* ========================================================================
   2. SUBSCRIBE BAR - MAKE VISIBLE AND FUNCTIONAL
   ======================================================================== */

/* Newsletter Widget in Header (if it exists) */
.header-widget,
.header-newsletter {
  background-color: #8B1538 !important;
  padding: 0.75rem 1.5rem !important;
  border-radius: 8px !important;
  margin-left: auto !important;
}

.header-newsletter form {
  display: flex !important;
  gap: 0.5rem !important;
  align-items: center !important;
}

.header-newsletter input[type="email"] {
  background-color: #FFFFFF !important;
  border: 1px solid #D1D5DB !important;
  padding: 0.5rem 1rem !important;
  border-radius: 6px !important;
  color: #111827 !important;
  min-width: 250px !important;
  font-size: 0.875rem !important;
}

.header-newsletter input[type="email"]::placeholder {
  color: #6B7280 !important;
}

.header-newsletter button {
  background-color: #6B0F2B !important;
  color: #FFFFFF !important;
  border: none !important;
  padding: 0.5rem 1.5rem !important;
  border-radius: 6px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  transition: background-color 0.2s ease !important;
}

.header-newsletter button:hover {
  background-color: #4A0A1E !important;
}

/* Dark mode subscribe bar - handled by dark-mode.css */

/* ========================================================================
   3. ANNOUNCEMENT BAR - TOP OF PAGE
   ======================================================================== */

.announcement-bar {
  background: linear-gradient(135deg, #8B1538 0%, #6B0F2B 100%) !important;
  color: #FFFFFF !important;
  padding: 0.75rem 0 !important;
  text-align: center !important;
  font-size: 0.875rem !important;
  position: sticky !important;
  top: 0 !important;
  z-index: 10000 !important;
}

.announcement-bar-content {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  gap: 1rem !important;
}

.announcement-bar a {
  color: #FFFFFF !important;
  font-weight: 600 !important;
  text-decoration: underline !important;
  text-underline-offset: 2px !important;
}

.announcement-bar a:hover {
  color: #F9FAFB !important;
}

/* Push site header below announcement bar */
.announcement-bar ~ .site-header {
  top: 50px !important;
}

/* Dark mode announcement bar - handled by dark-mode.css */

/* ========================================================================
   4. MOBILE RESPONSIVE - STACK PROPERLY
   ======================================================================== */

@media (max-width: 768px) {
  .header-inner {
    flex-wrap: wrap !important;
    flex-direction: row !important;
    justify-content: space-between !important;
    align-items: center !important;
    gap: 0 !important;
  }

  .main-navigation {
    display: none !important;
  }

  .main-navigation.active {
    display: block !important;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--color-cream, #FAF8F5);
    padding: var(--space-4, 1rem);
    box-shadow: 0 4px 12px rgba(0,0,0,0.1);
    z-index: 9999;
  }

  .main-navigation.active ul {
    flex-direction: column !important;
    width: 100% !important;
  }

  .main-navigation li a {
    display: block !important;
    width: 100% !important;
    text-align: center !important;
    padding: 0.75rem 0 !important;
  }

  .header-cta {
    display: none !important;
  }

  .mobile-menu-toggle {
    display: block !important;
  }

  /* Logo sizing for mobile — extra specificity to beat critical fixes 80px rule */
  .site-header .site-branding img,
  .site-header .site-branding .custom-logo,
  .site-header .custom-logo-link .custom-logo {
    max-height: 36px !important;
    width: auto !important;
  }

  .site-branding .site-title {
    font-size: 1.25rem !important;
  }

  .header-newsletter {
    width: 100% !important;
  }

  .header-newsletter form {
    flex-direction: column !important;
    width: 100% !important;
  }

  .header-newsletter input[type="email"] {
    width: 100% !important;
  }

  .header-newsletter button {
    width: 100% !important;
  }
}

/* ========================================================================
   5. ENSURE NO OVERLAP - CLEAR LAYOUT
   ======================================================================== */

.site-branding {
  flex-shrink: 0 !important;
}

.main-navigation {
  flex-grow: 1 !important;
  justify-content: center !important;
}

.header-newsletter {
  flex-shrink: 0 !important;
}

/* Make sure header doesn't overlap content */
.site-main {
  margin-top: 2rem !important;
  min-width: 0 !important; /* Fix flexbox expansion — prevents content from blowing out .site-content flex container */
  overflow-x: hidden !important;
}


/* ========================================================================
   NEWSLETTER FORM MESSAGES
   ======================================================================== */

.form-message {
  padding: 1rem 1.5rem;
  border-radius: 6px;
  margin-top: 1rem;
  font-size: 0.875rem;
  font-weight: 500;
  animation: slideDown 0.3s ease;
}

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

.form-message-success {
  background-color: #D1FAE5;
  color: #065F46;
  border: 1px solid #6EE7B7;
}

.form-message-error {
  background-color: #FEE2E2;
  color: #991B1B;
  border: 1px solid #FCA5A5;
}

/* Dark mode form messages - handled by dark-mode.css */

/* Newsletter Form Button States */
.newsletter-button:disabled,
.newsletter-form button:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

/* ========================================================================
   OPUS 4.5 LAYOUT SYSTEM - Modern, Spacious, Responsive
   Based on 2026 best practices: Apple HIG, Baymard Institute, NN/G
   ======================================================================== */

/* ========================================================================
   1. CONTAINER SYSTEM - Flexible Width with Strategic Constraints
   ======================================================================== */

:root {
  /* Container Widths - Content-First Approach */
  --container-full: 1600px;        /* Maximum page width - increased to accommodate wider content */
  --container-wide: 1500px;        /* Standard content width - increased to accommodate 948px content + 360px sidebar */
  --container-default: 1140px;     /* Default container */
  --container-narrow: 960px;       /* Narrow content (landing pages) */
  --container-reading: 720px;      /* Optimal reading width (blog posts) */
  --container-tight: 640px;        /* Very focused content */

  /* Spacing Scale - Harmonious Rhythm */
  --space-xs: 0.5rem;    /* 8px */
  --space-sm: 1rem;      /* 16px */
  --space-md: 1.5rem;    /* 24px */
  --space-lg: 2rem;      /* 32px */
  --space-xl: 3rem;      /* 48px */
  --space-2xl: 4rem;     /* 64px */
  --space-3xl: 6rem;     /* 96px */
  --space-4xl: 8rem;     /* 128px */

  /* Responsive Padding */
  --padding-page: clamp(1.5rem, 5vw, 3rem);
  --padding-section: clamp(3rem, 10vw, 6rem);
}

/* Universal Container */
.container,
.container-default {
  width: 100%;
  max-width: var(--container-default);
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--padding-page);
  padding-right: var(--padding-page);
}

/* Container Variations */
.container-full {
  max-width: var(--container-full);
}

.container-wide {
  max-width: var(--container-wide);
}

.container-narrow {
  max-width: var(--container-narrow);
}

.container-reading {
  max-width: var(--container-reading);
}

.container-tight {
  max-width: var(--container-tight);
}

/* ========================================================================
   2. ARTICLE LAYOUT - Optimal Reading Experience
   ======================================================================== */

/* Single Post Container - Generous Breathing Room */
.single-post-article {
  max-width: 100%;
  margin: 0 auto;
}

/* Post Header - Full Width Background, Narrow Content */
.post-header {
  background-color: var(--color-bg-secondary);
  padding: var(--space-3xl) 0 var(--space-2xl);
  margin-bottom: var(--space-3xl);
}

.post-header .container-narrow {
  max-width: var(--container-reading);
  margin: 0 auto;
  padding: 0 var(--padding-page);
}

/* Post Content - Optimal Reading Width (66ch ≈ 720px) */
.post-content,
.entry-content {
  max-width: var(--container-reading);
  margin: 0 auto;
  padding: 0 var(--padding-page);
}

/* Post Content Wrapper - Flexible Layout */
.post-content-wrapper {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-2xl);
  max-width: var(--container-wide);
  margin: 0 auto;
  padding: 0 var(--padding-page);
}

/* Two-Column Layout: Content + Sidebar (Desktop Only) */
@media (min-width: 1024px) {
  .post-content-wrapper {
    grid-template-columns: minmax(0, 948px) minmax(300px, 360px);
    gap: var(--space-3xl);
  }

  .post-content {
    padding: 0; /* Remove padding when in grid */
  }

  .post-sidebar {
    position: sticky;
    top: calc(var(--space-2xl) + 80px); /* Account for sticky header */
    height: fit-content;
  }
}

/* Post Footer - Full Width Section */
.post-footer {
  background-color: var(--color-bg-secondary);
  padding: var(--space-3xl) 0;
  margin-top: var(--space-4xl);
}

.post-footer .container-narrow {
  max-width: var(--container-wide);
  margin: 0 auto;
  padding: 0 var(--padding-page);
}

/* ========================================================================
   3. VERTICAL RHYTHM - Consistent Spacing
   ======================================================================== */

/* Section Spacing */
section {
  padding: var(--padding-section) 0;
}

/* Block-Level Elements */
.post-content > * + *,
.entry-content > * + * {
  margin-top: var(--space-lg);
}

/* Headings Get More Space Above */
.post-content h2,
.entry-content h2 {
  margin-top: var(--space-3xl);
  margin-bottom: var(--space-lg);
}

.post-content h3,
.entry-content h3 {
  margin-top: var(--space-2xl);
  margin-bottom: var(--space-md);
}

.post-content h4,
.entry-content h4,
.post-content h5,
.entry-content h5,
.post-content h6,
.entry-content h6 {
  margin-top: var(--space-xl);
  margin-bottom: var(--space-sm);
}

/* First Element No Top Margin */
.post-content > *:first-child,
.entry-content > *:first-child {
  margin-top: 0;
}

/* ========================================================================
   4. MEDIA ELEMENTS - Images, Videos, Embeds
   ======================================================================== */

/* Images - Responsive by Default */
.post-content img,
.entry-content img {
  max-width: 100%;
  height: auto;
  display: block;
  margin: var(--space-2xl) auto;
  border-radius: 8px;
  box-shadow: var(--shadow-md);
}

/* Full-Width Images - Break Out of Reading Width */
.post-content .alignfull,
.entry-content .alignfull {
  width: 100vw;
  max-width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  margin-top: var(--space-3xl);
  margin-bottom: var(--space-3xl);
}

/* Wide Images - Expand Beyond Reading Width */
.post-content .alignwide,
.entry-content .alignwide {
  max-width: var(--container-default);
  margin-left: auto;
  margin-right: auto;
  margin-top: var(--space-3xl);
  margin-bottom: var(--space-3xl);
}

@media (min-width: 768px) {
  .post-content .alignwide,
  .entry-content .alignwide {
    width: calc(100% + 8rem);
    max-width: calc(100% + 8rem);
    margin-left: -4rem;
    margin-right: -4rem;
  }
}

/* Figure Captions */
.post-content figure,
.entry-content figure {
  margin: var(--space-2xl) 0;
}

.post-content figcaption,
.entry-content figcaption {
  font-family: var(--font-ui);
  font-size: var(--text-sm);
  color: var(--color-text-tertiary);
  text-align: center;
  margin-top: var(--space-sm);
  font-style: italic;
}

/* Video Embeds - Responsive 16:9 Aspect Ratio */
.post-content iframe,
.entry-content iframe,
.post-content embed,
.entry-content embed,
.post-content video,
.entry-content video {
  max-width: 100%;
  margin: var(--space-2xl) 0;
  border-radius: 8px;
  box-shadow: var(--shadow-lg);
}

/* WordPress Embed Wrapper */
.wp-block-embed,
.wp-embed-responsive {
  margin: var(--space-2xl) 0;
}

.wp-block-embed__wrapper {
  position: relative;
  padding-bottom: 56.25%; /* 16:9 aspect ratio */
  height: 0;
  overflow: hidden;
}

.wp-block-embed__wrapper iframe,
.wp-block-embed__wrapper embed,
.wp-block-embed__wrapper video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  margin: 0;
}

/* ========================================================================
   5. CALLOUT BOXES - Styled Content Blocks
   ======================================================================== */

/* Base Callout Style */
.callout,
.wp-block-quote.is-style-large {
  background-color: var(--color-cream-light);
  border-left: 4px solid var(--color-burgundy);
  padding: var(--space-lg) var(--space-xl);
  margin: var(--space-2xl) 0;
  border-radius: 8px;
  box-shadow: var(--shadow-sm);
}

/* Callout Variations */
.callout-warning {
  background-color: #FEF3C7;
  border-left-color: #F59E0B;
}

.callout-info {
  background-color: #DBEAFE;
  border-left-color: #3B82F6;
}

.callout-success {
  background-color: #D1FAE5;
  border-left-color: #10B981;
}

.callout-danger {
  background-color: #FEE2E2;
  border-left-color: #EF4444;
}

/* Dark mode callouts - handled by dark-mode.css */

/* Callout Title */
.callout-title {
  font-family: var(--font-ui);
  font-weight: 700;
  font-size: var(--text-lg);
  margin-bottom: var(--space-sm);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
}

/* ========================================================================
   6. SCRIPTURE REFERENCES - Theological Highlight Boxes
   ======================================================================== */

.scripture-reference,
.bible-verse {
  background: linear-gradient(135deg, var(--color-cream) 0%, var(--color-cream-light) 100%);
  border-left: 4px solid var(--color-burgundy);
  padding: var(--space-lg) var(--space-xl);
  margin: var(--space-2xl) 0;
  font-family: var(--font-body);
  font-style: italic;
  font-size: var(--text-lg);
  line-height: var(--leading-relaxed);
  border-radius: 8px;
  box-shadow: var(--shadow-md);
  position: relative;
}

.scripture-reference::before {
  content: '"';
  font-family: var(--font-display);
  font-size: 4em;
  color: var(--color-burgundy-light);
  position: absolute;
  top: -0.2em;
  left: 0.2em;
  opacity: 0.2;
  line-height: 1;
  font-weight: 700;
}

.scripture-reference cite,
.bible-verse cite {
  display: block;
  font-family: var(--font-ui);
  font-style: normal;
  font-weight: 600;
  font-size: var(--text-sm);
  color: var(--color-burgundy);
  margin-top: var(--space-sm);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
}

/* Dark mode scripture references - handled by dark-mode.css */

/* ========================================================================
   7. PULL QUOTES - Eye-Catching Highlights
   ======================================================================== */

.pullquote,
.wp-block-pullquote {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 700;
  line-height: var(--leading-tight);
  color: var(--color-burgundy);
  text-align: center;
  margin: var(--space-3xl) 0;
  padding: var(--space-2xl) var(--space-xl);
  border-top: 3px solid var(--color-burgundy);
  border-bottom: 3px solid var(--color-burgundy);
  position: relative;
}

/* Pullquote decorative quotes - only for WP block pullquotes (not custom shortcode) */
.wp-block-pullquote::before,
.wp-block-pullquote::after {
  content: '"';
  font-size: 3em;
  color: var(--color-burgundy-light);
  opacity: 0.3;
  position: absolute;
}

.wp-block-pullquote::before {
  top: 0.1em;
  left: 0.1em;
}

.wp-block-pullquote::after {
  bottom: 0.1em;
  right: 0.1em;
  content: '"';
}

/* Custom shortcode pullquotes: quotes handled by .pullquote-mark element */
.pullquote::before,
.pullquote::after {
  content: none;
}

/* Dark mode pullquotes - handled by dark-mode.css */

/* ========================================================================
   8. RESPONSIVE BREAKPOINTS - Mobile-First Approach
   ======================================================================== */

/* Mobile First - Base Styles Above Apply to 320px+ */

/* Small Phones (360px+) */
@media (min-width: 360px) {
  :root {
    --padding-page: 1.25rem;
  }
}

/* Large Phones / Small Tablets (480px+) */
@media (min-width: 480px) {
  :root {
    --padding-page: 1.5rem;
    --padding-section: 4rem;
  }

  .post-header {
    padding: var(--space-3xl) 0;
  }
}

/* Tablets (768px+) */
@media (min-width: 768px) {
  :root {
    --padding-page: 2rem;
    --padding-section: 5rem;
  }

  /* Enable two-column layouts */
  .post-meta-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-lg);
  }
}

/* Small Laptops (1024px+) */
@media (min-width: 1024px) {
  :root {
    --padding-page: 2.5rem;
    --padding-section: 6rem;
  }

  /* Content + Sidebar layout activated (see above) */

  /* Full-width images get more dramatic */
  .post-content .alignfull,
  .entry-content .alignfull {
    margin-top: var(--space-4xl);
    margin-bottom: var(--space-4xl);
  }
}

/* Standard Desktops (1280px+) */
@media (min-width: 1280px) {
  :root {
    --padding-page: 3rem;
  }

  /* Maximum comfortable reading experience */
  .post-content,
  .entry-content {
    font-size: var(--text-lg);
  }
}

/* Large Desktops (1440px+) */
@media (min-width: 1440px) {
  /* Even more generous spacing on large screens */
  .post-footer {
    padding: var(--space-4xl) 0;
  }

  section {
    padding: var(--space-4xl) 0;
  }
}

/* ========================================================================
   9. PRINT STYLES - Beautiful Printed Articles
   ======================================================================== */

@media print {
  .post-content-wrapper {
    grid-template-columns: 1fr;
  }

  .post-sidebar {
    display: none;
  }

  .post-content {
    max-width: 100%;
  }

  img {
    max-width: 100%;
    page-break-inside: avoid;
  }

  h2, h3, h4, h5, h6 {
    page-break-after: avoid;
  }

  .callout,
  .scripture-reference {
    page-break-inside: avoid;
  }
}

/* ========================================================================
   10. ACCESSIBILITY - Screen Readers & Keyboard Navigation
   ======================================================================== */

/* Skip to Content Link */
.skip-link {
  position: absolute;
  top: -40px;
  left: 0;
  background: var(--color-burgundy);
  color: white;
  padding: 8px;
  text-decoration: none;
  z-index: 100000;
}

.skip-link:focus {
  top: 0;
}

/* Focus Visible for Keyboard Navigation */
a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible {
  outline: 3px solid var(--color-burgundy);
  outline-offset: 2px;
}

/* ========================================================================
   LAYOUT SYSTEM - FORCE OVERRIDES FOR GENERATEPRESS
   ======================================================================== */

/* Override GeneratePress Container Widths */
.site-content .content-area,
.inside-article,
article.single-post-article {
  max-width: 100% !important;
  width: 100% !important;
}

/* Post Content - Force Optimal Reading Width (DISABLED - see line 4619 for active styles) */
/*.post-content,
.entry-content,
article .entry-content {
  max-width: 720px !important;
  width: 100% !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 1.5rem !important;
  padding-right: 1.5rem !important;
}*/

/* Post Header - Force Proper Width */
.post-header .container-reading {
  max-width: 720px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding: 0 1.5rem !important;
}

/* Remove GeneratePress Default Padding */
.separate-containers .inside-article {
  padding: 0 !important;
}

/* Post Content Wrapper - Override GeneratePress Grid */
.post-content-wrapper {
  display: block !important;
  max-width: var(--container-wide) !important;
  margin: 0 auto !important;
  padding: 2rem 1.5rem !important;
}

@media (min-width: 1024px) {
  .post-content-wrapper {
    display: grid !important;
    grid-template-columns: minmax(0, 948px) minmax(280px, 360px) !important;
    gap: 4rem !important;
    padding: 3rem !important;
  }

  .post-content,
  article .entry-content {
    padding: 0 !important;
  }
}

/* Paragraphs - Force Proper Spacing */
.post-content p,
.entry-content p,
article p {
  margin-bottom: 1.5em !important;
  line-height: 1.625 !important;
  max-width: 100% !important;
}

/* Headings - Force Proper Spacing */
.post-content h2,
.entry-content h2 {
  margin-top: 3rem !important;
  margin-bottom: 1.5rem !important;
  font-size: clamp(2rem, 1.75rem + 1.25vw, 2.5rem) !important;
}

.post-content h3,
.entry-content h3 {
  margin-top: 2.5rem !important;
  margin-bottom: 1rem !important;
  font-size: clamp(1.5rem, 1.35rem + 0.75vw, 2rem) !important;
}

/* Images - Force Responsive */
.post-content img,
.entry-content img,
article img {
  max-width: 100% !important;
  height: auto !important;
  margin: 2rem auto !important;
  display: block !important;
}

/* Remove Default WordPress/GeneratePress Constraints */
.site {
  max-width: 100% !important;
}

.site-content {
  max-width: 100% !important;
  padding: 0 !important;
}

.container,
.grid-container {
  max-width: 100% !important;
}

/* Post Footer - Full Width */
.post-footer {
  max-width: 100% !important;
  width: 100% !important;
  padding: 4rem 0 !important;
  margin-top: 4rem !important;
  background-color: var(--color-bg-secondary) !important;
}

.post-footer .container-wide {
  max-width: 1280px !important;
  margin: 0 auto !important;
  padding: 0 1.5rem !important;
}

/* Lists - Proper Spacing */
.post-content ul,
.post-content ol,
.entry-content ul,
.entry-content ol {
  margin: 1.5rem 0 !important;
  padding-left: 2rem !important;
}

.post-content li,
.entry-content li {
  margin-bottom: 0.75rem !important;
  line-height: 1.625 !important;
}

/* Blockquotes - Beautiful Styling */
.post-content blockquote,
.entry-content blockquote {
  margin: 2.5rem 0 !important;
  padding: 1.5rem 2rem !important;
  border-left: 4px solid var(--color-burgundy) !important;
  background: var(--color-cream-light) !important;
  font-size: clamp(1.125rem, 1.05rem + 0.35vw, 1.25rem) !important;
}

/* Dark mode toggle button - handled by dark-mode.css */

/* Manual dark mode (body.dark-mode class) - handled by dark-mode.css */

/* Native system preference dark mode - handled by dark-mode.css */


/* ========================================================================
   REMOVE SIDEBAR FROM SPECIFIC PAGES - Full Width Layout
   ======================================================================== */

/* Target: About (46), Start Here (47), Privacy (49), Terms (50) */
.page-id-46 .sidebar,
.page-id-47 .sidebar,
.page-id-49 .sidebar,
.page-id-50 .sidebar,
.page-id-46 .widget-area,
.page-id-47 .widget-area,
.page-id-49 .widget-area,
.page-id-50 .widget-area {
  display: none !important;
}

/* Make content full-width on these pages */
.page-id-46 .site-content,
.page-id-47 .site-content,
.page-id-49 .site-content,
.page-id-50 .site-content,
.page-id-46 .content-area,
.page-id-47 .content-area,
.page-id-49 .content-area,
.page-id-50 .content-area {
  max-width: 900px !important;
  width: 100% !important;
  margin: 0 auto !important;
  padding: 3rem 2rem !important;
}

/* Full width entry content */
.page-id-46 .entry-content,
.page-id-47 .entry-content,
.page-id-49 .entry-content,
.page-id-50 .entry-content {
  max-width: 100% !important;
}

/* ========================================================================
   CONTINUE READING SECTION - Recent Posts at Bottom
   ======================================================================== */

.continue-reading-section {
  margin-top: 4rem;
  padding-top: 3rem;
  border-top: 2px solid var(--color-burgundy);
}

.continue-reading-section h3 {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  font-weight: 700;
  color: var(--color-burgundy);
  margin-bottom: 2rem;
  text-align: center;
}

.continue-reading-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 2rem;
  margin-bottom: 2rem;
}

.continue-reading-card {
  background: var(--color-cream-light);
  padding: 1.5rem;
  border-radius: 8px;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  min-height: 200px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  position: relative;
  overflow: hidden;
}

.continue-reading-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.3);
}

.continue-reading-card h4 {
  font-size: var(--text-xl);
  font-weight: 700;
  margin-bottom: 0.5rem;
  position: relative;
  z-index: 2;
}

.continue-reading-card h4 a {
  color: #FFFFFF;
  text-decoration: none;
  text-shadow: 0 2px 4px rgba(0,0,0,0.8);
}

.continue-reading-card h4 a:hover {
  color: #F87171;
}

.continue-reading-card .excerpt {
  font-size: var(--text-sm);
  color: #E5E7EB;
  line-height: 1.6;
  text-shadow: 0 1px 2px rgba(0,0,0,0.8);
  position: relative;
  z-index: 2;
}

/* Dark mode for continue reading - handled by dark-mode.css */

/* ============================================
   Newsletter & Contact Forms
   ============================================ */

.newsletter-signup-box,
.contact-form-box {
  background: var(--color-ivory);
  border: 2px solid var(--color-gold);
  border-radius: 8px;
  padding: 2rem;
  margin: 2rem 0;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}

.newsletter-form .form-group,
.contact-form .form-group {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.newsletter-form input[type="email"],
.contact-form input[type="email"],
.contact-form textarea {
  width: 100%;
  padding: 0.875rem 1rem;
  font-family: var(--font-body);
  font-size: var(--text-base);
  border: 2px solid var(--color-slate);
  border-radius: 4px;
  background: #FFFFFF;
  color: var(--color-graphite);
  transition: all 0.2s ease;
}

.newsletter-form input[type="email"]:focus,
.contact-form input[type="email"]:focus,
.contact-form textarea:focus {
  outline: none;
  border-color: var(--color-crimson);
  box-shadow: 0 0 0 3px rgba(193, 18, 31, 0.1);
}

.contact-form textarea {
  min-height: 120px;
  resize: vertical;
  font-family: var(--font-body);
}

.newsletter-form button[type="submit"],
.contact-form button[type="submit"] {
  padding: 0.875rem 2rem;
  font-family: var(--font-ui);
  font-size: var(--text-base);
  font-weight: 600;
  color: #FFFFFF;
  background: var(--color-crimson);
  border: none;
  border-radius: 4px;
  cursor: pointer;
  transition: all 0.2s ease;
  align-self: flex-start;
}

.newsletter-form button[type="submit"]:hover,
.contact-form button[type="submit"]:hover {
  background: #A00F1A;
  transform: translateY(-1px);
  box-shadow: 0 4px 8px rgba(193, 18, 31, 0.3);
}

.newsletter-form button[type="submit"]:active,
.contact-form button[type="submit"]:active {
  transform: translateY(0);
}

.newsletter-form button[type="submit"]:disabled,
.contact-form button[type="submit"]:disabled {
  background: var(--color-slate);
  cursor: not-allowed;
  transform: none;
}

/* Form messages */
.form-message {
  padding: 1rem;
  margin-top: 1rem;
  border-radius: 4px;
  font-family: var(--font-body);
  font-size: var(--text-sm);
}

.form-message-success {
  background: #D1FAE5;
  color: #065F46;
  border: 1px solid #10B981;
}

.form-message-error {
  background: #FEE2E2;
  color: #991B1B;
  border: 1px solid #EF4444;
}

/* Dark mode for forms - handled by dark-mode.css */

/* Responsive */
@media (min-width: 640px) {
  .newsletter-form .form-group {
    flex-direction: row;
    align-items: center;
  }

  .newsletter-form input[type="email"] {
    flex: 1;
  }

  .newsletter-form button[type="submit"] {
    flex-shrink: 0;
  }
}

/* ============================================
   READING PROGRESS BAR
   ============================================ */

#reading-progress {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: rgba(193, 18, 31, 0.1);
  z-index: 10000 !important; /* Above header (9999) */
  pointer-events: none;
}

#reading-progress .progress-bar {
  height: 100%;
  background: var(--color-crimson);
  width: 0%;
  transition: width 0.1s ease-out;
}

/* ============================================
   APPLE-INSPIRED ARTICLE TYPOGRAPHY
   Clean, spacious, highly readable design
   ============================================ */

/* Article Container - Premium Reading Experience */
.site-main article.single-post .post-content-wrapper .post-content,
.single-post .entry-content,
.single-post .post-content,
.post-content-wrapper .post-content,
article.post .entry-content,
article.post .post-content {
  max-width: 948px !important; /* 820px content + 128px padding */
  width: auto !important; /* Override width: 100% from parent theme */
  margin-left: auto !important;
  margin-right: auto !important;
  padding: 0 4rem !important;
  box-sizing: border-box !important;
  font-size: 19px !important;
  line-height: 1.58 !important; /* Apple-style line height for optimal readability */
  letter-spacing: 0.012em !important; /* Subtle letter spacing for better readability */
  color: var(--color-graphite) !important; /* Uses design system variable, dark-mode.css overrides */
  font-feature-settings: "kern" 1; /* Enable kerning */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Generous paragraph spacing - Apple style */
.single-post .entry-content p,
.single-post .post-content p {
  margin-bottom: 1.5em !important;
  margin-top: 0 !important;
  max-width: 100% !important;
}

.single-post .entry-content p + p,
.single-post .post-content p + p {
  margin-top: 1.25em !important;
}

/* Apple-style list spacing with proper indentation */
.single-post .entry-content ul,
.single-post .entry-content ol,
.single-post .post-content ul,
.single-post .post-content ol {
  margin: 1.75em 0 !important;
  padding-left: 2.5em !important; /* Proper indentation like Apple */
  list-style-position: outside !important;
}

.single-post .entry-content ul,
.single-post .post-content ul {
  list-style-type: disc !important;
}

.single-post .entry-content ol,
.single-post .post-content ol {
  list-style-type: decimal !important;
}

/* List items - clean spacing */
.single-post .entry-content li,
.single-post .post-content li {
  margin-bottom: 0.875em !important;
  margin-top: 0 !important;
  padding-left: 0.5em !important; /* Additional spacing after bullet */
  line-height: 1.58 !important;
}

.single-post .entry-content li:last-child,
.single-post .post-content li:last-child {
  margin-bottom: 0 !important;
}

/* Nested lists */
.single-post .entry-content li ul,
.single-post .entry-content li ol,
.single-post .post-content li ul,
.single-post .post-content li ol {
  margin-top: 0.75em !important;
  margin-bottom: 0.5em !important;
}

/* ============================================
   PULL QUOTES - Beautiful Emphasis
   ============================================ */

.pull-quote,
blockquote.pull-quote {
  font-family: var(--font-display);
  font-size: 1.75rem;
  line-height: 1.4;
  font-weight: 600;
  color: var(--color-crimson);
  text-align: center;
  margin: 3rem auto;
  padding: 2rem 3rem;
  max-width: 600px;
  border: none;
  position: relative;
  font-style: italic;
}

.pull-quote::before {
  content: '"';
  font-size: 4rem;
  position: absolute;
  top: -0.5rem;
  left: 1rem;
  color: var(--color-gold);
  font-family: Georgia, serif;
  line-height: 1;
}

/* Standard Blockquotes */
blockquote {
  border-left: 4px solid var(--color-crimson);
  margin: 2rem 0;
  padding: 1.5rem 2rem;
  background: var(--color-ivory);
  font-style: italic;
  color: var(--color-slate);
}

blockquote p {
  margin-bottom: 0.75em !important;
}

blockquote cite {
  display: block;
  margin-top: 1rem;
  font-style: normal;
  font-size: 0.9em;
  color: var(--color-slate);
}

/* ============================================
   CALLOUT BOXES - Highlight Key Points
   ============================================ */

.callout,
.info-box,
.key-point {
  background: linear-gradient(135deg, #FFF5E6 0%, #F6F3ED 100%);
  border-left: 6px solid var(--color-gold);
  border-radius: 4px;
  padding: 2rem;
  margin: 2.5rem 0;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}

.callout-title,
.info-box-title {
  font-family: var(--font-ui);
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--color-crimson);
  margin-bottom: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* Different callout types */
.callout.warning {
  background: linear-gradient(135deg, #FFF4E6 0%, #FFF0DC 100%);
  border-left-color: #FF8C42;
}

.callout.scripture {
  background: linear-gradient(135deg, #E8F4F8 0%, #D4E8EE 100%);
  border-left-color: var(--color-sky);
}

.callout.application {
  background: linear-gradient(135deg, #F0F9FF 0%, #E0F2FE 100%);
  border-left-color: #0EA5E9;
}

/* ============================================
   SOCIAL SHARING - Top & Bottom with Icons
   ============================================ */

.social-share-wrapper {
  margin: 3rem 0;
  padding: 2rem 0;
  border-top: 1px solid #E5E7EB;
  border-bottom: 1px solid #E5E7EB;
}

.social-share-wrapper.top {
  margin-top: 1rem;
  border-top: none;
}

.social-share-wrapper.bottom {
  margin-bottom: 2rem;
}

.social-share-title {
  font-family: var(--font-ui);
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-slate);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: 1rem;
}

.social-share-buttons {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
  align-items: center;
}

.social-share-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--color-ivory);
  border: 2px solid #E5E7EB;
  color: var(--color-graphite);
  text-decoration: none;
  transition: all 0.2s ease;
  font-size: 1.25rem;
}

.social-share-button:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.social-share-button.twitter {
  border-color: #1DA1F2;
  color: #1DA1F2;
}

.social-share-button.twitter:hover {
  background: #1DA1F2;
  color: white;
}

.social-share-button.facebook {
  border-color: #1877F2;
  color: #1877F2;
}

.social-share-button.facebook:hover {
  background: #1877F2;
  color: white;
}

.social-share-button.linkedin {
  border-color: #0A66C2;
  color: #0A66C2;
}

.social-share-button.linkedin:hover {
  background: #0A66C2;
  color: white;
}

.social-share-button.email {
  border-color: var(--color-slate);
  color: var(--color-slate);
}

.social-share-button.email:hover {
  background: var(--color-graphite);
  color: white;
}

.social-share-button.copy {
  border-color: var(--color-gold);
  color: var(--color-gold);
}

.social-share-button.copy:hover {
  background: var(--color-gold);
  color: white;
}

/* Floating Social Share (Desktop) */
.floating-social-share {
  position: fixed;
  left: 2rem;
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  z-index: 100;
  opacity: 0;
  transition: opacity 0.3s ease;
}

.floating-social-share.visible {
  opacity: 1;
}

@media (max-width: 1200px) {
  .floating-social-share {
    display: none;
  }
}

/* ============================================
   IMPROVED NEWSLETTER BOXES
   ============================================ */

/* Inline Newsletter CTA */
.inline-newsletter-cta {
  background: linear-gradient(135deg, var(--color-crimson) 0%, #A00F1A 100%);
  color: white;
  padding: 3rem 2.5rem;
  margin: 4rem 0;
  border-radius: 8px;
  text-align: center;
  box-shadow: 0 8px 24px rgba(193, 18, 31, 0.2);
}

.inline-newsletter-cta h3 {
  font-family: var(--font-display);
  font-size: 2rem;
  font-weight: 700;
  color: rgba(255, 255, 255, 0.8) !important;
  margin: 0 0 0.5rem 0;
  border: none;
  padding: 0;
}

.inline-newsletter-cta p {
  font-size: 1.125rem;
  color: rgba(255, 255, 255, 0.8) !important;
  margin-bottom: 2rem !important;
  max-width: 500px;
  margin-left: auto;
  margin-right: auto;
}

.inline-newsletter-cta .newsletter-form {
  max-width: 500px;
  margin: 0 auto;
}

.inline-newsletter-cta .form-group {
  display: flex;
  gap: 0.75rem;
  flex-direction: column;
  align-items: stretch;
}

@media (min-width: 640px) {
  .inline-newsletter-cta .form-group {
    flex-direction: row;
    align-items: stretch;
  }
}

.inline-newsletter-cta input[type="email"] {
  flex: 1;
  padding: 1rem 1.25rem;
  border: 2px solid rgba(255, 255, 255, 0.3);
  background: rgba(255, 255, 255, 0.1);
  color: white;
  border-radius: 6px;
  font-size: 1rem;
  height: auto;
  min-height: 52px;
}

.inline-newsletter-cta input[type="email"]::placeholder {
  color: rgba(255, 255, 255, 0.7);
}

.inline-newsletter-cta input[type="email"]:focus {
  outline: none;
  border-color: white;
  background: rgba(255, 255, 255, 0.15);
}

.inline-newsletter-cta button[type="submit"] {
  padding: 1rem 2rem;
  background: white;
  color: var(--color-crimson);
  border: none;
  border-radius: 6px;
  font-family: var(--font-ui);
  font-size: 1rem;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.2s ease;
  white-space: nowrap;
  height: auto;
  min-height: 52px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.inline-newsletter-cta button[type="submit"]:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

.inline-newsletter-cta .social-proof {
  font-size: 0.875rem;
  color: rgba(255, 255, 255, 0.8);
  margin-top: 1rem;
  text-align: center;
  display: block;
  width: 100%;
}

/* Enhanced sidebar newsletter widget */
.widget.newsletter-widget {
  background: var(--color-ivory);
  padding: 2rem;
  border-radius: 8px;
  border: 2px solid var(--color-gold);
}

.widget.newsletter-widget h3 {
  font-family: var(--font-display);
  color: var(--color-crimson);
  margin-bottom: 0.75rem;
}

/* ============================================
   CLICK TO TWEET QUOTES
   ============================================ */

.tweet-quote {
  background: linear-gradient(135deg, #E8F4F8 0%, #D4E8EE 100%);
  border-left: 4px solid #1DA1F2;
  padding: 1.5rem 2rem;
  margin: 2rem 0;
  border-radius: 4px;
  position: relative;
}

.tweet-quote-text {
  font-size: 1.125rem;
  line-height: 1.6;
  color: var(--color-graphite);
  margin-bottom: 1rem;
}

.tweet-quote-button {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  background: #1DA1F2;
  color: white;
  text-decoration: none;
  border-radius: 4px;
  font-size: 0.875rem;
  font-weight: 600;
  transition: all 0.2s ease;
}

.tweet-quote-button:hover {
  background: #1a91da;
  transform: translateY(-1px);
}

/* Dark mode improvements - handled by dark-mode.css */

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

@media (max-width: 768px) {
  .single-post .entry-content,
  .single-post .post-content {
    padding: 0 1.5rem !important;
    font-size: 17px !important;
  }

  .pull-quote,
  blockquote.pull-quote {
    font-size: 1.375rem;
    padding: 1.5rem 2rem;
  }

  .callout,
  .info-box,
  .key-point {
    padding: 1.5rem;
    margin: 2rem 0;
  }

  .inline-newsletter-cta {
    padding: 2rem 1.5rem;
  }

  .inline-newsletter-cta h3 {
    font-size: 1.5rem;
  }
}

/* ============================================
   CONTENT UPGRADES & CTAs
   ============================================ */

.content-upgrade {
  background: var(--color-ivory);
  border: 2px solid var(--color-gold);
  border-radius: 8px;
  padding: 2rem;
  margin: 3rem 0;
  text-align: center;
}

.content-upgrade-icon {
  font-size: 3rem;
  color: var(--color-crimson);
  margin-bottom: 1rem;
}

.content-upgrade h4 {
  font-family: var(--font-display);
  font-size: 1.5rem;
  color: var(--color-crimson);
  margin: 0 0 0.5rem 0;
}

.content-upgrade p {
  color: var(--color-slate);
  margin-bottom: 1.5rem !important;
}

.content-upgrade-button {
  display: inline-block;
  padding: 0.875rem 2rem;
  background: var(--color-crimson);
  color: white;
  text-decoration: none;
  border-radius: 6px;
  font-family: var(--font-ui);
  font-weight: 700;
  transition: all 0.2s ease;
}

.content-upgrade-button:hover {
  background: #A00F1A;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(193, 18, 31, 0.3);
}

/* ============================================
   FIXES FOR AUDIT ISSUES
   ============================================ */

/* Fix: Article container margins - prevent flush with browser edge */
.single-post .site,
.single-post .site-content {
  padding-left: max(2rem, env(safe-area-inset-left)) !important;
  padding-right: max(2rem, env(safe-area-inset-right)) !important;
}

/* Fix: Hide old sidebar social boxes */
.single-post .sidebar .widget:has(h3:contains("Share This Post")),
.single-post .sidebar .widget:has(h3:contains("Get Weekly Theology")),
complementary .widget {
  display: none !important;
}

/* Better selector to hide sidebar widgets on single posts */
.single-post complementary,
.single-post aside.widget-area {
  display: none !important;
}

/* Fix: Ensure social share buttons stay within bounds */
.social-share-wrapper {
  max-width: 100%;
  box-sizing: border-box;
}

/* Fix: Better icon visibility for all share buttons */
.social-share-button svg {
  width: 20px;
  height: 20px;
  display: block;
}

/* Override any transform that might hide icons */
.social-share-button img,
.social-share-button svg {
  opacity: 1 !important;
  visibility: visible !important;
}

/* New social buttons - Threads and WhatsApp */
.social-share-button.threads {
  border-color: #000000;
  color: #000000;
}

.social-share-button.threads:hover {
  background: #000000;
  color: white;
}

.social-share-button.whatsapp {
  border-color: #25D366;
  color: #25D366;
}

.social-share-button.whatsapp:hover {
  background: #25D366;
  color: white;
}

/* Dark mode for new buttons - handled by dark-mode.css */

/* Hide old sidebar widgets (Share This Post and Get Weekly Theology boxes) */
aside.post-sidebar,
.sidebar-widget.share-widget,
.sidebar-widget.newsletter-widget {
  display: none !important;
}

/* Show sidebar for book reviews (override above hide) */
aside.post-sidebar:has(.book-review-widget) {
  display: block !important;
}

aside.post-sidebar:has(.book-review-widget) .sidebar-widget:not(.book-review-widget) {
  display: none !important;
}

/* Apple-inspired heading hierarchy for articles */
.single-post .entry-content h2,
.single-post .post-content h2 {
  font-size: 32px !important;
  font-weight: 700 !important;
  line-height: 1.125 !important;
  letter-spacing: -0.002em !important;
  margin-top: 2.5em !important;
  margin-bottom: 0.75em !important;
  color: var(--color-graphite) !important; /* Uses design system variable, dark-mode.css overrides */
  border-bottom: none !important; /* Clean Apple style - no borders */
}

.single-post .entry-content h3,
.single-post .post-content h3 {
  font-size: 24px !important;
  font-weight: 700 !important;
  line-height: 1.25 !important;
  letter-spacing: -0.001em !important;
  margin-top: 2em !important;
  margin-bottom: 0.65em !important;
  color: var(--color-graphite) !important; /* Uses design system variable, dark-mode.css overrides */
}

.single-post .entry-content h4,
.single-post .post-content h4 {
  font-size: 21px !important;
  font-weight: 600 !important;
  line-height: 1.3 !important;
  margin-top: 1.75em !important;
  margin-bottom: 0.6em !important;
  color: var(--color-slate) !important;
}

.single-post .entry-content h5,
.single-post .post-content h5 {
  font-size: 19px !important;
  font-weight: 600 !important;
  line-height: 1.35 !important;
  margin-top: 1.5em !important;
  margin-bottom: 0.5em !important;
  color: var(--color-slate) !important;
  text-transform: none !important; /* Apple doesn't use uppercase */
}

.single-post .entry-content h6,
.single-post .post-content h6 {
  font-size: 17px !important;
  font-weight: 600 !important;
  line-height: 1.4 !important;
  margin-top: 1.5em !important;
  margin-bottom: 0.5em !important;
  color: var(--color-slate) !important;
  text-transform: none !important;
}

/* First heading after content start - less top margin */
.single-post .entry-content > h2:first-child,
.single-post .entry-content > h3:first-child,
.single-post .post-content > h2:first-child,
.single-post .post-content > h3:first-child {
  margin-top: 0 !important;
}

/* Spacing between headings and following elements */
.single-post .entry-content h2 + p,
.single-post .entry-content h3 + p,
.single-post .entry-content h4 + p,
.single-post .post-content h2 + p,
.single-post .post-content h3 + p,
.single-post .post-content h4 + p {
  margin-top: 0 !important;
}

/* Responsive typography - Mobile optimization */
@media (max-width: 768px) {
  .single-post .entry-content,
  .single-post .post-content {
    font-size: 17px !important;
    padding: 0 1.5rem !important;
  }
  
  .single-post .entry-content h2,
  .single-post .post-content h2 {
    font-size: 28px !important;
  }
  
  .single-post .entry-content h3,
  .single-post .post-content h3 {
    font-size: 22px !important;
  }
  
  .single-post .entry-content ul,
  .single-post .entry-content ol,
  .single-post .post-content ul,
  .single-post .post-content ol {
    padding-left: 2em !important;
  }
}

/* ============================================
   CONVERSION-OPTIMIZED ARTICLE FORMATTING
   Based on 2026 best practices research
   ============================================ */

/* Increase article margins for better readability */
.single-post .entry-content,
.single-post .post-content {
  padding: 0 4rem !important; /* Increased from 2rem - more breathing room */
}

.single-post .site-content {
  padding-left: 4rem !important;
  padding-right: 4rem !important;
}

/* CALLOUT BOXES - High visibility for key points */
.callout,
.callout-info,
.callout-warning,
.callout-success,
.callout-tip {
  margin: 2.5em 0 !important;
  padding: 1.5rem 2rem !important;
  border-left: 4px solid var(--color-crimson) !important;
  background: rgba(193, 18, 31, 0.05) !important;
  border-radius: 4px !important;
  font-size: 17px !important;
  line-height: 1.6 !important;
}

.callout-info {
  border-left-color: #0284c7 !important;
  background: rgba(2, 132, 199, 0.05) !important;
}

.callout-warning {
  border-left-color: #f59e0b !important;
  background: rgba(245, 158, 11, 0.05) !important;
}

.callout-success {
  border-left-color: #16a34a !important;
  background: rgba(22, 163, 74, 0.05) !important;
}

.callout-tip {
  border-left-color: #8b5cf6 !important;
  background: rgba(139, 92, 246, 0.05) !important;
}

.callout strong,
.callout-info strong,
.callout-warning strong,
.callout-success strong,
.callout-tip strong {
  display: block !important;
  font-size: 18px !important;
  font-weight: 700 !important;
  margin-bottom: 0.5em !important;
  color: var(--color-graphite) !important;
}

/* PULL QUOTES - Emphasized quotations */
.pull-quote,
blockquote.featured {
  font-family: var(--font-display) !important;
  font-size: 28px !important;
  line-height: 1.4 !important;
  font-weight: 600 !important;
  font-style: italic !important;
  color: var(--color-crimson) !important;
  text-align: center !important;
  margin: 3rem auto !important;
  padding: 2.5rem 3rem !important;
  max-width: 600px !important;
  border: none !important;
  background: rgba(193, 18, 31, 0.03) !important;
  border-top: 2px solid var(--color-crimson) !important;
  border-bottom: 2px solid var(--color-crimson) !important;
  position: relative !important;
}

.pull-quote::before {
  content: '"' !important;
  font-size: 60px !important;
  position: absolute !important;
  top: -10px !important;
  left: 20px !important;
  color: var(--color-gold) !important;
  font-family: Georgia, serif !important;
  line-height: 1 !important;
  opacity: 0.3 !important;
}

/* Standard blockquotes */
.single-post .entry-content blockquote,
.single-post .post-content blockquote {
  border-left: 4px solid var(--color-crimson) !important;
  margin: 2rem 0 !important;
  padding: 1.5rem 2rem !important;
  background: var(--color-ivory) !important;
  font-style: italic !important;
  color: var(--color-slate) !important;
  font-size: 18px !important;
  line-height: 1.65 !important;
}

.single-post .entry-content blockquote p,
.single-post .post-content blockquote p {
  margin-bottom: 0.75em !important;
}

.single-post .entry-content blockquote cite,
.single-post .post-content blockquote cite {
  display: block !important;
  margin-top: 1rem !important;
  font-style: normal !important;
  font-size: 0.9em !important;
  color: var(--color-slate) !important;
  font-weight: 600 !important;
}

.single-post .entry-content blockquote cite::before,
.single-post .post-content blockquote cite::before {
  content: "— " !important;
}

/* INLINE CTAs - Conversion optimized positioning */
.inline-cta {
  margin: 3rem 0 !important;
  padding: 2rem !important;
  background: linear-gradient(135deg, var(--color-crimson) 0%, #991725 100%) !important;
  border-radius: 8px !important;
  text-align: center !important;
  color: white !important;
}

.inline-cta h3 {
  color: white !important;
  font-size: 24px !important;
  font-weight: 700 !important;
  margin-bottom: 0.75rem !important;
}

.inline-cta p {
  color: rgba(255,255,255,0.9) !important;
  font-size: 17px !important;
  margin-bottom: 1.5rem !important;
}

.inline-cta .button,
.inline-cta .cta-button {
  background: white !important;
  color: var(--color-crimson) !important;
  padding: 14px 32px !important;
  border-radius: 6px !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  display: inline-block !important;
  transition: transform 0.2s ease, box-shadow 0.2s ease !important;
}

.inline-cta .button:hover,
.inline-cta .cta-button:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 20px rgba(0,0,0,0.2) !important;
}

/* INTERNAL LINK CTAs - 121% higher CTR than sidebar */
.internal-link-cta {
  display: block !important;
  margin: 2rem 0 !important;
  padding: 1.5rem 2rem !important;
  background: rgba(193, 18, 31, 0.03) !important;
  border-left: 4px solid var(--color-crimson) !important;
  border-radius: 4px !important;
  text-decoration: none !important;
  transition: all 0.3s ease !important;
}

.internal-link-cta:hover {
  background: rgba(193, 18, 31, 0.08) !important;
  transform: translateX(4px) !important;
}

.internal-link-cta strong {
  display: block !important;
  color: var(--color-crimson) !important;
  font-size: 20px !important;
  font-weight: 700 !important;
  margin-bottom: 0.5rem !important;
}

.internal-link-cta span {
  color: var(--color-slate) !important;
  font-size: 16px !important;
}

/* IMAGE OPTIMIZATION - Better visual hierarchy */
.single-post .entry-content img,
.single-post .post-content img {
  margin: 2.5rem auto !important;
  border-radius: 8px !important;
  box-shadow: 0 4px 20px rgba(0,0,0,0.08) !important;
  max-width: 100% !important;
  height: auto !important;
}

.single-post .entry-content figure,
.single-post .post-content figure {
  margin: 2.5rem 0 !important;
}

.single-post .entry-content figcaption,
.single-post .post-content figcaption {
  text-align: center !important;
  font-size: 15px !important;
  color: var(--color-slate) !important;
  font-style: italic !important;
  margin-top: 1rem !important;
}

/* Responsive - Mobile optimization */
@media (max-width: 768px) {
  .single-post .entry-content,
  .single-post .post-content,
  .single-post .site-content {
    padding-left: 2rem !important;
    padding-right: 2rem !important;
  }
  
  .pull-quote,
  blockquote.featured {
    font-size: 22px !important;
    padding: 2rem 1.5rem !important;
  }
  
  .callout,
  .callout-info,
  .callout-warning,
  .callout-success,
  .callout-tip {
    padding: 1.25rem 1.5rem !important;
  }
}

/* CONVERSION OPTIMIZATIONS */

/* Above-fold CTA (304% better conversion) */
.above-fold-cta {
  margin: 2rem 0 !important;
  padding: 2rem !important;
  background: var(--color-crimson) !important;
  color: white !important;
  text-align: center !important;
  border-radius: 8px !important;
}

/* Center-aligned CTAs (682% more clicks) */
.center-cta {
  text-align: center !important;
}

/* Bottom-of-article CTA */
.bottom-cta {
  margin: 3rem 0 2rem !important;
  padding: 2.5rem !important;
  background: linear-gradient(135deg, #1a1a1a 0%, #2d2d2d 100%) !important;
  border-radius: 8px !important;
  text-align: center !important;
  color: white !important;
}

.bottom-cta h3 {
  color: white !important;
  font-size: 28px !important;
  margin-bottom: 1rem !important;
}

.bottom-cta p {
  color: rgba(255,255,255,0.85) !important;
  font-size: 18px !important;
  margin-bottom: 1.5rem !important;
}

/* ============================================
   FIX: Center content on wide screens
   ============================================ */

/* Limit site width and center it - single posts need more width for wider content */
.single-post .site {
  max-width: 1700px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* Add breathing room on all screen sizes - REMOVED: Was breaking homepage full-width sections */
/* .site-content {
  max-width: 1200px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 2rem !important;
  padding-right: 2rem !important;
} */

/* Single post - even more focused */
.single-post .site-content {
  max-width: 1000px !important;
}

/* Article container */
.single-post .inside-article {
  max-width: 800px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* Force wider content layout - Override all previous rules */
@media (min-width: 1024px) {
  .post-content-wrapper,
  article .post-content-wrapper,
  .single-post .post-content-wrapper {
    max-width: 1500px !important;
    grid-template-columns: minmax(0, 948px) minmax(300px, 360px) !important;
  }

  /* Deep Dive 2-column override: TOC + Content (sidebar hidden by default) */
  body.single-post .post-content-wrapper.deep-dive-layout,
  .single-post article .post-content-wrapper.deep-dive-layout {
    grid-template-columns: 220px minmax(0, 1fr) !important;
    max-width: 1200px !important;
    gap: 2rem !important;
  }

  /* Show sidebar for deep dives (chapter navigation) */
  .deep-dive-article aside.post-sidebar {
    display: block !important;
  }

  /* When sidebar IS visible, use 3-column grid */
  body.single-post .post-content-wrapper.deep-dive-layout:has(aside.post-sidebar) {
    grid-template-columns: 200px minmax(0, 1fr) 260px !important;
    max-width: 1300px !important;
  }
}

/* ============================================
   PERFORMANCE OPTIMIZATIONS
   Reduce scroll jank and improve rendering
   ============================================ */

/* GPU acceleration for frequently animated elements */
#reading-progress,
#reading-progress .progress-bar {
  will-change: transform, width;
  transform: translateZ(0);
  backface-visibility: hidden;
}

/* Optimize images during scroll */
img {
  content-visibility: auto;
}

/* Reduce paint complexity on hover states during scroll */
@media (hover: hover) {
  * {
    /* Only apply transitions when not scrolling */
    transition-duration: var(--transition-base);
  }
}

/* Optimize box-shadows with better performance */
.post-card,
.featured-post,
.sidebar-widget {
  will-change: auto; /* Only promote to GPU when needed */
}

/* Contain layout shifts */
article,
.post-content,
.sidebar {
  contain: layout style paint;
}

/* Dark mode text colors now handled by dark-mode.css */

/* ============================================
   CRITICAL: CTA Text Color Override - NUCLEAR OPTION
   ============================================ */

/* Ultra-specific selectors to override everything */
body.single-post article.single-post-article .post-content-wrapper .post-content .inline-newsletter-cta h3,
body.single article .post-content .inline-newsletter-cta h3,
.single-post .entry-content .inline-newsletter-cta h3,
.single-post .post-content .inline-newsletter-cta h3,
.entry-content .inline-newsletter-cta h3,
.post-content .inline-newsletter-cta h3,
.inline-newsletter-cta h3 {
  color: rgba(255, 255, 255, 0.8) !important;
}

body.single-post article.single-post-article .post-content-wrapper .post-content .inline-newsletter-cta p,
body.single article .post-content .inline-newsletter-cta p,
.single-post .entry-content .inline-newsletter-cta p,
.single-post .post-content .inline-newsletter-cta p,
.entry-content .inline-newsletter-cta p,
.post-content .inline-newsletter-cta p,
.inline-newsletter-cta p {
  color: rgba(255, 255, 255, 0.8) !important;
}

.inline-newsletter-cta .social-proof {
  color: rgba(255, 255, 255, 0.8) !important;
}

/* ========================================================================
   CONTENT GATE - Bible Deep Dives Paywall
   ======================================================================== */

.gated-preview {
  position: relative;
}

.content-gate {
  position: relative;
  margin-top: -8rem;
  padding-top: 8rem;
}

.content-gate-overlay {
  position: absolute;
  top: 0;
  left: -2rem;
  right: -2rem;
  height: 8rem;
  background: linear-gradient(to bottom, transparent, var(--color-ivory));
  pointer-events: none;
}

.content-gate-cta {
  background: var(--color-ivory);
  border: 2px solid var(--color-gold);
  border-radius: var(--radius-lg);
  padding: var(--space-10) var(--space-8);
  text-align: center;
  max-width: 600px;
  margin: 0 auto;
}

.content-gate-cta h3 {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  color: var(--color-graphite);
  margin-bottom: var(--space-3);
}

.content-gate-cta p {
  color: var(--color-slate);
  margin-bottom: var(--space-6);
  line-height: 1.6;
}

.content-gate-cta .newsletter-form-fields {
  flex-direction: column;
  align-items: stretch;
  max-width: 360px;
  margin: 0 auto;
  gap: var(--space-3);
}

.content-gate-cta .newsletter-input {
  border: 2px solid var(--color-gold);
  background: white;
}

.content-gate-cta .newsletter-button {
  background: var(--color-crimson);
  color: white;
  border: none;
  cursor: pointer;
}

.content-gate-cta .newsletter-button:hover {
  background: #7A1230;
  transform: translateY(-1px);
}

.gate-privacy {
  font-size: var(--text-sm);
  color: var(--color-slate);
  margin-top: var(--space-3);
}

.gate-login-form .newsletter-form-fields {
  flex-direction: column;
  align-items: stretch;
  max-width: 360px;
  margin: 0 auto;
  gap: var(--space-3);
}

.gate-login-form .newsletter-input {
  border: 2px solid var(--color-gold);
  background: white;
}

.gate-login-form .newsletter-button {
  background: var(--color-crimson);
  color: white;
  border: none;
  cursor: pointer;
}

.gate-login-form .newsletter-button:hover {
  background: #7A1230;
  transform: translateY(-1px);
}

.gate-login-link {
  font-size: var(--text-sm);
  color: var(--color-slate);
  margin-top: var(--space-2);
}

.gate-login-link a {
  color: var(--color-accent);
  text-decoration: underline;
  cursor: pointer;
}

.gate-login-link a:hover {
  color: var(--color-accent-hover, var(--color-accent));
}

/* ========================================================================
   PAYMENT MODAL — PayPal Link + Thank-You Banner
   ======================================================================== */

/* PayPal secondary link */
.support-modal-paypal-link {
  display: block;
  text-align: center;
  margin-top: var(--space-3);
  font-size: var(--text-sm);
  color: var(--color-slate);
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: color 0.2s ease;
}

.support-modal-paypal-link:hover {
  color: #003087; /* PayPal blue */
}

/* Thank-you banner */
.support-thank-you-banner {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 10000;
  background: linear-gradient(135deg, #059669, #10B981);
  color: #FFFFFF;
  padding: 0;
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease, padding 0.4s ease;
  display: flex;
  align-items: center;
  justify-content: center;
}

.support-thank-you-banner.visible {
  max-height: 80px;
  padding: 14px 20px;
}

.thank-you-content {
  flex: 1;
  text-align: center;
  font-size: var(--text-base);
  line-height: 1.5;
}

.thank-you-content strong {
  font-family: var(--font-display);
}

.thank-you-dismiss {
  background: none;
  border: none;
  color: rgba(255, 255, 255, 0.8);
  font-size: 1.5rem;
  cursor: pointer;
  padding: 0 0.5rem;
  min-height: auto !important;
  line-height: 1;
  transition: color 0.2s ease;
}

.thank-you-dismiss:hover {
  color: #FFFFFF;
}

/* ============================================
   MOBILE ARTICLE BODY TEXT FIX
   Must come last to override all desktop padding rules.
   Uses article.post selector to match specificity of
   desktop rule at line ~3798 (specificity 0,2,1).
   ============================================ */
@media (max-width: 768px) {
  /* Override the 4rem desktop padding — matches article.post specificity */
  .single-post .post-content,
  .single-post .entry-content,
  article.post .entry-content,
  article.post .post-content,
  .post-content-wrapper .post-content {
    padding: 0 1rem !important;
    font-size: 17px !important;
    line-height: 1.65 !important;
  }

  .single-post .site-content {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }

  /* Headings: scale down for narrow viewport */
  .single-post .entry-content h2,
  .single-post .post-content h2,
  article.post .entry-content h2,
  article.post .post-content h2 {
    font-size: 22px !important;
    line-height: 1.3 !important;
  }

  .single-post .entry-content h3,
  .single-post .post-content h3,
  article.post .entry-content h3,
  article.post .post-content h3 {
    font-size: 19px !important;
  }

  /* Post title */
  .single-post .post-title,
  .single-post .entry-title {
    font-size: 1.75rem !important;
    line-height: 1.2 !important;
    padding: 0 !important;
  }
}


/* ==========================================================================
   Sensitive Media — Blur Filter for Graphic Content
   Usage: Wrap image in <div class="sensitive-media" data-warning="...">
   Readers click to reveal. Like Telegram's spoiler/sensitive content filter.
   ========================================================================== */

.sensitive-media {
    position: relative;
    cursor: pointer;
    overflow: hidden;
    border-radius: 8px;
    margin: 2rem 0;
    background: var(--color-graphite);
}

/* Blurred image */
.sensitive-media img {
    display: block;
    width: 100%;
    height: auto;
    filter: blur(30px);
    transform: scale(1.1); /* prevent blur edge bleed */
    transition: filter 0.6s ease, transform 0.6s ease;
}

/* Warning overlay */
.sensitive-media .sensitive-overlay {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    background: rgba(30, 30, 30, 0.7);
    padding: 2rem;
    transition: opacity 0.4s ease;
    z-index: 2;
}

.sensitive-media .sensitive-overlay .sensitive-icon {
    width: 48px;
    height: 48px;
    margin-bottom: 1rem;
    opacity: 0.9;
}

.sensitive-media .sensitive-overlay .sensitive-icon svg {
    width: 100%;
    height: 100%;
    fill: none;
    stroke: white;
    stroke-width: 1.5;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.sensitive-media .sensitive-overlay .sensitive-warning {
    font-family: var(--font-headings, 'Playfair Display', serif);
    font-size: 1.125rem;
    font-weight: 700;
    color: white;
    margin-bottom: 0.5rem;
    line-height: 1.3;
}

.sensitive-media .sensitive-overlay .sensitive-description {
    font-size: 0.875rem;
    color: rgba(255, 255, 255, 0.75);
    line-height: 1.5;
    max-width: 400px;
    margin-bottom: 1.25rem;
}

.sensitive-media .sensitive-overlay .sensitive-reveal-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.625rem 1.5rem;
    font-size: 0.8125rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: white;
    background: rgba(255, 255, 255, 0.15);
    border: 1px solid rgba(255, 255, 255, 0.3);
    border-radius: 4px;
    transition: all 0.2s ease;
    cursor: pointer;
}

.sensitive-media .sensitive-overlay .sensitive-reveal-btn:hover {
    background: rgba(255, 255, 255, 0.25);
    border-color: rgba(255, 255, 255, 0.5);
}

/* Revealed state */
.sensitive-media.revealed img {
    filter: none;
    transform: scale(1);
}

.sensitive-media.revealed .sensitive-overlay {
    opacity: 0;
    pointer-events: none;
}

/* Re-hide button (appears after reveal) */
.sensitive-media .sensitive-rehide {
    position: absolute;
    top: 0.75rem;
    right: 0.75rem;
    padding: 0.375rem 0.75rem;
    font-size: 0.6875rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: white;
    background: rgba(0, 0, 0, 0.6);
    border: none;
    border-radius: 4px;
    cursor: pointer;
    opacity: 0;
    transition: opacity 0.3s ease;
    z-index: 3;
}

.sensitive-media.revealed .sensitive-rehide {
    opacity: 1;
}

.sensitive-media .sensitive-rehide:hover {
    background: rgba(0, 0, 0, 0.8);
}

/* Source attribution under sensitive media */
.sensitive-media-source {
    font-size: 0.8125rem;
    color: var(--color-stone);
    font-style: italic;
    margin-top: -1.5rem;
    margin-bottom: 2rem;
    padding-left: 0.25rem;
}

/* Mobile adjustments */
@media (max-width: 768px) {
    .sensitive-media .sensitive-overlay {
        padding: 1.25rem;
    }

    .sensitive-media .sensitive-overlay .sensitive-warning {
        font-size: 1rem;
    }

    .sensitive-media .sensitive-overlay .sensitive-description {
        font-size: 0.8125rem;
    }

    .sensitive-media .sensitive-overlay .sensitive-icon {
        width: 36px;
        height: 36px;
    }
}

/* =============================================
   BOOK REVIEW STYLES
   Challies-style layout with prominent affiliate link
   ============================================= */

/* Content type badge for book_review */
.content-type-badge.book_review {
    background: var(--color-gold);
    color: var(--color-graphite);
}

/* Amazon-Style Product Card (Sidebar) */
.amazon-card {
    background: #fff;
    border: 1px solid #d5d9d9;
    border-radius: 8px;
    padding: 0;
    text-align: center;
    position: sticky;
    top: 2rem;
    overflow: hidden;
    box-shadow: 0 2px 5px rgba(17, 17, 17, 0.08);
}

.amazon-card-image {
    background: #f7f8f8;
    padding: var(--space-6) var(--space-4);
    border-bottom: 1px solid #e7e8e8;
}

.amazon-card-image img {
    width: 100%;
    max-width: 280px;
    height: auto;
    margin: 0 auto;
    display: block;
    transition: transform var(--transition-base);
}

.amazon-card-image img:hover {
    transform: scale(1.02);
}

.amazon-card-body {
    padding: var(--space-4) var(--space-6) var(--space-6);
    text-align: left;
}

.amazon-card-title {
    font-family: var(--font-body);
    font-size: var(--text-lg);
    font-weight: 400;
    line-height: 1.35;
    margin: 0 0 var(--space-1);
}

.amazon-card-title a {
    color: #0f1111;
    text-decoration: none;
}

.amazon-card-title a:hover {
    color: #c7511f;
    text-decoration: underline;
}

.amazon-card-author {
    font-family: var(--font-ui);
    font-size: var(--text-sm);
    color: #565959;
    margin: 0 0 var(--space-3);
}

/* Amazon-style star rating */
.amazon-card-rating {
    margin: var(--space-2) 0 var(--space-4);
    line-height: 1;
}

.amazon-star {
    font-size: 1.25rem;
    color: #d5d9d9;
    letter-spacing: -1px;
}

.amazon-star.filled {
    color: #ffa41c;
}

.amazon-rating-text {
    font-family: var(--font-ui);
    font-size: var(--text-sm);
    color: #007185;
    margin-left: var(--space-2);
    vertical-align: middle;
}

/* Amazon orange buy button */
.amazon-buy-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    width: 100%;
    background: linear-gradient(to bottom, #f7dfa5, #f0c14b);
    border: 1px solid #a88734;
    border-radius: 8px;
    color: #111 !important;
    padding: 10px var(--space-4);
    font-family: var(--font-ui);
    font-weight: 600;
    font-size: var(--text-base);
    text-decoration: none !important;
    cursor: pointer;
    transition: all var(--transition-fast);
}

.amazon-buy-btn:hover,
.amazon-buy-btn:focus {
    background: linear-gradient(to bottom, #f5d78e, #eeb933);
    color: #111 !important;
    text-decoration: none !important;
    box-shadow: 0 2px 5px rgba(17, 17, 17, 0.15);
}

.amazon-buy-btn .amazon-smile {
    flex-shrink: 0;
}

.amazon-card-formats {
    font-family: var(--font-ui);
    font-size: var(--text-sm);
    color: #565959;
    margin: var(--space-3) 0 0;
    text-align: center;
}

.amazon-card-disclosure {
    font-size: 11px;
    color: #999;
    margin: var(--space-3) 0 0;
    line-height: 1.4;
    text-align: center;
}

/* Book Data Card (inline in content) */
.book-data-card {
    background: var(--color-ivory);
    border: 1px solid rgba(0, 0, 0, 0.08);
    border-left: 4px solid var(--color-gold);
    border-radius: var(--radius-md);
    padding: var(--space-8);
    margin: var(--space-8) 0;
    font-family: var(--font-ui);
}

.book-data-card p {
    font-family: var(--font-ui);
    font-size: var(--text-sm);
    line-height: 1.6;
    margin-bottom: var(--space-1);
}

.book-data-card > p > strong:only-child,
.book-data-card > strong {
    color: var(--color-graphite);
    font-size: var(--text-sm);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    display: block;
    margin-top: var(--space-6);
    margin-bottom: var(--space-2);
    padding-bottom: var(--space-2);
    border-bottom: 1px solid var(--color-gold);
}

.book-data-card > p:first-child > strong:only-child,
.book-data-card > strong:first-child {
    margin-top: 0;
}

.book-data-card ul {
    list-style: none;
    padding: 0;
    margin: 0 0 var(--space-2) 0;
}

.book-data-card li {
    font-size: var(--text-sm);
    color: var(--color-graphite);
    padding: var(--space-2) 0;
    border-bottom: 1px solid rgba(0, 0, 0, 0.04);
    line-height: 1.6;
}

.book-data-card li:last-child {
    border-bottom: none;
}

.book-data-card li strong {
    display: inline;
    text-transform: none;
    letter-spacing: normal;
    margin: 0;
    padding: 0;
    border: none;
    font-size: inherit;
}

/* Book Review CTA (inline in content) */
.book-review-cta {
    text-align: center;
    margin: var(--space-8) 0 var(--space-4);
}

.affiliate-button {
    display: inline-block;
    background: var(--color-crimson);
    color: #fff !important;
    padding: var(--space-4) var(--space-8);
    border-radius: var(--radius-md);
    font-family: var(--font-ui);
    font-weight: 700;
    font-size: var(--text-lg);
    text-decoration: none !important;
    transition: all var(--transition-base);
    box-shadow: var(--shadow-md);
}

.affiliate-button:hover,
.affiliate-button:focus {
    background: #a00e1a;
    color: #fff !important;
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
    text-decoration: none !important;
}

/* Who Should Read This — Table Styling */
.post-content table {
    width: 100%;
    border-collapse: collapse;
    margin: var(--space-6) 0;
    font-family: var(--font-ui);
    font-size: var(--text-sm);
}

.post-content table thead th {
    background: var(--color-graphite);
    color: #fff;
    padding: var(--space-3) var(--space-4);
    text-align: left;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    font-size: var(--text-xs);
}

.post-content table tbody td {
    padding: var(--space-3) var(--space-4);
    border-bottom: 1px solid rgba(0, 0, 0, 0.08);
    vertical-align: top;
    line-height: 1.5;
}

.post-content table tbody tr:nth-child(even) {
    background: rgba(0, 0, 0, 0.02);
}

.post-content table tbody tr:hover {
    background: rgba(215, 178, 90, 0.08);
}

/* Mobile adjustments for book reviews */
@media (max-width: 768px) {
    .book-review-widget {
        position: static;
        margin-bottom: var(--space-6);
    }

    .book-data-card {
        padding: var(--space-4);
    }

    .post-content table {
        display: block;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    .affiliate-button {
        display: block;
        text-align: center;
    }
}

/* ============================================
   READING TIME & TOPIC TAGS
   ============================================ */

.reading-time {
    font-family: var(--font-ui);
    font-size: var(--text-xs);
    color: var(--color-graphite);
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.post-topic-tags {
    display: inline;
}

.topic-tag {
    font-family: var(--font-ui);
    font-size: var(--text-xs);
    color: var(--color-blood-red);
    text-decoration: none;
    letter-spacing: 0.02em;
    transition: color var(--transition-fast);
    margin-right: var(--space-1);
}

.topic-tag:hover {
    color: var(--color-ink);
    text-decoration: underline;
}

/* ============================================
   PREV/NEXT POST NAVIGATION
   ============================================ */

.post-navigation {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-6);
    margin-bottom: var(--space-10);
    padding-bottom: var(--space-8);
    border-bottom: 1px solid rgba(0, 0, 0, 0.08);
}

.post-nav-link {
    display: block;
    padding: var(--space-5) var(--space-6);
    background: var(--color-parchment);
    border: 1px solid rgba(0, 0, 0, 0.06);
    border-radius: 6px;
    text-decoration: none;
    transition: all var(--transition-base);
}

.post-nav-link:hover {
    border-color: var(--color-blood-red);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
    transform: translateY(-1px);
}

.post-nav-prev {
    text-align: left;
}

.post-nav-next {
    text-align: right;
    grid-column: 2;
}

/* When only one link exists */
.post-nav-next:first-child {
    grid-column: 2;
}

.post-nav-label {
    display: block;
    font-family: var(--font-ui);
    font-size: var(--text-xs);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-graphite);
    margin-bottom: var(--space-2);
}

.post-nav-title {
    display: block;
    font-family: var(--font-heading);
    font-size: var(--text-base);
    font-weight: 600;
    color: var(--color-ink);
    line-height: 1.4;
}

.post-nav-link:hover .post-nav-title {
    color: var(--color-blood-red);
}

@media (max-width: 768px) {
    .post-navigation {
        grid-template-columns: 1fr;
        gap: var(--space-4);
    }

    .post-nav-next {
        text-align: left;
        grid-column: 1;
    }

    .post-nav-next:first-child {
        grid-column: 1;
    }

    .post-meta-top {
        flex-wrap: wrap;
    }
}

/* ========================================================================
   BIBLE DEEP DIVES - Landing Page & Book Gallery
   ======================================================================== */

/* --- Landing Page Hero --- */

.bdd-hero {
    background-color: var(--color-graphite);
    color: #fff;
    padding: var(--space-16) 0;
    text-align: center;
}

.bdd-hero-content {
    max-width: 720px;
    margin: 0 auto;
}

.bdd-hero-label {
    display: inline-block;
    font-family: var(--font-ui);
    font-size: var(--text-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-gold);
    margin-bottom: var(--space-4);
}

.bdd-hero-title {
    font-family: var(--font-display);
    font-size: var(--text-5xl);
    font-weight: 700;
    line-height: 1.1;
    margin: 0 0 var(--space-6);
    color: #fff;
}

.bdd-hero-subtitle {
    font-family: var(--font-body);
    font-size: var(--text-lg);
    line-height: 1.7;
    color: #D1D5DB;
    margin: 0 0 var(--space-8);
}

.bdd-hero-stats {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: var(--space-6);
    flex-wrap: wrap;
}

.bdd-stat {
    display: flex;
    flex-direction: column;
    align-items: center;
}

.bdd-stat-number {
    font-family: var(--font-display);
    font-size: var(--text-4xl);
    font-weight: 700;
    color: var(--color-gold);
    line-height: 1;
}

.bdd-stat-label {
    font-family: var(--font-ui);
    font-size: var(--text-sm);
    color: #9CA3AF;
    margin-top: var(--space-1);
}

.bdd-stat-divider {
    width: 1px;
    height: 40px;
    background: #374151;
}

/* --- Books Library --- */

.bdd-library {
    padding: var(--space-16) 0;
}

.bdd-testament-section {
    margin-bottom: var(--space-12);
}

.bdd-testament-title {
    font-family: var(--font-display);
    font-size: var(--text-2xl);
    font-weight: 700;
    color: var(--color-graphite);
    margin: 0 0 var(--space-6);
    padding-bottom: var(--space-3);
    border-bottom: 2px solid var(--color-gold);
}

.bdd-books-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: var(--space-6);
}

.bdd-book-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-6);
    background: #fff;
    border: 1px solid #E5E7EB;
    border-radius: var(--radius-md);
    text-decoration: none;
    color: inherit;
    transition: all var(--transition-base);
}

.bdd-book-card:hover {
    border-color: var(--color-gold);
    box-shadow: var(--shadow-md);
    transform: translateY(-2px);
}

.bdd-book-card-body {
    flex: 1;
    min-width: 0;
}

.bdd-book-name {
    font-family: var(--font-display);
    font-size: var(--text-xl);
    font-weight: 700;
    margin: 0 0 var(--space-2);
    color: var(--color-graphite);
}

.bdd-book-meta {
    font-family: var(--font-ui);
    font-size: var(--text-sm);
    color: var(--color-slate);
    margin-bottom: var(--space-3);
}

.bdd-book-progress {
    height: 4px;
    background: #E5E7EB;
    border-radius: 2px;
    overflow: hidden;
}

.bdd-book-progress-bar {
    height: 100%;
    background: var(--color-gold);
    border-radius: 2px;
    transition: width var(--transition-slow);
}

.bdd-book-arrow {
    font-size: var(--text-xl);
    color: var(--color-slate);
    margin-left: var(--space-4);
    flex-shrink: 0;
    transition: transform var(--transition-fast);
}

.bdd-book-card:hover .bdd-book-arrow {
    transform: translateX(4px);
    color: var(--color-gold);
}

/* --- Empty State --- */

.bdd-empty-state {
    text-align: center;
    padding: var(--space-16) 0;
}

.bdd-empty-state h2 {
    font-family: var(--font-display);
    margin-bottom: var(--space-4);
}

.bdd-empty-state p {
    color: var(--color-slate);
    max-width: 480px;
    margin: 0 auto;
}

/* --- How It Works --- */

.bdd-how-it-works {
    padding: var(--space-12) 0;
    background: #FAFAF8;
    border-bottom: 1px solid #E5E7EB;
}

.bdd-section-title {
    font-family: var(--font-display);
    font-size: var(--text-2xl);
    font-weight: 700;
    color: var(--color-graphite);
    text-align: center;
    margin: 0 0 var(--space-10);
}

.bdd-hiw-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-8);
    max-width: 900px;
    margin: 0 auto;
}

.bdd-hiw-step {
    text-align: center;
}

.bdd-hiw-number {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: var(--color-gold);
    color: var(--color-graphite);
    font-family: var(--font-ui);
    font-size: var(--text-lg);
    font-weight: 700;
    margin-bottom: var(--space-4);
}

.bdd-hiw-step h3 {
    font-family: var(--font-display);
    font-size: var(--text-lg);
    font-weight: 700;
    color: var(--color-graphite);
    margin: 0 0 var(--space-3);
}

.bdd-hiw-step p {
    font-size: var(--text-sm);
    color: var(--color-slate);
    line-height: 1.7;
    margin: 0;
}

@media (max-width: 768px) {
    .bdd-hiw-grid {
        grid-template-columns: 1fr;
        gap: var(--space-6);
    }
}

/* --- Featured Book --- */

.bdd-featured-book {
    margin-bottom: var(--space-12);
}

.bdd-featured-header {
    margin-bottom: var(--space-8);
    padding-bottom: var(--space-6);
    border-bottom: 2px solid var(--color-gold);
}

.bdd-testament-label {
    display: inline-block;
    font-family: var(--font-ui);
    font-size: var(--text-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-gold);
    margin-bottom: var(--space-2);
}

.bdd-featured-book-title {
    font-family: var(--font-display);
    font-size: var(--text-4xl);
    font-weight: 700;
    color: var(--color-graphite);
    margin: 0 0 var(--space-3);
}

.bdd-featured-description {
    font-size: var(--text-lg);
    color: var(--color-slate);
    line-height: 1.7;
    margin: 0 0 var(--space-4);
    max-width: 600px;
}

.bdd-featured-stats {
    font-family: var(--font-ui);
    font-size: var(--text-sm);
    color: var(--color-slate);
    margin-bottom: var(--space-4);
}

.bdd-featured-progress {
    max-width: 300px;
}

/* --- Chapter Section --- */

.bdd-chapter-section {
    margin-bottom: var(--space-10);
}

.bdd-chapter-heading {
    font-family: var(--font-ui);
    font-size: var(--text-sm);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-gold);
    margin: 0 0 var(--space-6);
}

/* --- Pillar Card (Landing Page) --- */

.bdd-pillar-card {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
    background: #fff;
    border: 1px solid #E5E7EB;
    border-radius: var(--radius-md);
    overflow: hidden;
    margin-bottom: var(--space-6);
    transition: box-shadow var(--transition-base);
}

.bdd-pillar-card:hover {
    box-shadow: var(--shadow-lg);
}

.bdd-pillar-image {
    position: relative;
    aspect-ratio: 16 / 10;
    overflow: hidden;
}

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

.bdd-pillar-card:hover .bdd-pillar-image img {
    transform: scale(1.03);
}

.bdd-premium-badge {
    position: absolute;
    top: var(--space-3);
    right: var(--space-3);
    font-family: var(--font-ui);
    font-size: var(--text-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: var(--space-1) var(--space-3);
    background: var(--color-graphite);
    color: var(--color-gold);
    border-radius: var(--radius-sm);
}

.bdd-pillar-body {
    padding: var(--space-8);
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.bdd-pillar-title {
    font-family: var(--font-display);
    font-size: var(--text-2xl);
    font-weight: 700;
    line-height: 1.3;
    margin: 0 0 var(--space-3);
}

.bdd-pillar-title a {
    color: var(--color-graphite);
    text-decoration: none;
}

.bdd-pillar-title a:hover {
    color: var(--color-crimson);
}

.bdd-pillar-excerpt {
    color: var(--color-slate);
    line-height: 1.7;
    margin: 0 0 var(--space-4);
}

.bdd-pillar-meta {
    font-family: var(--font-ui);
    font-size: var(--text-sm);
    color: var(--color-slate);
    margin-bottom: var(--space-4);
}

.bdd-read-btn {
    display: inline-block;
    font-family: var(--font-ui);
    font-size: var(--text-sm);
    font-weight: 600;
    text-decoration: none;
    padding: var(--space-3) var(--space-6);
    border-radius: var(--radius-sm);
    transition: all var(--transition-fast);
}

.bdd-read-premium {
    background: var(--color-crimson);
    color: #fff;
}

.bdd-read-premium:hover {
    background: #a30f1a;
    color: #fff;
}

@media (max-width: 768px) {
    .bdd-pillar-card {
        grid-template-columns: 1fr;
    }

    .bdd-pillar-image {
        aspect-ratio: 16 / 9;
    }
}

/* --- Satellite Cards (Landing Page) --- */

.bdd-satellites-section {
    margin-top: var(--space-4);
}

.bdd-satellites-label {
    font-family: var(--font-ui);
    font-size: var(--text-sm);
    font-weight: 600;
    color: var(--color-slate);
    margin: 0 0 var(--space-4);
}

.bdd-satellites-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-4);
}

.bdd-satellite-card {
    display: block;
    background: #fff;
    border: 1px solid #E5E7EB;
    border-radius: var(--radius-md);
    padding: var(--space-5);
    text-decoration: none;
    color: inherit;
    transition: all var(--transition-base);
}

.bdd-satellite-card:hover {
    border-color: var(--color-gold);
    box-shadow: var(--shadow-md);
    transform: translateY(-2px);
}

.bdd-satellite-top {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--space-3);
}

.bdd-free-badge {
    font-family: var(--font-ui);
    font-size: var(--text-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: var(--space-1) var(--space-2);
    background: #ECFDF5;
    color: #065F46;
    border-radius: var(--radius-sm);
}

.bdd-satellite-title {
    font-family: var(--font-display);
    font-size: var(--text-base);
    font-weight: 700;
    line-height: 1.3;
    margin: 0 0 var(--space-2);
    color: var(--color-graphite);
}

.bdd-satellite-excerpt {
    font-size: var(--text-sm);
    color: var(--color-slate);
    line-height: 1.6;
    margin: 0 0 var(--space-3);
}

.bdd-satellite-meta {
    font-family: var(--font-ui);
    font-size: var(--text-xs);
    color: var(--color-crimson);
    font-weight: 600;
}

@media (max-width: 768px) {
    .bdd-satellites-grid {
        grid-template-columns: 1fr;
    }
}

/* --- Book CTA --- */

.bdd-book-cta {
    text-align: center;
    margin-top: var(--space-8);
    padding-top: var(--space-6);
    border-top: 1px solid #E5E7EB;
}

.bdd-view-all-btn {
    display: inline-block;
    font-family: var(--font-ui);
    font-size: var(--text-sm);
    font-weight: 600;
    color: var(--color-crimson);
    text-decoration: none;
    padding: var(--space-3) var(--space-6);
    border: 1px solid var(--color-crimson);
    border-radius: var(--radius-sm);
    transition: all var(--transition-fast);
}

.bdd-view-all-btn:hover {
    background: var(--color-crimson);
    color: #fff;
}

/* --- Subscribe CTA --- */

.bdd-subscribe-cta {
    background: var(--color-graphite);
    color: #fff;
    padding: var(--space-16) 0;
    text-align: center;
}

.bdd-subscribe-cta h2 {
    font-family: var(--font-display);
    color: #fff;
    margin: 0 0 var(--space-4);
}

.bdd-subscribe-cta p {
    color: #D1D5DB;
    margin-bottom: var(--space-6);
}

.bdd-subscribe-cta .form-privacy {
    color: #6B7280;
    font-size: var(--text-sm);
    margin-top: var(--space-3);
}

/* --- Breadcrumb --- */

.bdd-breadcrumb {
    padding: var(--space-4) 0;
    font-family: var(--font-ui);
    font-size: var(--text-sm);
    color: var(--color-slate);
}

.bdd-breadcrumb a {
    color: var(--color-sky);
    text-decoration: none;
}

.bdd-breadcrumb a:hover {
    text-decoration: underline;
}

.bdd-breadcrumb-sep {
    margin: 0 var(--space-2);
    color: var(--color-slate);
}

/* --- Book Gallery Header --- */

.bbg-header {
    background: var(--color-graphite);
    color: #fff;
    padding: var(--space-12) 0 var(--space-8);
    text-align: center;
}

.bbg-title {
    font-family: var(--font-display);
    font-size: var(--text-4xl);
    font-weight: 700;
    color: #fff;
    margin: 0 0 var(--space-4);
}

.bbg-description {
    font-size: var(--text-lg);
    color: #D1D5DB;
    max-width: 600px;
    margin: 0 auto var(--space-6);
    line-height: 1.7;
}

.bbg-stats {
    font-family: var(--font-ui);
    font-size: var(--text-sm);
    color: #9CA3AF;
    margin-bottom: var(--space-6);
}

.bbg-progress {
    max-width: 400px;
    height: 6px;
    background: #374151;
    border-radius: 3px;
    margin: 0 auto;
    overflow: hidden;
}

.bbg-progress-bar {
    height: 100%;
    background: var(--color-gold);
    border-radius: 3px;
    transition: width var(--transition-slow);
}

/* --- Chapter Groups --- */

.bbg-chapters {
    padding: var(--space-12) 0;
}

.bbg-chapter-group {
    margin-bottom: var(--space-8);
}

.bbg-chapter-label {
    font-family: var(--font-ui);
    font-size: var(--text-sm);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-gold);
    margin: 0 0 var(--space-6);
}

.bbg-chapter-divider {
    height: 1px;
    background: linear-gradient(to right, transparent, var(--color-gold), transparent);
    margin: var(--space-12) 0;
}

/* --- Pillar Card --- */

.bbg-pillar-card {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-6);
    background: #fff;
    border: 1px solid #E5E7EB;
    border-radius: var(--radius-md);
    overflow: hidden;
    margin-bottom: var(--space-6);
    transition: box-shadow var(--transition-base);
}

.bbg-pillar-card:hover {
    box-shadow: var(--shadow-lg);
}

.bbg-pillar-image {
    aspect-ratio: 16 / 9;
    overflow: hidden;
}

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

.bbg-pillar-card:hover .bbg-pillar-image img {
    transform: scale(1.03);
}

.bbg-pillar-content {
    padding: var(--space-6);
}

.bbg-role-badge {
    display: inline-block;
    font-family: var(--font-ui);
    font-size: var(--text-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: var(--space-1) var(--space-3);
    border-radius: var(--radius-sm);
    margin-bottom: var(--space-3);
}

.bbg-role-pillar {
    background: var(--color-gold);
    color: var(--color-graphite);
}

.bbg-pillar-title {
    font-family: var(--font-display);
    font-size: var(--text-2xl);
    font-weight: 700;
    line-height: 1.3;
    margin: 0 0 var(--space-3);
}

.bbg-pillar-title a {
    color: var(--color-graphite);
    text-decoration: none;
}

.bbg-pillar-title a:hover {
    color: var(--color-crimson);
}

.bbg-pillar-excerpt {
    color: var(--color-slate);
    line-height: 1.7;
    margin: 0 0 var(--space-4);
}

.bbg-pillar-meta {
    font-family: var(--font-ui);
    font-size: var(--text-sm);
    color: var(--color-slate);
    margin-bottom: var(--space-4);
}

.bbg-pillar-cta {
    display: inline-block;
    font-family: var(--font-ui);
    font-size: var(--text-sm);
    font-weight: 600;
    color: var(--color-crimson);
    text-decoration: none;
    transition: color var(--transition-fast);
}

.bbg-pillar-cta:hover {
    color: var(--color-graphite);
}

/* --- Satellite Cards --- */

.bbg-satellites-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-4);
}

.bbg-satellite-card {
    background: #fff;
    border: 1px solid #E5E7EB;
    border-radius: var(--radius-md);
    padding: var(--space-6);
    transition: all var(--transition-base);
}

.bbg-satellite-card:hover {
    border-color: var(--color-gold);
    box-shadow: var(--shadow-md);
    transform: translateY(-2px);
}

.bbg-satellite-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--space-3);
}

.bbg-type-badge {
    display: inline-block;
    font-family: var(--font-ui);
    font-size: var(--text-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: var(--space-1) var(--space-3);
    border-radius: var(--radius-sm);
}

.bbg-type-greek_vocabulary {
    background: #EEF2FF;
    color: #4338CA;
}

.bbg-type-historical_context {
    background: #FEF3C7;
    color: #92400E;
}

.bbg-type-theology {
    background: #F0FDF4;
    color: #166534;
}

.bbg-type-application {
    background: #FFF1F2;
    color: #9F1239;
}

.bbg-type-cross_references {
    background: #F0F9FF;
    color: #075985;
}

.bbg-satellite-time {
    font-family: var(--font-ui);
    font-size: var(--text-xs);
    color: var(--color-slate);
}

.bbg-satellite-title {
    font-family: var(--font-display);
    font-size: var(--text-lg);
    font-weight: 700;
    margin: 0 0 var(--space-2);
    line-height: 1.3;
}

.bbg-satellite-title a {
    color: var(--color-graphite);
    text-decoration: none;
}

.bbg-satellite-title a:hover {
    color: var(--color-crimson);
}

.bbg-satellite-excerpt {
    font-size: var(--text-sm);
    color: var(--color-slate);
    line-height: 1.6;
    margin: 0 0 var(--space-3);
}

/* --- Chapter Navigation Sidebar Widget --- */

.chapter-nav-widget {
    border: 1px solid #E5E7EB;
    border-radius: var(--radius-md);
    padding: var(--space-6) !important;
    background: #F9FAFB !important;
}

.chapter-nav-label {
    font-family: var(--font-ui);
    font-size: var(--text-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-slate);
    margin: 0 0 var(--space-3);
}

.chapter-nav-list {
    list-style: none;
    padding: 0;
    margin: 0 0 var(--space-4);
}

.chapter-nav-list li {
    display: flex;
    align-items: flex-start;
    gap: var(--space-2);
    margin-bottom: var(--space-3);
    line-height: 1.4;
}

.chapter-nav-type-dot {
    display: inline-block;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    margin-top: 6px;
    flex-shrink: 0;
}

.chapter-nav-dot-greek_vocabulary { background: #4338CA; }
.chapter-nav-dot-historical_context { background: #92400E; }
.chapter-nav-dot-theology { background: #166534; }
.chapter-nav-dot-application { background: #9F1239; }
.chapter-nav-dot-cross_references { background: #075985; }

.chapter-nav-list a {
    font-size: var(--text-sm);
    color: var(--color-graphite);
    text-decoration: none;
    line-height: 1.4;
}

.chapter-nav-list a:hover {
    color: var(--color-crimson);
}

.chapter-nav-type {
    display: block;
    font-family: var(--font-ui);
    font-size: var(--text-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    color: var(--color-slate);
}

.chapter-nav-pillar-link {
    display: block;
    font-family: var(--font-display);
    font-size: var(--text-base);
    font-weight: 600;
    color: var(--color-crimson);
    text-decoration: none;
    margin-bottom: var(--space-4);
    line-height: 1.4;
}

.chapter-nav-pillar-link:hover {
    color: var(--color-graphite);
}

.chapter-nav-book-link {
    display: block;
    font-family: var(--font-ui);
    font-size: var(--text-sm);
    font-weight: 600;
    color: var(--color-sky);
    text-decoration: none;
    padding-top: var(--space-4);
    border-top: 1px solid #E5E7EB;
}

.chapter-nav-book-link:hover {
    text-decoration: underline;
}

/* --- Responsive: Tablet (768px+) --- */

@media (min-width: 768px) {
    .bdd-hero {
        padding: var(--space-16) 0 var(--space-12);
    }

    .bbg-pillar-card {
        grid-template-columns: 1fr 1fr;
    }

    .bbg-pillar-image {
        aspect-ratio: auto;
    }

    .bbg-satellites-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* --- Responsive: Desktop (1024px+) --- */

@media (min-width: 1024px) {
    .bdd-hero-title {
        font-size: 3.5rem;
    }

    .bbg-title {
        font-size: var(--text-5xl);
    }

    .bbg-pillar-title {
        font-size: var(--text-3xl);
    }

    .bbg-satellites-grid {
        grid-template-columns: repeat(3, 1fr);
    }

    .chapter-nav-widget {
        background: transparent !important;
        border: none;
        padding: 0 0 var(--space-6) 0 !important;
    }
}

/* ========================================================================
   DEEP DIVE PREMIUM FEATURES
   Sticky TOC, Tooltips, Pull Quotes, Takeaway Boxes, Footnotes,
   Audio Player, Font Controls, Reading Position Resume
   ======================================================================== */

/* --- Deep Dive Layout: 3-column with sticky TOC --- */

.deep-dive-layout {
    position: relative;
}

@media (min-width: 1200px) {
    .deep-dive-layout {
        display: grid !important;
        margin: 0 auto !important;
        padding: 0 var(--space-6) !important;
    }

    .deep-dive-layout .deep-dive-toc {
        order: -1;
    }

    .deep-dive-layout .post-content {
        order: 0;
        max-width: none !important;
        padding: 0 2rem !important;
    }

    .deep-dive-layout .post-sidebar {
        order: 1;
    }
}

/* --- Sticky Table of Contents --- */

.deep-dive-toc {
    display: none; /* Shown by JS when enough headings exist */
}

@media (min-width: 1200px) {
    .deep-dive-toc {
        position: sticky;
        top: 80px;
        max-height: calc(100vh - 120px);
        overflow-y: auto;
        padding: var(--space-4) 0;
        scrollbar-width: thin;
        scrollbar-color: rgba(0,0,0,0.15) transparent;
    }

    .deep-dive-toc::-webkit-scrollbar {
        width: 3px;
    }

    .deep-dive-toc::-webkit-scrollbar-thumb {
        background: rgba(0,0,0,0.15);
        border-radius: 3px;
    }
}

.toc-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--space-4);
    padding-bottom: var(--space-3);
    border-bottom: 1px solid rgba(0,0,0,0.08);
}

.toc-title {
    font-family: var(--font-ui);
    font-size: var(--text-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-slate);
    margin: 0;
}

.toc-collapse-btn {
    background: none;
    border: none;
    cursor: pointer;
    padding: 2px;
    color: var(--color-slate);
    transition: transform var(--transition-fast);
}

.toc-collapsed .toc-collapse-btn svg {
    transform: rotate(180deg);
}

.toc-collapsed .toc-list {
    display: none;
}

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

.toc-item {
    margin-bottom: 2px;
}

.toc-item-sub {
    padding-left: var(--space-4);
}

.toc-link {
    display: block;
    font-family: var(--font-ui);
    font-size: 12px;
    line-height: 1.4;
    color: var(--color-slate);
    text-decoration: none;
    padding: 4px 8px;
    border-left: 2px solid transparent;
    border-radius: 0 3px 3px 0;
    transition: all var(--transition-fast);
}

.toc-link:hover {
    color: var(--color-graphite);
    background: rgba(0,0,0,0.03);
}

.toc-link.toc-active {
    color: var(--color-crimson);
    border-left-color: var(--color-crimson);
    font-weight: 600;
    background: rgba(193, 18, 31, 0.04);
}

.toc-progress {
    margin-top: var(--space-4);
    height: 2px;
    background: rgba(0,0,0,0.06);
    border-radius: 1px;
    overflow: hidden;
}

.toc-progress-bar {
    height: 100%;
    background: var(--color-gold);
    width: 0%;
    transition: width 0.15s ease-out;
    border-radius: 1px;
}

/* --- Mobile TOC Button --- */

.toc-mobile-btn {
    display: none;
}

@media (max-width: 1199px) {
    .toc-mobile-btn {
        display: flex;
        align-items: center;
        justify-content: center;
        position: fixed;
        bottom: 24px;
        left: 24px;
        width: 48px;
        height: 48px;
        background: var(--color-graphite);
        color: #fff;
        border: none;
        border-radius: 50%;
        box-shadow: 0 4px 12px rgba(0,0,0,0.25);
        cursor: pointer;
        z-index: 999;
        transition: transform var(--transition-fast), background var(--transition-fast);
    }

    .toc-mobile-btn:hover {
        transform: scale(1.1);
        background: var(--color-crimson);
    }
}

.toc-mobile-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.5);
    z-index: 10000;
    display: flex;
    align-items: flex-end;
    justify-content: center;
}

.toc-mobile-panel {
    background: #fff;
    width: 100%;
    max-width: 500px;
    max-height: 70vh;
    border-radius: 16px 16px 0 0;
    padding: var(--space-6);
    overflow-y: auto;
}

.toc-mobile-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--space-4);
    padding-bottom: var(--space-3);
    border-bottom: 1px solid rgba(0,0,0,0.08);
}

.toc-mobile-header h4 {
    font-family: var(--font-display);
    font-size: var(--text-lg);
    font-weight: 700;
    margin: 0;
    color: var(--color-graphite);
}

.toc-mobile-close {
    background: none;
    border: none;
    font-size: 24px;
    color: var(--color-slate);
    cursor: pointer;
    padding: 0 4px;
}

.toc-mobile-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.toc-mobile-list .toc-item {
    margin-bottom: 4px;
}

.toc-mobile-list .toc-link {
    font-size: var(--text-sm);
    padding: 10px 12px;
    border-radius: 6px;
}

.toc-mobile-list .toc-link:hover,
.toc-mobile-list .toc-link.toc-active {
    background: rgba(0,0,0,0.04);
}

/* --- Greek/Hebrew Hover Tooltips --- */

.lang-term {
    position: relative;
    display: inline;
    cursor: help;
    border-bottom: 1px dotted currentColor;
    padding-bottom: 1px;
}

.lang-greek {
    color: #4338CA;
}

.lang-hebrew {
    color: #7C2D12;
}

.lang-tooltip {
    display: none;
    position: absolute;
    bottom: calc(100% + 8px);
    left: 50%;
    transform: translateX(-50%);
    width: 260px;
    padding: var(--space-4);
    background: var(--color-graphite);
    color: #F9FAFB;
    border-radius: var(--radius-md);
    font-style: normal;
    font-size: var(--text-sm);
    line-height: 1.5;
    box-shadow: 0 8px 24px rgba(0,0,0,0.3);
    z-index: 1000;
    pointer-events: none;
}

.lang-tooltip::after {
    content: '';
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    border: 6px solid transparent;
    border-top-color: var(--color-graphite);
}

.lang-term:hover .lang-tooltip,
.lang-term:focus .lang-tooltip {
    display: block;
}

.lang-tooltip-label {
    display: block;
    font-family: var(--font-ui);
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-gold);
    margin-bottom: var(--space-2);
}

.lang-tooltip-word {
    display: block;
    font-size: var(--text-lg);
    font-weight: 700;
    margin-bottom: 2px;
}

.lang-tooltip-translit {
    display: block;
    font-size: var(--text-sm);
    color: #D1D5DB;
    margin-bottom: var(--space-2);
}

.lang-tooltip-parsing {
    display: block;
    font-size: var(--text-xs);
    color: #9CA3AF;
    margin-bottom: var(--space-2);
}

.lang-tooltip-meaning {
    display: block;
    font-size: var(--text-sm);
    color: #F3F4F6;
    padding-top: var(--space-2);
    border-top: 1px solid #374151;
}

.lang-tooltip-strongs {
    display: block;
    font-size: var(--text-xs);
    color: #6B7280;
    margin-top: var(--space-2);
}

/* --- Pull Quotes --- */

.pullquote {
    position: relative;
    margin: var(--space-10) auto;
    padding: var(--space-8) var(--space-8) var(--space-6);
    max-width: 600px;
    text-align: center;
    border-top: 2px solid var(--color-gold);
    border-bottom: 2px solid var(--color-gold);
}

.pullquote-mark {
    font-family: var(--font-display);
    font-size: 4rem;
    line-height: 1;
    color: var(--color-gold);
    opacity: 0.4;
    position: absolute;
    top: -8px;
    left: 50%;
    transform: translateX(-50%);
    background: #fff;
    padding: 0 var(--space-3);
}

.pullquote-text {
    font-family: var(--font-display);
    font-size: var(--text-xl);
    font-weight: 600;
    line-height: 1.5;
    color: var(--color-graphite);
    font-style: italic;
    margin: 0;
    padding: 0;
    border: none;
    background: none;
}

.pullquote-attribution {
    display: block;
    font-family: var(--font-ui);
    font-size: var(--text-sm);
    font-style: normal;
    color: var(--color-slate);
    margin-top: var(--space-4);
}

/* --- Key Takeaway Boxes --- */

.key-takeaway {
    margin: var(--space-8) 0;
    background: linear-gradient(135deg, #FFFBEB, #FEF3C7);
    border: 1px solid #FCD34D;
    border-left: 4px solid var(--color-gold);
    border-radius: 0 var(--radius-md) var(--radius-md) 0;
    overflow: hidden;
}

.key-takeaway-header {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-4) var(--space-6);
    border-bottom: 1px solid rgba(252, 211, 77, 0.4);
}

.key-takeaway-icon {
    color: var(--color-gold);
    font-size: var(--text-sm);
}

.key-takeaway-title {
    font-family: var(--font-ui);
    font-size: var(--text-sm);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #92400E;
}

.key-takeaway-body {
    padding: var(--space-4) var(--space-6);
}

.key-takeaway-body p {
    font-size: var(--text-base) !important;
    color: #78350F;
    line-height: 1.7;
    margin-bottom: var(--space-2);
}

.key-takeaway-body p:last-child {
    margin-bottom: 0;
}

/* --- Enhanced Scripture Blockquotes (Deep Dives) --- */

.deep-dive-article .post-content blockquote {
    position: relative;
    margin: var(--space-8) 0;
    padding: var(--space-6) var(--space-8);
    background: #FAF8F5;
    border: none;
    border-left: 3px solid var(--color-gold);
    border-radius: 0 var(--radius-md) var(--radius-md) 0;
    font-style: italic;
}

.deep-dive-article .post-content blockquote p {
    font-family: var(--font-heading);
    font-size: var(--text-lg) !important;
    line-height: 1.7 !important;
    color: var(--color-graphite);
}

.deep-dive-article .post-content blockquote p:last-child {
    margin-bottom: 0;
}

/* --- Footnote Superscripts --- */

.footnote-inline {
    position: relative;
    display: inline;
}

.footnote-sup {
    font-size: 0.65em;
    font-weight: 600;
    color: var(--color-crimson);
    cursor: help;
    vertical-align: super;
    line-height: 0;
    margin-left: 1px;
}

/* Expandable footnote text (hidden by default) */
.footnote-expand {
    display: none;
    font-size: var(--text-sm);
    font-style: normal;
    color: var(--color-text-light);
    line-height: 1.5;
    background: var(--color-warm-gray);
    border-left: 2px solid var(--color-crimson);
    padding: var(--space-2) var(--space-3);
    margin: var(--space-2) 0;
    border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
}

/* Tapped/active state: show inline expansion */
.footnote-inline.footnote-active .footnote-expand {
    display: block;
}

/* On touch devices, tap to toggle */
@media (hover: none) {
    .footnote-sup {
        cursor: pointer;
        padding: 2px 4px;
    }
}

/* --- Article Toolbar --- */

.deep-dive-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: var(--space-3);
    margin-top: var(--space-6);
    padding: var(--space-4) 0;
    border-top: 1px solid rgba(0,0,0,0.08);
    border-bottom: 1px solid rgba(0,0,0,0.08);
}

.toolbar-left {
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.toolbar-reading-time {
    font-family: var(--font-ui);
    font-size: var(--text-sm);
    color: var(--color-slate);
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.toolbar-reading-time svg {
    flex-shrink: 0;
}

.toolbar-separator {
    color: #D1D5DB;
}

.toolbar-right {
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.toolbar-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    background: #F3F4F6;
    border: 1px solid #E5E7EB;
    border-radius: 6px;
    font-family: var(--font-ui);
    font-size: var(--text-xs);
    font-weight: 600;
    color: var(--color-graphite);
    cursor: pointer;
    text-decoration: none;
    transition: all var(--transition-fast);
    white-space: nowrap;
}

.toolbar-btn:hover {
    background: #E5E7EB;
    border-color: #D1D5DB;
}

.toolbar-btn.active {
    background: var(--color-crimson);
    color: #fff;
    border-color: var(--color-crimson);
}

.toolbar-font-controls {
    display: flex;
    gap: 2px;
}

.toolbar-font-btn {
    padding: 6px 8px;
    font-size: var(--text-xs);
    line-height: 1;
}

.font-btn-label {
    font-weight: 700;
}

.font-btn-minus,
.font-btn-plus {
    font-size: 10px;
    opacity: 0.7;
}

/* --- Audio Player --- */

.deep-dive-audio-player {
    position: sticky;
    top: 4px; /* Below reading progress bar */
    z-index: 9998;
    background: var(--color-graphite);
    color: #fff;
    padding: 10px var(--space-6);
    display: flex;
    align-items: center;
    box-shadow: 0 4px 12px rgba(0,0,0,0.2);
}

.audio-player-inner {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    width: 100%;
    max-width: 900px;
    margin: 0 auto;
}

.audio-play-btn {
    background: none;
    border: none;
    color: #fff;
    cursor: pointer;
    padding: 4px;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: rgba(255,255,255,0.1);
    transition: background var(--transition-fast);
}

.audio-play-btn:hover {
    background: rgba(255,255,255,0.2);
}

.audio-progress-wrap {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    flex: 1;
}

.audio-time {
    font-family: var(--font-ui);
    font-size: 11px;
    color: #9CA3AF;
    min-width: 36px;
    text-align: center;
    flex-shrink: 0;
}

.audio-progress-bar {
    flex: 1;
    height: 4px;
    background: #374151;
    border-radius: 2px;
    cursor: pointer;
    position: relative;
}

.audio-progress-fill {
    height: 100%;
    background: var(--color-gold);
    border-radius: 2px;
    width: 0%;
    transition: width 0.1s linear;
}

.audio-speed-btn {
    background: rgba(255,255,255,0.1);
    border: none;
    color: #D1D5DB;
    cursor: pointer;
    padding: 4px 8px;
    font-family: var(--font-ui);
    font-size: 11px;
    font-weight: 600;
    border-radius: 4px;
    transition: background var(--transition-fast);
    flex-shrink: 0;
}

.audio-speed-btn:hover {
    background: rgba(255,255,255,0.2);
    color: #fff;
}

.audio-close-btn {
    background: none;
    border: none;
    color: #6B7280;
    cursor: pointer;
    font-size: 20px;
    padding: 0 4px;
    flex-shrink: 0;
}

.audio-close-btn:hover {
    color: #fff;
}

/* --- Reading Position Resume Banner --- */

.reading-resume-banner {
    position: fixed;
    bottom: 24px;
    right: 24px;
    z-index: 9999;
    background: var(--color-graphite);
    color: #fff;
    border-radius: var(--radius-md);
    box-shadow: 0 8px 24px rgba(0,0,0,0.3);
    overflow: hidden;
    animation: slideUp 0.3s ease-out;
}

@keyframes slideUp {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
}

.resume-banner-inner {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-3) var(--space-4);
}

.resume-text {
    font-family: var(--font-ui);
    font-size: var(--text-sm);
    color: #D1D5DB;
    white-space: nowrap;
}

.resume-btn {
    border: none;
    cursor: pointer;
    font-family: var(--font-ui);
    font-size: var(--text-sm);
    font-weight: 600;
    border-radius: 4px;
    transition: background var(--transition-fast);
}

.resume-yes {
    background: var(--color-gold);
    color: var(--color-graphite);
    padding: 6px 14px;
    white-space: nowrap;
}

.resume-yes:hover {
    background: #D4A843;
}

.resume-dismiss {
    background: transparent;
    color: #6B7280;
    font-size: 18px;
    padding: 2px 6px;
}

.resume-dismiss:hover {
    color: #fff;
}

/* --- Responsive: Premium Features --- */

@media (max-width: 768px) {
    .deep-dive-toolbar {
        flex-direction: column;
        align-items: flex-start;
    }

    .toolbar-right {
        width: 100%;
        justify-content: flex-start;
        flex-wrap: wrap;
    }

    .lang-tooltip {
        width: 220px;
        left: 0;
        transform: none;
    }

    .lang-tooltip::after {
        left: 20px;
        transform: none;
    }

    .footnote-content {
        position: fixed;
        bottom: 0;
        left: 0;
        right: 0;
        top: auto;
        width: 100%;
        max-height: 50vh;
        border-radius: 16px 16px 0 0;
        padding: var(--space-6);
        overflow-y: auto;
    }

    .reading-resume-banner {
        left: 16px;
        right: 16px;
        bottom: 16px;
    }

    .deep-dive-audio-player {
        padding: 8px var(--space-4);
    }

    .audio-player-inner {
        gap: var(--space-2);
    }

    .audio-speed-btn {
        display: none;
    }

    .pullquote {
        margin: var(--space-8) 0;
        padding: var(--space-6) var(--space-4) var(--space-4);
    }

    .pullquote-text {
        font-size: var(--text-lg);
    }
}

/* =============================================
   Author Byline & Bio Box
   ============================================= */

.post-author-byline a {
    color: var(--color-slate);
    text-decoration: none;
    transition: color var(--transition-fast);
}

.post-author-byline a:hover {
    color: var(--color-crimson);
}

.author-bio-box {
    display: flex;
    gap: var(--space-5);
    align-items: flex-start;
    padding: var(--space-6);
    margin: var(--space-8) 0;
    background: var(--color-ivory);
    border-left: 3px solid var(--color-crimson);
    border-radius: 4px;
}

.author-bio-avatar img {
    border-radius: 50%;
    width: 80px;
    height: 80px;
    object-fit: cover;
    flex-shrink: 0;
}

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

.author-bio-name {
    font-family: var(--font-ui);
    font-size: var(--text-lg);
    margin: 0 0 var(--space-2) 0;
    color: var(--color-graphite);
}

.author-bio-name a {
    color: var(--color-graphite);
    text-decoration: none;
    transition: color var(--transition-fast);
}

.author-bio-name a:hover {
    color: var(--color-crimson);
}

.author-bio-text {
    font-family: var(--font-body);
    font-size: var(--text-sm);
    color: var(--color-slate);
    line-height: 1.6;
    margin: 0 0 var(--space-3) 0;
}

.author-bio-link {
    font-family: var(--font-ui);
    font-size: var(--text-sm);
    color: var(--color-crimson);
    text-decoration: none;
    font-weight: 500;
    transition: opacity var(--transition-fast);
}

.author-bio-link:hover {
    opacity: 0.8;
}

@media (max-width: 600px) {
    .author-bio-box {
        flex-direction: column;
        align-items: center;
        text-align: center;
        gap: var(--space-3);
        padding: var(--space-5);
    }
}
