/*
 * =========================================================
 * OLYTIC SOLUTIONS - Post / Article Base Styles
 * post.css
 *
 * Shared foundation for all Insights subpages.
 * Each post page imports this plus its own post-specific
 * stylesheet for any unique layout overrides.
 *
 * Covers:
 *   - Post header (breadcrumb, category, title, meta)
 *   - Post body typography (prose, pull quotes, callouts)
 *   - Two-column post layout with optional sidebar
 *   - Post footer CTA block
 *   - Back-link breadcrumb
 *
 * Requires: tokens.css, typography.css, layout.css
 * =========================================================
 */

/* ─── Post Header ────────────────────────────────────────── */

.post-header {
  padding-top: calc(var(--space-20) + var(--nav-height));
  padding-bottom: var(--space-16);
  background-color: var(--bg-white);
  border-bottom: var(--border-default);
}

.post-header__inner {
  max-width: 780px;
}

/* Breadcrumb */
.post-breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: var(--tracking-wide);
  margin-bottom: var(--space-6);
}

.post-breadcrumb__link {
  color: var(--color-muted);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.post-breadcrumb__link:hover {
  color: var(--color-teal);
}

.post-breadcrumb__sep {
  color: var(--color-muted);
  opacity: 0.5;
}

.post-breadcrumb__current {
  color: var(--color-body-steel);
}

/* Category tag */
.post-category {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  color: var(--color-teal);
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
  display: block;
  margin-bottom: var(--space-5);
}

/* Post title */
.post-title {
  font-size: var(--text-4xl);
  font-weight: var(--weight-bold);
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  color: var(--color-obsidian);
  margin-bottom: var(--space-6);
  max-width: 22ch;
}

/* Subtitle / dek */
.post-subtitle {
  font-size: var(--text-lg);
  color: var(--color-body-steel);
  line-height: var(--leading-snug);
  margin-bottom: var(--space-8);
  max-width: 54ch;
}

/* Meta row */
.post-meta {
  display: flex;
  align-items: center;
  gap: var(--space-5);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-muted);
  letter-spacing: var(--tracking-wide);
  flex-wrap: wrap;
}

.post-meta__sep {
  color: var(--color-gold);
  opacity: 0.7;
}

@media (max-width: 768px) {
  .post-header {
    padding-top: calc(var(--space-16) + var(--nav-height-mobile));
    padding-bottom: var(--space-10);
  }

  .post-title {
    font-size: var(--text-3xl);
  }
}

/* ─── Post Body - Prose ──────────────────────────────────── */

.post-body {
  padding-top: var(--space-16);
  padding-bottom: var(--space-16);
}

/* Default: narrow reading column */
.post-body__prose {
  max-width: 68ch;
}

.post-body__prose p {
  font-size: var(--text-md);
  color: var(--color-body-steel);
  line-height: var(--leading-body);
  margin-bottom: var(--space-6);
}

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

.post-body__prose h2 {
  font-size: var(--text-2xl);
  font-weight: var(--weight-bold);
  color: var(--color-obsidian);
  margin-top: var(--space-12);
  margin-bottom: var(--space-5);
  letter-spacing: var(--tracking-tight);
}

.post-body__prose h3 {
  font-size: var(--text-xl);
  font-weight: var(--weight-bold);
  color: var(--color-navy);
  margin-top: var(--space-10);
  margin-bottom: var(--space-4);
}

.post-body__prose h4 {
  font-size: var(--text-lg);
  font-weight: var(--weight-semibold);
  color: var(--color-navy);
  margin-top: var(--space-8);
  margin-bottom: var(--space-3);
}

.post-body__prose ul,
.post-body__prose ol {
  padding-left: var(--space-6);
  margin-bottom: var(--space-6);
}

.post-body__prose li {
  font-size: var(--text-md);
  color: var(--color-body-steel);
  line-height: var(--leading-body);
  margin-bottom: var(--space-2);
}

.post-body__prose strong {
  font-weight: var(--weight-semibold);
  color: var(--color-obsidian);
}

/* ─── Pull Quote ─────────────────────────────────────────── */

.pull-quote {
  border-left: var(--border-gold-thick);
  padding: var(--space-6) var(--space-8);
  margin: var(--space-10) 0;
  background-color: var(--color-surface);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
}

.pull-quote__text {
  font-size: var(--text-xl);
  font-weight: var(--weight-medium);
  color: var(--color-navy);
  line-height: var(--leading-snug);
  letter-spacing: var(--tracking-tight);
  margin-bottom: var(--space-3);
  font-style: normal;
}

.pull-quote__attribution {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-muted);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
}

/* ─── Stat Callout ───────────────────────────────────────── */

.stat-callout {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding: var(--space-6) var(--space-8);
  background-color: var(--color-surface);
  border-radius: var(--radius-lg);
}

.stat-callout__number {
  font-size: var(--text-4xl);
  font-weight: var(--weight-bold);
  color: var(--color-obsidian);
  letter-spacing: var(--tracking-tight);
  line-height: 1;
}

.stat-callout__number span {
  color: var(--color-gold);
}

.stat-callout__label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-muted);
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
}

.stat-callout__desc {
  font-size: var(--text-sm);
  color: var(--color-body-steel);
  line-height: var(--leading-body);
  margin-top: var(--space-2);
}

/* ─── Stat Grid (3-up) ───────────────────────────────────── */

.stats-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
  margin: var(--space-10) 0;
}

@media (max-width: 768px) {
  .stats-grid {
    grid-template-columns: 1fr;
    gap: var(--space-4);
  }
}

/* ─── Post with Sidebar Layout ───────────────────────────── */

.post-layout--sidebar {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: var(--space-16);
  align-items: start;
}

.post-sidebar {
  position: sticky;
  top: calc(var(--nav-height) + var(--space-8));
}

.post-sidebar__card {
  background-color: var(--color-surface);
  border-radius: var(--radius-lg);
  padding: var(--space-7);
  margin-bottom: var(--space-6);
}

.post-sidebar__heading {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  color: var(--color-gold);
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
  margin-bottom: var(--space-5);
}

.post-sidebar__list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.post-sidebar__list li {
  font-size: var(--text-sm);
  color: var(--color-body-steel);
  line-height: var(--leading-body);
  padding: var(--space-3) 0;
  border-bottom: 1px solid rgba(200, 169, 110, 0.20);
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
}

.post-sidebar__list li:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.post-sidebar__list li::before {
  content: '→';
  color: var(--color-gold);
  font-size: var(--text-sm);
  flex-shrink: 0;
  margin-top: 1px;
}

.post-sidebar__stat {
  text-align: center;
  padding: var(--space-5);
}

.post-sidebar__stat-number {
  font-size: var(--text-3xl);
  font-weight: var(--weight-bold);
  color: var(--color-obsidian);
  display: block;
  letter-spacing: var(--tracking-tight);
  line-height: 1;
  margin-bottom: var(--space-2);
}

.post-sidebar__stat-number em {
  color: var(--color-gold);
  font-style: normal;
}

.post-sidebar__stat-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-muted);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
}

@media (max-width: 900px) {
  .post-layout--sidebar {
    grid-template-columns: 1fr;
    gap: var(--space-10);
  }

  .post-sidebar {
    position: static;
    order: -1;  /* Sidebar moves to top on mobile */
  }
}

/* ─── Before / After Split ───────────────────────────────── */

.before-after {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: var(--border-default);
  margin: var(--space-10) 0;
}

.before-after__col {
  padding: var(--space-8);
}

.before-after__col--before {
  background-color: var(--color-surface);
  border-right: var(--border-default);
}

.before-after__col--after {
  background-color: var(--bg-white);
}

.before-after__label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
  display: block;
  margin-bottom: var(--space-5);
}

.before-after__col--before .before-after__label {
  color: var(--color-muted);
}

.before-after__col--after .before-after__label {
  color: var(--color-teal);
}

.before-after__heading {
  font-size: var(--text-lg);
  font-weight: var(--weight-bold);
  color: var(--color-obsidian);
  margin-bottom: var(--space-5);
  line-height: var(--leading-snug);
}

.before-after__list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.before-after__list li {
  font-size: var(--text-sm);
  color: var(--color-body-steel);
  line-height: var(--leading-body);
  padding: var(--space-3) 0;
  border-bottom: 1px solid #E4E4E2;
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
}

.before-after__list li:last-child {
  border-bottom: none;
}

.before-after__col--before .before-after__list li::before {
  content: '×';
  color: var(--color-muted);
  font-weight: var(--weight-bold);
  flex-shrink: 0;
}

.before-after__col--after .before-after__list li::before {
  content: '✓';
  color: var(--color-teal);
  font-weight: var(--weight-bold);
  flex-shrink: 0;
}

@media (max-width: 640px) {
  .before-after {
    grid-template-columns: 1fr;
  }

  .before-after__col--before {
    border-right: none;
    border-bottom: var(--border-default);
  }
}

/* ─── Timeline / Progression ─────────────────────────────── */

.post-timeline {
  position: relative;
  padding-left: var(--space-10);
  margin: var(--space-10) 0;
}

.post-timeline::before {
  content: '';
  position: absolute;
  left: calc(var(--space-5) - 1px);
  top: var(--space-4);
  bottom: var(--space-4);
  width: 2px;
  background: linear-gradient(to bottom, var(--color-gold), var(--color-teal));
}

.timeline-entry {
  position: relative;
  margin-bottom: var(--space-10);
}

.timeline-entry:last-child {
  margin-bottom: 0;
}

.timeline-entry__marker {
  position: absolute;
  left: calc(-1 * var(--space-10));
  top: var(--space-1);
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background-color: var(--bg-white);
  border: 2px solid var(--color-gold);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: var(--weight-bold);
  color: var(--color-gold);
  z-index: 1;
}

.timeline-entry__label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-gold);
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
  display: block;
  margin-bottom: var(--space-3);
}

.timeline-entry__heading {
  font-size: var(--text-xl);
  font-weight: var(--weight-bold);
  color: var(--color-obsidian);
  margin-bottom: var(--space-3);
}

.timeline-entry__body {
  font-size: var(--text-base);
  color: var(--color-body-steel);
  line-height: var(--leading-body);
}

/* ─── Post Footer CTA ────────────────────────────────────── */

.post-footer-cta {
  background-color: var(--color-surface);
  border-top: var(--border-default);
  padding: var(--space-16) 0;
}

.post-footer-cta__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-10);
  flex-wrap: wrap;
}

.post-footer-cta__text h3 {
  font-size: var(--text-xl);
  color: var(--color-obsidian);
  margin-bottom: var(--space-3);
}

.post-footer-cta__text p {
  font-size: var(--text-base);
  color: var(--color-muted);
  max-width: 52ch;
}

.post-footer-cta__actions {
  display: flex;
  gap: var(--space-4);
  flex-wrap: wrap;
  flex-shrink: 0;
}

@media (max-width: 768px) {
  .post-footer-cta__inner {
    flex-direction: column;
    align-items: flex-start;
  }
}
