/* ===========================================================
   VNISH — Blog UI kit styles (uses ../../colors_and_type.css)
   =========================================================== */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--fg-2);font-family:var(--font-body);-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
.container{max-width:1180px;margin:0 auto;padding:0 32px}
.container--narrow{max-width:760px}

/* ---- Nav (shared look with landing) ---- */
.nav{position:sticky;top:0;z-index:50;background:rgba(10,13,17,.72);backdrop-filter:blur(14px);border-bottom:1px solid var(--border-soft)}
.nav-inner{display:flex;align-items:center;gap:32px;height:68px}
.nav-links{display:flex;gap:28px;margin-left:8px}
.nav-links a{font-size:14.5px;font-weight:500;color:var(--fg-2);transition:color var(--dur)}
.nav-links a:hover,.nav-links a.active{color:var(--fg-1)}
.nav-right{margin-left:auto;display:flex;align-items:center;gap:12px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:var(--font-body);font-weight:600;font-size:15px;border-radius:var(--r-md);padding:13px 22px;cursor:pointer;border:1px solid transparent;transition:transform var(--dur-fast) var(--ease-out),background var(--dur),box-shadow var(--dur),border-color var(--dur);white-space:nowrap}
.btn svg{width:17px;height:17px}
.btn-primary{background:var(--grad-accent);color:var(--accent-ink);box-shadow:var(--glow-accent)}
.btn-primary:hover{background:linear-gradient(180deg,var(--lime-100),var(--lime-300))}
.btn-primary:active{transform:translateY(1px)}
.btn-secondary{background:var(--surface-raised);color:var(--fg-1);border-color:var(--border-strong)}
.btn-secondary:hover{background:var(--surface-hover);border-color:var(--ink-500)}
.btn-sm{padding:9px 15px;font-size:13.5px}

/* ---- Blog header ---- */
.blog-head{padding:64px 0 8px;position:relative;overflow:hidden;background-image:var(--grad-hero)}
.blog-head .eyebrow{font-family:var(--font-mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent)}
.blog-head h1{font-family:var(--font-display);font-weight:600;font-size:clamp(34px,4.6vw,52px);letter-spacing:-.026em;color:var(--fg-1);margin:16px 0 0;line-height:1.05}
.blog-head p{font-size:18px;color:var(--fg-2);max-width:560px;margin:16px 0 0}

/* ---- Topic filters ---- */
.topics{display:flex;flex-wrap:wrap;gap:10px;padding:32px 0 8px}
.topic{font-family:var(--font-body);font-size:13.5px;font-weight:600;color:var(--fg-2);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-pill);padding:9px 16px;cursor:pointer;transition:all var(--dur)}
.topic:hover{border-color:var(--ink-500);color:var(--fg-1)}
.topic.active{background:var(--accent-soft);border-color:var(--accent-line);color:var(--accent)}

/* ---- Featured post ---- */
.featured{display:grid;grid-template-columns:1.15fr 1fr;gap:0;border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden;background:var(--surface);margin:8px 0 8px;cursor:pointer;transition:border-color var(--dur)}
.featured:hover{border-color:var(--border-strong)}
.featured .cover{min-height:340px;position:relative;background:linear-gradient(135deg,var(--ink-800),var(--ink-900))}
.cover-art{position:absolute;inset:0}
.cover-tag{position:absolute;top:18px;left:18px;font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);background:rgba(10,13,17,.6);backdrop-filter:blur(6px);border:1px solid var(--accent-line);border-radius:var(--r-pill);padding:6px 12px}
.featured .body{padding:40px;display:flex;flex-direction:column;justify-content:center}
.featured .body .k{font-family:var(--font-mono);font-size:12px;color:var(--accent);letter-spacing:.06em;text-transform:uppercase}
.featured .body h2{font-family:var(--font-display);font-weight:600;font-size:clamp(24px,2.4vw,32px);letter-spacing:-.02em;color:var(--fg-1);line-height:1.12;margin:14px 0 0}
.featured .body p{font-size:15.5px;line-height:1.6;color:var(--fg-3);margin:14px 0 0}
.meta{display:flex;align-items:center;gap:14px;margin-top:22px;font-size:13px;color:var(--fg-3)}
.meta .av{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--lime-300),var(--lime-500));display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:12px;color:var(--accent-ink)}
.meta .dot{width:3px;height:3px;border-radius:50%;background:var(--ink-500)}

/* ---- Article grid ---- */
.section{padding:48px 0 96px}
.grid-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:24px}
.grid-head h3{font-family:var(--font-display);font-weight:600;font-size:22px;color:var(--fg-1);margin:0}
.grid-head a{font-size:14px;color:var(--accent);font-weight:600;display:inline-flex;align-items:center;gap:6px}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.acard{border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;background:var(--surface);cursor:pointer;transition:transform var(--dur),border-color var(--dur);display:flex;flex-direction:column}
.acard:hover{transform:translateY(-3px);border-color:var(--border-strong)}
.acard .cover{height:172px;position:relative;background:linear-gradient(135deg,var(--ink-800),var(--ink-900))}
.acard .pad{padding:20px;display:flex;flex-direction:column;flex:1}
.acard .k{font-family:var(--font-mono);font-size:11px;color:var(--accent);letter-spacing:.06em;text-transform:uppercase}
.acard h4{font-family:var(--font-display);font-weight:600;font-size:18px;letter-spacing:-.012em;color:var(--fg-1);line-height:1.22;margin:12px 0 0}
.acard p{font-size:14px;line-height:1.55;color:var(--fg-3);margin:10px 0 0}
.acard .meta{margin-top:auto;padding-top:18px}

/* ---- decorative cover motifs (no external images) ---- */
.motif{position:absolute;inset:0;overflow:hidden}
.motif.grid::before{content:"";position:absolute;inset:0;background-image:linear-gradient(var(--grid-line) 1px,transparent 1px),linear-gradient(90deg,var(--grid-line) 1px,transparent 1px);background-size:28px 28px;mask-image:radial-gradient(80% 80% at 70% 20%,#000,transparent 75%)}
.motif .glow{position:absolute;width:60%;height:60%;border-radius:50%;filter:blur(40px)}
.motif.g1 .glow{background:rgba(236,188,39,.22);top:-10%;right:-5%}
.motif.g2 .glow{background:rgba(56,189,248,.18);bottom:-15%;left:-5%}
.motif.g3 .glow{background:rgba(236,188,39,.16);top:30%;left:30%}
.motif .spark{position:absolute;left:0;right:0;bottom:0;height:55%}
.motif .chip{position:absolute;width:64px;height:64px;border:2px solid var(--accent-line);border-radius:12px;top:50%;left:50%;transform:translate(-50%,-50%)}
.motif .chip::before{content:"";position:absolute;inset:14px;border:2px solid var(--accent-line);border-radius:4px}

/* ---- Newsletter ---- */
.news{border:1px solid var(--accent-line);border-radius:var(--r-2xl);background:radial-gradient(120% 140% at 100% 0%,rgba(236,188,39,.14),transparent 55%),linear-gradient(180deg,var(--ink-800),var(--ink-850));padding:44px;display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap}
.news h3{font-family:var(--font-display);font-weight:600;font-size:26px;letter-spacing:-.02em;color:var(--fg-1);margin:0 0 8px}
.news p{font-size:15px;color:var(--fg-2);margin:0;max-width:420px}
.news-form{display:flex;gap:10px;flex-wrap:wrap}
.news-form input{background:var(--surface-raised);border:1px solid var(--border-strong);border-radius:var(--r-md);padding:13px 16px;color:var(--fg-1);font-family:var(--font-body);font-size:14.5px;min-width:240px;outline:none}
.news-form input:focus{border-color:var(--accent-line);box-shadow:0 0 0 3px var(--accent-soft)}

/* ---- Article reading view ---- */
.article-head{padding:48px 0 0}
.crumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--fg-3);margin-bottom:24px}
.crumb a:hover{color:var(--accent)}
.crumb svg{width:14px;height:14px}
.article-head .k{font-family:var(--font-mono);font-size:12px;color:var(--accent);letter-spacing:.08em;text-transform:uppercase}
.article-head h1{font-family:var(--font-display);font-weight:600;font-size:clamp(32px,4.4vw,48px);letter-spacing:-.026em;color:var(--fg-1);line-height:1.07;margin:16px 0 0}
.article-head .lede{font-size:19px;line-height:1.55;color:var(--fg-2);margin:20px 0 0}
.article-cover{height:380px;border-radius:var(--r-xl);overflow:hidden;position:relative;margin:32px 0 0;border:1px solid var(--border);background:linear-gradient(135deg,var(--ink-800),var(--ink-900))}
.prose{padding:40px 0 0;font-size:17px;line-height:1.75;color:var(--ink-100)}
.prose h2{font-family:var(--font-display);font-weight:600;font-size:27px;letter-spacing:-.02em;color:var(--fg-1);margin:40px 0 14px}
.prose h3{font-family:var(--font-display);font-weight:600;font-size:20px;color:var(--fg-1);margin:30px 0 10px}
.prose p{margin:0 0 20px;color:var(--ink-200)}
.prose a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.prose ul{margin:0 0 20px;padding-left:22px}
.prose li{margin:0 0 10px;color:var(--ink-200)}
.prose strong{color:var(--fg-1);font-weight:700}
.prose code{font-family:var(--font-mono);font-size:14px;background:var(--ink-850);border:1px solid var(--border);border-radius:6px;padding:2px 7px;color:var(--accent)}
.callout{border:1px solid var(--accent-line);background:var(--accent-soft);border-radius:var(--r-lg);padding:20px 22px;margin:28px 0;display:flex;gap:14px}
.callout svg{width:20px;height:20px;color:var(--accent);flex:none;margin-top:2px}
.callout p{margin:0;font-size:15px;color:var(--ink-100)}
.codeblock{background:var(--ink-950);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px 20px;margin:24px 0;font-family:var(--font-mono);font-size:13.5px;line-height:1.7;color:var(--ink-100);overflow-x:auto}
.codeblock .c{color:var(--fg-3)}
.codeblock .g{color:var(--accent)}
.share{display:flex;align-items:center;gap:10px;padding:32px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin:40px 0}
.share span{font-size:13px;color:var(--fg-3);margin-right:6px}
.share a{width:38px;height:38px;border-radius:var(--r-sm);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--fg-2);transition:all var(--dur)}
.share a:hover{color:var(--accent);border-color:var(--accent-line)}
.share svg{width:17px;height:17px}

/* ---- Footer ---- */
.footer{border-top:1px solid var(--border);padding:56px 0 40px;margin-top:40px}
.foot-bottom{display:flex;align-items:center;justify-content:space-between;font-size:13px;color:var(--fg-3);flex-wrap:wrap;gap:16px}
.foot-social{display:flex;gap:10px}
.foot-social a{width:36px;height:36px;border-radius:var(--r-sm);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--fg-2);transition:all var(--dur)}
.foot-social a:hover{color:var(--accent);border-color:var(--accent-line)}
.foot-social svg{width:17px;height:17px}

@keyframes revealIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
.reveal{animation:revealIn .6s var(--ease-out) both}
@media (prefers-reduced-motion: reduce){.reveal{animation:none}}

@media(max-width:920px){
  .featured{grid-template-columns:1fr}.cards{grid-template-columns:1fr 1fr}
  .nav-links{display:none}.news{flex-direction:column;align-items:flex-start}
}
@media(max-width:560px){.cards{grid-template-columns:1fr}}
