:root{color-scheme:light dark;--bg:#f8fafc;--body-bg:radial-gradient(circle at top left,#dbeafe 0,#f8fafc 34rem),var(--bg);--text:#0f172a;--muted:#64748b;--line:#d7dee9;--accent:#0891b2;--accent2:#7c3aed;--good:#15803d;--card-bg:linear-gradient(180deg,rgba(255,255,255,.92),rgba(255,255,255,.72));--mini-bg:rgba(255,255,255,.78);--button-bg:rgba(15,23,42,.035);--code-bg:#eef2f7;--pre-bg:#0f172a;--shadow:0 20px 60px rgba(15,23,42,.10);--hero-gradient:linear-gradient(90deg,#0f172a,#0891b2,#7c3aed);--tag-text:#6d28d9;--tag-line:#ddd6fe;--tag-bg:rgba(124,58,237,.08)}@media(prefers-color-scheme:dark){:root{--bg:#0b1020;--body-bg:radial-gradient(circle at top left,#172554 0,#0b1020 32rem),var(--bg);--text:#e5edf8;--muted:#94a3b8;--line:#26324f;--accent:#67e8f9;--accent2:#a78bfa;--good:#86efac;--card-bg:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.03));--mini-bg:rgba(255,255,255,.035);--button-bg:rgba(255,255,255,.04);--code-bg:#111827;--pre-bg:#020617;--shadow:0 20px 60px rgba(0,0,0,.18);--hero-gradient:linear-gradient(90deg,#fff,#67e8f9,#a78bfa);--tag-text:#c4b5fd;--tag-line:#4c1d95;--tag-bg:rgba(124,58,237,.12)}}*{box-sizing:border-box}body{margin:0;background:var(--body-bg);color:var(--text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,segoe ui,noto sans sc,sans-serif;line-height:1.7}a{color:inherit;text-decoration:none}main,.site-header,.site-footer{max-width:1080px;margin:0 auto;padding:0 22px}.site-header{display:flex;align-items:center;justify-content:space-between;padding-top:24px;padding-bottom:24px}.brand{font-weight:800;font-size:24px;letter-spacing:.08em}.site-header nav{display:flex;gap:18px;flex-wrap:wrap;color:var(--muted)}.site-header nav a:hover,.section-title a,.repo-link{color:var(--accent)}.hero{padding:88px 0 72px}.eyebrow{color:var(--accent);font-weight:700;letter-spacing:.12em}.hero h1{font-size:clamp(44px,8vw,84px);line-height:1;margin:12px 0;background:var(--hero-gradient);-webkit-background-clip:text;color:transparent}.lead{font-size:20px;color:var(--muted);max-width:720px}.hero-actions{display:flex;gap:14px;margin-top:28px}.button{border:1px solid var(--line);padding:11px 18px;border-radius:999px;background:var(--button-bg)}.button.primary{background:linear-gradient(90deg,#0891b2,#7c3aed);border:0;color:#fff}.section-grid{display:grid;grid-template-columns:1.6fr .9fr;gap:28px}.section-title{display:flex;align-items:center;justify-content:space-between;gap:16px}.card{background:var(--card-bg);border:1px solid var(--line);border-radius:22px;padding:22px;box-shadow:var(--shadow);backdrop-filter:blur(14px)}.post-list{display:grid;gap:16px}.post-list.wide{max-width:860px}.post-card h2,.post-card h3,.project-card h2{margin:.25rem 0}.post-card p,.project-card p,.mini-card span{color:var(--muted)}.meta{font-size:14px;color:var(--good)}.project-mini-list,.project-grid{display:grid;gap:16px}.mini-card{display:block;padding:16px;border:1px solid var(--line);border-radius:18px;background:var(--mini-bg)}.mini-card strong,.mini-card span{display:block}.page-heading{padding:54px 0 30px}.page-heading h1,.article h1{font-size:clamp(34px,6vw,58px);line-height:1.1;margin:.2em 0}.project-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.tags{display:flex;gap:8px;flex-wrap:wrap;margin:18px 0}.tags span{font-size:13px;color:var(--tag-text);border:1px solid var(--tag-line);background:var(--tag-bg);border-radius:999px;padding:3px 9px}.article{max-width:820px}.article-header{padding:54px 0 18px}.toc{background:var(--mini-bg);border:1px solid var(--line);border-radius:18px;padding:16px 18px;margin:10px 0 28px;color:var(--muted)}.toc strong{display:block;color:var(--text);margin-bottom:8px}.toc nav ul{margin:.2em 0 .2em 1.1em;padding:0}.toc a{color:var(--accent)}.content{color:var(--text)}.content h2{margin-top:2em;border-top:1px solid var(--line);padding-top:1em}.content a{color:var(--accent)}.content pre{overflow:auto;padding:18px;border-radius:16px;background:var(--pre-bg);border:1px solid var(--line);color:#e5edf8}.content code{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,liberation mono,monospace}.content :not(pre)>code{background:var(--code-bg);border:1px solid var(--line);border-radius:6px;padding:.1em .35em}.site-footer{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;color:var(--muted);border-top:1px solid var(--line);margin-top:72px;padding-top:28px;padding-bottom:32px}@media(max-width:760px){.site-header{align-items:flex-start;gap:16px;flex-direction:column}.section-grid{grid-template-columns:1fr}.hero{padding:52px 0}.hero-actions{flex-direction:column}.button{text-align:center}}.hero-profile{display:grid;grid-template-columns:1.4fr 340px;gap:28px;align-items:center}.profile-card{text-align:center}.profile-card img{width:112px;height:112px;border-radius:28px;object-fit:cover;margin-bottom:14px}.profile-card strong,.profile-card span{display:block}.profile-card span{color:var(--muted)}.profile-links{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:16px}.profile-links a,.card-actions a{color:var(--accent)}.feature-projects{margin-bottom:36px}.project-grid.featured{grid-template-columns:repeat(3,1fr)}.install-line{display:block;margin-top:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-facts{display:grid;gap:10px;margin:16px 0 0}.project-facts div{display:grid;gap:4px}.project-facts dt{font-size:13px;color:var(--good);font-weight:700}.project-facts dd{margin:0;color:var(--muted);overflow-wrap:anywhere}.project-facts.large{grid-template-columns:1fr}.card-actions,.project-actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center}.project-detail-card{margin:0 0 28px}.post-nav{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-top:34px}.copy-code{position:absolute;right:10px;top:10px;border:1px solid var(--line);background:rgba(255,255,255,8%);color:#e5edf8;border-radius:999px;padding:4px 10px;cursor:pointer}.content pre{position:relative}.search-box{margin-top:24px}.pagefind-ui{--pagefind-ui-primary:var(--accent);--pagefind-ui-text:var(--text);--pagefind-ui-background:var(--mini-bg);--pagefind-ui-border:var(--line);--pagefind-ui-tag:var(--code-bg);--pagefind-ui-border-width:1px;--pagefind-ui-border-radius:18px;font-family:inherit}.pagefind-ui__search-input{background:var(--mini-bg)!important;color:var(--text)!important}@media(max-width:900px){.hero-profile{grid-template-columns:1fr}.project-grid.featured{grid-template-columns:1fr}}@media(max-width:760px){.profile-card{text-align:left}.profile-links{justify-content:flex-start}.project-actions .button{width:100%}}