:root{--accent: rgb(227, 104, 119);--accent-hover: rgb(207, 84, 99);--bg: #faf9f7;--surface: #ffffff;--text: #2d2d2d;--text-muted: #6b6b6b;--border: #e8e4df;--shadow: 0 2px 16px rgba(0, 0, 0, .06);--radius: 12px;--max-width: 800px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:18px;scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:var(--text);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.container{max-width:var(--max-width);margin:0 auto;padding:0 1.5rem}h1{font-size:2.6rem;font-weight:800;line-height:1.15;letter-spacing:-.02em}h2{font-size:1.6rem;font-weight:700;margin-bottom:1.5rem}h3{font-size:1.1rem;font-weight:600;margin-bottom:.5rem}p{margin-bottom:1rem;color:var(--text-muted)}.text-accent{color:var(--accent)}.navbar{background:var(--surface);border-bottom:1px solid var(--border);padding:.75rem 0;text-align:center}.navbar .container{display:flex;justify-content:center;flex-wrap:wrap;gap:.75rem 1.5rem}.navbar a{font-size:.9rem;font-weight:600;color:var(--text-muted);text-decoration:none;white-space:nowrap}.navbar a:hover{color:var(--accent);text-decoration:none}.navbar a.active{color:var(--accent)}footer{text-align:center;padding:2rem 0;font-size:.85rem;color:var(--text-muted);border-top:1px solid var(--border)}.blog-header{text-align:center;padding:4rem 0 2rem}.blog-header h1{margin-bottom:.5rem}.blog-header .subtitle{font-size:1.1rem;color:var(--text-muted);max-width:540px;margin:0 auto}.post-list{list-style:none;display:flex;flex-direction:column;gap:1.5rem;padding-bottom:3rem}.post-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.75rem 2rem;box-shadow:var(--shadow)}.post-card:hover{border-color:var(--accent)}.post-card h2{font-size:1.3rem;margin-bottom:.5rem}.post-card h2 a{color:var(--text)}.post-card h2 a:hover{color:var(--accent);text-decoration:none}.post-card .post-meta{font-size:.85rem;color:var(--text-muted);margin-bottom:.75rem;display:flex;flex-wrap:wrap;gap:.5rem 1rem;align-items:center}.post-card .post-excerpt{color:var(--text-muted);font-size:.95rem;margin-bottom:0}.post-card .category-badge{display:inline-block;background:var(--bg);color:var(--accent);border:1px solid var(--accent);border-radius:20px;padding:.15rem .75rem;font-size:.8rem;font-weight:600}.post-card .tag-list{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.75rem}.post-card .tag{display:inline-block;background:var(--bg);color:var(--text-muted);border-radius:4px;padding:.15rem .5rem;font-size:.8rem}.post-card>:last-child{margin-bottom:0}.category-filter{display:flex;justify-content:center;flex-wrap:wrap;gap:.5rem;margin-bottom:2rem}.category-filter a{display:inline-block;padding:.4rem 1rem;border:1px solid var(--border);border-radius:20px;font-size:.85rem;font-weight:600;color:var(--text-muted);background:var(--surface);transition:background .2s,color .2s,border-color .2s}.category-filter a:hover,.category-filter a.active{background:var(--accent);color:#fff;border-color:var(--accent);text-decoration:none}.article-hero{text-align:center;padding:4rem 0 2rem}.article-hero h1{margin-bottom:.75rem}.article-hero .article-meta{font-size:.9rem;color:var(--text-muted);display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem 1rem;align-items:center}.article-content{padding:1rem 0 4rem}.article-content :where(h1,h2,h3,h4,h5,h6){margin-top:2.5rem;margin-bottom:1rem}.article-content :where(h1,h2,h3,h4,h5,h6):first-child{margin-top:0}.article-content p{margin-bottom:1.25rem;line-height:1.75}.article-content ul,.article-content ol{margin-bottom:1.25rem;padding-left:1.5rem;color:var(--text-muted)}.article-content li{margin-bottom:.4rem}.article-content blockquote{border-left:4px solid var(--accent);padding-left:1rem;margin:1.5rem 0;color:var(--text-muted);font-style:italic}.article-content blockquote>:last-child{margin-bottom:0}.article-content pre{background:#1e1e1e;color:#d4d4d4;border-radius:var(--radius);padding:1.25rem;overflow-x:auto;margin-bottom:1.25rem;font-size:.85rem}.article-content :not(pre)>code{background:var(--bg);color:var(--accent);padding:.15rem .4rem;border-radius:4px;font-size:.9em}.article-content img{max-width:100%;border-radius:var(--radius);margin:1.5rem 0}.article-content figure{margin:1.5rem 0}.article-content figure img{margin:0}.article-content figure figcaption{text-align:center;font-size:.85rem;color:var(--text-muted);margin-top:.5rem}.article-footer{border-top:1px solid var(--border);padding:2rem 0 4rem}.article-footer .tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.article-footer .tags a{display:inline-block;background:var(--bg);color:var(--text-muted);border-radius:4px;padding:.2rem .65rem;font-size:.85rem}.article-footer .tags a:hover{background:var(--accent);color:#fff;text-decoration:none}.article-footer .back-link{display:inline-block;font-size:.9rem;font-weight:600}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.article-content .footnotes{margin-top:3rem;padding-top:1.5rem;border-top:1px solid var(--border);font-size:.9rem;color:var(--text-muted)}.article-content .footnotes ol{padding-left:1.5rem;margin-bottom:0}.article-content .footnotes li{margin-bottom:.5rem}.article-content .footnotes li:target{background:var(--bg);border-radius:var(--radius);padding:.5rem;margin:-.5rem}.article-content sup a{font-size:.75em;font-weight:600;text-decoration:none}.article-content sup a:hover{text-decoration:underline}.tag-header{text-align:center;padding:4rem 0 2rem}.tag-header h1{margin-bottom:.5rem}.tag-header .subtitle{font-size:1rem;color:var(--text-muted)}.rss-link{display:inline-flex;align-items:center;gap:.35rem;font-size:.85rem;font-weight:600;color:var(--text-muted);padding:.4rem 1rem;border:1px solid var(--border);border-radius:20px;margin-bottom:2rem}.rss-link:hover{border-color:var(--accent);color:var(--accent);text-decoration:none}@media(max-width:640px){h1{font-size:2rem}.blog-header,.article-hero,.tag-header{padding:3rem 0 1.5rem}.post-card{padding:1.25rem 1.5rem}}
