/* =========================================================
   Blog styles — extends styles.css (same palette & fonts)
   ========================================================= */

.blogwrap { max-width: 760px; margin: 0 auto; padding: 40px 24px 0; }
.blogwrap--wide { max-width: 1100px; }

/* breadcrumb */
.crumbs { font-size: 0.85rem; color: var(--ink-soft); margin: 18px 0 26px; display: flex; gap: 8px; flex-wrap: wrap; }
.crumbs a { color: var(--emerald); }
.crumbs span { opacity: 0.5; }

/* article header */
.post__cat {
  display: inline-block; font-size: 0.74rem; font-weight: 700; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--emerald); background: var(--mint-2);
  padding: 6px 12px; border-radius: 100px; margin-bottom: 18px;
}
.post__title {
  font-family: var(--font-display); font-weight: 800; letter-spacing: -0.02em;
  font-size: clamp(2rem, 5vw, 3rem); line-height: 1.05; margin-bottom: 16px;
}
.post__meta { display: flex; gap: 16px; flex-wrap: wrap; color: var(--ink-soft); font-size: 0.9rem; margin-bottom: 26px; }
.post__meta b { color: var(--forest); font-weight: 600; }

/* disclaimer banner */
.notice {
  display: flex; gap: 12px; background: #fff7ec; border: 1px solid #f3dcae;
  border-radius: 14px; padding: 14px 16px; font-size: 0.92rem; color: #7a5a1e; margin: 0 0 30px;
}
.notice strong { color: #6b4d12; }

/* article body typography */
.post__body { font-size: 1.08rem; color: #243a31; }
.post__body > p { margin: 0 0 20px; }
.post__body h2 {
  font-family: var(--font-display); font-weight: 700; letter-spacing: -0.01em;
  font-size: 1.7rem; line-height: 1.15; margin: 46px 0 14px; scroll-margin-top: 90px;
}
.post__body h3 { font-family: var(--font-display); font-weight: 600; font-size: 1.25rem; margin: 30px 0 10px; }
.post__body a { color: var(--emerald); text-decoration: underline; text-underline-offset: 3px; text-decoration-thickness: 1.5px; }
.post__body a:hover { color: var(--forest); }
.post__body strong { color: var(--forest); }
.post__body ul, .post__body ol { margin: 0 0 22px; padding-left: 22px; }
.post__body li { margin-bottom: 9px; }
.post__body img { border-radius: 16px; margin: 8px 0; }

/* lead paragraph */
.post__lead { font-size: 1.22rem; line-height: 1.5; color: var(--ink); margin-bottom: 28px; }

/* table of contents */
.toc {
  background: var(--paper); border: 1px solid var(--line); border-radius: 16px;
  padding: 20px 24px; margin: 0 0 36px;
}
.toc p { font-family: var(--font-display); font-weight: 700; margin-bottom: 10px; font-size: 0.95rem; }
.toc ol { margin: 0; padding-left: 18px; columns: 2; gap: 24px; }
.toc li { margin-bottom: 6px; font-size: 0.95rem; }
.toc a { color: var(--ink-soft); text-decoration: none; }
.toc a:hover { color: var(--emerald); }

/* "at a glance" card */
.glance {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(140px,1fr)); gap: 12px;
  background: var(--mint-2); border-radius: 18px; padding: 22px; margin: 28px 0;
}
.glance div { display: flex; flex-direction: column; gap: 3px; }
.glance span { font-size: 0.74rem; text-transform: uppercase; letter-spacing: 0.05em; color: var(--ink-soft); }
.glance b { font-family: var(--font-display); font-size: 1.05rem; color: var(--forest); }

/* figure / image placeholder */
.figure { margin: 26px 0; }
.figure img { width: 100%; height: auto; border-radius: 16px; display: block; }
.figure__ph {
  position: relative; border-radius: 16px; overflow: hidden; min-height: 220px;
  display: grid; place-items: center; text-align: center; padding: 26px;
  background: linear-gradient(150deg, #f0d9cb, #e7c2ab); color: #7a4a32;
}
.figure__ph--skin { background: linear-gradient(150deg, #f2dccd, #e4bca3); }
.figure figcaption { font-size: 0.86rem; color: var(--ink-soft); margin-top: 9px; padding-left: 2px; }
/* simple CSS bite illustrations */
.bite-illus { display: flex; gap: 18px; align-items: center; justify-content: center; }
.spot { border-radius: 50%; }
.spot--mosq { width: 46px; height: 46px; background: radial-gradient(circle, #d6432e, #e3795f 62%, transparent 74%); box-shadow: 0 0 0 8px rgba(214,67,46,0.14); }
.spot--bed { width: 26px; height: 26px; background: radial-gradient(circle, #c43a28, #e0795f 65%); }
.spot--sm { width: 16px; height: 16px; background: radial-gradient(circle, #cf4030, #e07a60); }

/* comparison table */
.tablewrap { overflow-x: auto; margin: 28px 0; border-radius: 14px; border: 1px solid var(--line); }
table.cmp { width: 100%; border-collapse: collapse; font-size: 0.96rem; min-width: 520px; }
table.cmp th, table.cmp td { text-align: left; padding: 13px 16px; border-bottom: 1px solid var(--line); }
table.cmp thead th { background: var(--forest); color: #fff; font-family: var(--font-display); font-weight: 600; }
table.cmp tbody tr:nth-child(even) { background: var(--mint-2); }
table.cmp td:first-child { font-weight: 600; color: var(--forest); }

/* callout / key takeaway */
.callout {
  border-left: 4px solid var(--leaf); background: var(--mint-2);
  padding: 16px 20px; border-radius: 0 14px 14px 0; margin: 26px 0;
}
.callout p { margin: 0; }

/* in-article CTA */
.appcta {
  background: linear-gradient(150deg, var(--emerald), var(--forest)); color: #fff;
  border-radius: 22px; padding: 30px 28px; margin: 38px 0; text-align: center;
}
.appcta h3 { font-family: var(--font-display); font-weight: 700; font-size: 1.45rem; color: #fff; margin-bottom: 8px; }
.appcta p { opacity: 0.85; margin-bottom: 20px; max-width: 46ch; margin-inline: auto; }
.appcta .btn { background: #fff; color: var(--forest); }

/* FAQ reuse from styles.css .faq; add spacing */
.post__body .faq { margin: 18px 0 10px; }

/* related posts */
.related { border-top: 1px solid var(--line); margin-top: 50px; padding-top: 36px; }
.related h2 { font-family: var(--font-display); font-size: 1.5rem; margin-bottom: 20px; }
.related__grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px,1fr)); gap: 16px; }
.rcard {
  display: block; background: var(--paper); border: 1px solid var(--line); border-radius: 16px;
  padding: 20px; transition: transform 0.35s var(--ease), box-shadow 0.35s var(--ease); text-decoration: none !important;
}
.rcard:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.rcard span { font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--emerald); font-weight: 700; }
.rcard b { display: block; font-family: var(--font-display); font-weight: 600; font-size: 1.08rem; color: var(--ink); margin-top: 6px; }

/* blog index listing */
.bloghead { text-align: center; padding: 30px 24px 10px; max-width: 720px; margin: 0 auto; }
.bloghead h1 { font-family: var(--font-display); font-weight: 800; font-size: clamp(2.2rem,5vw,3.2rem); letter-spacing: -0.02em; }
.bloghead p { color: var(--ink-soft); font-size: 1.12rem; margin-top: 14px; }
.postlist { max-width: 1100px; margin: 0 auto; padding: 40px 24px 0; display: grid; grid-template-columns: repeat(auto-fill, minmax(300px,1fr)); gap: 22px; }
.pcard {
  display: flex; flex-direction: column; background: var(--paper); border: 1px solid var(--line);
  border-radius: 20px; overflow: hidden; transition: transform 0.35s var(--ease), box-shadow 0.35s var(--ease);
  text-decoration: none !important;
}
.pcard:hover { transform: translateY(-5px); box-shadow: var(--shadow-md); }
.pcard__top { height: 140px; display: grid; place-items: center; font-size: 3rem; }
.pcard__body { padding: 20px 22px 24px; }
.pcard__cat { font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--emerald); font-weight: 700; }
.pcard__title { font-family: var(--font-display); font-weight: 700; font-size: 1.2rem; color: var(--ink); margin: 7px 0 8px; line-height: 1.2; }
.pcard__desc { color: var(--ink-soft); font-size: 0.95rem; }
.pcard--soon { opacity: 0.62; pointer-events: none; }
.pcard--soon .pcard__cat::after { content: " · coming soon"; color: var(--ink-soft); }

@media (max-width: 560px) {
  .toc ol { columns: 1; }
  .blogwrap { padding-top: 20px; }
}
