:root{--bg: #ffffff;--bg-muted: #f6f7f9;--fg: #0b0c0e;--fg-muted: #4a5160;--border: #e3e6eb;--link: #0b6bcb;--link-hover: #08518f;--code-bg: #f1f3f6;--code-fg: #0b0c0e;--pill-bg: #eef1f6;--pill-fg: #1f2937;--max-width: 720px;--measure: 70ch;--radius: 6px;--font-body: -apple-system, BlinkMacSystemFont, "Segoe UI", Inter, Helvetica, Arial, sans-serif, "Apple Color Emoji";--font-mono: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, "Liberation Mono", monospace}@media (prefers-color-scheme: dark){:root{--bg: #0b0c0e;--bg-muted: #14171c;--fg: #e7eaf0;--fg-muted: #9aa3b2;--border: #2a2f37;--link: #6fb8ff;--link-hover: #a0d0ff;--code-bg: #14171c;--code-fg: #e7eaf0;--pill-bg: #1c2027;--pill-fg: #c5cdda}}*{box-sizing:border-box}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{margin:0;background:var(--bg);color:var(--fg);font-family:var(--font-body);font-size:17px;line-height:1.65;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}a{color:var(--link);text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:1px}a:hover{color:var(--link-hover)}img{max-width:100%;height:auto}h1,h2,h3,h4,h5,h6{line-height:1.25;margin:1.6em 0 .5em;font-weight:650;letter-spacing:-.01em}h1{font-size:2rem;margin-top:.4em}h2{font-size:1.4rem}h3{font-size:1.15rem}.heading-anchor{margin-right:.4em;color:var(--fg-muted);text-decoration:none;opacity:0;transition:opacity .15s}h1:hover .heading-anchor,h2:hover .heading-anchor,h3:hover .heading-anchor,h4:hover .heading-anchor{opacity:.7}p{margin:0 0 1em;max-width:var(--measure)}ul,ol{padding-left:1.4em}code{font-family:var(--font-mono);background:var(--code-bg);color:var(--code-fg);padding:.1em .35em;border-radius:4px;font-size:.92em}pre.code-block{background:var(--code-bg);color:var(--code-fg);padding:1em 1.1em;border-radius:var(--radius);overflow-x:auto;font-size:.92em;line-height:1.55;border:1px solid var(--border)}pre.code-block code{background:transparent;padding:0}blockquote{margin:1.5em 0;padding:.4em 1.2em;border-left:3px solid var(--border);color:var(--fg-muted)}hr{border:0;border-top:1px solid var(--border);margin:2em 0}.page{min-height:100vh;display:flex;flex-direction:column}.site-header{display:flex;align-items:center;justify-content:space-between;padding:.5rem clamp(1rem,4vw,2rem);border-bottom:1px solid var(--border)}.site-brand{font-weight:700;font-size:1.05rem;color:var(--fg);text-decoration:none;letter-spacing:-.01em;display:inline-flex;align-items:center;min-height:48px;padding:0 .4rem}.site-nav{display:flex;gap:.4rem;align-items:center}.site-nav a{color:var(--fg);text-decoration:none;font-weight:500;display:inline-flex;align-items:center;min-height:48px;min-width:48px;justify-content:center;padding:0 .7rem}.site-nav a:hover{color:var(--link)}.lang-switch{font-size:.82rem;border:1px solid var(--border);border-radius:var(--radius)}main{flex:1;padding:clamp(1.5rem,4vw,3rem) clamp(1rem,4vw,2rem);max-width:var(--max-width);width:100%;margin:0 auto}.site-footer{border-top:1px solid var(--border);padding:1.5rem clamp(1rem,4vw,2rem);color:var(--fg-muted);font-size:.9rem;text-align:center}.site-footer a{color:var(--fg-muted);text-decoration:none}.site-footer a:hover{color:var(--link)}.hero{display:flex;align-items:center;gap:1.4rem;margin-bottom:2.5rem}.hero-photo{width:96px;height:96px;border-radius:50%;object-fit:cover;border:2px solid var(--border)}.hero h1{margin:0 0 .25em}.tagline{color:var(--fg-muted);margin:0;font-size:1.05rem}.skill-list,.project-list,.post-list{list-style:none;padding:0;margin:1rem 0 2rem;display:grid;grid-template-columns:1fr;gap:1.2rem}@media (min-width: 700px){.skill-list,.project-list{grid-template-columns:1fr 1fr}}.skill,.project,.post-card{border:1px solid var(--border);border-radius:var(--radius);padding:1.1rem 1.2rem;background:var(--bg-muted)}.skill h3,.project h3,.post-card h2{margin:0 0 .4rem;font-size:1.1rem}.skill p,.project p,.post-excerpt{margin:0;color:var(--fg-muted)}.project a,.post-card a{color:var(--fg)}.project a:hover,.post-card a:hover{color:var(--link)}.blog-teaser{margin:2.5rem 0 1rem;padding:1.2rem;border-radius:var(--radius);background:var(--bg-muted);border:1px solid var(--border)}.blog-header{margin-bottom:2rem}.blog-tagline{color:var(--fg-muted)}.post-meta{color:var(--fg-muted);font-size:.88rem;margin:.3rem 0 .7rem}.post-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.7rem}.tag-pill{display:inline-block;padding:.15rem .55rem;background:var(--pill-bg);color:var(--pill-fg);text-decoration:none;border-radius:999px;font-size:.82rem;font-weight:500}.tag-pill:hover{background:var(--link);color:#fff}.post-header{margin-bottom:1.8rem}.post-content{max-width:var(--measure)}.post-content h2{margin-top:1.8em}.post-content>*{max-width:var(--measure)}.post-content pre{max-width:100%}.post-footer{margin-top:3rem;padding-top:1.5rem;border-top:1px solid var(--border);color:var(--fg-muted);font-size:.95rem}.elmsh{background:var(--code-bg)}.elmsh-line:before{color:var(--fg-muted)}@media (prefers-color-scheme: dark){.elmsh-comm{color:#6b7686}.elmsh-kw{color:#c792ea}.elmsh-str{color:#c3e88d}.elmsh-typ{color:#82aaff}.elmsh-num{color:#f78c6c}.elmsh-fn{color:#82aaff}.elmsh-var{color:#ffcb6b}.elmsh-bn,.elmsh1{color:#89ddff}}@media (prefers-color-scheme: light){.elmsh-comm{color:#6b7686}.elmsh-kw{color:#7c4dff}.elmsh-str{color:#00875a}.elmsh-typ{color:#1e6bd6}.elmsh-num{color:#d97706}.elmsh-fn{color:#1e6bd6}.elmsh-var{color:#b45309}.elmsh-bn,.elmsh1{color:#0e7490}}
