/* ==========================================================================
   SINGLE BLOG / JOURNAL POST — ported from design/blog-single-mockup.html.
   Renders standard WordPress/Gutenberg post content in the brand design
   language. Loads only on single posts. Prefix: aaa-bl-
   Uses the --aaa-* design tokens.
   ========================================================================== */

.aaa-bl-single{--bl-readw:760px}
.aaa-bl-single em{font-style:italic}

/* reading progress bar */
.aaa-bl-progress{position:fixed;top:0;left:0;height:4px;width:0;background:linear-gradient(90deg,var(--aaa-blue),var(--aaa-gold));z-index:65;transition:width .1s}

/* ── HERO ── */
.aaa-bl-hero{padding:42px 0 0}
.aaa-bl-crumb{font-size:.9rem;color:var(--aaa-ink-soft);display:flex;gap:8px;flex-wrap:wrap;font-weight:500;margin-bottom:20px}
.aaa-bl-crumb a:hover{color:var(--aaa-blue)}
.aaa-bl-crumb .sep{opacity:.5}
.aaa-bl-head{max-width:840px}
.aaa-bl-cat{display:inline-block;background:var(--aaa-sky);color:var(--aaa-blue-ink);font-size:.74rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:7px 15px;border-radius:50px;margin-bottom:18px}
.aaa-bl-head h1{font-size:clamp(2.2rem,4.6vw,3.5rem);margin:0 0 18px;font-family:var(--aaa-serif);line-height:1.12}
.aaa-bl-dek{font-size:1.25rem;color:var(--aaa-ink-soft);line-height:1.6;max-width:64ch}
.aaa-bl-meta{display:flex;align-items:center;gap:14px;margin:26px 0 30px;flex-wrap:wrap}
.aaa-bl-meta .av{width:50px;height:50px;border-radius:50%;background:linear-gradient(135deg,var(--aaa-sky),#cfe0f5);display:grid;place-items:center;font-family:var(--aaa-serif);color:var(--aaa-blue);font-weight:700;font-size:1.1rem;flex-shrink:0;overflow:hidden}
.aaa-bl-meta .av img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.aaa-bl-meta .by b{font-weight:700;display:block;font-size:.98rem;color:var(--aaa-ink)}
.aaa-bl-meta .by small{color:var(--aaa-ink-soft);font-size:.86rem}
.aaa-bl-meta .dot{width:4px;height:4px;border-radius:50%;background:var(--aaa-line)}
.aaa-bl-meta .mi{font-size:.9rem;color:var(--aaa-ink-soft);font-weight:500}

.aaa-bl-feat{border-radius:var(--aaa-radius);overflow:hidden;box-shadow:var(--aaa-shadow);margin:6px 0 0;aspect-ratio:16/8}
.aaa-bl-feat img{width:100%;height:100%;object-fit:cover}
.aaa-bl-feat-cap{font-size:.84rem;color:var(--aaa-ink-soft);text-align:center;margin-top:12px;font-style:italic}

/* ── LAYOUT ── */
.aaa-bl-layout{display:grid;grid-template-columns:1fr 300px;gap:60px;align-items:start;padding:54px 0 40px}

/* ── ARTICLE (the_content) ── */
.aaa-bl-article{max-width:var(--bl-readw);font-size:1.12rem;line-height:1.8;color:#22324a}
.aaa-bl-article > *{margin-bottom:24px}
.aaa-bl-article > *:last-child{margin-bottom:0}
.aaa-bl-article p{margin:0 0 24px}
.aaa-bl-article > p:first-of-type{font-size:1.3rem;line-height:1.6;color:var(--aaa-ink);font-weight:500} /* auto-lead */
.aaa-bl-article h2{font-family:var(--aaa-serif);font-size:1.9rem;margin:44px 0 14px;color:var(--aaa-ink);line-height:1.18;scroll-margin-top:110px}
.aaa-bl-article h3{font-family:var(--aaa-serif);font-size:1.4rem;margin:32px 0 10px;color:var(--aaa-ink);scroll-margin-top:110px}
.aaa-bl-article h4{font-family:var(--aaa-serif);font-size:1.18rem;margin:26px 0 8px;color:var(--aaa-ink);scroll-margin-top:110px}
.aaa-bl-article strong,.aaa-bl-article b{color:var(--aaa-ink)}
.aaa-bl-article a{color:var(--aaa-blue);font-weight:600;border-bottom:1px solid rgba(23,129,254,.35);transition:.2s}
.aaa-bl-article a:hover{border-bottom-color:var(--aaa-blue)}
.aaa-bl-article ul,.aaa-bl-article ol{margin:0 0 24px;padding-left:26px}
.aaa-bl-article li{margin-bottom:10px}
.aaa-bl-article ul li::marker{color:var(--aaa-blue)}
.aaa-bl-article ol li::marker{color:var(--aaa-blue);font-weight:700}

/* images / figures (Gutenberg) */
.aaa-bl-article figure,.aaa-bl-article .wp-block-image{margin:34px 0}
.aaa-bl-article img{max-width:100%;height:auto;border-radius:14px}
.aaa-bl-article figure img,.aaa-bl-article .wp-block-image img{box-shadow:var(--aaa-shadow-sm)}
.aaa-bl-article figcaption{font-size:.86rem;color:var(--aaa-ink-soft);text-align:center;margin-top:10px;font-style:italic}

/* blockquote / pullquote */
.aaa-bl-article blockquote,.aaa-bl-article .wp-block-quote{margin:38px 0;padding:8px 0 8px 30px;border-left:5px solid var(--aaa-gold);font-family:var(--aaa-serif);font-style:italic;font-size:1.6rem;line-height:1.45;color:var(--aaa-ink)}
.aaa-bl-article blockquote p{margin-bottom:10px;font-size:inherit}
.aaa-bl-article blockquote cite,.aaa-bl-article .wp-block-quote cite{display:block;font-family:var(--aaa-sans);font-style:normal;font-size:.95rem;color:var(--aaa-ink-soft);font-weight:600;margin-top:12px}
.aaa-bl-article .wp-block-pullquote{border:none;border-left:5px solid var(--aaa-blue);background:var(--aaa-mist);border-radius:0 14px 14px 0;padding:26px 30px;text-align:left}
.aaa-bl-article .wp-block-pullquote p{font-family:var(--aaa-serif);font-style:italic;font-size:1.5rem;color:var(--aaa-ink)}

/* tables */
.aaa-bl-article table,.aaa-bl-article .wp-block-table table{width:100%;border-collapse:collapse;font-size:1rem}
.aaa-bl-article th,.aaa-bl-article td{padding:12px 14px;border:1px solid var(--aaa-line);text-align:left}
.aaa-bl-article thead th{background:var(--aaa-mist);font-family:var(--aaa-sans);color:var(--aaa-ink);font-weight:700}

/* optional editor callout boxes (author can add via a Group block + class) */
.aaa-bl-article .aaa-bl-tip,.aaa-bl-article .aaa-bl-key{border-radius:14px;padding:24px 28px;margin:34px 0;font-size:1rem;line-height:1.7}
.aaa-bl-article .aaa-bl-tip{background:var(--aaa-sand)}
.aaa-bl-article .aaa-bl-tip b,.aaa-bl-article .aaa-bl-tip strong{color:var(--aaa-gold-deep)}
.aaa-bl-article .aaa-bl-key{background:var(--aaa-mist);border:1px solid var(--aaa-line)}

/* tags */
.aaa-bl-tags{display:flex;flex-wrap:wrap;gap:10px;margin:42px 0 0}
.aaa-bl-tags a{font-size:.84rem;font-weight:600;color:var(--aaa-ink-soft);background:var(--aaa-mist);border:1px solid var(--aaa-line);padding:7px 15px;border-radius:50px;text-decoration:none}
.aaa-bl-tags a:hover{color:var(--aaa-blue);border-color:var(--aaa-blue)}

/* ── SIDEBAR ── */
.aaa-bl-side{position:sticky;top:100px;display:grid;gap:22px}
.aaa-bl-share{border:1px solid var(--aaa-line);border-radius:16px;padding:20px}
.aaa-bl-share p{font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;color:var(--aaa-ink-soft);margin:0 0 14px}
.aaa-bl-share-row{display:flex;gap:10px;flex-wrap:wrap}
.aaa-bl-share-row a,.aaa-bl-share-row button{width:42px;height:42px;border-radius:50%;border:1px solid var(--aaa-line);display:grid;place-items:center;font-weight:700;font-size:.92rem;color:var(--aaa-ink-soft);transition:.2s;background:#fff;cursor:pointer;text-decoration:none;font-family:var(--aaa-sans)}
.aaa-bl-share-row a:hover,.aaa-bl-share-row button:hover{background:var(--aaa-blue);color:#fff;border-color:var(--aaa-blue)}
.aaa-bl-toc{border:1px solid var(--aaa-line);border-radius:16px;padding:22px}
.aaa-bl-toc h4{font-family:var(--aaa-sans);font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--aaa-blue);margin:0 0 14px}
.aaa-bl-toc a{display:block;font-size:.95rem;color:var(--aaa-ink-soft);padding:7px 0;border-bottom:1px solid var(--aaa-line);font-weight:500;text-decoration:none;transition:.2s}
.aaa-bl-toc a:last-child{border-bottom:none}
.aaa-bl-toc a:hover,.aaa-bl-toc a.active{color:var(--aaa-blue);padding-left:5px}
.aaa-bl-sidecta{background:var(--aaa-navy);color:#fff;border-radius:18px;padding:26px}
.aaa-bl-sidecta .aaa-eyebrow{color:var(--aaa-gold)}
.aaa-bl-sidecta h4{font-family:var(--aaa-serif);font-size:1.35rem;color:#fff;margin:8px 0}
.aaa-bl-sidecta p{font-size:.92rem;opacity:.85;margin:0 0 18px}
.aaa-bl-sidecta .aaa-btn{width:100%;font-size:.95rem;padding:.9em 1.4em}

/* ── AUTHOR ── */
.aaa-bl-author{background:var(--aaa-mist);border-radius:20px;padding:34px;display:flex;gap:24px;align-items:center}
.aaa-bl-author .av{width:84px;height:84px;border-radius:50%;background:linear-gradient(135deg,var(--aaa-sky),#cfe0f5);display:grid;place-items:center;font-family:var(--aaa-serif);color:var(--aaa-blue);font-weight:700;font-size:1.9rem;flex-shrink:0;overflow:hidden}
.aaa-bl-author .av img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.aaa-bl-author .aaa-eyebrow{margin-bottom:4px}
.aaa-bl-author h3{font-family:var(--aaa-serif);font-size:1.4rem;margin:0 0 6px;color:var(--aaa-ink)}
.aaa-bl-author p{color:var(--aaa-ink-soft);font-size:.98rem;margin:0 0 10px}
.aaa-bl-author .links a{color:var(--aaa-blue);font-weight:600;font-size:.9rem;margin-right:16px;text-decoration:none}

/* ── CONTEXTUAL CTA BAND ── */
.aaa-bl-ctaband{position:relative;color:#fff;overflow:hidden;border-radius:24px}
.aaa-bl-ctaband .bg{position:absolute;inset:0}
.aaa-bl-ctaband .bg img{width:100%;height:100%;object-fit:cover}
.aaa-bl-ctaband .bg::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(7,18,38,.92),rgba(11,91,211,.78))}
.aaa-bl-ctaband .in{position:relative;z-index:2;padding:48px 44px;display:flex;justify-content:space-between;align-items:center;gap:30px;flex-wrap:wrap}
.aaa-bl-ctaband h3{font-family:var(--aaa-serif);font-size:clamp(1.6rem,2.6vw,2.2rem);color:#fff;margin:0}
.aaa-bl-ctaband h3 em{font-style:italic;color:var(--aaa-gold)}
.aaa-bl-ctaband p{opacity:.9;margin:8px 0 0;max-width:46ch}

/* ── RELATED ── */
.aaa-bl-related{background:var(--aaa-mist)}
.aaa-bl-post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.aaa-bl-card{background:#fff;border:1px solid var(--aaa-line);border-radius:var(--aaa-radius);overflow:hidden;transition:.3s;display:flex;flex-direction:column;text-decoration:none}
.aaa-bl-card:hover{transform:translateY(-6px);box-shadow:var(--aaa-shadow)}
.aaa-bl-card .ph{aspect-ratio:16/10;overflow:hidden;position:relative;background:var(--aaa-sky)}
.aaa-bl-card .ph img{width:100%;height:100%;object-fit:cover;transition:.5s}
.aaa-bl-card:hover .ph img{transform:scale(1.06)}
.aaa-bl-card .ph .cat{position:absolute;top:12px;left:12px;background:rgba(255,255,255,.92);color:var(--aaa-blue-ink);font-size:.7rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:5px 11px;border-radius:50px}
.aaa-bl-card .b{padding:20px 22px 24px;display:flex;flex-direction:column;flex:1}
.aaa-bl-card .b .m{font-size:.82rem;color:var(--aaa-ink-soft);margin-bottom:8px;font-weight:500}
.aaa-bl-card h3{font-family:var(--aaa-serif);font-size:1.2rem;line-height:1.25;margin:0 0 10px;color:var(--aaa-ink)}
.aaa-bl-card:hover h3{color:var(--aaa-blue)}
.aaa-bl-card .b p{font-size:.93rem;color:var(--aaa-ink-soft);margin:0 0 16px}
.aaa-bl-card .rd{margin-top:auto;color:var(--aaa-blue);font-weight:700;font-size:.9rem}

/* ── NEWSLETTER ── */
.aaa-bl-news{background:var(--aaa-navy);color:#fff;text-align:center}
.aaa-bl-news .aaa-eyebrow{color:var(--aaa-gold)}
.aaa-bl-news h2{font-family:var(--aaa-serif);font-size:clamp(1.9rem,3.4vw,2.6rem);color:#fff;margin:12px 0 0}
.aaa-bl-news h2 em{font-style:italic;color:var(--aaa-gold)}
.aaa-bl-news p{opacity:.86;max-width:52ch;margin:14px auto 26px}
.aaa-bl-news form{display:flex;gap:12px;max-width:520px;margin:0 auto;flex-wrap:wrap}
.aaa-bl-news input{flex:1;min-width:220px;padding:15px 20px;border-radius:50px;border:none;font-family:var(--aaa-sans);font-size:1rem;outline:none}
.aaa-bl-news small{display:block;opacity:.6;font-size:.8rem;margin-top:14px}
.aaa-bl-news .aaa-form-msg{margin-top:14px;font-weight:600;min-height:1em}

/* ── Responsive ── */
@media(max-width:980px){
  .aaa-bl-layout{grid-template-columns:1fr;gap:34px}
  .aaa-bl-side{position:static;display:grid;grid-template-columns:1fr 1fr;gap:18px}
  .aaa-bl-toc{display:none}
  .aaa-bl-post-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .aaa-bl-side{grid-template-columns:1fr}
  .aaa-bl-post-grid{grid-template-columns:1fr}
  .aaa-bl-author{flex-direction:column;text-align:center}
  .aaa-bl-ctaband .in{flex-direction:column;text-align:center}
  .aaa-bl-feat{aspect-ratio:16/10}
}
