/* ===== Individual blog article redesign (scoped to .blogx-post so the global header/footer are never touched) ===== */
.blogx-post{
  --ink-900:#0a0a0a; --ink-800:#111827;
  --zinc-50:#fafafa; --zinc-100:#f4f4f5; --zinc-200:#e4e4e7; --zinc-300:#d4d4d8;
  --zinc-400:#a1a1aa; --zinc-500:#71717a; --zinc-600:#52525b; --zinc-700:#3f3f46;
  --slate-50:#f8fafc; --slate-200:#e2e8f0; --slate-500:#64748b; --slate-700:#334155;
  --bg:#ffffff; --page:#f9fafb; --text:#0f172a; --muted:#475569; --faint:#64748b; --quiet:#94a3b8;
  --border:#e5e7eb; --border-strong:#cbd5e1; --border-soft:#f1f5f9;
  --good:#047857; --good-strong:#059669; --good-tint:#f0fdf4; --good-border:#bbf7d0;
  --pro:#1d4ed8; --pro-tint:#eff6ff; --pro-border:#bfdbfe;
  --shadow-sm:0 1px 2px rgba(15,23,42,.05), 0 10px 28px rgba(15,23,42,.04);
  --shadow-md:0 4px 6px -1px rgba(0,0,0,.08), 0 2px 4px -2px rgba(0,0,0,.06);
  --r-sm:6px; --r-md:8px; --r-lg:10px; --r-xl:12px; --r-2xl:16px; --r-full:999px;
  color:var(--text); background:var(--bg);
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;
  line-height:1.6; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  padding-top:var(--blogx-header-h, 64px);
}
.blogx-post *{ margin:0; padding:0; box-sizing:border-box; }
.blogx-post a{ text-decoration:none; color:inherit; }
.blogx-post img{ max-width:100%; height:auto; display:block; }
.blogx-post .wrap{ max-width:1180px; margin:0 auto; padding:0 24px; }

/* reading progress */
.blogx-post .progress{ position:fixed; top:0; left:0; height:3px; background:var(--good); z-index:200; width:0; transition:width .1s linear; }

/* shell */
.blogx-post .shell{ display:grid; grid-template-columns:minmax(0,1fr) 332px; gap:48px; align-items:start; padding:28px 0 56px; }
.blogx-post .rail{ position:sticky; top:calc(var(--blogx-header-h,64px) + 20px); display:flex; flex-direction:column; gap:16px; }

/* breadcrumbs */
.blogx-post .crumbs{ display:flex; align-items:center; flex-wrap:wrap; gap:8px; font-size:.78rem; color:var(--faint); margin-bottom:18px; }
.blogx-post .crumbs a:hover{ color:var(--text); }
.blogx-post .crumbs i{ font-size:.56rem; color:var(--zinc-300); }

/* eyebrow + chips */
.blogx-post .eyebrow{ display:flex; flex-wrap:wrap; align-items:center; gap:8px; margin-bottom:14px; }
.blogx-post .chip{ display:inline-flex; align-items:center; gap:7px; font-size:.72rem; font-weight:700; padding:5px 11px; border-radius:var(--r-full); background:var(--zinc-100); color:var(--zinc-700); border:1px solid var(--border); letter-spacing:.01em; }
.blogx-post .chip i{ font-size:.66rem; color:var(--zinc-400); }
.blogx-post .chip.cat{ background:var(--ink-900); color:#fff; border-color:var(--ink-900); }
.blogx-post .chip.cat .cc{ font-family:ui-monospace,Menlo,monospace; font-weight:800; letter-spacing:.04em; }
.blogx-post .chip.live{ background:var(--good-tint); color:var(--good); border-color:var(--good-border); }
.blogx-post .chip.live .dot{ width:7px; height:7px; border-radius:50%; background:var(--good-strong); animation:lapulse 2s infinite; }
@keyframes lapulse{ 0%{box-shadow:0 0 0 0 rgba(5,150,105,.45);} 70%{box-shadow:0 0 0 6px rgba(5,150,105,0);} 100%{box-shadow:0 0 0 0 rgba(5,150,105,0);} }
@media (prefers-reduced-motion: reduce){ .blogx-post .chip.live .dot{ animation:none; } }

/* headline */
.blogx-post h1.title{ font-size:2.55rem; line-height:1.08; letter-spacing:-.025em; font-weight:800; margin-bottom:16px; text-align:left; text-wrap:pretty; }
.blogx-post .standfirst{ font-size:1.18rem; line-height:1.55; color:var(--slate-700); margin-bottom:22px; max-width:62ch; font-weight:400; }

/* byline */
.blogx-post .byline{ display:flex; align-items:center; gap:13px; flex-wrap:wrap; padding:16px 0; border-top:1px solid var(--border); border-bottom:1px solid var(--border); margin-bottom:26px; }
.blogx-post .by-av{ width:44px; height:44px; border-radius:50%; background:var(--ink-800); color:#fff; display:flex; align-items:center; justify-content:center; font-weight:700; font-size:.95rem; flex-shrink:0; overflow:hidden; }
.blogx-post .by-av img{ width:100%; height:100%; object-fit:cover; }
.blogx-post .by-id{ line-height:1.35; }
.blogx-post .by-name{ font-weight:700; font-size:.92rem; display:flex; align-items:center; gap:6px; }
.blogx-post .tick{ width:15px; height:15px; border-radius:50%; background:var(--pro); color:#fff; display:inline-flex; align-items:center; justify-content:center; font-size:.55rem; flex-shrink:0; }
.blogx-post .by-role{ font-size:.8rem; color:var(--faint); }
.blogx-post .by-spacer{ flex:1; min-width:14px; }
.blogx-post .by-meta{ display:flex; flex-direction:column; align-items:flex-end; gap:2px; font-size:.8rem; color:var(--faint); }
.blogx-post .by-meta .updated{ color:var(--good); font-weight:600; }
.blogx-post .by-meta i{ width:14px; text-align:center; color:var(--zinc-400); margin-right:5px; }

/* lead: generated branded card (used when the article has no featured image) */
.blogx-post .lead{ position:relative; border-radius:var(--r-2xl); overflow:hidden; border:1px solid var(--border); background:linear-gradient(150deg,#0a0a0a 0%, #1f2937 100%); color:#fff; padding:34px 32px; margin-bottom:30px; aspect-ratio:1200/600; display:flex; flex-direction:column; justify-content:space-between; }
.blogx-post .lead::after{ content:""; position:absolute; inset:0; background-image:repeating-linear-gradient(135deg, rgba(255,255,255,.035) 0 2px, transparent 2px 22px); pointer-events:none; }
.blogx-post .lead-top{ display:flex; align-items:center; justify-content:space-between; gap:12px; position:relative; z-index:1; }
.blogx-post .lead-cc{ font-family:ui-monospace,Menlo,monospace; font-weight:800; font-size:1.05rem; letter-spacing:.08em; border:1.5px solid rgba(255,255,255,.4); border-radius:8px; padding:5px 12px; flex-shrink:0; }
.blogx-post .lead-brand{ display:flex; align-items:center; gap:9px; font-size:.82rem; color:rgba(255,255,255,.78); font-weight:600; text-align:right; }
.blogx-post .lead-brand .b{ width:26px; height:26px; border-radius:7px; background:#fff; color:#0a0a0a; display:flex; align-items:center; justify-content:center; font-weight:800; font-size:.66rem; flex-shrink:0; }
.blogx-post .lead-body{ position:relative; z-index:1; }
.blogx-post .lead-kicker{ font-size:.74rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:rgba(255,255,255,.6); margin-bottom:10px; }
.blogx-post .lead-headline{ font-size:clamp(1.4rem,3.4vw,2.2rem); font-weight:800; letter-spacing:-.02em; line-height:1.12; color:#fff; }
.blogx-post .lead-date{ font-size:.86rem; color:rgba(255,255,255,.62); margin-top:12px; }

/* lead: real featured photo */
.blogx-post .lead-photo{ border-radius:var(--r-2xl); overflow:hidden; border:1px solid var(--border); margin-bottom:30px; box-shadow:var(--shadow-sm); }
.blogx-post .lead-photo img{ width:100%; height:auto; }

/* prose (renders the stored article HTML body) */
.blogx-post .prose > *:first-child{ margin-top:0; }
.blogx-post .prose h2{ font-size:1.5rem; font-weight:800; letter-spacing:-.018em; margin:38px 0 16px; padding-bottom:10px; border-bottom:1px solid var(--border); scroll-margin-top:calc(var(--blogx-header-h,64px) + 20px); }
.blogx-post .prose h3{ font-size:1.18rem; font-weight:700; letter-spacing:-.01em; margin:28px 0 12px; scroll-margin-top:calc(var(--blogx-header-h,64px) + 20px); }
.blogx-post .prose h4{ font-size:1rem; font-weight:700; margin:22px 0 10px; }
.blogx-post .prose p{ font-size:1.05rem; color:var(--slate-700); margin-bottom:16px; line-height:1.72; max-width:72ch; }
.blogx-post .prose a{ color:var(--good); text-decoration:underline; text-underline-offset:2px; text-decoration-thickness:1.5px; font-weight:500; }
.blogx-post .prose ul, .blogx-post .prose ol{ margin:0 0 18px; padding-left:1.35em; color:var(--slate-700); max-width:72ch; }
.blogx-post .prose li{ font-size:1.05rem; line-height:1.7; margin-bottom:9px; }
.blogx-post .prose strong{ color:var(--text); font-weight:700; }
.blogx-post .prose img{ border-radius:var(--r-xl); border:1px solid var(--border); margin:22px 0; }
.blogx-post .prose blockquote{ border-left:3px solid var(--ink-900); padding:6px 0 6px 20px; margin:26px 0; font-size:1.18rem; line-height:1.5; font-weight:600; color:var(--text); }
.blogx-post .prose table{ width:100%; border-collapse:collapse; margin:22px 0; font-size:.95rem; display:block; overflow-x:auto; }
.blogx-post .prose th, .blogx-post .prose td{ border:1px solid var(--border); padding:10px 12px; text-align:left; }
.blogx-post .prose th{ background:var(--slate-50); font-weight:700; }

/* tags */
.blogx-post .tagrow{ display:flex; flex-wrap:wrap; gap:8px; margin-top:30px; padding-top:24px; border-top:1px solid var(--border); }
.blogx-post .tag{ font-size:.8rem; font-weight:600; padding:6px 12px; border-radius:var(--r-full); background:var(--zinc-100); color:var(--zinc-700); border:1px solid var(--border); transition:.13s; }
.blogx-post .tag:hover{ background:var(--ink-900); color:#fff; border-color:var(--ink-900); }

/* author bio */
.blogx-post .authorbox{ display:flex; gap:16px; align-items:flex-start; background:var(--slate-50); border:1px solid var(--border); border-radius:var(--r-xl); padding:20px 22px; margin-top:30px; }
.blogx-post .authorbox .av{ width:56px; height:56px; border-radius:50%; background:var(--ink-800); color:#fff; display:flex; align-items:center; justify-content:center; font-weight:700; font-size:1.1rem; flex-shrink:0; overflow:hidden; }
.blogx-post .authorbox .av img{ width:100%; height:100%; object-fit:cover; }
.blogx-post .authorbox .nm{ font-weight:700; font-size:1rem; display:flex; align-items:center; gap:6px; }
.blogx-post .authorbox .rl{ font-size:.82rem; color:var(--faint); margin-bottom:8px; }
.blogx-post .authorbox p{ font-size:.92rem; color:var(--slate-700); line-height:1.6; }

/* rail cards */
.blogx-post .card{ background:#fff; border:1px solid var(--border); border-radius:var(--r-2xl); padding:18px; }
.blogx-post .card.dark{ background:var(--ink-900); color:#fff; border-color:var(--ink-900); }
.blogx-post .toc-h{ font-size:.7rem; font-weight:800; letter-spacing:.07em; text-transform:uppercase; color:var(--faint); margin-bottom:12px; }
.blogx-post .toc{ display:flex; flex-direction:column; gap:1px; }
.blogx-post .toc a{ display:flex; align-items:center; gap:10px; font-size:.86rem; color:var(--muted); padding:7px 9px; border-radius:var(--r-md); transition:.13s; }
.blogx-post .toc a:hover{ background:var(--zinc-50); color:var(--text); }
.blogx-post .toc a.on{ background:var(--zinc-100); color:var(--text); font-weight:600; }

.blogx-post .digest h3{ font-size:1.08rem; font-weight:800; letter-spacing:-.01em; margin-bottom:7px; }
.blogx-post .digest p{ font-size:.85rem; color:rgba(255,255,255,.72); line-height:1.5; margin-bottom:14px; }
.blogx-post .digest .field{ display:flex; gap:7px; }
.blogx-post .digest input[type=email]{ flex:1; min-width:0; border:1px solid rgba(255,255,255,.18); background:rgba(255,255,255,.06); color:#fff; border-radius:var(--r-md); padding:10px 12px; font-size:.85rem; font-family:inherit; }
.blogx-post .digest input[type=email]::placeholder{ color:rgba(255,255,255,.5); }
.blogx-post .digest input[type=email]:focus{ outline:none; border-color:rgba(255,255,255,.4); }
.blogx-post .digest .fine{ font-size:.72rem; color:rgba(255,255,255,.5); margin-top:10px; }

.blogx-post .btn{ display:inline-flex; align-items:center; justify-content:center; gap:8px; font-size:.86rem; font-weight:600; border-radius:var(--r-xl); padding:9px 16px; cursor:pointer; border:1px solid transparent; transition:.15s; white-space:nowrap; font-family:inherit; }
.blogx-post .btn-good{ background:var(--good); color:#fff; border-color:var(--good); }
.blogx-post .btn-good:hover{ background:var(--good-strong); transform:translateY(-1px); box-shadow:var(--shadow-md); }
.blogx-post .btn-sm{ padding:8px 13px; font-size:.8rem; border-radius:var(--r-md); }

.blogx-post .share{ display:flex; gap:7px; }
.blogx-post .share a{ flex:1; height:40px; border:1px solid var(--border); border-radius:var(--r-md); display:flex; align-items:center; justify-content:center; color:var(--muted); transition:.15s; cursor:pointer; }
.blogx-post .share a:hover{ background:var(--zinc-50); border-color:var(--border-strong); color:var(--text); }
.blogx-post .share a.copied{ background:var(--good-tint); border-color:var(--good-border); color:var(--good); }

.blogx-post .stat-row{ display:grid; grid-template-columns:1fr 1fr; gap:1px; background:var(--border); border:1px solid var(--border); border-radius:var(--r-lg); overflow:hidden; }
.blogx-post .stat{ background:#fff; padding:12px 14px; }
.blogx-post .stat .k{ font-size:.68rem; font-weight:700; letter-spacing:.04em; text-transform:uppercase; color:var(--faint); }
.blogx-post .stat .v{ font-size:1.35rem; font-weight:800; letter-spacing:-.02em; margin-top:2px; }
.blogx-post .stat .v.good{ color:var(--good); }

/* related strip */
.blogx-post .related{ border-top:1px solid var(--border); padding:40px 0 8px; margin-top:8px; }
.blogx-post .related h2{ font-size:1.3rem; font-weight:800; letter-spacing:-.015em; margin-bottom:18px; }
.blogx-post .rel-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.blogx-post .rel{ border:1px solid var(--border); border-radius:var(--r-xl); overflow:hidden; background:#fff; transition:.15s; display:flex; flex-direction:column; }
.blogx-post .rel:hover{ border-color:var(--border-strong); box-shadow:var(--shadow-sm); transform:translateY(-2px); }
.blogx-post .rel-img{ aspect-ratio:16/9; background:linear-gradient(150deg,#0a0a0a,#1f2937); color:#fff; padding:14px 16px; display:flex; flex-direction:column; justify-content:space-between; position:relative; overflow:hidden; }
.blogx-post .rel-img:not(.has-img)::after{ content:""; position:absolute; inset:0; background-image:repeating-linear-gradient(135deg, rgba(255,255,255,.04) 0 2px, transparent 2px 18px); }
.blogx-post .rel-cc{ font-family:ui-monospace,Menlo,monospace; font-weight:800; font-size:.82rem; letter-spacing:.06em; border:1.2px solid rgba(255,255,255,.35); border-radius:6px; padding:3px 8px; align-self:flex-start; position:relative; z-index:1; }
.blogx-post .rel-n{ font-size:1.7rem; font-weight:800; letter-spacing:-.02em; position:relative; z-index:1; }
.blogx-post .rel-n small{ font-size:.42em; font-weight:600; color:rgba(255,255,255,.7); margin-left:5px; }
.blogx-post .rel-body{ padding:13px 15px 16px; }
.blogx-post .rel-cat{ font-size:.7rem; font-weight:700; letter-spacing:.04em; text-transform:uppercase; color:var(--faint); }
.blogx-post .rel-title{ font-size:.98rem; font-weight:700; line-height:1.3; margin:5px 0 0; }
.blogx-post .rel:hover .rel-title{ color:var(--good); }
.blogx-post .rel-meta{ font-size:.76rem; color:var(--quiet); margin-top:8px; }

/* responsive */
@media (max-width:1080px){
  .blogx-post .shell{ grid-template-columns:1fr; gap:0; }
  .blogx-post .rail{ position:static; margin-top:36px; }
  .blogx-post .rail .toc-card{ display:none; }
}
@media (max-width:760px){
  .blogx-post h1.title{ font-size:1.95rem; }
  .blogx-post .standfirst{ font-size:1.06rem; }
  .blogx-post .prose p, .blogx-post .prose ul, .blogx-post .prose ol{ max-width:none; }
  .blogx-post .rel-grid{ grid-template-columns:1fr; }
  .blogx-post .wrap{ padding:0 18px; }
  .blogx-post .by-meta{ align-items:flex-start; }
  .blogx-post .lead{ padding:24px 22px; }
}
    
