/* blog.css — article + blog-index styling for "התופרת והכובסת".
   Extends styles.css (design tokens, fonts) — load AFTER it.
   Same print-shop language: ink, kraft, fabric red. No gradients, no shadows. */

/* ───────────────────────── shared shell ───────────────────────── */
.blog-wrap {
  max-width: 760px;
  margin: 0 auto;
  padding: 0 24px;
}
.blog-index-wrap {
  max-width: 1040px;
  margin: 0 auto;
  padding: 0 24px;
}

/* compact masthead for inner pages */
.bm-mast {
  max-width: 1040px;
  margin: 0 auto;
  padding: 22px 24px 0;
}
.bm-mast-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}
.bm-brand {
  font-family: var(--display);
  font-size: clamp(1.5rem, 4vw, 2.1rem);
  color: var(--ink);
  margin: 0;
  line-height: 1;
}
.bm-brand .amp { color: var(--red); font-style: italic; font-family: var(--display); padding: 0 .15em; }
.bm-nav { display: flex; gap: 18px; font-family: var(--mono); font-size: 12px; letter-spacing: .04em; }
.bm-nav a { border-bottom: 1px solid var(--hair-2); padding-bottom: 2px; }
.bm-nav a:hover { color: var(--red); border-bottom-color: var(--red); }
.bm-rule { height: 0; border-top: 1.4px solid var(--ink); margin: 16px 0 0; }

/* ───────────────────────── breadcrumb ───────────────────────── */
.crumb {
  font-family: var(--mono);
  font-size: 11.5px;
  letter-spacing: .03em;
  color: var(--ink-3-aa);
  margin: 26px 0 8px;
}
.crumb a { border-bottom: 1px dotted var(--hair-2); }
.crumb a:hover { color: var(--red); }
.crumb span[aria-current] { color: var(--ink-2); }

/* ───────────────────────── article header ───────────────────────── */
.article-cat {
  display: inline-block;
  font-family: var(--mono);
  font-size: 9.5px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--kraft);
  background: var(--red);
  border: 1px solid var(--red-ink);
  padding: 3px 10px;
  transform: rotate(-3deg);
  margin-bottom: 16px;
}
.article-h1 {
  font-family: var(--display);
  font-weight: 400;
  font-size: clamp(1.8rem, 5.4vw, 3rem);
  line-height: 1.12;
  color: var(--ink);
  margin: 6px 0 14px;
  text-wrap: balance;
}
.article-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 16px;
  font-family: var(--mono);
  font-size: 11.5px;
  letter-spacing: .03em;
  color: var(--ink-3-aa);
  padding-bottom: 20px;
  border-bottom: 1px solid var(--hair);
  margin-bottom: 8px;
}
.article-meta b { color: var(--ink-2); font-weight: 700; }

/* answer-first lede (AEO) */
.article-lede {
  font-size: 1.16rem;
  line-height: 1.62;
  color: var(--ink-2);
  margin: 24px 0 8px;
  font-weight: 500;
}

/* ───────────────────────── table of contents ───────────────────────── */
.toc {
  border: 1px solid var(--hair-2);
  border-inline-start: 3px solid var(--red);
  background: rgba(241,233,212,0.5);
  padding: 16px 20px;
  margin: 28px 0;
}
.toc h2 {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink-3-aa);
  margin: 0 0 10px;
}
.toc ol { margin: 0; padding-inline-start: 20px; }
.toc li { margin: 5px 0; font-size: 0.96rem; }
.toc a { border-bottom: 1px solid transparent; }
.toc a:hover { color: var(--red); border-bottom-color: var(--red); }

/* ───────────────────────── article body ───────────────────────── */
.article-body { font-size: 1.06rem; line-height: 1.75; }
.article-body h2 {
  font-family: var(--display);
  font-weight: 400;
  font-size: clamp(1.4rem, 3.6vw, 1.9rem);
  color: var(--ink);
  margin: 44px 0 12px;
  padding-top: 6px;
  scroll-margin-top: 16px;
}
.article-body h3 {
  font-family: var(--body);
  font-weight: 700;
  font-size: 1.18rem;
  color: var(--ink);
  margin: 28px 0 8px;
}
.article-body p { margin: 0 0 18px; }
.article-body a { border-bottom: 1px solid var(--hair-2); }
.article-body a:hover { color: var(--red); border-bottom-color: var(--red); }
.article-body ul, .article-body ol { margin: 0 0 20px; padding-inline-start: 24px; }
.article-body li { margin: 7px 0; }
.article-body strong { font-weight: 700; color: var(--ink); }
.article-body blockquote {
  margin: 24px 0;
  padding: 4px 20px;
  border-inline-start: 3px solid var(--red);
  color: var(--ink-2);
  font-size: 1.1rem;
}

/* tip / note callout */
.callout {
  border: 1px dashed var(--hair-2);
  background: rgba(241,233,212,0.45);
  padding: 16px 20px;
  margin: 24px 0;
}
.callout-tag {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--red);
  display: block;
  margin-bottom: 6px;
}

/* HowTo steps */
.howto-steps { list-style: none; counter-reset: step; margin: 24px 0; padding: 0; }
.howto-steps > li {
  counter-increment: step;
  position: relative;
  padding: 14px 56px 14px 0;
  border-bottom: 1px solid var(--hair);
}
.howto-steps > li::before {
  content: counter(step);
  position: absolute;
  inset-inline-start: 0;
  top: 12px;
  width: 36px; height: 36px;
  display: grid; place-items: center;
  font-family: var(--mono); font-weight: 700; font-size: 15px;
  color: var(--kraft); background: var(--ink);
  border: 2px solid var(--red);
}
.howto-steps h3 { margin: 0 0 4px; }
.howto-steps p { margin: 0; color: var(--ink-2); }

/* key takeaways box */
.takeaways {
  border: 1.4px solid var(--ink);
  border-top: 4px solid var(--red);
  padding: 20px 24px;
  margin: 32px 0;
}
.takeaways h2 {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--red);
  margin: 0 0 12px;
}
.takeaways ul { margin: 0; padding-inline-start: 22px; }
.takeaways li { margin: 8px 0; }

/* FAQ */
.faq { margin: 40px 0; }
.faq > h2 {
  font-family: var(--display); font-weight: 400;
  font-size: clamp(1.4rem, 3.6vw, 1.9rem);
  margin: 0 0 16px;
}
.faq details {
  border-bottom: 1px solid var(--hair);
  padding: 14px 0;
}
.faq summary {
  font-weight: 700;
  cursor: pointer;
  list-style: none;
  position: relative;
  padding-inline-end: 28px;
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after {
  content: "+";
  position: absolute;
  inset-inline-end: 0;
  font-family: var(--mono);
  color: var(--red);
  font-size: 1.2rem;
  line-height: 1;
}
.faq details[open] summary::after { content: "–"; }
.faq details p { margin: 12px 0 2px; color: var(--ink-2); }

/* author / E-E-A-T box */
.author-box {
  display: flex;
  gap: 16px;
  align-items: flex-start;
  border: 1px solid var(--hair-2);
  background: rgba(241,233,212,0.5);
  padding: 18px 20px;
  margin: 36px 0;
}
.author-mark {
  flex: 0 0 auto;
  width: 48px; height: 48px;
  display: grid; place-items: center;
  font-family: var(--display); font-size: 1.5rem;
  color: var(--kraft); background: var(--ink);
  border: 2px solid var(--red);
}
.author-box .who { font-weight: 700; margin: 0 0 2px; }
.author-box .bio { margin: 0; font-size: 0.95rem; color: var(--ink-2); }

/* article CTA */
.article-cta {
  border: 1.4px solid var(--ink);
  background: var(--ink);
  color: var(--kraft);
  padding: 28px 24px;
  margin: 40px 0;
  text-align: center;
}
.article-cta h2 { font-family: var(--display); font-weight: 400; color: var(--kraft); margin: 0 0 8px; font-size: 1.5rem; }
.article-cta p { color: rgba(232,222,197,.85); margin: 0 0 18px; }
.article-cta .btns { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }
.article-cta a {
  font-family: var(--mono); font-size: 13px; letter-spacing: .03em;
  padding: 11px 20px; border: 1.4px solid var(--kraft);
}
.article-cta a.wa { background: var(--red); border-color: var(--red-ink); color: var(--kraft); }
.article-cta a.wa:hover { background: var(--red-ink); }
.article-cta a.tel { background: transparent; color: var(--kraft); }
.article-cta a.tel:hover { background: var(--kraft); color: var(--ink); }

/* related */
.related { margin: 40px 0 8px; }
.related h2 {
  font-family: var(--mono); font-size: 11px; letter-spacing: .14em;
  text-transform: uppercase; color: var(--ink-3-aa); margin: 0 0 14px;
}
.related ul { list-style: none; margin: 0; padding: 0; display: grid; gap: 0; }
.related li { border-top: 1px solid var(--hair); }
.related a { display: block; padding: 12px 0; font-weight: 500; }
.related a:hover { color: var(--red); }
.related a span { font-family: var(--mono); font-size: 11px; color: var(--red); margin-inline-end: 8px; }

/* ───────────────────────── blog index ───────────────────────── */
.blog-hero { text-align: center; padding: 36px 0 12px; }
.blog-hero h1 {
  font-family: var(--display); font-weight: 400;
  font-size: clamp(2rem, 6vw, 3.2rem); margin: 0 0 10px; color: var(--ink);
}
.blog-hero p { color: var(--ink-2); max-width: 560px; margin: 0 auto; }

.post-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 0;
  border-top: 1.4px solid var(--ink);
  margin: 32px 0;
}
.post-card {
  border-bottom: 1px solid var(--hair);
  border-inline-start: 1px solid var(--hair);
  padding: 24px 22px;
  display: flex;
  flex-direction: column;
  min-height: 200px;
  transition: background .15s;
}
.post-card:hover { background: rgba(241,233,212,0.55); }
.post-card .cat {
  font-family: var(--mono); font-size: 9.5px; letter-spacing: .14em;
  text-transform: uppercase; color: var(--red); margin-bottom: 10px;
}
.post-card h2 {
  font-family: var(--display); font-weight: 400; font-size: 1.32rem;
  line-height: 1.2; margin: 0 0 10px; color: var(--ink);
}
.post-card h2 a { border: 0; }
.post-card h2 a:hover { color: var(--red); }
.post-card p { font-size: 0.96rem; color: var(--ink-2); margin: 0 0 16px; flex: 1; }
.post-card .more {
  font-family: var(--mono); font-size: 11.5px; color: var(--ink);
  border-top: 1px solid var(--hair); padding-top: 10px;
}
.post-card .more b { color: var(--red); }

/* prominent blog button in the homepage masthead top row */
.t2-mast-blog {
  background: var(--red);
  color: var(--kraft) !important;
  border: 1px solid var(--red-ink);
  padding: 5px 16px;
  font-family: var(--mono);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .04em;
  white-space: nowrap;
  transition: background .15s;
}
.t2-mast-blog:hover { background: var(--red-ink); color: var(--kraft) !important; }
@media (prefers-reduced-motion: reduce) { .t2-mast-blog { transition: none; } }

/* in-page "from the blog" teaser on homepage */
.t2-blog-teaser { padding: 0 0 64px; border-bottom: 1px solid var(--hair); margin-bottom: 56px; }
.t2-blog-teaser .post-grid { margin-top: 24px; }

@media (max-width: 600px) {
  .post-grid { grid-template-columns: 1fr; }
  .article-body { font-size: 1.02rem; }
}

/* respect reduced motion */
@media (prefers-reduced-motion: reduce) {
  .post-card { transition: none; }
}
