:root{color-scheme:dark;--bg: #080b0f;--bg-soft: #10161d;--panel: #141b24;--panel-strong: #182331;--text: #edf6ff;--muted: #9eb1c7;--line: rgba(156, 217, 255, .18);--accent: #4ee1b8;--accent-2: #69b7ff;--accent-3: #ffd166;--danger: #ff6b8a;--shadow: 0 22px 70px rgba(0, 0, 0, .32);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans SC,PingFang SC,Microsoft YaHei,sans-serif}*{box-sizing:border-box}html{background:var(--bg);min-width:320px}body{margin:0;color:var(--text);background:linear-gradient(135deg,rgba(78,225,184,.08),transparent 28rem),linear-gradient(315deg,rgba(105,183,255,.1),transparent 24rem),var(--bg);letter-spacing:0}body:before{position:fixed;inset:0;z-index:-1;pointer-events:none;content:"";background-image:linear-gradient(rgba(255,255,255,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.045) 1px,transparent 1px);background-size:42px 42px;mask-image:linear-gradient(to bottom,black,transparent 78%)}a{color:inherit;text-decoration:none}img{display:block;max-width:100%}button,input,textarea{font:inherit}.shell{width:min(1120px,calc(100% - 40px));margin-inline:auto}.skip-link{position:absolute;left:16px;top:12px;z-index:10;padding:10px 14px;color:#06100d;background:var(--accent);border-radius:8px;transform:translateY(-150%)}.skip-link:focus{transform:translateY(0)}.site-header{position:sticky;top:0;z-index:5;border-bottom:1px solid var(--line);background:#080b0fc7;backdrop-filter:blur(18px)}.nav{display:flex;align-items:center;justify-content:space-between;gap:24px;min-height:72px}.nav-main{display:inline-flex;align-items:center;gap:14px}.brand{display:inline-flex;align-items:center;gap:12px;min-width:max-content;font-weight:800}.tag-entry{display:inline-flex;align-items:center;gap:8px;min-height:38px;padding:0 12px;border:1px solid rgba(78,225,184,.4);border-radius:8px;color:var(--accent);background:#4ee1b814;font-weight:800;transition:border-color .16s ease,background .16s ease,transform .16s ease,box-shadow .16s ease}.tag-entry:hover{border-color:#4ee1b8b3;background:#4ee1b824;transform:translateY(-1px);box-shadow:0 10px 26px #4ee1b81f}.nav-divider{width:1px;height:24px;background:var(--line)}.brand-mark{display:block;width:34px;height:34px;object-fit:cover;border-radius:8px;box-shadow:0 0 34px #4ee1b859}.nav-links{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.nav-pill-group{--nav-slice: 12px;display:inline-flex;align-items:stretch;gap:0}.nav-pill-half{display:inline-flex;align-items:center;justify-content:center;min-height:40px;padding:0 18px;border:1px solid var(--line);background:#ffffff09;color:var(--muted);font-size:.94rem;transition:border-color .16s ease,background .16s ease,color .16s ease,transform .16s ease,box-shadow .16s ease}.nav-pill-half-left{border-radius:8px 0 0 8px;border-right:0}.nav-pill-half-right{border-radius:0 8px 8px 0}.nav-links a,.pill-link,.tag{border:1px solid var(--line);border-radius:8px;background:#ffffff09;transition:border-color .16s ease,background .16s ease,color .16s ease,transform .16s ease,box-shadow .16s ease}.nav-links a{padding:9px 12px;color:var(--muted);font-size:.94rem}.nav-pill-group .nav-pill-half{padding:9px 14px;border-radius:0}.nav-pill-group .nav-pill-half-left{border-radius:8px 0 0 8px;clip-path:polygon(0 0,100% 0,calc(100% - var(--nav-slice)) 100%,0 100%)}.nav-pill-group .nav-pill-half-right{border-radius:0 8px 8px 0;margin-left:calc(var(--nav-slice) * -1 + 1px);padding-left:22px;clip-path:polygon(var(--nav-slice) 0,100% 0,100% 100%,0 100%)}.pill-link{display:inline-flex;align-items:center;min-height:40px;padding:0 16px}.nav-links a:hover,.nav-links a[aria-current=page],.pill-link:hover,a.tag:hover{color:var(--text);border-color:#4ee1b88a;background:#4ee1b81a}.nav-links a:hover,.pill-link:hover,a.tag:hover{transform:translateY(-1px);box-shadow:0 10px 26px #4ee1b81f}.nav-pill-half:hover,.nav-pill-half[aria-current=page]{color:var(--text);background:#4ee1b81a}.hero,.page-head{padding:68px 0 28px}.hero-grid{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(280px,.75fr);gap:28px;align-items:stretch}.eyebrow{margin:0 0 16px;color:var(--accent);font-size:.86rem;font-weight:800;text-transform:uppercase}.eyebrow-links{display:flex;flex-wrap:wrap;gap:8px}.eyebrow-links a,.eyebrow-links span{display:inline-flex;align-items:center;min-height:32px;padding:0 10px;border:1px solid rgba(78,225,184,.36);border-radius:8px;color:var(--accent);background:#4ee1b814}.eyebrow-links a{transition:border-color .16s ease,background .16s ease,transform .16s ease,box-shadow .16s ease}.eyebrow-links a:hover{border-color:#4ee1b8b3;background:#4ee1b824;transform:translateY(-1px);box-shadow:0 10px 26px #4ee1b81f}h1,h2,h3,p{overflow-wrap:anywhere}h1{margin:0;max-width:820px;font-size:clamp(2.35rem,8vw,5.2rem);line-height:.96;letter-spacing:0}.hero-title{max-width:none;white-space:nowrap;font-size:clamp(2.4rem,6vw,5.2rem)}h2{margin:0;font-size:clamp(1.7rem,4vw,2.45rem);letter-spacing:0}h3{margin:0;font-size:1.18rem}.lead{max-width:720px;margin:22px 0 0;color:var(--muted);font-size:1.08rem;line-height:1.85}.slogan{display:grid;grid-template-columns:repeat(4,max-content);gap:18px;align-items:start;margin-top:30px}.slogan div{display:grid;justify-items:center;gap:8px}.slogan strong{color:var(--text);font-size:clamp(1.32rem,2.5vw,1.95rem);font-weight:800;line-height:1.1}.slogan span{color:var(--muted);font-size:.95rem;font-weight:700;line-height:1.2}.actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px}.button{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:0 16px;border:1px solid rgba(78,225,184,.5);border-radius:8px;color:#06100d;background:var(--accent);font-weight:800;transition:border-color .16s ease,background .16s ease,color .16s ease,transform .16s ease,box-shadow .16s ease}.button.secondary{color:var(--text);background:transparent}.button:hover{border-color:#4ee1b8c7;background:#6cf0cc;transform:translateY(-2px);box-shadow:0 16px 34px #4ee1b838}.button.secondary:hover{color:var(--text);background:#4ee1b81f}.profile-panel,.card,.metric,.toc-panel{border:1px solid var(--line);border-radius:8px;background:linear-gradient(180deg,#ffffff12,#ffffff09);box-shadow:var(--shadow)}.profile-panel{padding:22px}.profile-top{display:flex;gap:16px;align-items:center}.avatar{width:82px;height:82px;object-fit:cover;object-position:center 42%;border:1px solid var(--line);border-radius:8px}.profile-panel p{color:var(--muted);line-height:1.75}.signal-list{display:grid;gap:10px;margin-top:18px}.signal{display:flex;justify-content:space-between;gap:14px;padding:11px 0;border-top:1px solid var(--line);color:var(--muted)}.signal strong{color:var(--text)}.section{padding:34px 0}.section-title{display:flex;align-items:end;justify-content:space-between;gap:18px;margin-bottom:18px}.section-title p{max-width:560px;margin:0;color:var(--muted);line-height:1.7}.grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.post-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.card{overflow:hidden}.card,.resume-links a{transition:border-color .16s ease,background .16s ease,color .16s ease,transform .16s ease,box-shadow .16s ease}.card[data-card-link]{cursor:pointer}.card[data-card-link]:hover,a.card:hover{border-color:#4ee1b88f;background:linear-gradient(180deg,#4ee1b81f,#ffffff0a);transform:translateY(-2px);box-shadow:0 24px 76px #00000061}.card[data-card-link]:focus-visible{outline:2px solid var(--accent);outline-offset:4px}.post-grid .card{--thumb-size: 190px;display:grid;grid-template-columns:var(--thumb-size) minmax(0,1fr);align-items:start;height:var(--thumb-size);min-height:var(--thumb-size)}.card-image{width:var(--thumb-size);height:var(--thumb-size);aspect-ratio:1 / 1;object-fit:cover;border-right:1px solid var(--line)}.card-body{display:flex;flex-direction:column;justify-content:center;min-width:0;height:100%;overflow:hidden;padding:14px 22px 14px 26px}.meta{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:8px;color:var(--muted);font-size:.84rem;line-height:1.2;font-weight:600}.meta-item{display:inline-flex;align-items:center;font:inherit;line-height:inherit}.meta-link{min-height:26px;padding:0 8px;border:1px solid var(--line);border-radius:8px;color:var(--muted);background:#ffffff09;transition:border-color .16s ease,background .16s ease,color .16s ease,transform .16s ease,box-shadow .16s ease}.meta-link:hover{color:var(--text);border-color:#4ee1b88a;background:#4ee1b81a;transform:translateY(-1px);box-shadow:0 10px 26px #4ee1b81f}.card p{margin:8px 0 0;color:var(--muted);line-height:1.55;display:-webkit-box;overflow:hidden;-webkit-box-orient:vertical;-webkit-line-clamp:2}.tag-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.tag{padding:6px 9px;color:var(--muted);font-size:.84rem}.metric{padding:18px}.metric strong{display:block;margin-bottom:8px;color:var(--accent-3);font-size:1.5rem}.metric span{color:var(--muted);line-height:1.7}.taxonomy-card{justify-content:start;min-height:220px}.opensource-list{display:flex;flex-direction:column;gap:14px}.opensource-card{position:relative;display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:22px;min-height:0}.opensource-card-main{min-width:0}.opensource-card-head{display:flex;align-items:center}.opensource-title-wrap{display:flex;align-items:center;gap:14px;min-width:0}.opensource-title-block{display:flex;flex-direction:column;gap:4px;min-width:0}.opensource-title-wrap h3{margin:0}.opensource-repo-name{color:var(--accent);font-size:.88rem;line-height:1.2}.opensource-badge{flex:0 0 auto;display:grid;place-items:center;width:56px;height:56px;border:1px solid rgba(78,225,184,.4);border-radius:999px;color:var(--accent);background:#4ee1b814;font-size:1rem;font-weight:900}.opensource-side{display:flex;align-items:center;gap:12px}.opensource-repo-link{display:inline-flex;align-items:center;gap:8px;flex:0 0 auto;min-width:0;height:32px;padding:0 10px;border:1px solid rgba(78,225,184,.22);border-radius:8px;color:var(--muted);background:#ffffff08;font-size:.84rem;line-height:1;font-weight:700;transition:border-color .16s ease,background .16s ease,color .16s ease,transform .16s ease,box-shadow .16s ease}.opensource-repo-link svg{width:16px;height:16px}.opensource-repo-link:hover{color:var(--text);border-color:#4ee1b885;background:#4ee1b81a;transform:translateY(-1px);box-shadow:0 10px 24px #4ee1b81f}.opensource-side .tag-row{margin-top:0}.tag-taxonomy-card{min-height:150px}.taxonomy-links{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}.tag-filters{margin-top:18px}.tag-filter-row{display:flex;flex-wrap:wrap;gap:10px}.tag-filter-row .pill-link[data-active=true]{color:var(--text);border-color:#4ee1b88a;background:#4ee1b81a}.tag-counts{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}.tag-count-item{display:inline-flex;align-items:center;min-height:30px;padding:0 9px;border:1px solid var(--line);border-radius:8px;color:var(--muted);background:#ffffff09;font-size:.84rem;font-weight:700}[data-tag-card][hidden]{display:none!important}.article-shell{display:grid;width:min(1120px,calc(100% - 40px));margin:0 auto;padding:28px 0 64px}.article-shell.with-sidebar{grid-template-columns:minmax(0,1fr) 240px;gap:42px;align-items:start}.prose{width:100%;margin:0;color:#dbe8f7;line-height:1.9;font-size:1.04rem}.page-prose{width:min(760px,calc(100% - 40px));margin:0 auto;padding:28px 0 64px}.resume-hero{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:28px;align-items:end}.resume-page{display:grid;gap:30px;padding:28px 0 70px}.resume-card{border:1px solid var(--line);border-radius:8px;background:linear-gradient(180deg,#ffffff12,#ffffff09);box-shadow:var(--shadow);padding:22px}.resume-profile{display:flex;gap:16px;align-items:center}.resume-profile strong,.resume-profile span{display:block}.resume-profile span,.resume-card p,.resume-list,.muted{color:var(--muted);line-height:1.75}.resume-avatar{width:78px;height:78px}.resume-section{display:grid;grid-template-columns:220px minmax(0,1fr);gap:28px;align-items:start}.resume-section.two-column{align-items:center}.resume-section-head{position:sticky;top:94px}.resume-section-head h2{font-size:clamp(1.45rem,3vw,2rem)}.section-note{margin:12px 0 0;color:var(--muted);line-height:1.7;font-size:.95rem}.resume-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.resume-list{padding-left:1.15rem;margin:14px 0 0}.resume-list li+li{margin-top:8px}.resume-links{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}.resume-links a{display:inline-flex;align-items:center;min-height:34px;padding:0 11px;border:1px solid rgba(78,225,184,.36);border-radius:8px;color:var(--accent);background:#4ee1b814;font-size:.9rem;font-weight:700}.resume-links a:hover{border-color:#4ee1b8b3;background:#4ee1b824;transform:translateY(-1px);box-shadow:0 10px 26px #4ee1b81f}.skill-cloud{display:flex;flex-wrap:wrap;gap:10px}.skill-cloud span,.status{display:inline-flex;align-items:center;min-height:34px;padding:0 11px;border:1px solid var(--line);border-radius:8px;color:var(--muted);background:#ffffff09;font-size:.92rem}.status{margin-bottom:10px;color:var(--accent-3)}.timeline{display:grid;gap:14px}.timeline-item{display:grid;gap:10px}.workflow-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.workflow-card{display:grid;gap:10px;align-content:start;transition:border-color .16s ease,background .16s ease,transform .16s ease}.workflow-card:hover{border-color:#4ee1b88f;background:linear-gradient(180deg,#4ee1b81f,#ffffff0a);transform:translateY(-2px)}.workflow-step{width:max-content;max-width:100%;padding:6px 10px;border:1px solid rgba(255,209,102,.36);border-radius:8px;color:var(--accent-3);background:#ffd16614;font-size:.86rem;font-weight:800;overflow-wrap:anywhere}.compact-posts{grid-template-columns:1fr}.compact-posts .card{--thumb-size: 176px;height:var(--thumb-size);min-height:var(--thumb-size)}.compact-posts .card-body{justify-content:center}.compact-posts .card p{-webkit-line-clamp:3}.compact-posts .tag-row{display:none}.prose h2,.prose h3{margin-top:2em;margin-bottom:.6em}.prose p,.prose ul,.prose ol,.prose blockquote{margin:1em 0}.prose a{color:var(--accent);text-decoration:underline;text-underline-offset:4px}.prose pre{overflow-x:auto;padding:16px;border:1px solid var(--line);border-radius:8px}.prose code{overflow-wrap:anywhere}.prose blockquote{padding-left:18px;border-left:3px solid var(--accent);color:var(--muted)}.article-sidebar{position:sticky;top:96px;display:grid;grid-column:2;grid-row:1;gap:14px;align-self:start}.toc-cover{width:100%;aspect-ratio:1 / 1;object-fit:cover;border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow)}.toc-panel{padding:16px}.toc-panel strong{display:block;margin-bottom:12px;color:var(--text)}.toc-panel nav{display:grid;gap:8px}.toc-panel a{color:var(--muted);line-height:1.55;font-size:.92rem}.toc-panel a:hover{color:var(--accent)}.article-side-title a{color:var(--accent);line-height:1.45;font-size:1rem;font-weight:900}.toc-panel .toc-depth-3{padding-left:14px;font-size:.86rem}.related-list{display:grid;gap:10px}.related-item{display:grid;gap:6px;padding:11px;border:1px solid var(--line);border-radius:8px;background:#ffffff09;transition:border-color .16s ease,background .16s ease,transform .16s ease,box-shadow .16s ease}.related-item:hover{border-color:#4ee1b88f;background:#4ee1b81a;transform:translateY(-1px);box-shadow:0 10px 26px #4ee1b81a}.related-item span{color:var(--text);line-height:1.45;font-size:.92rem;font-weight:800}.related-item small,.related-item em{color:var(--muted);line-height:1.45;font-size:.78rem;font-style:normal}.related-item em{color:var(--accent)}.comment-shell{padding-top:0}.comment-panel{min-width:0}.comment-panel :global(.giscus),.comment-panel :global(.giscus-frame){width:100%}.comment-preview{display:grid;gap:12px;margin-top:18px}.comment-preview[hidden]{display:none}.comment-preview-item{display:grid;grid-template-columns:42px minmax(0,1fr);gap:12px;padding:14px;border:1px solid var(--line);border-radius:8px;background:#ffffff09}.comment-preview-avatar{display:grid;place-items:center;width:42px;height:42px;border:1px solid rgba(78,225,184,.36);border-radius:8px;color:#06100d;background:var(--accent);font-weight:900}.comment-preview-body{min-width:0}.comment-preview-head,.comment-preview-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center;justify-content:space-between}.comment-preview-head span,.comment-preview-actions{color:var(--muted);font-size:.9rem}.comment-preview-body p{margin:8px 0 12px;color:var(--muted);line-height:1.7}.link-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.site-footer{margin-top:44px;border-top:1px solid var(--line)}.footer-inner{display:flex;justify-content:space-between;gap:18px;padding:28px 0;color:var(--muted)}@media(max-width:820px){.shell{width:min(100% - 28px,1120px)}.nav{align-items:flex-start;flex-direction:column;padding:14px 0}.nav-links{justify-content:flex-start}.hero-grid,.resume-hero,.resume-section,.resume-grid,.workflow-grid,.post-grid,.grid,.link-grid,.article-shell.with-sidebar{grid-template-columns:1fr}.resume-section-head{position:static}.opensource-card{grid-template-columns:1fr;align-items:start}.opensource-side{justify-content:space-between;width:100%}.slogan{grid-template-columns:repeat(4,max-content);gap:10px}.slogan strong{font-size:1.05rem}.slogan span{font-size:.72rem}.post-grid .card{--thumb-size: 118px;grid-template-columns:var(--thumb-size) minmax(0,1fr);height:var(--thumb-size);min-height:var(--thumb-size)}.post-grid .card-body{padding:10px 12px 10px 16px}.post-grid .meta{margin-bottom:8px;font-size:.82rem}.post-grid .tag-row{margin-top:10px}.article-shell{width:min(100% - 28px,760px)}.article-sidebar{position:static;grid-column:auto;max-height:none}.hero,.page-head{padding-top:42px}.footer-inner,.section-title{align-items:flex-start;flex-direction:column}}.nav-pill-group[data-astro-cid-37fxchfa]{--nav-slice: 12px;display:inline-flex;align-items:stretch;gap:0}.nav-pill-half[data-astro-cid-37fxchfa]{display:inline-flex;align-items:center;justify-content:center;min-height:40px;padding:9px 18px}.nav-pill-group[data-astro-cid-37fxchfa] .nav-pill-half-left[data-astro-cid-37fxchfa]{border-radius:8px 0 0 8px;clip-path:polygon(0 0,100% 0,calc(100% - var(--nav-slice)) 100%,0 100%)}.nav-pill-group[data-astro-cid-37fxchfa] .nav-pill-half-right[data-astro-cid-37fxchfa]{border-radius:0 8px 8px 0;margin-left:calc(var(--nav-slice) * -1 + 1px);padding-left:22px;clip-path:polygon(var(--nav-slice) 0,100% 0,100% 100%,0 100%)}
