/* Bloom blog stylesheet — loaded alongside /seo.css on blog routes. */

.blog-hero{padding:80px 0 48px}
.blog-hero .wrap{display:grid;gap:18px;max-width:880px}
.band-blog-index{padding:48px 0 96px}
.blog-index{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:14px}
.blog-card{margin:0}
.blog-card a{display:grid;gap:10px;padding:24px;border:1px solid var(--rule);border-radius:var(--radius-lg);background:#fff;transition:border-color .15s ease,box-shadow .15s ease;text-decoration:none}
.blog-card a:hover{border-color:var(--rule-strong);box-shadow:var(--shadow-card)}
.blog-card h2{margin:0;font-family:var(--font-sans);font-size:20px;line-height:1.25;font-weight:600;letter-spacing:-0.01em;color:var(--ink)}
.blog-card-meta{margin:0;color:var(--ink-3);font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:0;text-transform:uppercase}
.blog-card-desc{margin:0;color:var(--ink-2);font-size:14px;line-height:1.55}
.blog-card-tags{list-style:none;margin:6px 0 0;padding:0;display:flex;flex-wrap:wrap;gap:6px}
.blog-card-tags li{display:inline-flex;align-items:center;padding:3px 8px;border:1px solid var(--rule-strong);border-radius:3px;background:var(--paper-2);color:var(--ink-3);font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:.04em;text-transform:uppercase}

.blog-post{padding:0 0 64px}
.blog-post-head{display:grid;gap:14px;padding:72px 0 28px;max-width:760px;margin:0 auto}
.blog-post-head .eyebrow{margin:0}
.blog-eyebrow-link{color:var(--green-2);text-decoration:none}
.blog-eyebrow-link:hover{text-decoration:underline;text-underline-offset:3px}
.blog-post-head h1{font-size:clamp(34px,4.6vw,52px);letter-spacing:-0.02em;line-height:1.05}
.blog-post-meta{margin:0;color:var(--ink-3);font-family:var(--font-mono);font-size:12px;letter-spacing:.02em}
.blog-post-tags{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:6px}
.blog-post-tags li{display:inline-flex;align-items:center;padding:3px 8px;border:1px solid var(--rule-strong);border-radius:3px;background:var(--paper-2);color:var(--ink-3);font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:.04em;text-transform:uppercase}

.blog-post-body{padding:28px 0 32px;max-width:720px;margin:0 auto;font-size:17px;line-height:1.7;color:var(--ink)}
.blog-post-body h2{margin:48px 0 14px;font-size:28px;line-height:1.15;letter-spacing:-0.01em}
.blog-post-body h3{margin:32px 0 10px;font-size:20px;line-height:1.2;letter-spacing:-0.005em;font-weight:600}
.blog-post-body p{margin:0 0 18px;text-wrap:pretty}
.blog-post-body ul,.blog-post-body ol{margin:0 0 22px;padding-left:1.4em;line-height:1.65}
.blog-post-body li{margin:0 0 6px}
.blog-post-body li > p{margin:0 0 6px}
.blog-post-body a{color:var(--green-2);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}
.blog-post-body a:hover{text-decoration-thickness:2px}
.blog-post-body code{background:var(--paper-2);border:1px solid var(--rule);border-radius:3px;padding:1px 5px;font-size:.86em}
.blog-post-body pre{margin:0 0 22px;padding:16px 18px;background:var(--paper-2);border:1px solid var(--rule);border-radius:var(--radius);overflow-x:auto;font-size:13px;line-height:1.55}
.blog-post-body pre code{background:transparent;border:0;padding:0;font-size:inherit;border-radius:0}
.blog-post-body blockquote{margin:0 0 22px;padding:6px 0 6px 18px;border-left:3px solid var(--rule-strong);color:var(--ink-2)}
.blog-post-body hr{margin:36px 0;border:0;border-top:1px solid var(--rule)}

.blog-post-footer{display:grid;gap:32px;padding:24px 0 8px;max-width:760px;margin:0 auto}
.blog-cta{display:grid;gap:14px;padding:32px;border:1px solid var(--rule);border-radius:var(--radius-lg);background:var(--paper-2)}
.blog-cta h2{margin:0;font-size:22px;line-height:1.2}
.blog-cta p{margin:0;color:var(--ink-2)}
.blog-related,.blog-more{display:grid;gap:10px}
.blog-related h2,.blog-more h2{margin:0;font-size:14px;font-family:var(--font-mono);font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3)}
.blog-related ul,.blog-more ul{list-style:none;margin:0;padding:0;display:grid;gap:8px}
.blog-related a,.blog-more a{display:grid;gap:2px;padding:14px 16px;border:1px solid var(--rule);border-radius:var(--radius);background:#fff;transition:border-color .15s ease;text-decoration:none}
.blog-related a:hover,.blog-more a:hover{border-color:var(--ink)}
.blog-more a strong{font-size:15px;font-weight:600;color:var(--ink);letter-spacing:-0.005em}
.blog-more a span{color:var(--ink-2);font-size:13px;line-height:1.5}
