/* ============================================================
   Ease Essence — blog / journal styles (loads after styles.css)
   ============================================================ */

.blogwrap { max-width: 1100px; margin-inline: auto; padding-inline: 24px; }
.article { max-width: 760px; margin-inline: auto; padding-inline: 24px; }

/* breadcrumb */
.crumbs { font-size: .85rem; color: var(--ink-soft); padding: 1.4rem 0 0; }
.crumbs a { color: var(--blue-d); font-weight: 500; }
.crumbs a:hover { text-decoration: underline; }
.crumbs span { margin: 0 .35rem; color: #B7C4CC; }

/* ---------- blog index ---------- */
.blog-hero { text-align: center; padding: 3rem 0 1rem; }
.blog-hero .kicker { color: var(--green-d); }
.blog-hero h1 { font-size: clamp(2.1rem, 4.4vw, 3.1rem); margin: .6rem 0 0; color: var(--ink); }
.blog-hero p { color: var(--ink-soft); font-size: 1.1rem; max-width: 56ch; margin: 1rem auto 0; }

.featured { display: grid; grid-template-columns: 1.15fr .85fr; gap: 1.8rem; align-items: stretch; margin: 2.4rem 0 3rem; background: #fff; border: 1px solid var(--line); border-radius: var(--r-xl); overflow: hidden; box-shadow: var(--shadow); }
.featured__img { overflow: hidden; min-height: 280px; }
.featured__img img { width: 100%; height: 100%; object-fit: cover; }
.featured__body { padding: 2.4rem; display: flex; flex-direction: column; justify-content: center; }
.featured__body .post__cat { color: var(--green-d); }
.featured__body h2 { font-size: clamp(1.5rem, 3vw, 2.1rem); margin: .5rem 0 .7rem; color: var(--ink); line-height: 1.18; }
.featured__body p { color: var(--ink-soft); margin: 0 0 1.4rem; }

.cat-bar { display: flex; flex-wrap: wrap; gap: .6rem; justify-content: center; margin-bottom: 2.4rem; }
.cat-bar a { font-size: .9rem; font-weight: 600; color: var(--ink-soft); background: var(--mist); border: 1px solid var(--line); padding: .5rem 1rem; border-radius: 999px; }
.cat-bar a:hover, .cat-bar a.is-on { background: var(--green); color: #fff; border-color: transparent; }

.blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; padding-bottom: 4rem; }
.meta-row { display: flex; align-items: center; gap: .5rem; font-size: .82rem; color: var(--ink-soft); margin-top: .2rem; }
.meta-row .dot { width: 3px; height: 3px; border-radius: 50%; background: #C2CDD4; }

/* ---------- article ---------- */
.art-head { text-align: center; padding: 1.2rem 0 1.6rem; }
.art-cat { font-size: .76rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--green-d); }
.art-head h1 { font-size: clamp(2rem, 4.2vw, 3rem); line-height: 1.12; margin: .7rem 0 1rem; color: var(--ink); }
.art-meta { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: .6rem; font-size: .9rem; color: var(--ink-soft); }
.art-meta .av { width: 30px; height: 30px; border-radius: 50%; background: var(--grad); color: #fff; display: inline-grid; place-items: center; font-weight: 700; font-size: .8rem; }
.art-meta .dot { width: 3px; height: 3px; border-radius: 50%; background: #C2CDD4; }
.art-cover { border-radius: var(--r-lg); overflow: hidden; margin: 1.8rem 0 2.4rem; box-shadow: var(--shadow); aspect-ratio: 16/8; }
.art-cover img { width: 100%; height: 100%; object-fit: cover; }

/* key takeaways (AI-citation friendly) */
.takeaways { background: var(--mist-2); border: 1px solid var(--line); border-left: 4px solid var(--green); border-radius: var(--r); padding: 1.4rem 1.6rem; margin: 0 0 2rem; }
.takeaways h2 { font-size: 1.05rem; margin: 0 0 .7rem; color: var(--ink); display: flex; align-items: center; gap: .5rem; }
.takeaways ul { margin: 0; padding-left: 1.2rem; }
.takeaways li { color: var(--ink); margin: .4rem 0; font-size: .98rem; }

/* prose */
.prose { color: #34424C; font-size: 1.08rem; line-height: 1.75; }
.prose > h2 { font-size: 1.62rem; color: var(--ink); margin: 2.4rem 0 .8rem; }
.prose > h3 { font-size: 1.26rem; color: var(--ink); margin: 1.8rem 0 .6rem; }
.prose p { margin: 0 0 1.15rem; }
.prose a { color: var(--blue-d); font-weight: 500; text-decoration: underline; text-underline-offset: 2px; }
.prose ul, .prose ol { margin: 0 0 1.2rem; padding-left: 1.4rem; }
.prose li { margin: .45rem 0; }
.prose strong { color: var(--ink); }
.prose blockquote { margin: 1.6rem 0; padding: 1rem 1.4rem; border-left: 4px solid var(--blue); background: var(--blue-l); border-radius: 0 var(--r) var(--r) 0; font-size: 1.1rem; color: var(--ink); }
.prose figure { margin: 1.8rem 0; }
.prose figure img { border-radius: var(--r); box-shadow: var(--shadow); }
.prose figcaption { font-size: .85rem; color: var(--ink-soft); text-align: center; margin-top: .6rem; }
.prose table { width: 100%; border-collapse: collapse; margin: 1.6rem 0; font-size: .98rem; }
.prose th, .prose td { border: 1px solid var(--line); padding: .7rem .9rem; text-align: left; }
.prose th { background: var(--mist); font-family: var(--display); }

/* callout */
.callout { background: #fff; border: 1px solid var(--line); border-radius: var(--r); padding: 1.3rem 1.5rem; margin: 1.8rem 0; }
.callout strong { color: var(--green-d); }

/* inline product CTA */
.art-cta { display: grid; grid-template-columns: auto 1fr auto; gap: 1.2rem; align-items: center; background: var(--grad); color: #fff; border-radius: var(--r-lg); padding: 1.6rem 1.8rem; margin: 2.6rem 0; box-shadow: var(--shadow); }
.art-cta img { height: 64px; width: 64px; object-fit: contain; background:#fff; border-radius: 14px; padding: 6px; }
.art-cta h3 { color: #fff; margin: 0 0 .2rem; font-size: 1.2rem; }
.art-cta p { margin: 0; color: rgba(255,255,255,.92); font-size: .92rem; }
.art-cta .btn { white-space: nowrap; }

/* author / disclaimer */
.art-foot { border-top: 1px solid var(--line); margin-top: 2.6rem; padding-top: 1.6rem; }
.art-disc { font-size: .84rem; color: var(--ink-soft); background: var(--mist); border-radius: var(--r); padding: 1rem 1.2rem; margin-top: 1.4rem; }

/* article FAQ reuse .faq from styles.css; add heading spacing */
.art-faq { margin: 2.6rem 0 0; }
.art-faq h2 { font-size: 1.5rem; color: var(--ink); margin: 0 0 1rem; }

/* related */
.related { background: var(--mist); padding: 3.4rem 0; margin-top: 3rem; }
.related h2 { text-align: center; font-size: 1.6rem; color: var(--ink); margin: 0 0 1.8rem; }
.related-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.4rem; }

@media (max-width: 860px) {
  .blog-grid, .related-grid { grid-template-columns: repeat(2, 1fr); }
  .featured { grid-template-columns: 1fr; }
  .featured__img { min-height: 220px; }
  .art-cta { grid-template-columns: 1fr; text-align: center; justify-items: center; }
}
@media (max-width: 560px) {
  .blog-grid, .related-grid { grid-template-columns: 1fr; }
}
