/* Stylst blog — shared styles for the hub + article pages. Builds on atelier.css
   (tokens, nav, footer, buttons). Warm paper + ink + clay, Newsreader headlines. */

.wrap { max-width:1100px; margin:0 auto; padding:0 32px; }

/* --- blog hub --- */
.blog-hero { text-align:center; max-width:680px; margin:0 auto; padding:64px 0 14px; }
.blog-hero h1 { font:500 50px/1.04 'Newsreader',serif; letter-spacing:-.02em; margin:14px 0 0; }
.blog-hero p { font:400 17px/1.55 'Hanken Grotesk'; color:var(--ink2); margin:16px 0 0; }

.posts { display:grid; grid-template-columns:repeat(2,1fr); gap:22px; padding:40px 0 8px; }
.pcard { display:flex; flex-direction:column; background:var(--raise); border:1px solid var(--line); border-radius:18px; padding:28px; text-decoration:none; color:var(--ink); transition:border-color .15s,transform .08s,box-shadow .15s; }
.pcard:hover { border-color:var(--clay); transform:translateY(-2px); box-shadow:var(--shadow); }
.pcard .cat { font:600 11px/1 'JetBrains Mono',monospace; letter-spacing:.13em; text-transform:uppercase; color:var(--clay); }
.pcard h2 { font:500 25px/1.16 'Newsreader',serif; letter-spacing:-.01em; margin:13px 0 0; }
.pcard p { font:400 15px/1.55 'Hanken Grotesk'; color:var(--ink2); margin:11px 0 0; flex:1; }
.pcard .meta { font:500 12.5px 'Hanken Grotesk'; color:var(--muted); margin-top:18px; display:flex; align-items:center; gap:9px; }
.pcard .meta .sep { width:4px; height:4px; border-radius:50%; background:var(--line2); }

/* --- article --- */
.post { max-width:720px; margin:0 auto; padding:52px 0 8px; }
.post .back { display:inline-flex; align-items:center; gap:7px; font:600 13px 'Hanken Grotesk'; color:var(--ink2); text-decoration:none; }
.post .back:hover { color:var(--clay); }
.post-head { margin-top:26px; }
.post-head .cat { font:600 11px/1 'JetBrains Mono',monospace; letter-spacing:.13em; text-transform:uppercase; color:var(--clay); }
.post-head h1 { font:500 44px/1.07 'Newsreader',serif; letter-spacing:-.02em; margin:14px 0 0; }
.post-head .dek { font:400 19px/1.5 'Hanken Grotesk'; color:var(--ink2); margin:16px 0 0; }
.post-meta { font:500 13px 'Hanken Grotesk'; color:var(--muted); margin-top:18px; display:flex; align-items:center; gap:9px; flex-wrap:wrap; }
.post-meta .sep { width:4px; height:4px; border-radius:50%; background:var(--line2); }

.post-body { margin-top:14px; }
.post-body h2 { font:500 30px/1.16 'Newsreader',serif; letter-spacing:-.01em; margin:42px 0 0; }
.post-body h3 { font:600 19px 'Hanken Grotesk'; margin:28px 0 0; }
.post-body p { font:400 17px/1.7 'Hanken Grotesk'; color:var(--ink); margin:18px 0 0; }
.post-body ul, .post-body ol { margin:18px 0 0; padding-left:24px; }
.post-body li { font:400 17px/1.65 'Hanken Grotesk'; color:var(--ink); margin:9px 0 0; }
.post-body li::marker { color:var(--clay); }
.post-body a { color:var(--clayhover); text-underline-offset:3px; }
.post-body strong { font-weight:600; }
.post-body blockquote { margin:26px 0 0; padding:4px 0 4px 22px; border-left:3px solid var(--clay); }
.post-body blockquote p { font:500 19px/1.55 'Newsreader',serif; color:var(--ink2); font-style:italic; }

.callout { margin:30px 0 0; background:var(--surface); border:1px solid var(--line); border-radius:14px; padding:22px 24px; }
.callout p { margin:0; font:400 15.5px/1.6 'Hanken Grotesk'; color:var(--ink2); }
.callout p:first-child { font-weight:600; color:var(--ink); }
.callout p + p { margin-top:8px; }

/* before/after figure inside an article (reuses /examples assets) */
.post-fig { margin:34px 0 0; }
.post-ba { position:relative; aspect-ratio:3/2; border-radius:16px; overflow:hidden; box-shadow:var(--shadow); user-select:none; touch-action:pan-y; background:#e7ddc9; cursor:ew-resize; }
.post-ba img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; -webkit-user-drag:none; }
.post-ba .pb-before { clip-path:inset(0 50% 0 0); }
.post-ba .pb-tag { position:absolute; bottom:12px; z-index:3; font:500 10.5px 'JetBrains Mono',monospace; border-radius:6px; padding:4px 8px; color:#f4efe6; background:rgba(33,28,21,.55); }
.post-ba .pb-tag.a { right:12px; } .post-ba .pb-tag.b { left:12px; }
.post-ba .pb-handle { position:absolute; top:0; bottom:0; width:3px; background:var(--surface); left:50%; transform:translateX(-50%); z-index:4; pointer-events:none; }
.post-ba .pb-knob { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:42px; height:42px; border-radius:50%; background:rgba(20,17,13,.5); border:1px solid rgba(255,255,255,.18); box-shadow:0 4px 16px rgba(0,0,0,.4); display:flex; align-items:center; justify-content:center; gap:5px; }
.post-ba .pb-knob i { width:7px; height:7px; border-color:#f4efe6; border-style:solid; }
.post-ba .pb-knob i.l { border-width:0 0 2px 2px; transform:rotate(45deg); }
.post-ba .pb-knob i.r { border-width:2px 2px 0 0; transform:rotate(45deg); }
.post-fig figcaption { text-align:center; font:500 13px/1.45 'Hanken Grotesk'; color:var(--muted); margin-top:12px; }

/* in-article CTA + bottom cta band */
.cta-band { margin:48px 0 0; background:var(--ink); border-radius:20px; padding:40px; text-align:center; }
.cta-band h2 { font:500 32px/1.1 'Newsreader',serif; color:var(--paper); margin:0; letter-spacing:-.01em; }
.cta-band p { font:400 16px/1.55 'Hanken Grotesk'; color:var(--paper); opacity:.74; margin:12px auto 0; max-width:440px; }
.cta-band .actions { display:flex; gap:12px; justify-content:center; margin-top:24px; flex-wrap:wrap; }
.cta-badges { display:flex; gap:12px; justify-content:center; margin-top:18px; flex-wrap:wrap; }
.cta-badge { display:inline-flex; align-items:center; gap:10px; background:#2b271f; border:1px solid #3a342a; color:var(--paper); border-radius:12px; padding:9px 16px; text-decoration:none; transition:opacity .15s; }
.cta-badge:hover { opacity:.85; }
.cta-badge span { display:flex; flex-direction:column; line-height:1.15; text-align:left; }
.cta-badge small { font:400 9.5px 'Hanken Grotesk'; opacity:.8; }
.cta-badge b { font:600 15px 'Hanken Grotesk'; }

/* related posts */
.related { max-width:720px; margin:48px auto 0; }
.related h2 { font:500 24px 'Newsreader',serif; margin:0 0 16px; }
.related-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:14px; }
.related a { display:block; background:var(--raise); border:1px solid var(--line); border-radius:14px; padding:18px 20px; text-decoration:none; color:var(--ink); transition:border-color .15s; }
.related a:hover { border-color:var(--clay); }
.related a .cat { font:600 10px 'JetBrains Mono',monospace; letter-spacing:.12em; text-transform:uppercase; color:var(--clay); }
.related a h3 { font:500 17px/1.25 'Newsreader',serif; margin:9px 0 0; }

@media (max-width:760px){
  .wrap { padding:0 18px; }
  .posts, .related-grid { grid-template-columns:1fr; }
  .blog-hero h1 { font-size:38px; }
  .post-head h1 { font-size:34px; }
  .post-body h2 { font-size:26px; }
  .cta-band { padding:32px 22px; }
}
