*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg:#fff;--fg:#000;--muted:#666;--border:#222;--accent:#fff}html{font-size:16px;scroll-behavior:smooth}body{background:var(--bg);font-family:Courier New,Courier,monospace;line-height:1.6;max-width:720px;margin:0 auto;padding:2rem 1.5rem}a,body{color:var(--fg)}a{text-decoration:underline;text-underline-offset:3px}a:hover{color:var(--muted)}h1{font-size:1.5rem}h1,h2{font-weight:700}h2{font-size:1.2rem;margin-bottom:1.5rem}h3{font-size:1rem;font-weight:700}p{margin-bottom:1rem}hr{border:none;border-top:1px solid var(--border);margin:2.5rem 0}nav,section{margin-bottom:4rem}nav{display:flex;gap:1.5rem}nav a{text-decoration:none;color:var(--muted);font-size:.875rem}nav a.active,nav a:hover{color:var(--fg)}.project-list{display:flex;flex-direction:column;gap:2rem}.project{border-top:1px solid var(--border);padding-top:1.5rem}.project-meta{font-size:.8rem;color:var(--muted);margin-top:.5rem}.project-links{display:flex;gap:1rem;margin-top:.75rem;font-size:.875rem}.post-list{display:flex;flex-direction:column;gap:0}.post-item{display:flex;justify-content:space-between;align-items:baseline;padding:.75rem 0;border-bottom:1px solid var(--border);gap:1rem}.post-item a{text-decoration:none}.post-item a:hover{text-decoration:underline}.post-date{font-size:.8rem;color:var(--muted);white-space:nowrap}.post-content{line-height:1.8}.post-content h1,.post-content h2,.post-content h3{margin:2rem 0 1rem}.post-content pre{border:1px solid var(--border);padding:1rem;overflow-x:auto;margin:1.5rem 0;font-size:.875rem;border-radius:4px}.post-content code{font-family:Courier New,Courier,monospace;font-size:.9em;background:#111;color:#eee;padding:.1em .3em;border-radius:3px}.post-content pre code{background:none;color:inherit;padding:0}.post-content ol,.post-content ul{margin:1rem 0 1rem 1.5rem}.post-content blockquote{border-left:2px solid var(--muted);padding-left:1rem;color:var(--muted);margin:1.5rem 0}.post-header{margin-bottom:3rem}.post-header .post-date{display:block;margin-top:.5rem}.back-link{display:inline-block;margin-bottom:2rem;font-size:.875rem;color:var(--muted);text-decoration:none}.back-link:hover{color:var(--fg)}@media (max-width:767px){.hide-on-mobile{display:none}}@media (min-width:768px){.show-on-mobile{display:none}}