@import url('https://fonts.googleapis.com/css2?family=Source+Serif+4:ital,wght@0,400;0,600;0,700;1,400&family=DM+Sans:ital,wght@0,400;0,500;0,600;0,700;1,400&family=JetBrains+Mono:wght@400;500&display=swap');
:root{--bg:#faf8f4;--surface:#fff;--ink:#1a1612;--ink-light:#6b5e4f;--ink-faint:#a89a8a;--accent:#b03a2e;--accent-hover:#8e2e24;--border:#e0d8cc;--border-light:#ede7dc;--comment-bg:#f5f1ea;--max-w:740px}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Source Serif 4',Georgia,serif;background:var(--bg);color:var(--ink);font-size:17px;line-height:1.7;-webkit-font-smoothing:antialiased}
a{color:var(--accent);text-decoration:none;transition:color .15s}a:hover{color:var(--accent-hover);text-decoration:underline}
.site-header{background:var(--surface);border-bottom:1px solid var(--border);padding:1.5rem 2rem;position:sticky;top:0;z-index:100}
.header-inner{max-width:var(--max-w);margin:0 auto;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.site-name{font-family:'DM Sans',sans-serif;font-size:1.1rem;font-weight:700;color:var(--ink);letter-spacing:-.02em;white-space:nowrap}.site-name a{color:inherit}.site-name a:hover{text-decoration:none;opacity:.7}
.search-wrap{position:relative;flex:0 1 280px}
.search-input{width:100%;padding:.45rem .75rem .45rem 2rem;border:1px solid var(--border);border-radius:6px;background:var(--bg);font-family:'DM Sans',sans-serif;font-size:.85rem;color:var(--ink);outline:none;transition:border-color .15s}.search-input:focus{border-color:var(--accent)}
.search-icon{position:absolute;left:.6rem;top:50%;transform:translateY(-50%);color:var(--ink-faint);font-size:.85rem;pointer-events:none}
.search-results{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:0 8px 30px rgba(0,0,0,.12);max-height:400px;overflow-y:auto;display:none;z-index:200}.search-results.open{display:block}
.search-result-item{display:block;padding:.65rem .85rem;border-bottom:1px solid var(--border-light);color:var(--ink);font-family:'DM Sans',sans-serif;font-size:.85rem}.search-result-item:last-child{border-bottom:none}.search-result-item:hover{background:var(--bg);text-decoration:none}
.search-result-item .sr-title{font-weight:600;display:block}.search-result-item .sr-meta{font-size:.75rem;color:var(--ink-faint);margin-top:.15rem}.search-result-item .sr-snippet{font-size:.78rem;color:var(--ink-light);margin-top:.2rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.search-no-results{padding:1rem;text-align:center;color:var(--ink-light);font-size:.85rem;font-family:'DM Sans',sans-serif}
.content{max-width:var(--max-w);margin:0 auto;padding:2rem}
.page-title{font-size:2rem;font-weight:700;letter-spacing:-.03em;margin-bottom:.35rem}.page-subtitle{color:var(--ink-light);font-size:.95rem;margin-bottom:1.25rem}
.controls-bar{display:flex;gap:.5rem;margin-bottom:1.5rem;font-family:'DM Sans',sans-serif;flex-wrap:wrap;align-items:center}
.filter-btn{padding:.35rem .85rem;border:1px solid var(--border);border-radius:5px;background:var(--surface);font-family:inherit;font-size:.8rem;cursor:pointer;transition:all .15s;color:var(--ink-light)}.filter-btn:hover{border-color:var(--accent);color:var(--accent)}.filter-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.sort-btn{padding:.35rem .85rem;border:1px solid var(--border);border-radius:5px;background:var(--surface);font-family:inherit;font-size:.8rem;cursor:pointer;transition:all .15s;color:var(--ink-light);margin-left:auto}.sort-btn:hover{border-color:var(--accent);color:var(--accent)}
.post-list{list-style:none}
.post-list-item{padding:1rem 0;border-bottom:1px solid var(--border-light);display:block;color:var(--ink)}.post-list-item:hover{text-decoration:none}.post-list-item:hover .pli-title{color:var(--accent)}
.pli-title{font-size:1.15rem;font-weight:600;transition:color .15s;letter-spacing:-.01em}.post-meta{font-family:'DM Sans',sans-serif;font-size:.78rem;color:var(--ink-faint);margin-top:.2rem}.post-snippet{font-size:.9rem;color:var(--ink-light);margin-top:.35rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.post-header{margin-bottom:2rem}.post-header .post-title{font-size:1.85rem;line-height:1.25}.post-header .post-meta{margin-top:.5rem;font-size:.85rem}
.post-type-badge{display:inline-block;font-family:'JetBrains Mono',monospace;font-size:.65rem;text-transform:uppercase;letter-spacing:.06em;background:var(--border-light);color:var(--ink-light);padding:.15rem .5rem;border-radius:3px;margin-left:.5rem;vertical-align:middle}
.post-body{font-size:1.05rem;line-height:1.75}.post-body p{margin-bottom:1rem}.post-body h2{font-size:1.4rem;margin:1.8rem 0 .6rem}.post-body h3{font-size:1.15rem;margin:1.4rem 0 .5rem}.post-body img{max-width:100%;height:auto;border-radius:4px;margin:1rem 0}.post-body blockquote{margin:1rem 0;padding:.5rem 1.25rem;border-left:3px solid var(--border);color:var(--ink-light);font-style:italic}.post-body pre{background:#2d2a26;color:#e8e0d4;padding:1rem;border-radius:6px;overflow-x:auto;font-family:'JetBrains Mono',monospace;font-size:.85rem;margin:1rem 0}.post-body code{font-family:'JetBrains Mono',monospace;font-size:.88em;background:var(--border-light);padding:.1em .35em;border-radius:3px}.post-body pre code{background:none;padding:0}.post-body ul,.post-body ol{margin:.75rem 0 .75rem 1.5rem}.post-body li{margin-bottom:.25rem}
.comments-section{margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid var(--border)}.comments-heading{font-family:'DM Sans',sans-serif;font-size:.95rem;font-weight:600;color:var(--ink-light);margin-bottom:1rem}
.comment{padding:.85rem 1rem;margin-bottom:.75rem;background:var(--comment-bg);border-radius:6px;border-left:3px solid var(--border)}.comment-author{font-family:'DM Sans',sans-serif;font-weight:600;font-size:.85rem}.comment-date{font-family:'DM Sans',sans-serif;font-size:.75rem;color:var(--ink-faint);margin-left:.4rem}.comment-body{font-size:.92rem;margin-top:.35rem;color:var(--ink)}.comment-body p{margin-bottom:.4rem}
.post-nav{display:flex;justify-content:space-between;gap:1rem;margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid var(--border);font-family:'DM Sans',sans-serif;font-size:.85rem}.post-nav a{max-width:45%}.post-nav .label{display:block;font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-faint);margin-bottom:.2rem}.post-nav .nav-title{font-weight:600}.post-nav .next{text-align:right;margin-left:auto}
.timeline-section{max-width:var(--max-w);margin:2rem auto 0;padding:0 2rem 2rem}
.timeline-heading{font-family:'DM Sans',sans-serif;font-size:.8rem;font-weight:600;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.75rem}
.timeline{display:flex;align-items:stretch;gap:0;border:1px solid var(--border);border-radius:8px;overflow:hidden;background:var(--surface)}
.tl-period{flex:1;text-align:center;padding:.55rem .25rem;font-family:'DM Sans',sans-serif;font-size:.72rem;cursor:pointer;transition:all .15s;border-right:1px solid var(--border-light);color:var(--ink-light);position:relative;min-width:0}
.tl-period:last-child{border-right:none}
.tl-period:hover{background:var(--bg);color:var(--accent)}
.tl-period .tl-label{display:block;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tl-period .tl-count{display:block;font-family:'JetBrains Mono',monospace;font-size:.65rem;color:var(--ink-faint);margin-top:.1rem}
.tl-period .tl-bar{position:absolute;bottom:0;left:15%;right:15%;height:3px;background:var(--accent);border-radius:2px 2px 0 0;opacity:.35}
.tl-period:hover .tl-bar{opacity:1}
.site-footer{max-width:var(--max-w);margin:0 auto;padding:1.5rem 2rem;text-align:center;font-family:'DM Sans',sans-serif;font-size:.78rem;color:var(--ink-faint);border-top:1px solid var(--border-light)}
@media(max-width:640px){.header-inner{flex-direction:column;align-items:stretch}.search-wrap{flex:1 1 auto}.page-title{font-size:1.5rem}.content{padding:1.25rem}.post-header .post-title{font-size:1.45rem}.timeline{flex-wrap:wrap}.tl-period{flex:0 0 auto;min-width:60px}}