/* ============================================================
   bombos · gedeelde stijl voor blog-index en artikelen
   Tokens 1-op-1 uit het bombos design system (_ds/tokens).
   ============================================================ */
:root{
  --ink-900:#1C1A17; --ink-800:#2A2722; --ink-700:#3D3833; --ink-600:#57514A;
  --ink-500:#7A7167; --ink-400:#9C9388; --ink-300:#C2B9AC; --ink-200:#E2DACB;
  --ink-100:#F0EADD; --ink-50:#FBF7EF;
  --paper:#FBF7EF; --card:#FFFFFF; --sunk:#F4EEE1; --wing:#F2ECDE;
  --honey-50:#FFFBEF; --honey-100:#FFF4D6; --honey-200:#FFE7A3; --honey-300:#FFD668;
  --honey-400:#FBC22E; --honey-500:#F2B109; --honey-600:#C8890C; --honey-700:#9A6A08; --honey-800:#6F4C09;
  --bloom:#9A53C4; --bloom-ink:#5C2C84; --bloom-soft:#F0E6F8;
  --leaf:#3C9A6A; --leaf-ink:#1F6843; --leaf-soft:#DFF0E4;
  --sky:#3E6FA8; --sky-ink:#234A77; --sky-soft:#DEE8F2;
  --nectar:#E2743A; --nectar-ink:#8A3C13;
  --border:#E2DACB; --border-strong:#C2B9AC;
  --font-display:'Fredoka','Hanken Grotesk',system-ui,sans-serif;
  --font-sans:'Hanken Grotesk',system-ui,-apple-system,sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,monospace;
  --shadow-card:0 4px 12px rgba(28,26,23,.08),0 2px 4px rgba(28,26,23,.04);
  --shadow-lg:0 12px 28px rgba(28,26,23,.10),0 4px 8px rgba(28,26,23,.05);
  --shadow-honey:0 6px 18px rgba(242,177,9,.28);
  --ease-out:cubic-bezier(.22,1,.36,1);
  --comb-line:rgba(28,26,23,.045);
  --radius:18px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:clip}
body{margin:0;overflow-x:clip;background:var(--paper);color:var(--ink-900);font-family:var(--font-sans);font-size:19px;line-height:1.75;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
::selection{background:var(--honey-200);color:var(--ink-900)}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;letter-spacing:-.02em;line-height:1.14;margin:0;text-wrap:balance}
p{margin:0}
a{color:inherit}
img{max-width:100%}
:focus-visible{outline:2.5px solid var(--honey-600);outline-offset:2px;border-radius:6px;box-shadow:0 0 0 3px var(--honey-200)}
.skip{position:absolute;left:-9999px;top:8px;z-index:100;background:var(--ink-900);color:#fff;padding:11px 18px;border-radius:11px;font-weight:600;text-decoration:none}
.skip:focus{left:8px}
.wrap{max-width:1120px;margin:0 auto;padding:0 24px}
@media (max-width:480px){.wrap{padding:0 18px}}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:12.5px;font-weight:500;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-500)}
.eyebrow::before{content:"";width:9px;height:9px;border-radius:50%;background:var(--honey-500);flex:0 0 auto}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;border:none;cursor:pointer;text-decoration:none;font-family:var(--font-sans);font-weight:600;font-size:15.5px;padding:13px 24px;border-radius:11px;line-height:1;transition:transform .12s var(--ease-out),box-shadow .12s var(--ease-out),background .12s var(--ease-out)}
.btn:active{transform:translateY(1px)}
.btn-honey{background:var(--honey-500);color:var(--ink-900);box-shadow:var(--shadow-honey)}
.btn-honey:hover{background:var(--honey-400)}
.btn-ghost{background:transparent;color:var(--ink-700);border:1.5px solid var(--border-strong)}
.btn-ghost:hover{border-color:var(--ink-500)}

/* ---------- nav ---------- */
.nav{position:sticky;top:0;z-index:40;background:rgba(251,247,239,.88);backdrop-filter:blur(10px);border-bottom:1px solid var(--border)}
.nav-in{display:flex;align-items:center;gap:24px;height:72px}
.brand{display:inline-flex;align-items:center;gap:10px;text-decoration:none}
.brand svg{width:34px;height:30px}
.brand b{font-family:var(--font-display);font-weight:600;font-size:23px;letter-spacing:-.02em}
.nav-links{display:flex;gap:24px;margin-left:10px}
.nav-links a{text-decoration:none;font-size:15px;font-weight:500;color:var(--ink-600)}
.nav-links a:hover{color:var(--ink-900)}
.nav-links a.on{color:var(--ink-900)}
.nav-cta{margin-left:auto;display:flex;align-items:center;gap:10px}
.nav-cta .btn{padding:11px 19px}
.nav-toggle{display:none;margin-left:auto;width:44px;height:44px;border:1.5px solid var(--border-strong);border-radius:11px;background:var(--card);cursor:pointer;align-items:center;justify-content:center;flex:0 0 auto;color:var(--ink-800)}
.nav-toggle svg{width:22px;height:22px}
.nav-panel{display:none}
@media (max-width:760px){
  .nav-links,.nav-cta{display:none}
  .nav-toggle{display:inline-flex}
  .nav.open .nav-panel{display:block;position:absolute;left:0;right:0;top:100%;background:var(--paper);border-bottom:1px solid var(--border);box-shadow:var(--shadow-lg);padding:10px 24px 18px}
  .nav-panel a{display:block;padding:13px 4px;font-size:16px;font-weight:500;color:var(--ink-700);text-decoration:none;border-bottom:1px solid var(--border)}
  .nav-panel a:last-of-type{border-bottom:none}
  .nav-panel .btn{display:flex;justify-content:center;margin-top:14px}
}

/* ---------- blog index ---------- */
.blog-hero{padding:70px 0 26px}
.blog-hero h1{font-size:clamp(38px,5vw,60px);margin-top:16px}
.blog-hero p{margin-top:16px;font-size:19px;color:var(--ink-600);max-width:34em}
.blog-list{padding:26px 0 90px;display:flex;flex-direction:column;gap:20px;max-width:820px}
.pcard{display:grid;grid-template-columns:132px 1fr;gap:26px;align-items:center;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:22px 24px;box-shadow:var(--shadow-card);text-decoration:none;color:inherit;transition:transform .18s var(--ease-out),box-shadow .18s var(--ease-out)}
.pcard:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
@media (prefers-reduced-motion:reduce){.pcard:hover{transform:none}}
.pcard-cover{width:132px;height:112px;border-radius:13px;display:flex;align-items:center;justify-content:center;flex:0 0 auto;overflow:hidden;position:relative}
.pcard-cover svg{width:52px;height:46px;position:relative;z-index:1}
.pcard-cat{font-family:var(--font-mono);font-size:11.5px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--honey-700)}
.pcard h2{font-size:22px;margin:7px 0 8px;line-height:1.22}
.pcard .excerpt{font-size:15.5px;color:var(--ink-600);line-height:1.55}
.pcard .pmeta{margin-top:11px;font-family:var(--font-mono);font-size:12px;color:var(--ink-500);display:flex;gap:8px;flex-wrap:wrap}
.pcard .pmeta span+span::before{content:"·";margin-right:8px;color:var(--ink-300)}
@media (max-width:620px){.pcard{grid-template-columns:1fr;gap:16px}.pcard-cover{width:100%;height:120px}}

/* cover tints */
.cov-honey{background:var(--honey-100)}.cov-honey svg{opacity:.95}
.cov-bloom{background:var(--bloom-soft)}
.cov-sky{background:var(--sky-soft)}
.cov-leaf{background:var(--leaf-soft)}
.cov-comb{background-image:radial-gradient(circle at 50% 0,transparent 0,transparent 7px,var(--comb-line) 7px,var(--comb-line) 8px,transparent 8px),radial-gradient(circle at 0 100%,transparent 0,transparent 7px,var(--comb-line) 7px,var(--comb-line) 8px,transparent 8px),radial-gradient(circle at 100% 100%,transparent 0,transparent 7px,var(--comb-line) 7px,var(--comb-line) 8px,transparent 8px);background-size:26px 45px}

/* ---------- article ---------- */
.post-hero{padding:56px 0 20px}
.crumbs{font-family:var(--font-mono);font-size:12.5px;color:var(--ink-600);margin-bottom:22px}
.crumbs a{color:var(--ink-500);text-decoration:none}
.crumbs a:hover{color:var(--ink-900)}
.crumbs span{margin:0 7px;color:var(--ink-300)}
.post-hero .post-cat{font-family:var(--font-mono);font-size:12.5px;font-weight:500;letter-spacing:.07em;text-transform:uppercase;color:var(--honey-700)}
.post-title{font-size:clamp(32px,4.6vw,52px);margin:14px 0 0;max-width:16ch}
.post-lead{margin-top:20px;font-size:21px;line-height:1.6;color:var(--ink-600);max-width:36ch;max-width:640px}
.post-meta{margin-top:24px;display:flex;align-items:center;gap:12px;flex-wrap:wrap;font-family:var(--font-mono);font-size:12.5px;color:var(--ink-600)}
.post-meta .who{display:inline-flex;align-items:center;gap:8px}
.post-meta .who img{width:26px;height:23px;object-fit:contain}
.post-meta .dot{color:var(--ink-300)}
.post-rule{height:1px;background:var(--border);max-width:720px;margin:34px 0 0}

/* body typography */
.prose{max-width:680px;padding:12px 0 40px;font-size:19px;line-height:1.78;color:var(--ink-800)}
.prose>p{margin:24px 0}
.prose>p:first-of-type{margin-top:20px}
.prose h2{font-size:29px;margin:52px 0 4px;letter-spacing:-.02em}
.prose h3{font-size:22px;margin:38px 0 2px}
.prose h2+p,.prose h3+p{margin-top:12px}
.prose a{color:var(--ink-900);text-decoration:underline;text-decoration-color:var(--honey-400);text-underline-offset:3px;text-decoration-thickness:2px}
.prose a:hover{text-decoration-color:var(--honey-600)}
.prose strong{font-weight:700;color:var(--ink-900)}
.prose ul,.prose ol{margin:22px 0;padding-left:0;list-style:none;display:flex;flex-direction:column;gap:12px}
.prose ul li{position:relative;padding-left:30px}
.prose ul li::before{content:"";position:absolute;left:6px;top:12px;width:7px;height:7px;border-radius:50%;background:var(--honey-500)}
.prose ol{counter-reset:n}
.prose ol li{position:relative;padding-left:38px;counter-increment:n}
.prose ol li::before{content:counter(n);position:absolute;left:0;top:2px;width:24px;height:24px;border-radius:7px;background:var(--honey-100);color:var(--honey-800);font-family:var(--font-mono);font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center}
.pullquote{margin:44px 0;padding:6px 0 6px 26px;border-left:3px solid var(--honey-500);font-family:var(--font-display);font-weight:500;font-size:26px;line-height:1.34;color:var(--ink-900);letter-spacing:-.01em}
.prose figure{margin:36px 0}
.prose .caption{font-family:var(--font-mono);font-size:12.5px;color:var(--ink-400);margin-top:8px}
.callout{margin:36px 0;background:var(--sunk);border:1px solid var(--border);border-radius:14px;padding:20px 22px;font-size:16.5px;line-height:1.6;color:var(--ink-700)}
.callout b{color:var(--ink-900)}

/* end-of-post CTA */
.post-cta{max-width:680px;margin:8px 0 0;background:var(--honey-50);border:1.5px solid var(--honey-200);border-radius:var(--radius);padding:28px 30px}
.post-cta h3{font-size:23px}
.post-cta p{margin:10px 0 18px;font-size:16px;color:var(--ink-600);line-height:1.6}

/* more posts */
.more{padding:56px 0 90px}
.more h2{font-size:24px;margin-bottom:22px}
.more-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;max-width:820px}
@media (max-width:620px){.more-grid{grid-template-columns:1fr}}
.mini{display:block;text-decoration:none;color:inherit;background:var(--card);border:1px solid var(--border);border-radius:14px;padding:18px 20px;box-shadow:var(--shadow-card);transition:transform .18s var(--ease-out),box-shadow .18s var(--ease-out)}
.mini:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
@media (prefers-reduced-motion:reduce){.mini:hover{transform:none}}
.mini .pcard-cat{font-size:11px}
.mini h3{font-size:17px;margin:6px 0 0;line-height:1.3}

/* ---------- footer ---------- */
footer{background:var(--ink-900);color:var(--ink-300);padding:56px 0 34px;margin-top:20px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:40px}
.foot-brand .brand b{color:#fff}
.foot-brand p{font-size:14px;max-width:26em;margin-top:14px;color:var(--ink-400)}
footer h4{font-family:var(--font-mono);font-size:11.5px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-500);margin:0 0 16px}
footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
footer ul a{text-decoration:none;font-size:14.5px;color:var(--ink-300)}
footer ul a:hover{color:#fff}
.foot-base{margin-top:48px;padding-top:22px;border-top:1px solid rgba(255,255,255,.09);display:flex;gap:16px;flex-wrap:wrap;font-size:13px;color:var(--ink-500)}
.foot-base span:last-child{margin-left:auto}
@media (max-width:700px){.foot-grid{grid-template-columns:1fr 1fr;gap:28px}}
@media (max-width:420px){.foot-grid{grid-template-columns:1fr}}
