/* ============================================================================
   Таро-Нейро — BLOG article styles (поверх /assets/design.css + /course/lesson.css)
   Одноколоночный лонгрид. Переиспользует типографику .content и блоки из lesson.css.
   ============================================================================ */

.article-wrap{position:relative; z-index:2; max-width:780px; margin:0 auto; padding:112px 24px 40px}

/* breadcrumb уже есть как .crumb в lesson.css; здесь чуть отступа */
.article-wrap .crumb{margin-bottom:18px}

/* ── Hero ── */
.bhero{margin:0 0 26px; border-radius:var(--radius); overflow:hidden; border:1px solid var(--line); position:relative; aspect-ratio:1536/1024; background:var(--bg-soft)}
.bhero img{width:100%; height:100%; object-fit:cover; display:block}
.bhero figcaption{position:absolute; left:0; right:0; bottom:0; padding:10px 14px; font-size:.82rem; color:var(--soft); background:linear-gradient(0deg,rgba(10,9,22,.78),transparent)}

/* ── Заголовок и мета ── */
.article-wrap h1{font-size:clamp(2rem,4.4vw,2.9rem); margin:0 0 .35em; line-height:1.12}
.article-wrap h1 .irid{background-image:var(--irid); background-size:220% auto; -webkit-background-clip:text; background-clip:text; color:transparent; -webkit-text-fill-color:transparent; animation:irid 7s linear infinite}
.bmeta{display:flex; align-items:center; gap:14px; flex-wrap:wrap; color:var(--muted); font-size:.86rem; margin-bottom:24px}
.bmeta .tag{font-family:var(--mono); text-transform:uppercase; letter-spacing:.1em; font-size:.7rem; color:var(--accent); background:var(--accent-soft); border:1px solid var(--line); padding:4px 10px; border-radius:999px}

/* ── TL;DR ── */
.tldr{margin:0 0 24px; padding:18px 22px; border-radius:var(--radius); background:var(--surface); border:1px solid var(--line); border-left:3px solid var(--gold)}
.tldr-title{font-family:var(--mono); text-transform:uppercase; letter-spacing:.14em; font-size:.7rem; color:var(--gold); margin-bottom:.6em}
.tldr ul{margin:0; padding-left:20px} .tldr li{color:var(--ink); margin-bottom:.45em; font-size:1rem; line-height:1.55} .tldr li:last-child{margin-bottom:0}

/* ── Оглавление ── */
.toc{margin:0 0 30px; padding:18px 22px; border-radius:var(--radius); background:var(--bg-soft); border:1px solid var(--line)}
.toc-title{font-family:var(--mono); text-transform:uppercase; letter-spacing:.14em; font-size:.7rem; color:var(--muted); margin-bottom:.7em}
.toc ol{margin:0; padding-left:20px; columns:2; column-gap:28px}
.toc li{margin-bottom:.4em} .toc a{color:var(--soft); text-decoration:none; font-size:.93rem; line-height:1.4} .toc a:hover{color:var(--ink)}
@media(max-width:560px){.toc ol{columns:1}}

/* ── Inline CTA-блоки ── */
.article-cta{position:relative; margin:2em 0; padding:24px 26px; border-radius:var(--radius); background:var(--bg-soft); text-align:center}
.article-cta::before{content:""; position:absolute; inset:0; padding:1px; border-radius:inherit; background:var(--irid); background-size:220% auto; animation:irid 7s linear infinite; -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0); -webkit-mask-composite:xor; mask-composite:exclude; pointer-events:none}
.article-cta b{display:block; font-family:var(--font-display); font-size:1.25rem; color:var(--ink); margin-bottom:.3em}
.article-cta p{color:var(--soft); margin:0 0 1em; font-size:.98rem}
.article-cta.mini{background:var(--surface); text-align:left; display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap}
.article-cta.mini::before{display:none}
.article-cta.mini b{margin:0; font-size:1.05rem}
.article-cta.mini .btn{flex:0 0 auto}
/* перебить .content a (specificity) — иначе текст кнопки красится в --accent и подчёркивается */
.article-cta .btn, .content a.btn{color:#fff; text-decoration:none}
.article-cta .btn:hover{color:#fff; text-decoration:none}

/* ── «Читайте также» ── */
.related{margin-top:44px; padding-top:28px; border-top:1px solid var(--line)}
.related h2{font-size:1.4rem; margin-bottom:18px}
.related-grid{display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:14px}
.related-card{display:block; padding:18px 20px; border-radius:var(--radius); background:var(--surface); border:1px solid var(--line); text-decoration:none; transition:transform .25s, border-color .25s, background .25s}
.related-card:hover{transform:translateY(-2px); border-color:var(--accent); background:var(--accent-soft)}
.related-card .rt{font-family:var(--mono); text-transform:uppercase; letter-spacing:.1em; font-size:.66rem; color:var(--accent); margin-bottom:.5em}
.related-card b{display:block; font-family:var(--font-display); color:var(--ink); font-size:1.02rem; line-height:1.3; margin-bottom:.35em}
.related-card span{color:var(--muted); font-size:.86rem; line-height:1.45}

/* ── disclaimer-сноска ── */
.bdisc{margin:2em 0 0; padding:14px 18px; border-radius:var(--radius-sm); background:var(--surface); border:1px solid var(--line); color:var(--muted); font-size:.86rem; line-height:1.55}

/* ── BLOG INDEX (хаб) ── */
.bloghub{position:relative; z-index:2; max-width:1080px; margin:0 auto; padding:122px 24px 50px}
.bloghub-head{text-align:center; max-width:640px; margin:0 auto 40px}
.bloghub-head h1{font-size:clamp(2.1rem,5vw,3.1rem); margin-bottom:.35em}
.bloghub-head h1 .irid{background-image:var(--irid); background-size:220% auto; -webkit-background-clip:text; background-clip:text; color:transparent; -webkit-text-fill-color:transparent; animation:irid 7s linear infinite}
.bloghub-head p{color:var(--soft); font-size:1.05rem}
.post-grid{display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:20px}
.post-card{display:flex; flex-direction:column; border-radius:var(--radius); overflow:hidden; background:var(--surface); border:1px solid var(--line); text-decoration:none; transition:transform .25s, border-color .25s}
.post-card:hover{transform:translateY(-3px); border-color:var(--accent)}
.post-card .pc-img{aspect-ratio:1536/1024; background:var(--bg-soft); overflow:hidden}
.post-card .pc-img img{width:100%; height:100%; object-fit:cover; display:block}
.post-card .pc-body{padding:18px 20px; display:flex; flex-direction:column; gap:8px; flex:1}
.post-card .pc-tag{font-family:var(--mono); text-transform:uppercase; letter-spacing:.1em; font-size:.66rem; color:var(--accent)}
.post-card h2{font-size:1.16rem; line-height:1.25; color:var(--ink); margin:0}
.post-card p{color:var(--soft); font-size:.92rem; line-height:1.5; margin:0}
.post-card .pc-meta{margin-top:auto; padding-top:6px; color:var(--muted); font-size:.82rem}
