/* ============================================================
   blog-page.css — Blog article restyle.
   Re-skins legacy classes used in old article HTML
   (.article-body, .callout, .checklist-box, .penalty-box, etc.)
   onto the dark CrewCompliance design system.
   Loads alongside product-page.css.
   ============================================================ */

/* Strip any legacy navy <header> that isn't pp-header */
body > header:not(.pp-header) { display: none !important; }

/* Hide the legacy article-header — we replace it with pp-hero in markup */
.article-header { display: none !important; }

/* Legacy .container that wraps the article-body becomes part of the page grid */
.pp-page-inner > .container,
.pp-page-wrap > .container {
  max-width: none !important;
  padding: 0 !important;
}

/* ── Article body card ───────────────────────────────── */
.article-body {
  background: var(--surface) !important;
  color: var(--fg-1) !important;
  border: 0.5px solid var(--border) !important;
  border-radius: 18px !important;
  padding: 38px clamp(20px, 4vw, 40px) !important;
  margin: 0 0 28px !important;
  max-width: none !important;
  backdrop-filter: blur(20px) saturate(140%);
  -webkit-backdrop-filter: blur(20px) saturate(140%);
  box-shadow:
    0 1px 0 rgba(255,255,255,.05) inset,
    0 30px 60px -28px rgba(0, 8, 30, 0.5),
    0 14px 30px -18px rgba(0, 8, 30, 0.3);
  font-size: 15px;
  line-height: 1.7;
}

/* Prose */
.article-body p {
  margin: 0 0 18px !important;
  font-size: 15px !important;
  line-height: 1.7 !important;
  color: var(--fg-1) !important;
}
.article-body p strong { color: var(--fg-0); font-weight: 500; }

.article-body h2 {
  font-size: clamp(22px, 2.6vw, 28px) !important;
  font-weight: 600 !important;
  letter-spacing: -0.015em !important;
  line-height: 1.15 !important;
  color: var(--fg-0) !important;
  margin: 36px 0 16px !important;
  padding: 18px 0 0 !important;
  border-top: 0.5px solid var(--border) !important;
  position: relative;
}
.article-body h2:first-of-type {
  margin-top: 4px !important;
  padding-top: 0 !important;
  border-top: none !important;
}
.article-body h2:not(:first-of-type)::before {
  content: "";
  position: absolute;
  top: -0.5px; left: 0;
  width: 48px; height: 2px;
  background: linear-gradient(90deg, var(--primary) 0%, var(--primary-glow) 100%);
  box-shadow: 0 0 12px color-mix(in oklab, var(--primary) 50%, transparent);
  border-radius: 1px;
}
.article-body h3 {
  font-size: 17px !important;
  font-weight: 500 !important;
  letter-spacing: -0.005em !important;
  color: var(--fg-0) !important;
  margin: 26px 0 12px !important;
  padding: 0 !important;
}

.article-body a {
  color: var(--primary-glow) !important;
  border-bottom: 0.5px dashed color-mix(in oklab, var(--primary) 50%, transparent);
  text-decoration: none !important;
}
.article-body a:hover { color: var(--primary) !important; }

/* Lists with arrow bullets */
.article-body ul {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 0 20px !important;
}
.article-body ul li {
  position: relative;
  padding: 8px 0 8px 26px !important;
  border-bottom: 0.5px solid var(--border) !important;
  font-size: 14.5px;
  line-height: 1.7;
  color: var(--fg-1);
}
.article-body ul li:last-child { border-bottom: none !important; }
.article-body ul li::before {
  content: "→";
  position: absolute;
  left: 2px; top: 8px;
  color: var(--primary-glow);
  font-family: var(--font-mono);
  font-weight: 600;
}
.article-body ol {
  counter-reset: blog-counter;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 0 20px !important;
}
.article-body ol li {
  position: relative;
  padding: 8px 0 8px 36px !important;
  border-bottom: 0.5px solid var(--border);
  font-size: 14.5px;
  line-height: 1.7;
  color: var(--fg-1);
  counter-increment: blog-counter;
}
.article-body ol li:last-child { border-bottom: none; }
.article-body ol li::before {
  content: counter(blog-counter, decimal-leading-zero);
  position: absolute;
  left: 0; top: 10px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  color: var(--primary-glow);
}
.article-body li strong { color: var(--fg-0); font-weight: 500; }

.article-body blockquote {
  margin: 22px 0;
  padding: 18px 22px;
  background: color-mix(in oklab, var(--surface-2) 60%, transparent);
  border-left: 3px solid var(--primary);
  border-radius: 0 12px 12px 0;
  font-size: 15px;
  font-style: italic;
  color: var(--fg-0);
}

.article-body hr {
  border: 0;
  border-top: 0.5px solid var(--border);
  margin: 32px 0;
}

.article-body table {
  width: 100%;
  border-collapse: collapse;
  margin: 22px 0;
  font-size: 14px;
  background: var(--surface-2);
  border: 0.5px solid var(--border);
  border-radius: 12px;
  overflow: hidden;
}
.article-body thead { background: color-mix(in oklab, var(--primary) 14%, var(--surface-2)); }
.article-body th, .article-body td {
  padding: 14px 18px;
  text-align: left;
  border-bottom: 0.5px solid var(--border);
  vertical-align: top;
  color: var(--fg-1);
}
.article-body th {
  color: var(--fg-0);
  font-weight: 500;
  letter-spacing: -0.005em;
}
.article-body tr:last-child td { border-bottom: 0; }

/* ── Callout (orange-tinted tip) ─────────────────────── */
.callout {
  background: linear-gradient(135deg,
    color-mix(in oklab, var(--primary) 12%, var(--surface-2)),
    var(--surface-2)) !important;
  border-left: 3px solid var(--primary) !important;
  border-radius: 0 12px 12px 0 !important;
  padding: 18px 22px !important;
  margin: 22px 0 !important;
}
.callout p { margin-bottom: 0 !important; font-size: 14.5px !important; color: var(--fg-0) !important; }

/* ── Checklist box (green/positive) ──────────────────── */
.checklist-box {
  background: linear-gradient(135deg,
    color-mix(in oklab, var(--accent) 14%, var(--surface-2)),
    var(--surface-2)) !important;
  border: 0.5px solid color-mix(in oklab, var(--accent) 40%, transparent) !important;
  border-radius: 12px !important;
  padding: 20px 22px !important;
  margin: 22px 0 !important;
}
.checklist-box h3 {
  font-size: 13.5px !important;
  font-weight: 600 !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
  color: var(--accent) !important;
  margin: 0 0 14px !important;
}
.checklist-box ul { margin: 0 !important; }
.checklist-box ul li {
  border-bottom: 0.5px solid color-mix(in oklab, var(--accent) 25%, transparent) !important;
  padding: 9px 0 9px 24px !important;
}
.checklist-box ul li::before {
  content: "✓" !important;
  color: var(--accent) !important;
  font-weight: 700;
}
.checklist-box ul li:last-child { border-bottom: none !important; }

/* ── Penalty / failure / red boxes ───────────────────── */
.penalty-box,
.failure-block,
.deficiency-item {
  background: linear-gradient(135deg,
    color-mix(in oklab, var(--red, #f87171) 12%, var(--surface-2)),
    var(--surface-2)) !important;
  border: 0.5px solid color-mix(in oklab, var(--red, #f87171) 35%, transparent) !important;
  border-radius: 12px !important;
  padding: 18px 22px !important;
  margin: 18px 0 !important;
}
.penalty-box h3,
.failure-block h3,
.deficiency-item h3 {
  color: var(--red, #f87171) !important;
  margin: 0 0 8px !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  display: flex;
  align-items: center;
  gap: 8px;
}
.failure-num {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  width: 22px; height: 22px;
  background: var(--red, #f87171) !important;
  color: #fff !important;
  border-radius: 50%;
  font-size: 11px !important;
  font-weight: 700;
  flex-shrink: 0;
}

/* ── Highlight / state / reduction boxes ─────────────── */
.state-box,
.reduction-box,
.highlight-row {
  background: var(--surface-2) !important;
  border: 0.5px solid var(--border) !important;
  border-left: 3px solid var(--primary) !important;
  border-radius: 0 12px 12px 0 !important;
  padding: 16px 20px !important;
  margin: 18px 0 !important;
}
.state-box h3,
.reduction-box h3,
.highlight-row h3 {
  color: var(--primary-glow) !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  letter-spacing: 0.02em !important;
  margin: 0 0 8px !important;
}

/* ── Options / compare grids ─────────────────────────── */
.options-grid,
.compare-grid,
.pricing-grid {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 14px !important;
  margin: 22px 0 !important;
}
@media (min-width: 720px) {
  .options-grid, .pricing-grid { grid-template-columns: repeat(3, minmax(0, 1fr)) !important; }
  .compare-grid { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
}

.option-card,
.pricing-card {
  background: var(--surface-2) !important;
  border: 0.5px solid var(--border) !important;
  border-radius: 14px !important;
  padding: 22px !important;
  color: var(--fg-1) !important;
}
.option-card.featured,
.pricing-card.featured {
  background: linear-gradient(135deg,
    color-mix(in oklab, var(--primary) 14%, var(--surface-2)),
    var(--surface-2)) !important;
  border-color: color-mix(in oklab, var(--primary) 40%, transparent) !important;
  position: relative;
}
.option-card h4,
.pricing-card h4 {
  font-size: 15px !important;
  font-weight: 600 !important;
  color: var(--fg-0) !important;
  margin: 0 0 8px !important;
  letter-spacing: -0.005em;
}
.option-card p,
.pricing-card p {
  font-size: 13.5px !important;
  color: var(--fg-1) !important;
  margin: 0 !important;
  line-height: 1.55;
}
.option-card.featured strong,
.pricing-card.featured strong { color: var(--primary-glow) !important; }
.option-card .price,
.pricing-card .price {
  font-size: 22px !important;
  font-weight: 600 !important;
  color: var(--fg-0) !important;
  margin: 10px 0 !important;
  letter-spacing: -0.02em;
}
.pricing-card-header {
  border-bottom: 0.5px solid var(--border);
  margin-bottom: 14px;
  padding-bottom: 14px;
}
.pricing-card-body .pros,
.pricing-card-body .cons {
  margin: 12px 0;
}
.pricing-card-body .pros::before {
  content: "✓ Pros";
  display: block;
  font-family: var(--font-mono);
  font-size: 10.5px;
  color: var(--accent);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 6px;
}
.pricing-card-body .cons::before {
  content: "✕ Cons";
  display: block;
  font-family: var(--font-mono);
  font-size: 10.5px;
  color: var(--red, #f87171);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 6px;
}

.compare-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  background: var(--surface-2);
  border: 0.5px solid var(--border);
  border-radius: 12px;
  padding: 16px 18px;
  margin: 12px 0;
}
@media (min-width: 640px) {
  .compare-row { grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); }
}
.compare-cell h4 {
  font-size: 13px !important;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--primary-glow) !important;
  margin: 0 0 8px !important;
}
.compare-cell p {
  font-size: 14px !important;
  color: var(--fg-1) !important;
  margin: 0 !important;
}

/* ── FAQ items ───────────────────────────────────────── */
.faq-item {
  background: var(--surface-2) !important;
  border: 0.5px solid var(--border) !important;
  border-radius: 12px !important;
  padding: 18px 22px !important;
  margin: 12px 0 !important;
}
.faq-item h3 {
  font-size: 15px !important;
  font-weight: 600 !important;
  color: var(--fg-0) !important;
  margin: 0 0 8px !important;
}
.faq-item p {
  margin: 0 !important;
  font-size: 14.5px !important;
  color: var(--fg-1) !important;
}

/* ── Deficiency list ─────────────────────────────────── */
.deficiency-list {
  display: grid;
  gap: 12px;
  margin: 22px 0;
}

/* ── Timeline table ──────────────────────────────────── */
.timeline-table { margin: 22px 0; }
.timeline-table table { margin: 0; }
.timeline-table th { background: color-mix(in oklab, var(--primary) 18%, var(--surface-2)) !important; }

/* ── Related posts ───────────────────────────────────── */
.related-posts {
  background: var(--surface-2) !important;
  border: 0.5px solid var(--border) !important;
  border-radius: 14px !important;
  padding: 22px 24px !important;
  margin: 28px 0 !important;
}
.related-posts h3 {
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: 0.10em !important;
  text-transform: uppercase !important;
  color: var(--fg-2) !important;
  font-family: var(--font-mono) !important;
  margin: 0 0 14px !important;
}
.related-posts ul {
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}
.related-posts ul li {
  padding: 9px 0 !important;
  border-bottom: 0.5px solid var(--border) !important;
  font-size: 14px;
}
.related-posts ul li::before { content: "" !important; display: none !important; }
.related-posts ul li:last-child { border-bottom: none !important; }
.related-posts a {
  color: var(--fg-0) !important;
  border-bottom: none !important;
  display: block;
  padding: 0 !important;
  transition: color 160ms, padding-left 160ms;
}
.related-posts a:hover {
  color: var(--primary-glow) !important;
  padding-left: 6px !important;
}

/* ── Bottom CTA section (legacy .cta-section) ────────── */
.cta-section {
  position: relative;
  z-index: 2;
  max-width: 1180px;
  margin: 12px auto 80px;
  padding: 0 clamp(16px, 4vw, 32px);
}
.cta-section > .container {
  max-width: none !important;
  padding: 0 !important;
}
.cta-section h2 {
  font-size: clamp(24px, 3vw, 32px);
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--fg-0);
  margin: 0 0 14px;
}
.cta-section h2 em {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  color: var(--primary-glow);
}
.cta-section p {
  font-size: 15px;
  line-height: 1.6;
  color: var(--fg-1);
  margin: 0 0 22px;
  max-width: 640px;
}
.cta-section .btn,
.cta-section a.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 13px 22px;
  border-radius: 999px;
  font-size: 14.5px;
  font-weight: 500;
  letter-spacing: -0.005em;
  background: linear-gradient(180deg, var(--primary) 0%, color-mix(in oklab, var(--primary) 78%, black) 100%);
  color: #fff !important;
  text-decoration: none;
  border: none;
  border-bottom: none !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.22),
    0 12px 28px -10px color-mix(in oklab, var(--primary) 60%, transparent);
  transition: filter 160ms, transform 160ms;
}
.cta-section .btn:hover { filter: brightness(1.08); transform: translateY(-1px); }

/* Card-style wrapper for the CTA */
.cta-section-card {
  background: var(--surface);
  border: 0.5px solid var(--border);
  border-radius: 18px;
  padding: 38px clamp(20px, 4vw, 40px);
}

/* Article CTA (mid-article inline button) */
.article-cta {
  text-align: center;
  margin: 28px 0;
}
.article-cta .btn { display: inline-flex; }
