/* ============================================================
   Inkstone — Blog / Insights
   Loaded after styles.css on blog pages.
   ============================================================ */

/* ---- breadcrumb ---- */
.crumb{ font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); display:flex; gap:9px; align-items:center; }
.crumb a{ color:var(--muted); transition:color .2s; }
.crumb a:hover{ color:var(--red); }
.crumb span{ color:var(--line2); }

/* ---- blog index ---- */
/* vertical-only padding so the .container's horizontal padding (side gutters) survives */
.blog-head{ padding-top:150px; padding-bottom:40px; }
.blog-head h1{ font-family:var(--serif); font-weight:400; font-size:72px; line-height:1.02; letter-spacing:-.02em; margin:18px 0 0; }
.blog-head h1 em{ font-style:italic; color:var(--red); }
.blog-head .sub{ font-size:19px; color:var(--muted); max-width:54ch; margin:20px 0 0; line-height:1.5; }

.post-list{ display:flex; flex-direction:column; border-top:1px solid var(--line); margin-top:8px; }
.post-row{ display:grid; grid-template-columns:160px 1fr auto; gap:40px; align-items:center;
  padding:36px 0; border-bottom:1px solid var(--line); color:inherit; text-decoration:none; transition:background .25s; }
.post-row:hover{ background:linear-gradient(90deg, transparent, color-mix(in srgb,var(--panel) 60%, transparent)); }
.post-row .cat{ font-family:var(--mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--red); }
.post-row .pdate{ font-family:var(--mono); font-size:11px; letter-spacing:.04em; color:var(--muted); margin-top:8px; }
.post-row h2{ font-size:27px; font-weight:600; letter-spacing:-.018em; margin:0 0 8px; transition:color .25s; }
.post-row:hover h2{ color:var(--red); }
.post-row p{ font-size:16px; line-height:1.5; color:var(--muted); margin:0; max-width:60ch; }
.post-row .go{ font-family:var(--mono); font-size:22px; color:var(--red); transition:transform .35s var(--ease); }
.post-row:hover .go{ transform:translateX(5px); }
[dir="rtl"] .post-row .go{ transform:scaleX(-1); }
[dir="rtl"] .post-row:hover .go{ transform:scaleX(-1) translateX(-5px); }

/* ---- article ---- */
/* vertical-only padding so the .container's horizontal padding (side gutters) survives */
.article{ padding-top:140px; padding-bottom:40px; }
.article-head{ max-width:760px; }
.article-head .cat{ font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--red); display:inline-flex; gap:9px; align-items:center; }
.article-head .cat::before{ content:''; width:7px; height:7px; border-radius:50%; background:var(--red); }
.article-head h1{ font-family:var(--serif); font-weight:400; font-size:58px; line-height:1.05; letter-spacing:-.02em; margin:20px 0 0; }
.article-head h1 em{ font-style:italic; color:var(--red); }
.article-meta{ display:flex; gap:18px; align-items:center; font-family:var(--mono); font-size:12px; letter-spacing:.04em; color:var(--muted); margin-top:24px; padding-top:22px; border-top:1px solid var(--line); }
.article-meta .dot{ width:5px; height:5px; border-radius:50%; background:var(--line2); }

.prose{ max-width:720px; margin:46px 0 0; }
.prose > *{ margin:0 0 22px; }
.prose p{ font-size:18px; line-height:1.72; color:#26241f; }
.prose h2{ font-family:var(--serif); font-weight:400; font-size:34px; line-height:1.12; letter-spacing:-.015em; margin:48px 0 4px; }
.prose h3{ font-size:21px; font-weight:600; letter-spacing:-.01em; margin:34px 0 2px; }
.prose strong{ font-weight:600; color:var(--ink); }
.prose a{ color:var(--red); text-decoration:underline; text-underline-offset:3px; text-decoration-thickness:1px; }
.prose ul, .prose ol{ padding-inline-start:22px; display:flex; flex-direction:column; gap:11px; }
.prose li{ font-size:18px; line-height:1.6; color:#26241f; }
.prose li::marker{ color:var(--red); }
.prose blockquote{ border-inline-start:3px solid var(--red); padding:4px 0 4px 22px; margin-inline-start:0;
  font-family:var(--serif); font-size:24px; line-height:1.4; color:var(--ink); }
.prose .lead{ font-size:21px; line-height:1.6; color:var(--ink); }
.prose .keyfact{ background:var(--panel); border:1px solid var(--line); border-radius:14px; padding:22px 26px; }
.prose .keyfact .kf-l{ font-family:var(--mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); margin-bottom:8px; }
.prose .keyfact .kf-v{ font-family:var(--serif); font-size:30px; line-height:1.1; }
.prose .keyfact .kf-v .u{ color:var(--red); }

/* ---- in-article CTA ---- */
.cta-box{ max-width:720px; margin:48px 0 0; background:var(--ink); color:var(--paper); border-radius:18px; padding:38px 40px;
  display:flex; align-items:center; justify-content:space-between; gap:30px; flex-wrap:wrap; }
.cta-box h3{ font-family:var(--serif); font-weight:400; font-size:28px; line-height:1.12; margin:0; }
.cta-box p{ font-size:15px; color:rgba(251,250,247,.66); margin:8px 0 0; max-width:42ch; }
.cta-box .btn{ flex:none; }

/* ---- related ---- */
.related{ max-width:720px; margin:54px 0 0; padding-top:30px; border-top:1px solid var(--line); }
.related .rl-label{ font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); margin-bottom:18px; }
.related .rl-grid{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.related a{ display:flex; align-items:center; justify-content:space-between; gap:12px; border:1px solid var(--line2); border-radius:12px; padding:18px 20px; color:var(--ink); text-decoration:none; transition:border-color .2s, background .2s; }
.related a:hover{ border-color:var(--ink); background:var(--panel); }
.related a .rl-t{ font-weight:600; font-size:15.5px; }
.related a .arw{ color:var(--red); }

/* ---- in-article FAQ: fit the article column (not the full-width service-page section) ---- */
.article #faq{ border-top:1px solid var(--line); padding:44px 0 0; margin-top:54px; }
.article #faq .container{ max-width:720px; width:100%; padding:0; margin:0; }
.article #faq .faq-grid{ display:block; }
.article #faq .section-head{ max-width:720px; margin:0 0 22px; }
.article #faq .section-head h2{ font-size:32px; }

@media (max-width:760px){
  .blog-head h1{ font-size:46px; }
  .article-head h1{ font-size:38px; }
  .article-meta{ flex-wrap:wrap; gap:10px 14px; }
  .post-row{ grid-template-columns:1fr; gap:10px; }
  .post-row .go{ display:none; }
  .prose, .cta-box, .related, .article-head{ max-width:100%; }
  .related .rl-grid{ grid-template-columns:1fr; }
  .cta-box{ flex-direction:column; align-items:flex-start; }
}
