:root{--bg: #0a0a0a;--bg-card: #111a11;--accent: #39ff14;--accent-dim: rgba(57,255,20,.55);--accent-muted: rgba(57,255,20,.12);--accent-label: #8ab820;--border: rgba(57,255,20,.1);--border-card: rgba(57,255,20,.14);--text: #f0f0ee;--text-secondary: rgba(240,240,238,.5);--text-tertiary: rgba(240,240,238,.25)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:17px!important}body{font-size:17px;background:var(--bg);color:var(--text);font-family:Newsreader,Georgia,serif;font-size:1rem;line-height:1.8;-webkit-font-smoothing:antialiased}a{color:var(--accent);text-decoration:none}hr{border:none;border-top:.5px solid var(--border);margin:2.5rem 0}.syne{font-family:Syne,sans-serif}.mono{font-family:JetBrains Mono,monospace}header{position:sticky;top:0;height:52px;background:var(--bg);border-bottom:.5px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 2rem;z-index:100}.logo{font-family:Syne,sans-serif;font-size:14px;font-weight:600;color:var(--text);text-decoration:none;letter-spacing:.04em}.logo-arrow{color:var(--accent)}nav{display:flex;gap:1.5rem}nav a{font-family:Syne,sans-serif;font-size:13px;color:var(--text-secondary);text-decoration:none;letter-spacing:.03em;transition:color .15s}nav a:hover{color:var(--text)}nav a[aria-current=page]{color:var(--text)}.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:4px}.nav-toggle span{display:block;width:20px;height:1.5px;background:var(--text-secondary);margin:4px 0;transition:transform .2s,opacity .2s}footer{border-top:.5px solid var(--border);padding:2rem 2rem 3rem}.footer-inner{max-width:640px;margin:0 auto}.footer-links,.footer-copy{font-family:Syne,sans-serif;font-size:12px;color:var(--text-tertiary);line-height:2}.footer-links a{color:var(--text-tertiary);text-decoration:none;transition:color .15s}.footer-links a:hover{color:var(--accent)}.article-item{padding:.9rem 0;border-bottom:.5px solid rgba(57,255,20,.06);list-style:none}.article-item:last-child{border-bottom:none}.article-title{font-family:Newsreader,serif;font-size:16px;font-weight:400;color:var(--text);text-decoration:none;line-height:1.45;display:block;transition:color .15s}.article-title:hover{color:var(--accent)}.article-meta{font-family:Syne,sans-serif;font-size:12px;color:var(--text-tertiary);margin-top:3px;letter-spacing:.02em}.series-nav{display:flex;justify-content:space-between;gap:1rem;margin-top:4rem;padding-top:2rem;border-top:.5px solid var(--border)}.series-nav-item{flex:1}.series-nav-item.next{text-align:right}.series-nav-label{font-family:Syne,sans-serif;font-size:11px;color:var(--text-tertiary);letter-spacing:.08em;text-transform:uppercase;display:block;margin-bottom:.35rem}.series-nav-title{font-family:Newsreader,serif;font-size:15px;color:var(--text-secondary);line-height:1.4;transition:color .15s}.series-nav-title:hover{color:var(--accent)}.home{max-width:640px;margin:0 auto;padding:4rem 2rem 5rem}.home-kicker{font-family:Syne,sans-serif;font-size:12px;font-weight:500;color:var(--accent-label);letter-spacing:.1em;text-transform:uppercase;margin-bottom:1.5rem}.home-intro{font-size:20px;line-height:1.65;margin-bottom:2.5rem}.home-intro a{color:var(--accent)}.home-intro em{font-style:italic;color:var(--text-secondary)}.series-label{font-family:Syne,sans-serif;font-size:11px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--text-tertiary);margin-bottom:1.25rem}.series-group{margin-bottom:2.5rem}.home-footer-links{display:flex;gap:2rem}.home-footer-links a{font-family:Syne,sans-serif;font-size:13px;color:var(--text-tertiary);text-decoration:none;letter-spacing:.03em;transition:color .15s}.home-footer-links a:hover{color:var(--accent)}.post-page{max-width:640px;margin:0 auto;padding:3.5rem 2rem 5rem}.post-kicker{font-family:Syne,sans-serif;font-size:11px;font-weight:500;color:var(--accent-label);letter-spacing:.1em;text-transform:uppercase;margin-bottom:1rem}.post-title{font-family:Newsreader,serif;font-size:32px;font-weight:400;line-height:1.25;letter-spacing:-.01em;color:var(--text);margin-bottom:1.25rem}.post-byline{font-family:Syne,sans-serif;font-size:13px;color:#f0f0ee6b;display:flex;gap:1rem;margin-bottom:3rem}.post-body p{margin-bottom:1.5rem;font-size:17px;color:#f0f0eed1;line-height:1.82}.post-body>p:first-of-type:first-letter{font-size:3.5em;line-height:.85;float:left;margin:.05em .1em 0 0;color:var(--accent);font-family:Newsreader,serif}.post-body blockquote{border-left:2px solid var(--accent);padding:.25rem 0 .25rem 1.5rem;margin:2rem 0;font-size:20px;font-style:italic;color:var(--text);line-height:1.55;background:none}.post-body code{font-family:JetBrains Mono,monospace;font-size:13px;background:var(--accent-muted);color:var(--accent-dim);padding:1px 6px;border-radius:3px}.post-body a{color:var(--accent);text-decoration:none;border-bottom:.5px solid rgba(57,255,20,.25)}.post-body a:hover{border-color:var(--accent)}.post-body h2{font-family:Syne,sans-serif;font-size:20px;font-weight:500;color:var(--text);margin:2.5rem 0 1rem}.post-body h3{font-family:Syne,sans-serif;font-size:16px;font-weight:500;color:var(--text-secondary);margin:2rem 0 .75rem}.post-body ul,.post-body ol{margin-bottom:1.5rem;padding-left:1.5rem;color:#f0f0eed1}.post-body li{margin-bottom:.5rem}.about-page{max-width:640px;margin:0 auto;padding:3.5rem 2rem 5rem}.about-page h1{font-family:Newsreader,serif;font-size:32px;font-weight:400;margin-bottom:1.5rem}.about-page h2{font-family:Syne,sans-serif;font-size:20px;font-weight:500;color:var(--text);margin:2.5rem 0 1rem}.about-page p{margin-bottom:1.5rem;color:#f0f0eed1;line-height:1.82}.about-page a{color:var(--accent);text-decoration:none;border-bottom:.5px solid rgba(57,255,20,.25)}.about-page a:hover{border-color:var(--accent)}.about-page strong{color:var(--text);font-weight:500}.fact-table{margin-top:1rem}.fact-row{display:flex;gap:1rem;margin-bottom:.55rem;font-size:14px}.fact-label{font-family:Syne,sans-serif;font-size:11px;color:var(--text-tertiary);min-width:120px;padding-top:2px;letter-spacing:.04em;text-transform:uppercase}.fact-value{color:var(--text-secondary)}.now-page{max-width:640px;margin:0 auto;padding:3.5rem 2rem 5rem}.now-page h1{font-family:Newsreader,serif;font-size:32px;font-weight:400;margin-bottom:.5rem}.now-updated{font-family:Syne,sans-serif;font-size:12px;color:var(--text-tertiary);margin-bottom:2.5rem;letter-spacing:.03em}.now-section h2{font-family:Syne,sans-serif;font-size:11px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-label);margin-bottom:.75rem;margin-top:2.5rem}.now-section p{color:#f0f0eebf;line-height:1.8}.projects-page{max-width:640px;margin:0 auto;padding:3.5rem 2rem 5rem}.projects-page h1{font-family:Newsreader,serif;font-size:32px;font-weight:400;margin-bottom:2rem}.project-card{background:var(--bg-card);border:.5px solid var(--border-card);border-radius:8px;padding:1.25rem;margin-bottom:.75rem;display:grid;grid-template-columns:1fr auto;gap:1rem;align-items:start}.project-name{font-family:Syne,sans-serif;font-size:14px;font-weight:500;color:var(--text);margin-bottom:.4rem}.project-name a{color:var(--text);text-decoration:none}.project-name a:hover{color:var(--accent)}.project-desc{font-size:13px;color:var(--text-secondary);line-height:1.6}.badge{font-family:Syne,sans-serif;font-size:10px;font-weight:500;letter-spacing:.07em;text-transform:uppercase;padding:3px 8px;border-radius:3px;white-space:nowrap}.badge-live{background:#39ff141a;color:#39ff14}.badge-building{background:#8ab8201f;color:#8ab820}.badge-backburner{background:#f0f0ee0f;color:#f0f0ee4d}.stack-page{max-width:640px;margin:0 auto;padding:3.5rem 2rem 5rem}.stack-page h1{font-family:Newsreader,serif;font-size:32px;font-weight:400;margin-bottom:.5rem}.stack-intro{font-family:Syne,sans-serif;font-size:13px;color:var(--text-secondary);margin-bottom:2.5rem}.stack-group{margin-bottom:2rem}.stack-group h2{font-family:Syne,sans-serif;font-size:11px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-label);margin-bottom:.75rem}.stack-group dl{margin:0}.stack-group dt{font-family:Syne,sans-serif;font-size:14px;font-weight:500;color:var(--text);margin-top:.75rem}.stack-group dd{font-size:13px;color:var(--text-secondary);margin-left:0;line-height:1.6}.writing-page{max-width:640px;margin:0 auto;padding:3rem 2rem 5rem}.writing-page h1{font-family:Newsreader,serif;font-size:32px;font-weight:400;margin-bottom:2rem}.error-page{max-width:640px;margin:0 auto;padding:6rem 2rem;text-align:center}.error-code{font-family:Syne,sans-serif;font-size:64px;font-weight:500;color:var(--accent);margin-bottom:1rem}.error-msg{font-family:Newsreader,serif;font-size:20px;color:var(--text-secondary);margin-bottom:2rem}.error-link{font-family:Syne,sans-serif;font-size:13px;color:var(--accent)}@media (max-width: 640px){header{padding:0 1.25rem}.nav-toggle{display:block}nav{display:none;position:absolute;top:52px;left:0;right:0;background:var(--bg);border-bottom:.5px solid var(--border);flex-direction:column;padding:1rem 1.25rem;gap:.75rem}nav.open{display:flex}.home,.post-page,.about-page,.now-page,.projects-page,.stack-page,.writing-page{padding-left:1.25rem;padding-right:1.25rem}.post-title{font-size:26px}.project-card{grid-template-columns:1fr;gap:.5rem}.fact-row{flex-direction:column;gap:.25rem}.fact-label{min-width:unset}}
