:root{--font-mono: "JetBrains Mono", "Fira Code", "Courier New", monospace;--bg: #000000;--fg: #ffffff;--fg-dim: #666666;--fg-mid: #aaaaaa;--border: #222222}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{background-color:var(--bg);color:var(--fg);font-family:var(--font-mono);font-size:14px;line-height:1.7;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;display:flex;flex-direction:column}a{color:var(--fg);text-decoration:none}a:hover{text-decoration:underline;text-underline-offset:3px}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.cursor{display:inline-block;width:.6em;height:1em;background:var(--fg);vertical-align:text-bottom;margin-left:2px;animation:blink 1.1s step-end infinite}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.page-enter{animation:fadeIn .25s ease forwards}.nav{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg);z-index:10}.nav-home{font-weight:500;color:var(--fg);letter-spacing:.02em;text-decoration:none}.nav-home:hover{text-decoration:none;opacity:.7}.nav-links{display:flex;gap:2rem}.nav-link{color:var(--fg-dim);font-size:13px;text-decoration:none;transition:color .15s;letter-spacing:.02em}.nav-link:hover,.nav-link.active{color:var(--fg);text-decoration:none}@media(max-width:480px){.nav{padding:1.2rem}.nav-links{gap:1.25rem}}.home{flex:1;display:flex;align-items:center;justify-content:center;padding:4rem 2rem}.home-content{max-width:520px;width:100%}.home-header{display:flex;align-items:baseline;gap:0;margin-bottom:.4rem}.home-name{font-size:clamp(1.4rem,4vw,2rem);font-weight:500;letter-spacing:-.01em;line-height:1}.home-divider{color:var(--fg-dim);margin-bottom:1.2rem;letter-spacing:-.05em;font-size:13px}.home-tagline{font-size:14px;color:var(--fg);margin-bottom:.3rem}.home-quote{font-size:13px;color:var(--fg-mid);margin-bottom:2.5rem;font-style:italic}.home-links{font-size:14px;display:flex;flex-wrap:wrap;gap:.1rem;align-items:baseline}.home-links a{color:var(--fg);text-decoration:none}.home-links a:hover{text-decoration:underline;text-underline-offset:3px}.dim,.sep{color:var(--fg-dim)}@media(max-width:480px){.home{align-items:flex-start;padding:3rem 1.5rem}}.about{flex:1;padding:3rem 2rem}.about-content{max-width:640px;margin:0 auto;width:100%}.section{margin-bottom:3rem}.section-label{font-size:12px;color:var(--fg-dim);margin-bottom:1rem;letter-spacing:.01em}.section-body{border-left:1px solid var(--border);padding-left:1.5rem}.entry{margin-bottom:1.8rem}.entry:last-child{margin-bottom:0}.entry-head{display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:.5rem;margin-bottom:.3rem}.entry-title{font-size:14px;font-weight:500;color:var(--fg)}.entry-date{font-size:12px;color:var(--fg-dim)}.entry-detail{font-size:13px;color:var(--fg-mid);line-height:1.7}@media(max-width:480px){.about{padding:2rem 1.5rem}.entry-head{flex-direction:column}}.projects{flex:1;padding:3rem 2rem}.projects-content{max-width:640px;margin:0 auto;width:100%}.projects-placeholder{border-left:1px solid var(--border);padding-left:1.5rem;margin-top:1rem}.projects-placeholder p{font-size:13px;color:var(--fg-dim);line-height:1.9}@media(max-width:480px){.projects{padding:2rem 1.5rem}}.blog{flex:1;padding:3rem 2rem}.blog-content{max-width:640px;margin:0 auto;width:100%}.post-list{display:flex;flex-direction:column;gap:2.5rem;margin-top:1.5rem;border-left:1px solid var(--border);padding-left:1.5rem}.post-entry{display:flex;flex-direction:column;gap:.3rem}.post-date{font-size:12px;color:var(--fg-dim)}.post-title{font-size:1.1rem;font-weight:500;color:var(--fg);text-decoration:none}.post-title:hover{text-decoration:underline;text-underline-offset:3px}.post-summary{font-size:13px;color:var(--fg-mid);line-height:1.6;margin-top:.2rem}.post-header{margin-bottom:3rem;border-bottom:1px solid var(--border);padding-bottom:2rem}.back-link{font-size:13px;color:var(--fg-dim);display:inline-block;margin-bottom:1.5rem}.back-link:hover{color:var(--fg)}.post-detail-title{font-size:1.8rem;font-weight:500;line-height:1.2;margin-bottom:.5rem;letter-spacing:-.01em}.post-detail-date{font-size:13px;color:var(--fg-dim)}.markdown-body{font-size:15px;line-height:1.8;color:var(--fg-mid)}.markdown-body p{margin-bottom:1.5rem}.markdown-body h1,.markdown-body h2,.markdown-body h3,.markdown-body h4{color:var(--fg);font-weight:500;margin-top:2.5rem;margin-bottom:1rem;line-height:1.3}.markdown-body h1{font-size:1.5rem}.markdown-body h2{font-size:1.3rem;border-bottom:1px solid var(--border);padding-bottom:.5rem}.markdown-body h3{font-size:1.1rem}.markdown-body ul,.markdown-body ol{margin-bottom:1.5rem;padding-left:1.5rem}.markdown-body li{margin-bottom:.5rem}.markdown-body a{color:var(--fg);text-decoration:underline;text-underline-offset:3px}.markdown-body a:hover{color:var(--fg-dim)}.markdown-body blockquote{border-left:2px solid var(--fg-dim);padding-left:1rem;margin-left:0;margin-right:0;margin-bottom:1.5rem;color:var(--fg-dim);font-style:italic}.markdown-body pre{background:#111;border:1px solid var(--border);padding:1rem;border-radius:4px;overflow-x:auto;margin-bottom:1.5rem;font-size:13px}.markdown-body code{font-family:var(--font-mono);background:#111;padding:.2em .4em;border-radius:3px;font-size:.9em;color:var(--fg)}.markdown-body pre code{background:none;padding:0;border-radius:0;color:inherit}@media(max-width:480px){.blog{padding:2rem 1.5rem}}.app{min-height:100vh;display:flex;flex-direction:column}
