:root{color-scheme:light;--bg: #f4f7f4;--surface: #ffffff;--ink: #18212b;--muted: #66717d;--line: #dce3df;--accent: #1f6f63;--accent-2: #ba5b35;--wash: #e8f0ec;--shadow: 0 18px 48px rgba(32, 47, 43, .1)}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-height:100vh;background:var(--bg);color:var(--ink);font:16px/1.72 ui-sans-serif,-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;overflow-wrap:anywhere}a{color:inherit;text-decoration:none}a:hover{color:var(--accent)}img{max-width:100%;height:auto}.site-header{position:sticky;top:0;z-index:20;height:64px;display:flex;align-items:center;justify-content:space-between;gap:24px;padding:0 max(22px,calc((100vw - 1120px)/2));border-bottom:1px solid rgba(220,227,223,.86);background:#f4f7f4eb;backdrop-filter:blur(16px)}.brand{font-weight:800;font-size:18px;letter-spacing:0}.nav{display:flex;align-items:center;gap:18px;color:var(--muted);font-size:14px}.site-footer{display:flex;justify-content:space-between;gap:16px;padding:30px max(22px,calc((100vw - 1120px)/2));border-top:1px solid var(--line);color:var(--muted);font-size:14px}.shell{max-width:1120px;margin:0 auto;padding:0 22px}.hero{min-height:calc(100svh - 64px);display:grid;align-items:center;padding:52px 0 40px}.hero-grid{display:grid;grid-template-columns:minmax(0,1.08fr) minmax(320px,.72fr);gap:42px;align-items:center}.kicker{margin:0 0 16px;color:var(--accent);font-size:13px;font-weight:760}h1,h2,h3{line-height:1.18;letter-spacing:0}.hero h1{margin:0;max-width:780px;font-size:clamp(42px,7vw,82px);font-weight:780}.hero-copy{margin:22px 0 0;max-width:680px;color:#40505c;font-size:18px;line-height:1.9}.hero-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:30px}.button{min-height:42px;display:inline-flex;align-items:center;justify-content:center;padding:0 15px;border:1px solid var(--line);border-radius:8px;background:var(--surface);box-shadow:0 8px 22px #202f2b0d}.button.primary{background:var(--ink);border-color:var(--ink);color:#fff}.button.primary:hover{color:#fff;background:#24313c}.portrait{aspect-ratio:4 / 5;border-radius:8px;overflow:hidden;background:var(--wash);box-shadow:var(--shadow)}.portrait img{width:100%;height:100%;object-fit:cover}.section{padding:54px 0}.section-head{display:flex;align-items:end;justify-content:space-between;gap:24px;margin-bottom:22px}.section-head h2{margin:0;font-size:28px}.section-head p{margin:6px 0 0;color:var(--muted);max-width:620px}.project-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.project{min-height:210px;padding:20px;border:1px solid var(--line);border-radius:8px;background:var(--surface);display:flex;flex-direction:column;justify-content:space-between}.project h3{margin:0 0 10px;font-size:20px}.project p{margin:0;color:var(--muted)}.stack{display:flex;flex-wrap:wrap;gap:7px;margin-top:18px}.stack span,.tag-row a,.tag-list a{border:1px solid var(--line);border-radius:999px;padding:4px 10px;color:var(--muted);font-size:13px;background:#fbfcfb}.post-list{display:grid;gap:12px}.post-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:18px;align-items:start;padding:20px 0;border-bottom:1px solid var(--line)}.post-row h2{margin:0 0 8px;font-size:22px}.post-row p{margin:0;color:var(--muted)}.meta{color:var(--muted);font-size:13px;white-space:nowrap}.page-head{padding:62px 0 28px}.page-head h1{margin:0 0 12px;font-size:42px}.page-head p{margin:0;color:var(--muted);max-width:680px}.article-shell{max-width:860px;margin:0 auto;padding:44px 22px 86px}.back-link{color:var(--muted);font-size:14px}.article-head{padding:22px 0 28px;border-bottom:1px solid var(--line)}.article-head h1{margin:8px 0 16px;font-size:clamp(34px,7vw,56px)}.eyebrow{margin:0;color:var(--accent);font-weight:740;font-size:13px}.article-meta{display:flex;gap:12px;flex-wrap:wrap;color:var(--muted);font-size:14px}.tag-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:18px}.prose{padding-top:28px}.prose :where(h2,h3){margin-top:34px}.prose p{margin:14px 0}.prose a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}.prose pre{overflow-x:auto;padding:16px;border-radius:8px;background:#101418;color:#f7f7f7}.prose code{font-family:ui-monospace,SFMono-Regular,Consolas,monospace;font-size:.92em}.prose :not(pre)>code{padding:2px 5px;border-radius:5px;background:#e8eeeb;color:#1f3934}.prose blockquote{margin:20px 0;padding:2px 0 2px 18px;border-left:3px solid var(--accent);color:#4a5a62}.prose table{width:100%;border-collapse:collapse;display:block;overflow-x:auto}.prose th,.prose td{border:1px solid var(--line);padding:8px 10px}.prose img{border-radius:8px;border:1px solid var(--line)}.tag-list{display:flex;flex-wrap:wrap;gap:10px;padding:0 0 64px}.empty{padding:34px;border:1px solid var(--line);border-radius:8px;background:var(--surface);color:var(--muted)}@media (max-width: 860px){.site-header{height:auto;min-height:64px;align-items:flex-start;padding-top:12px;padding-bottom:12px}.nav{flex-wrap:wrap;justify-content:flex-end;gap:10px 14px}.hero{min-height:auto;padding-top:42px}.hero-grid{grid-template-columns:1fr}.portrait{max-height:360px;aspect-ratio:16 / 10}.project-grid,.post-row{grid-template-columns:1fr}.meta{white-space:normal}}
