@import"https://fonts.googleapis.com/css2?family=Courier+Prime:ital,wght@0,400;0,700;1,400&family=Spectral:ital,wght@0,300;0,400;0,500;0,700;1,400;1,500&display=swap";:root{--bg: #fcfaf7;--ink: #1a1a1a;--ink-mid: #5a5a5a;--ink-faded: #9e9e9e;--rule: #d9d6cf;--marker: rgba(255, 235, 59, 1);--font-mono: "Courier Prime", ui-monospace, "SF Mono", Menlo, monospace;--font-serif: "Spectral", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Noto Sans SC", Georgia, sans-serif;--max-content: 700px;--sidebar-w: 360px}*{box-sizing:border-box}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--font-serif);font-size:21px;line-height:1.6;font-weight:400;position:relative;min-height:100vh}::selection{background:#ffeb3b66}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}@media(prefers-reduced-motion:reduce){@keyframes fadeIn{0%{opacity:0}to{opacity:1}}}::view-transition-old(root),::view-transition-new(root){animation:none}.sidebar__inner.vt-settled,.mobile-header.vt-settled{animation:none}a{color:inherit;text-decoration:none;transition:opacity .15s ease,color .15s ease}a:hover{opacity:.5}hr{border:none;border-top:1px solid var(--rule);margin:0}.paper-noise{position:fixed;inset:0;pointer-events:none;z-index:-1;opacity:.05;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 400 400' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='1.8' numOctaves='1' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}.ink-splatter{position:absolute;inset:0;pointer-events:none;z-index:-1;overflow:hidden}.ink-dot{position:absolute;transform:translate(-50%,-50%)}.ink-dot-inner{width:100%;height:100%;filter:url(#ink-tear) contrast(1.7) brightness(.85)}.layout{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh;position:relative}.main-area{grid-column:2;grid-row:1;padding:96px 48px;display:flex;flex-direction:column;align-items:center;min-width:0}.sidebar{grid-column:1;grid-row:1;border-right:1px solid var(--rule);padding:96px 32px 64px 64px;background:transparent;font-family:var(--font-mono)}.sidebar__inner{position:sticky;top:96px;max-height:calc(100vh - 128px);display:flex;flex-direction:column;animation:fadeIn .45s ease-out both}.sidebar__inner>.sidebar__logo,.sidebar__inner>.sidebar__lang,.sidebar__inner>.sidebar__about,.sidebar__inner>.sidebar__rule,.sidebar__inner>.sidebar__footer{flex-shrink:0}.sidebar__nav{flex:1 1 auto;min-height:0;overflow-y:auto;padding-right:6px;scrollbar-width:none}.sidebar__nav::-webkit-scrollbar{display:none}.sidebar__logo{display:flex;flex-direction:column;align-items:flex-start;font-family:var(--font-mono);font-size:21px;font-weight:700;color:var(--ink);margin:0 0 22px;letter-spacing:-.005em;gap:3px;height:53px}.sidebar__logo:hover{opacity:1}.sidebar__logo-line{display:flex;align-items:center;height:25px;line-height:25px;white-space:nowrap;contain:layout;filter:url(#ink-bleed);transform:translateZ(0)}.sidebar__logo-text{display:inline-block}.sidebar__logo-cursor{display:inline-block;width:2px;height:22px;background:var(--ink);margin-left:2px;animation:blinkCursor .8s step-end infinite}@keyframes blinkCursor{0%,to{opacity:0}50%{opacity:1}}.sidebar__lang{margin-bottom:12px}.sidebar__about{margin:0 0 28px;font-family:var(--font-mono);font-size:12px;letter-spacing:.1em}.sidebar__about a{color:var(--ink-faded);text-transform:uppercase;transition:color .15s ease}.sidebar__about a:hover{color:var(--ink);opacity:1}.sidebar__about a.is-active{color:var(--ink);font-weight:700}.lang-toggle{display:flex;align-items:center;gap:8px;font-size:12px;font-family:var(--font-mono);color:var(--ink-faded);letter-spacing:.1em}.lang-toggle a{color:var(--ink-faded);transition:color .15s ease}.lang-toggle a:hover{color:var(--ink);opacity:1}.lang-toggle a.is-active{color:var(--ink);font-weight:700}.lang-toggle__sep{color:var(--ink-faded);opacity:.4}.sidebar__rule{margin:0 0 32px}.sidebar__group{margin-bottom:36px}.sidebar__group:last-child{margin-bottom:0}.sidebar__year{font-family:var(--font-mono);font-size:12px;font-weight:400;letter-spacing:.2em;color:var(--ink-faded);margin:0 0 20px;filter:url(#ink-bleed)}.sidebar__list{list-style:none;padding:0;margin:0}.sidebar__footer{margin-top:40px;padding-top:20px;border-top:1px dotted var(--ink-faded);font-family:var(--font-mono);font-size:11px;letter-spacing:.22em;color:var(--ink-faded);opacity:.55;transition:opacity .2s}.sidebar__footer:hover{opacity:1}.sidebar__rss{color:inherit;text-decoration:none;text-transform:uppercase}.sidebar__rss:hover{color:var(--ink)}.sidebar__rss-sep{margin:0 6px;opacity:.5}.sidebar__item{position:relative;margin-bottom:22px}.sidebar__item:last-child{margin-bottom:0}.sidebar__item a{display:block;color:var(--ink-mid);line-height:1.5;font-family:var(--font-mono)}.sidebar__item a:hover{color:var(--ink);opacity:1}.sidebar__date{display:inline-block;font-size:12px;color:var(--ink-faded);letter-spacing:.04em;margin-bottom:5px;padding:0;position:relative}.sidebar__title{display:block;font-size:14px;font-weight:400;color:var(--ink-mid)}.sidebar__item.is-active .sidebar__date{color:var(--ink);--marker-rotate: 1deg;--marker-top: 50%;--marker-height: 80%;--marker-angle: 102deg;--marker-duration: .55s}.sidebar__item.is-active .sidebar__date:before{content:"";position:absolute;top:var(--marker-top);left:-7px;width:calc(100% + 14px);height:var(--marker-height);background:linear-gradient(var(--marker-angle),rgba(255,235,59,0) 0%,rgba(255,235,59,1) var(--marker-start, 6%),rgba(255,235,59,.85) 50%,rgba(255,235,59,1) var(--marker-end, 92%),rgba(255,235,59,0) 100%);transform:translateY(-50%) rotate(var(--marker-rotate)) skew(var(--marker-skew, -12deg));border-radius:var(--marker-radius, 8px 12px 10px 6px / 4px 6px 4px 4px);z-index:-1;mix-blend-mode:multiply;transform-origin:left center;animation:drawMarker var(--marker-duration) ease-out forwards;opacity:0}@keyframes drawMarker{0%{transform:translateY(-50%) rotate(var(--marker-rotate)) skew(var(--marker-skew, -12deg)) scaleX(0);opacity:0}to{transform:translateY(-50%) rotate(var(--marker-rotate)) skew(var(--marker-skew, -12deg)) scaleX(1);opacity:1}}.sidebar__item.is-active .sidebar__title{color:var(--ink);font-weight:700}.article{max-width:var(--max-content);width:100%;margin:0 auto;font-family:var(--font-serif)}.article__header{margin-bottom:56px;animation:fadeIn .45s ease-out .08s both}.article__date{font-family:var(--font-serif);font-size:14px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-mid);margin:0 0 40px;font-weight:400}.article__title{font-family:var(--font-serif);font-size:48px;font-weight:700;line-height:1.15;color:var(--ink);margin:0 0 24px;letter-spacing:-.012em}.article__subtitle{font-family:var(--font-serif);font-size:22px;font-weight:400;color:var(--ink-mid);line-height:1.5;margin:0;font-style:italic}.article__body{font-family:var(--font-serif);font-size:21px;line-height:1.6;color:var(--ink);font-weight:400;animation:fadeIn .5s ease-out .16s both}.article__title,.article__date,.article__body h2,.article__body h3{filter:url(#ink-bleed)}.article__subtitle,.article__body p,.article__body blockquote,.article__body li{filter:url(#ink-bleed-soft)}.article__body p:has(>img:only-child){filter:none}.article__body h2{font-family:var(--font-serif);font-size:32px;font-weight:700;line-height:1.25;color:var(--ink);letter-spacing:-.008em;margin:80px 0 28px;padding-bottom:14px;border-bottom:2px solid var(--ink)}.article__body h3{font-family:var(--font-serif);font-size:25px;font-weight:700;line-height:1.3;color:var(--ink);margin:56px 0 20px}.article__body p{margin:0 0 30px}.article__body img{display:block;max-width:100%;height:auto;margin:48px auto;opacity:0;transition:opacity .5s ease-out}.article__body img.loaded{opacity:1}.article__body strong{font-weight:700}.article__body em{font-style:italic;color:var(--ink-mid)}.article__body blockquote{margin:36px 0;padding:0 0 0 24px;border-left:3px solid var(--rule);color:var(--ink-mid);font-style:italic;font-size:21px}.article__body blockquote p{margin:0 0 8px}.article__body blockquote p:last-child{margin-bottom:0}.article__body blockquote em{font-style:normal}.article__body code{font-family:var(--font-mono);font-size:.85em;background:#0000000b;padding:1px 5px;border-radius:2px}.article__body pre{font-family:var(--font-mono);background:#0000000b;padding:18px 22px;border-radius:2px;overflow-x:auto;font-size:14px;line-height:1.65;margin:32px 0}.article__body pre code{background:none;padding:0;font-size:inherit}.article__body hr{width:40%;margin:60px auto}.article__body a{color:var(--ink);border-bottom:1px solid var(--ink-faded);padding-bottom:1px}.article__body a:hover{border-bottom-color:var(--ink);opacity:1}.article__body ul,.article__body ol{margin:0 0 30px;padding-left:26px}.article__body li{margin-bottom:8px}.empty-state{color:var(--ink-mid);font-size:17px;padding:64px 0;font-family:var(--font-serif);font-style:italic}.mobile-header{display:none}.more-notes{max-width:var(--max-content);width:100%;margin:96px auto 0;animation:fadeIn .5s ease-out .24s both}.more-notes__rule{border:none;border-top:1px solid var(--rule);margin:0 0 36px}.more-notes__heading{font-family:var(--font-mono);font-size:12px;font-weight:400;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-faded);margin:0 0 28px;filter:url(#ink-bleed)}.more-notes__list{list-style:none;padding:0;margin:0}.more-notes__item{margin-bottom:18px}.more-notes__item:last-child{margin-bottom:0}.more-notes__item a{display:grid;grid-template-columns:50px 1fr;gap:16px;align-items:baseline;font-family:var(--font-mono);color:var(--ink-mid);line-height:1.5;padding:6px 0;transition:color .15s ease}.more-notes__item a:hover{color:var(--ink);opacity:1}.more-notes__date{font-size:12px;color:var(--ink-faded);letter-spacing:.04em}.more-notes__title{font-size:15px;color:var(--ink-mid)}.more-notes__item a:hover .more-notes__title{color:var(--ink)}.sidebar-overlay{display:none;position:fixed;inset:0;background:#0006;z-index:140;opacity:0;pointer-events:none;transition:opacity .25s ease}.sidebar-toggle{display:none;position:fixed;bottom:20px;right:20px;width:40px;height:40px;background:var(--ink);border:none;cursor:pointer;z-index:200;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:0}.sidebar-toggle span{display:block;width:16px;height:1.5px;background:var(--bg);transition:transform .2s ease,opacity .2s ease}.sidebar-toggle.is-open span:nth-child(1){transform:translateY(5.5px) rotate(45deg)}.sidebar-toggle.is-open span:nth-child(2){opacity:0}.sidebar-toggle.is-open span:nth-child(3){transform:translateY(-5.5px) rotate(-45deg)}@media(max-width:1100px){:root{--sidebar-w: 300px}.sidebar{padding:80px 24px 64px 48px}.main-area{padding:80px 40px 96px}.article__title{font-size:40px}.article__body{font-size:20px}.article__body h2{font-size:28px}.article__body h3{font-size:22px}}@media(max-width:900px){.layout{grid-template-columns:1fr}.main-area{grid-column:1}.sidebar{position:fixed;top:0;left:0;width:86vw;max-width:340px;height:100vh;background:var(--bg);border-right:1px solid var(--rule);transform:translate(-100%);transition:transform .25s ease;z-index:150;padding:64px 28px 64px 40px;overflow-y:auto}.sidebar.is-open{transform:translate(0)}.sidebar-overlay{display:block}.sidebar-overlay.is-open{opacity:1;pointer-events:auto}.sidebar__inner{position:static;max-height:none;overflow:visible}.sidebar-toggle{display:flex}.mobile-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:22px 22px 18px;border-bottom:1px solid var(--rule);background:var(--bg);position:relative;z-index:50;animation:fadeIn .45s ease-out both}.mobile-header__logo{display:flex;flex-direction:column;color:var(--ink);font-family:var(--font-mono);font-size:22px;font-weight:700;letter-spacing:-.005em;gap:3px;height:57px}.mobile-header__logo:hover{opacity:1}.mobile-header__line{display:flex;align-items:center;height:27px;line-height:27px;white-space:nowrap;contain:layout;filter:url(#ink-bleed);transform:translateZ(0)}.mobile-header__text{display:inline-block}.mobile-header__cursor{display:inline-block;width:2px;height:22px;background:var(--ink);margin-left:2px;animation:blinkCursor .8s step-end infinite}.mobile-header .lang-toggle{flex-shrink:0;padding-top:8px}.sidebar__logo,.sidebar__lang,.sidebar__rule{display:none}.sidebar__about{margin:0 0 24px;padding-bottom:16px;border-bottom:1px dotted var(--rule)}.sidebar{padding-top:56px}.main-area{padding:40px 24px 80px}.more-notes{margin-top:64px}.more-notes__item{margin-bottom:20px}.more-notes__item a{display:block;padding:6px 0}.more-notes__date{display:block;font-size:11px;margin-bottom:4px}.more-notes__title{display:block;font-size:14px;line-height:1.45}.article__title{font-size:34px}.article__body{font-size:19px}.article__body h2{font-size:26px}.article__body h3{font-size:21px}.article__subtitle,.sidebar__logo{font-size:19px}}@media(max-width:480px){.main-area{padding:56px 20px 64px}.article__title{font-size:28px}.article__body{font-size:18px}.article__body h2{font-size:22px}}@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}}.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}
