.astro-route-announcer{position:absolute;left:0;top:0;clip:rect(0 0 0 0);clip-path:inset(50%);overflow:hidden;white-space:nowrap;width:1px;height:1px}@keyframes astroFadeInOut{0%{opacity:1}to{opacity:0}}@keyframes astroFadeIn{0%{opacity:0;mix-blend-mode:plus-lighter}to{opacity:1;mix-blend-mode:plus-lighter}}@keyframes astroFadeOut{0%{opacity:1;mix-blend-mode:plus-lighter}to{opacity:0;mix-blend-mode:plus-lighter}}@keyframes astroSlideFromRight{0%{transform:translate(100%)}}@keyframes astroSlideFromLeft{0%{transform:translate(-100%)}}@keyframes astroSlideToRight{to{transform:translate(100%)}}@keyframes astroSlideToLeft{to{transform:translate(-100%)}}@media(prefers-reduced-motion){::view-transition-group(*),::view-transition-old(*),::view-transition-new(*){animation:none!important}[data-astro-transition-scope]{animation:none!important}}@font-face{font-family:sourcesanspro;src:url(/blog/fonts/sourcesanspro.woff2) format("woff2"),url(/blog/fonts/sourcesanspro.woff) format("woff");font-weight:100 900;font-style:normal;font-display:swap}:root{color-scheme:light dark;--accent: #2f9e6e;--accent-strong: #247a55;--accent-soft: rgba(47, 158, 110, .12);--ink: #1f2328;--ink-soft: #4a5159;--ink-faint: #828d97;--paper: #fcfcfb;--paper-raised: #f5f5f2;--hairline: #e7e7e2;--code-inline: #b5520a;--code-inline-bg: #f1f0ec;--selection: rgba(47, 158, 110, .22);--font-sans: "sourcesanspro", -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "HarmonyOS Sans SC", "Hiragino Sans GB", "Microsoft YaHei", "Noto Sans CJK SC", sans-serif;--font-mono: ui-monospace, "SF Mono", "JetBrains Mono", Menlo, Consolas, "Liberation Mono", monospace;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-6: 1.5rem;--space-8: 2rem;--space-12: 3rem;--space-16: 4rem;--measure: 48rem;--radius: 8px;--ease: cubic-bezier(.22, .61, .36, 1);--dur: .18s}@media(prefers-color-scheme:dark){:root{--accent: #4ecb94;--accent-strong: #6fdaa9;--accent-soft: rgba(78, 203, 148, .15);--ink: #e7eaed;--ink-soft: #aeb6bf;--ink-faint: #7b848d;--paper: #131619;--paper-raised: #1b1f23;--hairline: #282d33;--code-inline: #f0934e;--code-inline-bg: #21262b;--selection: rgba(78, 203, 148, .26)}}*,*:before,*:after{box-sizing:border-box}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;background-color:var(--paper)}body{margin:0;color:var(--ink);background-color:var(--paper);font-family:var(--font-sans);font-size:17px;line-height:1.75;font-feature-settings:"kern","liga","calt";text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::selection{background-color:var(--selection)}:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:2px}img{max-width:100%;height:auto}.wrap{position:relative;z-index:1;display:flex;flex-direction:column;min-height:100vh;max-width:52rem;margin:0 auto}.page-surface{position:absolute;inset:0;z-index:0;background:color-mix(in srgb,var(--paper) 94%,transparent);backdrop-filter:blur(20px) saturate(160%);-webkit-backdrop-filter:blur(20px) saturate(160%);border-left:1px solid var(--hairline);border-right:1px solid var(--hairline);box-shadow:0 8px 40px #0000001f}.wrap>.site-header,.wrap>.container,.wrap>.site-footer{position:relative;z-index:1}.container{width:100%;max-width:var(--measure);margin:0 auto;padding:0 1.5rem;flex:1 0 auto}@media(max-width:56rem){.page-surface{border-left:none;border-right:none}}.bg{position:fixed;inset:0;z-index:0;opacity:1;background:linear-gradient(-45deg,#ee7752,#e73c7e,#23a6d5,#23d5ab);background-size:400% 400%;animation:bg-gradient 15s ease infinite;transition:opacity 4s ease-in-out}.bg .cur{position:absolute;inset:0;background-repeat:no-repeat;background-size:cover;background-position:center;animation:bg-fadein 1s}@keyframes bg-fadein{0%{opacity:0}to{opacity:1}}@keyframes bg-gradient{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.bg-controls{position:fixed;bottom:1.5rem;right:1.5rem;display:flex;flex-direction:column-reverse;align-items:center;gap:var(--space-3);z-index:10}.bg-fab{position:relative;width:52px;height:52px;flex-shrink:0;border:none;border-radius:50%;padding:0;background:color-mix(in srgb,var(--paper) 72%,transparent);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);box-shadow:0 4px 18px #00000024;color:var(--ink-soft);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color var(--dur) var(--ease),transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}.bg-fab:hover{color:var(--ink);transform:translateY(-1px);box-shadow:0 6px 22px #0000002e}.bg-fab:active{transform:translateY(0)}.bg-fab-ring{position:absolute;inset:0;width:100%;height:100%;transform:rotate(-90deg);pointer-events:none}.bg-fab-track{stroke:color-mix(in srgb,var(--ink) 14%,transparent);stroke-width:2.5}.bg-fab-progress{stroke:var(--accent);stroke-width:2.5;stroke-linecap:round}.bg-fab-icon{display:flex;position:relative}.bg-btn{width:44px;height:44px;border:none;border-radius:50%;background:color-mix(in srgb,var(--paper) 72%,transparent);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);box-shadow:0 4px 16px #0000001f;color:var(--ink-soft);cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transform:translateY(12px) scale(.8);pointer-events:none;transition:opacity var(--dur) var(--ease),transform var(--dur) var(--ease),color var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}.bg-controls:hover .bg-btn,.bg-controls:focus-within .bg-btn{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}.bg-btn:hover{color:var(--ink);transform:translateY(-1px) scale(1);box-shadow:0 6px 20px #00000029}.bg-btn:active{transform:translateY(0) scale(1)}.site-header{width:100%;max-width:var(--measure);margin:0 auto;padding:var(--space-12) 1.5rem var(--space-8);display:flex;flex-wrap:wrap;align-items:baseline;justify-content:space-between;gap:var(--space-2) var(--space-6)}.logo-link{text-decoration:none;display:inline-block}.logo-link h1{margin:0;font-size:1.35rem;font-weight:700;color:var(--ink);letter-spacing:-.015em}.nav{display:flex;flex-wrap:wrap;gap:var(--space-6);margin:0;padding:0;list-style:none}.nav a{position:relative;font-size:.72rem;font-weight:600;letter-spacing:.12em;color:var(--ink-faint);text-decoration:none;padding:2px 0;transition:color var(--dur) var(--ease)}.nav a:after{content:"";position:absolute;left:0;bottom:-2px;width:100%;height:1.5px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform var(--dur) var(--ease)}.nav a:hover,.nav a.active{color:var(--ink)}.nav a:hover:after,.nav a.active:after{transform:scaleX(1)}a{color:var(--ink);text-decoration:none}.post-content a,.post-excerpt a{color:var(--accent-strong);background-image:linear-gradient(var(--accent),var(--accent));background-position:0 100%;background-repeat:no-repeat;background-size:100% 1px;transition:background-size var(--dur) var(--ease),color var(--dur) var(--ease);padding-bottom:1px}.post-content a:hover,.post-excerpt a:hover{color:var(--accent);background-size:100% 2px}.site-footer{flex-shrink:0;max-width:var(--measure);width:100%;margin:var(--space-16) auto 0;padding:var(--space-6) 1.5rem var(--space-12);border-top:1px solid var(--hairline);color:var(--ink-faint);font-size:.82rem;letter-spacing:.01em}.site-footer a{color:var(--ink-soft);border-bottom:1px solid transparent;transition:border-color var(--dur) var(--ease)}.site-footer a:hover{border-bottom-color:var(--accent)}.post-list{margin:var(--space-4) 0 0;padding:0;list-style:none}.post-list-item{padding:var(--space-8) 0;border-bottom:1px solid var(--hairline)}.post-list-item:last-child{border-bottom:none}.post-title{margin:0 0 var(--space-2);font-size:1.5rem;font-weight:700;line-height:1.25;letter-spacing:-.02em}.post-title-link{color:var(--ink);transition:color var(--dur) var(--ease)}.post-title-link:hover{color:var(--accent)}.post-info{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-3);color:var(--ink-faint);font-size:.8rem;letter-spacing:.02em;font-variant-numeric:tabular-nums;margin-bottom:var(--space-3)}.post-from{display:inline-flex;align-items:center;gap:.3em;color:var(--accent);position:relative;padding-left:var(--space-3)}.post-from:before{content:"";position:absolute;left:0;top:50%;width:1px;height:.9em;transform:translateY(-50%);background:var(--hairline)}.post-excerpt{color:var(--ink-soft);font-size:1rem}.post-excerpt p{margin:.5rem 0}.read-more{display:inline-flex;align-items:center;gap:.35em;margin-top:var(--space-3);color:var(--accent);font-weight:600;font-size:.85rem;letter-spacing:.02em;transition:gap var(--dur) var(--ease),color var(--dur) var(--ease)}.read-more:after{content:"→";transition:transform var(--dur) var(--ease)}.read-more:hover{color:var(--accent-strong)}.read-more:hover:after{transform:translate(3px)}.post-single{padding-top:var(--space-2)}.post-single .post-title{font-size:clamp(1.9rem,5vw,2.4rem);line-height:1.18;margin-bottom:var(--space-3)}.post-content{margin-top:var(--space-8);font-size:1.0625rem}.post-content>*:first-child{margin-top:0}.post-content h1,.post-content h2,.post-content h3,.post-content h4{line-height:1.3;margin:var(--space-12) 0 var(--space-4);font-weight:700;letter-spacing:-.015em;scroll-margin-top:1.5rem}.post-content h2{font-size:1.45rem;padding-bottom:var(--space-2);border-bottom:1px solid var(--hairline)}.post-content h3{font-size:1.2rem}.post-content h4{font-size:1.05rem}.post-content p,.post-content ul,.post-content ol{margin:var(--space-4) 0}.post-content ul,.post-content ol{padding-left:1.4em}.post-content li{margin:var(--space-2) 0}.post-content li::marker{color:var(--accent)}.post-content img{display:block;margin:var(--space-8) auto;border-radius:var(--radius);border:1px solid var(--hairline)}.post-content blockquote{margin:var(--space-8) 0;padding:var(--space-2) 0 var(--space-2) var(--space-6);border-left:3px solid var(--accent);color:var(--ink-soft);font-style:italic}.post-content blockquote p{margin:var(--space-2) 0}.post-content blockquote p:first-child{margin-top:0}.post-content blockquote p:last-child{margin-bottom:0}.post-content :not(pre)>code{font-family:var(--font-mono);font-size:.86em;color:var(--code-inline);background:var(--code-inline-bg);padding:.15em .42em;border-radius:4px;word-break:break-word}.post-content :global(.expressive-code){margin:var(--space-6) 0}.post-content hr{border:0;margin:var(--space-12) auto;width:100%;text-align:center}.post-content hr:before{content:"· · ·";color:var(--ink-faint);letter-spacing:.6em;font-size:1rem}.post-content table{width:100%;border-collapse:collapse;margin:var(--space-6) 0;font-size:.94rem;display:block;overflow-x:auto}.post-content th,.post-content td{padding:var(--space-2) var(--space-3);border:1px solid var(--hairline);text-align:left;vertical-align:top}.post-content thead th{background:var(--paper-raised);font-weight:600}.post-content tbody tr:nth-child(2n){background:var(--paper-raised)}.post-content iframe,.post-content video{max-width:100%;margin:var(--space-6) auto;display:block;border-radius:var(--radius)}.post-tags{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-2);margin-top:var(--space-12);padding-top:var(--space-6);border-top:1px solid var(--hairline)}.post-tags .label{color:var(--ink-faint);font-size:.8rem;letter-spacing:.04em}.paginator{display:flex;justify-content:space-between;align-items:center;gap:var(--space-4);margin-top:var(--space-12);font-weight:600;font-size:.88rem}.paginator a{color:var(--ink-soft);transition:color var(--dur) var(--ease)}.paginator a:hover{color:var(--accent)}.paginator .next{margin-left:auto;text-align:right}.page-title{font-size:1.7rem;font-weight:700;letter-spacing:-.02em;margin:var(--space-4) 0 var(--space-8)}.archive-year{margin:var(--space-12) 0 var(--space-4);font-size:.95rem;font-weight:700;color:var(--ink-faint);letter-spacing:.08em;font-variant-numeric:tabular-nums}.archive-list{margin:0;padding:0;list-style:none}.archive-item{display:flex;gap:var(--space-4);padding:var(--space-3) 0;align-items:baseline;border-bottom:1px solid var(--hairline)}.archive-item:last-child{border-bottom:none}.archive-item time{flex-shrink:0;color:var(--ink-faint);font-size:.82rem;font-variant-numeric:tabular-nums;width:3.5rem}.archive-item .post-title-link{color:var(--ink-soft);transition:color var(--dur) var(--ease)}.archive-item .post-title-link:hover{color:var(--accent)}.tag-cloud{display:flex;flex-wrap:wrap;gap:var(--space-3);margin:var(--space-6) 0}.tag-chip{display:inline-flex;align-items:center;gap:.4em;padding:.3rem .85rem;background:var(--paper-raised);border:1px solid var(--hairline);border-radius:999px;font-size:.85rem;color:var(--ink-soft);transition:color var(--dur) var(--ease),border-color var(--dur) var(--ease),background var(--dur) var(--ease)}.tag-chip span{color:var(--ink-faint);font-variant-numeric:tabular-nums}.tag-chip:hover{border-color:var(--accent);background:var(--accent-soft);color:var(--ink)}.masto-intro{color:var(--ink-soft);font-size:.95rem;margin:0 0 var(--space-8)}.masto-intro a{color:var(--accent-strong);border-bottom:1px solid transparent;transition:border-color var(--dur) var(--ease)}.masto-intro a:hover{border-bottom-color:var(--accent)}.masto-status{color:var(--ink-faint);font-size:.95rem}.masto-status a{color:var(--accent-strong);margin-left:.4em}.masto-feed{display:flex;flex-direction:column}.masto-toot{--node-y: .82rem;position:relative;padding:0 0 var(--space-8) 1.9rem}.masto-toot:last-child{padding-bottom:0}.masto-toot:before{content:"";position:absolute;left:4px;top:0;bottom:0;width:2px;background:var(--hairline)}.masto-toot:first-child:before{top:var(--node-y)}.masto-toot:last-child:before{bottom:auto;height:var(--node-y)}.masto-toot:after{content:"";position:absolute;left:5px;top:var(--node-y);width:11px;height:11px;margin:-5.5px 0 0 -5.5px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px var(--paper)}.masto-time{display:inline-block;color:var(--ink-faint);font-size:.9rem;line-height:1.4;letter-spacing:.02em;font-variant-numeric:tabular-nums;transition:color var(--dur) var(--ease)}.masto-time:hover{color:var(--accent)}.masto-boost{display:block;color:var(--ink-faint);font-size:.78rem;letter-spacing:.02em;margin-top:var(--space-1)}.masto-content{margin-top:var(--space-2);font-size:1rem}.masto-content>*:first-child{margin-top:0}.masto-content>*:last-child{margin-bottom:0}.masto-content p{margin:var(--space-2) 0}.masto-media{margin-top:var(--space-3);border-radius:var(--radius);overflow:hidden;border:1px solid var(--hairline);background:var(--paper-raised)}.masto-media a{display:block;margin:0}.masto-media img,.masto-media video{display:block;width:100%;margin:0;border:0;border-radius:0}.masto-media--n1 img,.masto-media--n1 video{max-height:32rem;object-fit:cover}.masto-media--grid{display:grid;gap:2px;aspect-ratio:16 / 9}.masto-media--grid a,.masto-media--grid img,.masto-media--grid video{width:100%;height:100%}.masto-media--grid img,.masto-media--grid video{object-fit:cover}.masto-media--n2{grid-template-columns:1fr 1fr}.masto-media--n3,.masto-media--n4{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}.masto-media--n3>:first-child{grid-row:span 2}.masto-card{display:flex;flex-direction:column;margin-top:var(--space-3);border:1px solid var(--hairline);border-radius:var(--radius);overflow:hidden;background:var(--paper-raised);transition:border-color var(--dur) var(--ease)}.masto-card:hover{border-color:var(--accent)}.masto-card-img{width:100%;max-height:12rem;object-fit:cover}.masto-card-body{display:flex;flex-direction:column;gap:.25rem;padding:var(--space-3) var(--space-4)}.masto-card-title{color:var(--ink);font-size:.95rem;line-height:1.35}.masto-card-desc{color:var(--ink-soft);font-size:.85rem;line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.masto-card-host{color:var(--ink-faint);font-size:.75rem;letter-spacing:.02em}.masto-stats{display:flex;align-items:center;gap:var(--space-3);margin-top:var(--space-3);color:var(--ink-faint);font-size:.78rem;letter-spacing:.02em;font-variant-numeric:tabular-nums}.comments{margin-top:var(--space-16);padding-top:var(--space-8);border-top:1px solid var(--hairline)}@media(max-width:640px){body{font-size:16px}.site-header{padding-top:var(--space-8);padding-bottom:var(--space-6)}.post-title{font-size:1.3rem}.post-content{font-size:1rem}}::view-transition-group(surface){animation-duration:.55s;animation-timing-function:cubic-bezier(.4,0,.2,1)}::view-transition-group(site-bg),::view-transition-group(site-bg-controls),::view-transition-old(site-bg),::view-transition-new(site-bg),::view-transition-old(site-bg-controls),::view-transition-new(site-bg-controls){animation:none!important}::view-transition-old(site-bg),::view-transition-old(site-bg-controls){display:none}::view-transition-old(surface),::view-transition-new(surface){animation-duration:.55s;animation-timing-function:cubic-bezier(.4,0,.2,1)}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
