:root{--bg: #ffffff;--bg-subtle: #f8fafc;--bg-hover: #f1f5f9;--text: #0f172a;--text-muted: #64748b;--border: #e2e8f0;--accent: #2563eb;--accent-hover: #1d4ed8;--accent-subtle: #dbeafe;--tag-bg: #f1f5f9;--tag-text: #475569;--max-prose: 68ch;--max-wide: 960px;--font-mono: ui-monospace, "Cascadia Code", "Fira Code", Menlo, monospace}@media(prefers-color-scheme:dark){:root:not([data-theme=light]){--bg: #0d1117;--bg-subtle: #161b22;--bg-hover: #1c2128;--text: #e6edf3;--text-muted: #8b949e;--border: #30363d;--accent: #58a6ff;--accent-hover: #79b8ff;--accent-subtle: #1f3b6e;--tag-bg: #1c2128;--tag-text: #8b949e}}[data-theme=dark]{--bg: #0d1117;--bg-subtle: #161b22;--bg-hover: #1c2128;--text: #e6edf3;--text-muted: #8b949e;--border: #30363d;--accent: #58a6ff;--accent-hover: #79b8ff;--accent-subtle: #1f3b6e;--tag-bg: #1c2128;--tag-text: #8b949e}*,*:before,*:after{box-sizing:border-box}html{font-size:16px}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;font-size:1rem;line-height:1.65;background:var(--bg);color:var(--text);min-height:100vh;display:flex;flex-direction:column;-webkit-font-smoothing:antialiased;transition:background .15s,color .15s}img{max-width:100%;height:auto;display:block}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.wrapper{max-width:var(--max-wide);margin:0 auto;padding:0 1.5rem}main{flex:1;padding:2.5rem 0 5rem}header{border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10;background:color-mix(in srgb,var(--bg) 88%,transparent);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.header-inner{max-width:var(--max-wide);margin:0 auto;padding:0 1.5rem;height:58px;display:flex;align-items:center;justify-content:space-between;gap:1rem}.site-name{font-weight:700;font-size:1.05rem;color:var(--text);white-space:nowrap}.site-name:hover{color:var(--accent);text-decoration:none}nav{display:flex;align-items:center;gap:.125rem}nav a{color:var(--text-muted);padding:.35rem .65rem;border-radius:6px;font-size:.9rem;transition:color .15s,background .15s}nav a:hover{color:var(--text);background:var(--bg-hover);text-decoration:none}nav a.active{color:var(--text);font-weight:500}.header-right{display:flex;align-items:center;gap:.5rem}.theme-toggle{background:none;border:1px solid var(--border);border-radius:6px;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;width:34px;height:34px;flex-shrink:0;transition:color .15s,background .15s,border-color .15s;padding:0}.theme-toggle:hover{color:var(--text);background:var(--bg-hover);border-color:var(--text-muted)}footer{border-top:1px solid var(--border);padding:1.75rem 0;font-size:.85rem;color:var(--text-muted)}.footer-inner{max-width:var(--max-wide);margin:0 auto;padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}.footer-links{display:flex;gap:1rem}.footer-links a{color:var(--text-muted)}.footer-links a:hover{color:var(--text);text-decoration:none}.post-list{display:flex;flex-direction:column}.post-card{padding:1.375rem 0;border-bottom:1px solid var(--border)}.post-card:last-child{border-bottom:none}.post-card-title{font-size:1.15rem;font-weight:600;color:var(--text);line-height:1.35;display:block}.post-card-title:hover{color:var(--accent);text-decoration:none}.post-card-meta{font-size:.78rem;color:var(--text-muted);margin-top:.3rem;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.post-card-description{margin-top:.4rem;font-size:.925rem;color:var(--text-muted);line-height:1.55}.tags{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.5rem}.tag{background:var(--tag-bg);color:var(--tag-text);padding:.18rem .55rem;border-radius:4px;font-size:.73rem;font-family:var(--font-mono);text-decoration:none;transition:background .15s,color .15s}.tag:hover{background:var(--accent-subtle);color:var(--accent);text-decoration:none}.prose{max-width:var(--max-prose)}.prose :is(h1,h2,h3,h4){color:var(--text);line-height:1.3;font-weight:600;margin-top:2em;margin-bottom:.6em}.prose h1{font-size:2rem}.prose h2{font-size:1.45rem;border-bottom:1px solid var(--border);padding-bottom:.3em}.prose h3{font-size:1.2rem}.prose h4{font-size:1.05rem}.prose p{margin-bottom:1.2em}.prose :is(ul,ol){margin-bottom:1.2em;padding-left:1.5rem}.prose li{margin-bottom:.35em}.prose li>:is(ul,ol){margin-top:.35em;margin-bottom:0}.prose blockquote{border-left:3px solid var(--accent);margin:1.5em 0;padding:.6em 1rem;background:var(--bg-subtle);border-radius:0 6px 6px 0;color:var(--text-muted);font-style:italic}.prose blockquote p{margin:0}.prose hr{border:none;border-top:1px solid var(--border);margin:2.5em 0}.prose a{color:var(--accent);text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:1px}.prose strong{color:var(--text);font-weight:600}.prose code:not(pre code){font-family:var(--font-mono);font-size:.855em;background:var(--bg-subtle);border:1px solid var(--border);padding:.15em .4em;border-radius:4px;color:var(--text)}.prose img{border-radius:8px;margin:2em auto;border:1px solid var(--border)}.prose table{width:100%;border-collapse:collapse;margin-bottom:1.2em;font-size:.9em}.prose :is(th,td){padding:.5rem .75rem;border:1px solid var(--border)}.prose th{background:var(--bg-subtle);font-weight:600;text-align:left}.prose pre,pre{margin:1.5em 0;border-radius:8px;overflow:auto;font-size:.855rem;line-height:1.65;position:relative;border:1px solid #30363d}.prose pre>code,pre>code{display:block;padding:1.25rem 1.5rem;min-width:100%;font-family:var(--font-mono);background:none!important;border:none!important}.copy-btn{position:absolute;top:.6rem;right:.6rem;padding:.2rem .55rem;font-size:.68rem;font-family:var(--font-mono);background:#ffffff14;border:1px solid rgba(255,255,255,.12);color:#8b949e;border-radius:4px;cursor:pointer;opacity:0;transition:opacity .2s,background .15s,color .15s;line-height:1.5}pre:hover .copy-btn,.copy-btn:focus{opacity:1}.copy-btn:hover{background:#ffffff24;color:#e6edf3}.copy-btn.copied{color:#3fb950}.post-header{margin-bottom:2.5rem}.post-title{font-size:2.1rem;font-weight:700;line-height:1.2;color:var(--text);margin-bottom:.75rem}.post-meta{font-size:.85rem;color:var(--text-muted);display:flex;align-items:center;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}.post-meta .sep{color:var(--border)}.hero-image{width:100%;border-radius:10px;margin:1.5rem 0 2rem;border:1px solid var(--border);aspect-ratio:16/9;object-fit:cover}.post-nav{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:3.5rem;padding-top:2rem;border-top:1px solid var(--border)}.post-nav-link{display:flex;flex-direction:column;gap:.25rem;padding:1rem;border:1px solid var(--border);border-radius:8px;color:var(--text);transition:border-color .15s}.post-nav-link:hover{border-color:var(--accent);text-decoration:none}.post-nav-link .direction{font-size:.73rem;color:var(--text-muted)}.post-nav-link .nav-title{font-size:.875rem;font-weight:500;color:var(--text)}.post-nav-link.next{text-align:right}.page-header{margin-bottom:2rem}.page-title{font-size:1.65rem;font-weight:700;color:var(--text);margin-bottom:.5rem}.page-description{color:var(--text-muted);font-size:.95rem}.home-bio{padding:3rem 0 2.5rem;border-bottom:1px solid var(--border);margin-bottom:2.5rem}.home-name{font-size:1.8rem;font-weight:700;margin-bottom:.5rem;line-height:1.2}.home-tagline{color:var(--text-muted);font-size:1.05rem;max-width:52ch;line-height:1.55}.home-links{display:flex;gap:1.25rem;margin-top:1.25rem;flex-wrap:wrap}.home-links a{font-size:.875rem;color:var(--text-muted);display:flex;align-items:center;gap:.3rem}.home-links a:hover{color:var(--accent);text-decoration:none}.section-heading{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:1rem}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.25rem;margin-top:1.5rem}.project-card{border:1px solid var(--border);border-radius:10px;padding:1.25rem;transition:border-color .15s;display:flex;flex-direction:column}.project-card:hover{border-color:var(--accent)}.project-title{font-weight:600;font-size:.975rem;margin-bottom:.45rem;color:var(--text)}.project-description{font-size:.875rem;color:var(--text-muted);line-height:1.5;margin-bottom:.85rem;flex:1}.project-footer{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.project-links{display:flex;gap:.75rem}.project-links a{font-size:.8rem;color:var(--text-muted)}.project-links a:hover{color:var(--accent);text-decoration:none}.project-tags{display:flex;gap:.3rem;flex-wrap:wrap}.all-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.5rem}.all-tags .tag{font-size:.835rem;padding:.3rem .7rem}.tag-count{font-size:.7rem;opacity:.7}.about-content{max-width:var(--max-prose)}.updated-badge{font-size:.78rem;color:var(--text-muted);background:var(--bg-subtle);border:1px solid var(--border);padding:.15rem .5rem;border-radius:4px}@media(max-width:640px){.post-title{font-size:1.65rem}.home-name{font-size:1.5rem}.post-nav{grid-template-columns:1fr}.post-nav-link.next{text-align:left}nav a{padding:.3rem .5rem;font-size:.85rem}}@media(max-width:480px){.header-inner{gap:.5rem}nav a:not(.active){display:none}nav a.active{display:block}nav:before{content:"Nav";color:var(--text-muted);font-size:.85rem}}
