:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--bg:#f7f9fc;--surface:#fff;--surface-subtle:#fcfdff;--surface-muted:#f3f6f9;--text:#1f1f1f;--text-soft:#5f6368;--text-faint:#80868b;--border:#e5e9ef;--border-strong:#d7dde6;--accent:#1a73e8;--accent-hover:#1558b0;--accent-soft:#e8f0fe;--shadow-1:0 1px 2px rgba(15,23,42,.04), 0 1px 3px rgba(15,23,42,.06);--shadow-2:0 8px 24px rgba(15,23,42,.07), 0 2px 8px rgba(15,23,42,.05);--radius-sm:10px;--radius-md:14px;--radius-lg:18px;--radius-xl:24px;--radius-2xl:28px;--layout-max:1120px;--content-max:760px;--header-height:72px}*,:before,:after{box-sizing:border-box}html{scroll-behavior:smooth;scrollbar-gutter:stable;-webkit-text-size-adjust:100%;min-height:100%}body{background:var(--bg);min-height:100dvh;color:var(--text);text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;flex-direction:column;margin:0;font-family:Roboto,Noto Sans SC,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif;line-height:1.5;display:flex}img,svg,video,canvas{max-width:100%;display:block}a{color:inherit}::selection{color:var(--text);background:#dbe8ff}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}body>header{z-index:30;backdrop-filter:saturate(180%)blur(10px);border-bottom:1px solid var(--border);background:rgba(255,255,255,.9);position:sticky;top:0}.header-inner{max-width:var(--layout-max);min-height:var(--header-height);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem 1.5rem;margin:0 auto;padding:0 clamp(1rem,2.5vw,1.5rem);display:flex}.site-brand{flex:none}.site-brand a{min-height:40px;color:var(--text);letter-spacing:-.01em;border-radius:999px;align-items:center;padding:0 .25rem;font-size:1rem;font-weight:700;text-decoration:none;display:inline-flex}nav{scrollbar-width:none;flex-wrap:nowrap;justify-content:flex-end;gap:.5rem;display:flex;overflow:auto hidden}nav a{min-height:40px;color:var(--text-soft);transition:background-color var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);border:1px solid transparent;border-radius:999px;align-items:center;padding:0 .9rem;font-size:.95rem;font-weight:500;text-decoration:none;display:inline-flex}nav a:hover{background:var(--surface-muted);color:var(--text)}nav a:focus-visible{background:var(--surface);border-color:var(--border-strong)}nav a[aria-current=page]{background:var(--accent-soft);color:var(--accent)}body>main{flex:1;padding:clamp(1rem,2.6vw,2rem);display:flex}.main-inner{width:min(100%, var(--layout-max));flex-direction:column;flex:1;gap:clamp(1rem,2vw,1.5rem);margin:0 auto;display:flex}.main-inner>*{width:100%;margin:0}.main-inner>h1:first-child{letter-spacing:-.03em;color:var(--text);margin:0;padding-inline:.125rem;font-size:clamp(2rem,4vw,2.75rem);font-weight:700;line-height:1.1}body>footer{border-top:1px solid var(--border);background:rgba(255,255,255,.92)}.footer-inner{max-width:var(--layout-max);margin:0 auto;padding:1.5rem clamp(1rem,2.5vw,1.5rem)}.footer-line{color:var(--text-faint);letter-spacing:.02em;flex-wrap:wrap;justify-content:center;align-items:center;gap:.45rem;margin:0;font-size:.82rem;line-height:1.4;display:flex}.footer-label,.footer-version,.footer-sep{color:inherit}.footer-version{white-space:nowrap}.footer-version-error{color:var(--text-soft)}.profile{flex:1;place-items:center;min-height:min(72vh,760px);display:grid}.hero{border:1px solid var(--border);border-radius:var(--radius-2xl);width:min(100%,720px);box-shadow:var(--shadow-1);text-align:center;background:linear-gradient(#fff 0%,#fcfdff 100%);flex-direction:column;align-items:center;gap:1rem;padding:clamp(1.75rem,5vw,3.25rem);display:flex}.avatar{object-fit:cover;border:4px solid #fff;border-radius:50%;width:112px;height:112px;box-shadow:0 1px 2px rgba(15,23,42,.08),0 8px 20px rgba(15,23,42,.08)}.name{color:var(--text);letter-spacing:-.04em;margin:0;font-size:clamp(2rem,5vw,2.8rem);font-weight:700;line-height:1.05}.tagline{max-width:34ch;color:var(--text-soft);margin:0;font-size:1.05rem;line-height:1.7}.links{flex-wrap:wrap;justify-content:center;gap:.75rem;margin-top:.5rem;display:flex}.links a{min-height:42px;color:var(--text);background:var(--surface);border:1px solid var(--border);transition:background-color var(--transition-fast), border-color var(--transition-fast), transform var(--transition-fast);border-radius:999px;justify-content:center;align-items:center;padding:0 1rem;font-size:.95rem;font-weight:500;text-decoration:none;display:inline-flex;box-shadow:0 1px 2px rgba(15,23,42,.03)}.links a:hover{background:var(--surface-muted);border-color:var(--border-strong)}.posts-page{width:100%}.posts-list{width:min(100%, var(--content-max));flex-direction:column;gap:12px;margin:0 auto;display:flex}.post-list-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-1);transition:transform var(--transition-fast), box-shadow var(--transition-fast), border-color var(--transition-fast);overflow:hidden}.post-list-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-2)}.post-list-card:focus-within{border-color:var(--border-strong);box-shadow:var(--shadow-2)}.post-list-card .card-link{min-height:100%;color:inherit;grid-template-columns:1fr;text-decoration:none;display:grid}.post-list-card .cover{aspect-ratio:16/9;object-fit:cover;background:var(--surface-muted);width:100%}.post-list-card .content{flex-direction:column;gap:.625rem;min-width:0;padding:1.125rem 1.25rem 1.25rem;display:flex}.post-list-card .title{color:var(--text);letter-spacing:-.015em;margin:0;font-size:clamp(1.125rem,2vw,1.35rem);font-weight:700;line-height:1.28}.post-list-card .description{color:var(--text-soft);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:.98rem;line-height:1.65;display:-webkit-box;overflow:hidden}.post-list-card .meta{color:var(--text-faint);margin-top:auto;padding-top:.125rem;font-size:.88rem;line-height:1.4}.post{width:100%}.post-container{width:min(100%, var(--content-max));background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-2xl);box-shadow:var(--shadow-1);margin:0 auto;padding:clamp(1.5rem,4vw,3rem)}.post-header{border-bottom:1px solid var(--border);margin-bottom:clamp(1.5rem,3vw,2.5rem);padding-bottom:1.25rem}.post-title{color:var(--text);letter-spacing:-.04em;margin:0;font-size:clamp(2rem,5vw,3.1rem);font-weight:700;line-height:1.1}.post-meta{color:var(--text-soft);flex-wrap:wrap;align-items:center;gap:.75rem;margin-top:.8rem;font-size:.95rem;line-height:1.5;display:flex}.post-meta a{color:inherit;text-decoration:none}.post-meta a:hover{color:var(--accent);text-underline-offset:2px;text-decoration:underline}.post-main,.post-content{min-width:0}.prose{color:var(--text);letter-spacing:.002em;overflow-wrap:anywhere;word-break:break-word;font-size:1.0625rem;line-height:1.85}.prose>:first-child{margin-top:0}.prose>:last-child{margin-bottom:0}.prose :where(p,ul,ol,blockquote,pre,table,figure,.typst-svg-math-block){margin:0 0 1.25rem}.prose :where(h1,h2,h3,h4,h5,h6){color:var(--text);letter-spacing:-.025em;margin:2.25rem 0 1rem;font-weight:700;line-height:1.24}.prose h1{font-size:1.9rem}.prose h2{font-size:1.55rem}.prose h3{font-size:1.28rem}.prose h4{font-size:1.12rem}.prose p{color:var(--text);margin-bottom:1.25rem}.prose a{color:var(--accent);text-decoration:none}.prose a:hover{color:var(--accent-hover);text-underline-offset:2px;text-decoration:underline}.prose strong{font-weight:700}.prose em{font-style:italic}.prose ul,.prose ol{padding-left:1.35rem}.prose li+li{margin-top:.4rem}.prose blockquote{background:var(--accent-soft);color:#334155;border-left:3px solid var(--accent);border-radius:0 var(--radius-md) var(--radius-md) 0;padding:.9rem 1rem}.prose blockquote.draft-admonition{align-items:center;gap:.75rem;display:flex}.prose blockquote.draft-admonition>img{object-fit:contain;border-radius:0;flex:none;width:2.5rem;height:2.5rem;margin:0}.prose blockquote.draft-admonition>p{min-width:0;margin:0}.prose hr{border:0;border-top:1px solid var(--border);margin:2rem 0}.prose code{background:var(--surface-muted);border:1px solid var(--border);border-radius:8px;padding:.16em .38em;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace;font-size:.92em}.prose pre{border:1px solid var(--border);border-radius:var(--radius-md);background:#f8fafc;padding:1rem 1.125rem;overflow:auto;box-shadow:inset 0 1px rgba(255,255,255,.7)}.prose pre code{background:0 0;border:0;border-radius:0;padding:0;font-size:.92rem;line-height:1.65}.prose video,.prose canvas{background:var(--surface-muted);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;height:auto;margin:1.5rem auto}.prose img{background:var(--surface-muted);border:1px solid var(--border);border-radius:var(--radius-lg);height:auto;margin:1.5rem auto}.prose table{border-collapse:separate;border-spacing:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);width:100%;display:block;overflow-x:auto}.prose thead th{background:var(--surface-muted);color:var(--text);font-weight:600}.prose th,.prose td{text-align:left;border-bottom:1px solid var(--border);white-space:nowrap;padding:.75rem .875rem}.prose tr:last-child td{border-bottom:0}.prose .typst-svg-math-block svg{margin:1em auto;display:block}.prose .typst-svg-math-inline{vertical-align:middle;display:inline-block;transform:translateY(-.1em)}@media (width>=760px){.post-list-card .card-link{grid-template-columns:minmax(280px,34%) 1fr;align-items:stretch}.post-list-card .cover{aspect-ratio:auto;height:100%;min-height:100%}.post-list-card .content{padding:1.35rem 1.5rem}}@media (width<=760px){.header-inner{align-items:flex-start;padding-top:.75rem;padding-bottom:.75rem}nav{justify-content:flex-start;width:100%}body>main{padding:1rem}.hero{border-radius:24px}.post-container{border-radius:24px;padding:1.25rem 1rem 1.5rem}.prose{font-size:1rem;line-height:1.8}}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,:before,:after{transition:none!important;animation:none!important}}.content-loading{width:100%;max-width:42rem;margin:0 auto;padding:.5rem 0}.content-loading .meta,.content-loading .title,.content-loading .line{background:linear-gradient(90deg, var(--surface-muted,#f3f4f6) 25%, var(--surface,#fff) 50%, var(--surface-muted,#f3f4f6) 75%);background-size:200% 100%}.content-loading .meta{border-radius:999px;width:8rem;height:.9rem;margin-bottom:1rem}.content-loading .title{border-radius:.75rem;width:min(28rem,85%);height:2.2rem;margin-bottom:2rem}.content-loading .paragraph{flex-direction:column;gap:.75rem;margin-bottom:1.5rem;display:flex}.content-loading .line{border-radius:999px;width:100%;height:1rem}.content-loading .line.short{width:72%}.content-loading .shimmer{animation:1.4s ease-in-out infinite content-loading-shimmer}@keyframes content-loading-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media (prefers-reduced-motion:reduce){.content-loading .shimmer{animation:none}}