/* ===== ARTICLE (blog post) STYLES ===== */
/* Article hero */
  .art-hero{background:var(--navy);color:var(--bone);padding:72px 0 56px;border-bottom:1px solid var(--navy)}
  .art-hero .crumb{color:var(--ash)}
  .art-hero .crumb a{color:var(--ash);border-bottom-color:rgba(255,255,255,.18)}
  .art-hero .crumb span{color:var(--warm)}
  .art-hero .meta-row{display:flex;align-items:center;gap:18px;margin-bottom:22px;flex-wrap:wrap}
  .art-hero .cat{font-family:var(--head);font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--warm);font-weight:600;padding:6px 12px;border:1px solid var(--warm);border-radius:2px}
  .art-hero .date{font-family:var(--head);font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--ash);font-weight:500}
  .art-hero .read{font-family:var(--serif);font-style:italic;color:var(--ash);font-size:14px}
  .art-hero h1{font-family:var(--head);font-weight:600;font-size:60px;line-height:1.02;letter-spacing:-.035em;color:var(--bone);max-width:920px}
  .art-hero h1 i{font-family:var(--serif);font-style:italic;color:var(--warm);font-weight:400}
  .art-hero .byline{margin-top:28px;display:flex;align-items:center;gap:14px;padding-top:24px;border-top:1px solid rgba(255,255,255,.12);max-width:920px}
  .art-hero .byline .av{width:42px;height:42px;border-radius:50%;background:var(--bone) url('/assets/images/headshots/roger.jpg') center 18%/cover;border:1px solid var(--warm);flex:none}
  .art-hero .byline .who{font-family:var(--head);font-size:13px;color:var(--bone);font-weight:500}
  .art-hero .byline .who em{display:block;font-family:var(--serif);font-style:italic;color:var(--ash);font-size:12px;font-weight:400;margin-top:2px}

  /* Page-head byline avatar (shared by .page-head and .art-hero) */
  .byline{margin-top:22px;display:flex;align-items:center;gap:14px}
  .byline .av{width:42px;height:42px;border-radius:50%;background:var(--bone) url('/assets/images/headshots/roger.jpg') center 18%/cover;border:1px solid var(--warm);flex:none}
  .byline .who{font-family:var(--head);font-size:13px;color:var(--navy);font-weight:500}
  .byline .who em{display:block;font-family:var(--serif);font-style:italic;color:var(--steel);font-size:12px;font-weight:400;margin-top:2px}

/* Article body grid */
  .art-grid{display:grid;grid-template-columns:1fr 380px;gap:80px;padding:64px 0 88px;align-items:start}
  .art-body{max-width:680px;font-family:var(--body);font-size:17px;line-height:1.75;color:var(--navy)}
  .art-body p{margin-bottom:22px;color:var(--steel)}
  .art-body p strong{color:var(--navy);font-weight:500}
  .art-body p a{color:var(--navy);border-bottom:1px solid var(--warm);transition:background .18s var(--ease)}
  .art-body p a:hover{background:rgba(212,160,60,.12)}
  .art-body .lede{font-family:var(--serif);font-style:italic;font-size:22px;line-height:1.5;color:var(--navy);margin-bottom:32px;padding-bottom:32px;border-bottom:1px solid var(--fog)}
  .art-body h2{font-family:var(--head);font-weight:600;font-size:30px;letter-spacing:-.025em;line-height:1.15;color:var(--navy);margin:54px 0 18px;display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:baseline}
  .art-body h2 .n{font-family:var(--head);font-size:11px;letter-spacing:.28em;color:var(--warm);font-weight:600;text-transform:uppercase}
  .art-body h2 i{font-family:var(--serif);font-style:italic;color:var(--steel);font-weight:400}
  .art-body h3{font-family:var(--head);font-weight:600;font-size:20px;letter-spacing:-.01em;color:var(--navy);margin:36px 0 12px}
  .art-body h3 i{font-family:var(--serif);font-style:italic;color:var(--steel);font-weight:400}
  .art-body ul{margin:0 0 24px;padding-left:0}
  .art-body ul li{position:relative;padding:8px 0 8px 28px;color:var(--steel);border-bottom:1px solid var(--fog)}
  .art-body ul li::before{content:'§';position:absolute;left:0;top:8px;font-family:var(--head);color:var(--warm);font-weight:600;font-size:14px}
  .art-body ul li strong{color:var(--navy);font-weight:500;font-family:var(--head)}
  .art-body blockquote,.art-body .pull{font-family:var(--serif);font-style:italic;font-size:24px;line-height:1.4;color:var(--navy);border-left:3px solid var(--warm);padding:6px 0 6px 24px;margin:36px 0}
  .art-body .pull cite{display:block;font-family:var(--head);font-style:normal;font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--steel);font-weight:600;margin-top:14px}

  /* Mid-article callout box */
  .callout{margin:36px 0;border:1px solid var(--navy);background:var(--bone);padding:0;display:grid;grid-template-columns:auto 1fr;gap:0}
  .callout .label{background:var(--navy);color:var(--warm);padding:24px 18px;font-family:var(--head);font-size:11px;letter-spacing:.3em;text-transform:uppercase;font-weight:600;writing-mode:vertical-rl;transform:rotate(180deg);display:flex;align-items:center;justify-content:center}
  .callout .body{padding:24px 28px}
  .callout .body h4{font-family:var(--head);font-weight:600;font-size:18px;letter-spacing:-.01em;color:var(--navy);margin-bottom:8px}
  .callout .body h4 i{font-family:var(--serif);font-style:italic;color:var(--steel);font-weight:400}
  .callout .body p{color:var(--steel);font-size:15px;line-height:1.6;margin-bottom:14px}
  .callout .body p:last-child{margin-bottom:0}
  .callout .body a{font-family:var(--head);font-weight:500;font-size:13px;color:var(--navy);border-bottom:1px solid var(--navy);padding-bottom:2px}

  /* Stats data row inside body */
  .data-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--fog);border:1px solid var(--navy);margin:32px 0}
  .data-row .d{background:var(--milk);padding:20px 22px}
  .data-row .k{font-family:var(--head);font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--steel);font-weight:600;margin-bottom:6px}
  .data-row .v{font-family:var(--head);font-weight:600;font-size:24px;letter-spacing:-.02em;color:var(--navy)}
  .data-row .v em{color:var(--warm);font-style:normal;font-size:14px;margin-left:4px;letter-spacing:0}

  /* Sticky sidebar */
  .art-side{position:sticky;top:96px;display:flex;flex-direction:column;gap:24px}
  .lead-card{border:1px solid var(--navy);background:var(--milk);padding:0;overflow:hidden}
  .lead-card .lc-head{background:var(--navy);color:var(--bone);padding:18px 22px;display:flex;justify-content:space-between;align-items:baseline}
  .lead-card .lc-head .ttl{font-family:var(--head);font-weight:600;font-size:14px;letter-spacing:-.005em}
  .lead-card .lc-head .n{font-family:var(--head);font-size:10px;letter-spacing:.28em;color:var(--warm);font-weight:600;text-transform:uppercase}
  .lead-card form{padding:22px}
  .lc-fld{margin-bottom:14px}
  .lc-fld label{display:block;font-family:var(--head);font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--steel);font-weight:600;margin-bottom:5px}
  .lc-fld input,.lc-fld select,.lc-fld textarea{width:100%;background:transparent;border:none;border-bottom:1px solid var(--fog);color:var(--navy);font-family:var(--body);font-size:15px;padding:5px 0;outline:none;transition:border-color .2s var(--ease)}
  .lc-fld textarea{min-height:60px;resize:vertical}
  .lc-fld input:focus,.lc-fld select:focus,.lc-fld textarea:focus{border-bottom-color:var(--warm)}
  .lead-card form .btn-warm{width:100%;justify-content:center;margin-top:6px}
  .lead-card .lc-foot{padding:0 22px 18px;font-family:var(--serif);font-style:italic;color:var(--steel);font-size:12.5px;text-align:center;line-height:1.5}
  .lead-card .lc-or{padding:14px 22px;background:var(--bone);border-top:1px solid var(--fog);text-align:center}
  .lead-card .lc-or .label{font-family:var(--head);font-size:10px;letter-spacing:.28em;color:var(--steel);font-weight:600;text-transform:uppercase;margin-bottom:6px;display:block}
  .lead-card .lc-or .tel{font-family:var(--head);font-weight:600;font-size:24px;color:var(--navy);letter-spacing:-.01em;display:block;margin-bottom:2px}
  .lead-card .lc-or em{font-family:var(--serif);font-style:italic;color:var(--steel);font-size:12px}

  /* TOC */
  .toc{border:1px solid var(--navy);background:var(--bone);padding:22px}
  .toc h5{font-family:var(--head);font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--warm);font-weight:600;margin-bottom:6px;display:flex;justify-content:space-between;align-items:baseline}
  .toc h5 em{font-family:var(--serif);font-style:italic;color:var(--steel);text-transform:none;letter-spacing:.02em;font-size:12px;font-weight:400}
  .toc .rl{height:1px;background:linear-gradient(90deg,var(--warm) 0,var(--warm) 24px,var(--fog) 24px,var(--fog) 100%);margin-bottom:14px}
  .toc ol{list-style:none;counter-reset:toc;padding:0;margin:0}
  .toc ol li{counter-increment:toc;padding:9px 0 9px 28px;font-size:13.5px;color:var(--steel);border-bottom:1px solid var(--fog);position:relative;font-family:var(--head);font-weight:500;line-height:1.4;letter-spacing:-.005em;cursor:pointer;transition:color .18s var(--ease)}
  .toc ol li::before{content:counter(toc,decimal-leading-zero);position:absolute;left:0;top:9px;font-family:var(--head);font-size:10px;letter-spacing:.18em;color:var(--warm);font-weight:600}
  .toc ol li:hover{color:var(--navy)}
  .toc ol li:last-child{border-bottom:none}

  /* Author / share strip after article */
  .art-footer{border-top:1px solid var(--navy);padding:32px 0;margin-top:48px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px}
  .art-footer .signed{display:flex;align-items:center;gap:14px}
  .art-footer .signed .av{width:48px;height:48px;border-radius:50%;background:var(--bone) url('/assets/images/headshots/roger.jpg') center 18%/cover;border:1px solid var(--navy);flex:none}
  .art-footer .signed .who{font-family:var(--head);font-size:13px;color:var(--navy);font-weight:600}
  .art-footer .signed .who em{display:block;font-family:var(--serif);font-style:italic;color:var(--steel);font-size:13px;font-weight:400;margin-top:3px}
  .art-footer .share{display:flex;align-items:center;gap:14px;font-family:var(--head);font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--steel);font-weight:600}
  .art-footer .share a{padding:8px 14px;border:1px solid var(--navy);border-radius:2px;color:var(--navy);font-size:11px;letter-spacing:.18em;transition:all .2s var(--ease)}
  .art-footer .share a:hover{background:var(--navy);color:var(--bone)}

  /* Related */
  .related{padding:64px 0;background:var(--bone);border-top:1px solid var(--navy);border-bottom:1px solid var(--navy)}
  .related .rel-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:32px;border-bottom:1px solid var(--navy);padding-bottom:16px}
  .related .rel-head h2{font-family:var(--head);font-weight:600;font-size:28px;letter-spacing:-.02em;color:var(--navy)}
  .related .rel-head h2 i{font-family:var(--serif);font-style:italic;color:var(--steel);font-weight:400}
  .related .rel-head a{font-family:var(--head);font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:600;color:var(--navy);border-bottom:1px solid var(--navy);padding-bottom:2px}
  .rel-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--fog);border:1px solid var(--navy)}
  .rel-card{background:var(--milk);padding:24px 22px;display:flex;flex-direction:column;transition:background .2s var(--ease)}
  .rel-card:hover{background:var(--white)}
  .rel-card .meta{font-family:var(--head);font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--steel);font-weight:600;margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid var(--fog);display:flex;justify-content:space-between;align-items:baseline}
  .rel-card .meta em{font-family:var(--serif);font-style:italic;color:var(--warm);text-transform:none;letter-spacing:.02em;font-weight:400;font-size:11px}
  .rel-card h3{font-family:var(--head);font-weight:600;font-size:17px;letter-spacing:-.01em;line-height:1.22;margin-bottom:10px}
  .rel-card h3 i{font-family:var(--serif);font-style:italic;color:var(--steel);font-weight:400}
  .rel-card p{font-size:13.5px;color:var(--steel);line-height:1.55}

  @media(max-width:1100px){
    .art-grid{grid-template-columns:1fr;gap:48px}
    .art-side{position:static}
    .art-hero h1{font-size:44px}
    .rel-grid{grid-template-columns:1fr}
  }
  @media(max-width:680px){
    .art-hero{padding:48px 0 36px}
    .art-hero h1{font-size:32px}
    .art-body{font-size:16px}
    .art-body h2{font-size:24px;grid-template-columns:1fr;gap:6px}
    .data-row{grid-template-columns:1fr}
    .callout{grid-template-columns:1fr}
    .callout .label{writing-mode:horizontal-tb;transform:none;padding:14px 22px;text-align:left;justify-content:flex-start}
  }


/* ===== FAQ on blog posts (uses <details>/summary) ===== */
.faq-list details{border-bottom:1px solid var(--fog);padding:18px 0}
.faq-list summary{list-style:none;cursor:pointer;display:grid;grid-template-columns:auto 1fr auto;gap:18px;align-items:baseline;font-family:var(--head);font-weight:500;font-size:18px;letter-spacing:-.01em;color:var(--navy);line-height:1.4}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary .n{font-family:var(--head);font-size:11px;letter-spacing:.22em;color:var(--warm);font-weight:600}
.faq-list summary .mk{font-family:var(--head);font-size:18px;color:var(--steel);font-weight:400;transition:transform .2s var(--ease)}
.faq-list details[open] summary .mk{transform:rotate(45deg);color:var(--warm)}
.faq-list details > div{padding:16px 0 8px 62px;color:var(--steel);font-size:15px;line-height:1.7}
.faq-list details > div strong{color:var(--navy);font-weight:500}
@media(max-width:680px){.faq-list details > div{padding-left:0}.faq-list summary{font-size:16px;grid-template-columns:auto 1fr auto;gap:12px}}

/* Body styles for rich prose shipped in $post['body'] -- fallback when headings don't carry section numbers */
.art-body > h2:not([class]){display:block;margin-top:54px;margin-bottom:18px}
.art-body > h3:not([class]){margin-top:36px;margin-bottom:12px}
.art-body > p + ul,.art-body > ul{margin:0 0 24px;padding-left:0}
.art-body > ol{margin:0 0 24px;padding-left:22px;color:var(--steel)}
.art-body > ol li{padding:6px 0;line-height:1.65}
