@charset "UTF-8";:root{--max-bezier-to-full:cubic-bezier(.5,0,1,.5);--max-bezier-to-collapse:cubic-bezier(0,.5,.5,1)}@keyframes float-in{0%{opacity:0;transform:translateY(var(--float-distance,10%))}to{opacity:1;transform:translateY(0)}}.float-in-enter-active,.float-in-leave-active{transition:all .2s!important}.float-in-leave-active{position:absolute!important}.float-in-enter-from,.float-in-leave-to{opacity:0;transform:translateY(var(--float-distance,10%))}.float-in-move{transition:transform .2s!important}.collapse-enter-active,.collapse-leave-active{overflow:hidden;overflow:clip;transition:max-height .1s}.collapse-enter-from,.collapse-leave-to{max-height:0;transition-timing-function:var(--max-bezier-to-collapse)}.collapse-enter-to,.collapse-leave-from{max-height:50vh;transition-timing-function:var(--max-bezier-to-full)}.article{line-height:1.8;margin:1rem}.article p{margin:.5em 0}.article>*,.article>p{margin:1rem 0}.article :target{animation:highlight 3s;border-radius:.2rem}@keyframes highlight{50%{background-color:var(--c-primary-soft)}}.article>:where(h1,h2,h3,h4,h5,h6){color:var(--c-text);font-family:var(--font-creative);font-weight:550;margin:1.6em 0 .8em}.article :where(menu,ol,ul):not([class]){font-size:.9rem;margin:.5em 0;padding-inline-start:1.5em}.article :where(menu,ol,ul):not([class]),.article :where(menu,ol,ul):not([class]) ol ol ol{list-style:revert}.article :where(menu,ol,ul):not([class]) ol,.article :where(menu,ol,ul):not([class]) ol ol ol ol{list-style-type:lower-alpha}.article :where(menu,ol,ul):not([class]) ol ol,.article :where(menu,ol,ul):not([class]) ol ol ol ol ol{list-style-type:lower-roman}.article :where(menu,ol,ul):not([class]) ol,.article :where(menu,ol,ul):not([class]) ul{margin-top:0}.article :where(menu,ol,ul):not([class])>li{margin:.2em 0}.article :where(menu,ol,ul):not([class])>li::marker{color:var(--c-primary)}.article blockquote{background-color:var(--c-bg-2);border-inline-start:4px solid var(--c-border);border-radius:4px;font-size:.9rem;padding:.2rem .8rem}.article blockquote>.z-codeblock{margin:0 -.8rem}.article img{max-width:100%}.article img.icon{height:1.4em;transform:translateY(-.1em);vertical-align:middle}.article img.image,.article img:not([class]){border-radius:.5rem;display:block;margin:1rem auto}.article hr{border-top:.4em dashed var(--c-border);margin:3em 0}.article strong{background:linear-gradient(var(--c-primary-soft),var(--c-primary-soft)) no-repeat bottom/100% 30%}.article del{opacity:.5}.article.md-tech>h2>a:before{color:#fff;content:"#"}.article.md-tech>:where(h2,h3,h4,h5,h6)>a:before{background-color:var(--c-primary);border-radius:.2rem;content:"";margin-inline-end:.5em;padding:0 2px;text-autospace:no-autospace}.article.md-story .title-like,.article.md-story h1,.article.md-story h2,.article.md-story h3,.article.md-story h4,.article.md-story h5,.article.md-story h6{font-family:var(--font-serif);font-weight:bolder;position:relative;text-align:center;text-wrap:balance}.article.md-story>h2:before{background-image:linear-gradient(var(--c-primary-soft),transparent);border-radius:2.5em;content:"";height:2.5em;margin:-.4em 0 0 -.7em;position:absolute;width:2.5em;z-index:-1}.article.md-story>h3:after{background-color:var(--c-primary-soft);bottom:0;content:"";height:.7em;position:absolute;width:.4em}.article.md-story :not([class])>p,.article.md-story>p{text-indent:2em}.article.md-story :not([class])>p>[class],.article.md-story>p>[class]{text-indent:0}.light,:root{--hue-theme:220deg;--c-text:hsl(var(--hue-theme) 0% 0%);--c-text-1:hsl(var(--hue-theme) 0% 20%);--c-text-2:hsl(var(--hue-theme) 0% 40%);--c-text-3:hsl(var(--hue-theme) 0% 70%);--c-bg:hsl(var(--hue-theme) 0% 100%);--c-bg-1:hsl(var(--hue-theme) 20% 98%);--c-bg-2:hsl(var(--hue-theme) 10% 95%);--c-bg-3:hsl(var(--hue-theme) 10% 92%);--c-bg-soft:hsl(var(--hue-theme) 20% 20%/10%);--c-border:hsl(var(--hue-theme) 10% 91%);--c-bg-a50:hsl(var(--hue-theme) 20% 98%/50%);--c-bg-a80:hsl(var(--hue-theme) 20% 98%/80%);--c-primary:hsl(var(--hue-theme) 100% 55%);--c-primary-soft:hsl(var(--hue-theme) 100% 60%/15%);--c-accent:#52e0e0;--ld-bg-blur:var(--c-bg-1);--ld-bg-card:var(--c-bg);--ld-bg-active:var(--c-bg);--ld-shadow:var(--c-bg-soft);color-scheme:light dark}.dark{--c-text:hsl(var(--hue-theme) 0% 100%);--c-text-1:hsl(var(--hue-theme) 0% 90%);--c-text-2:hsl(var(--hue-theme) 0% 70%);--c-text-3:hsl(var(--hue-theme) 0% 50%);--c-bg:hsl(var(--hue-theme) 0% 7%);--c-bg-1:hsl(var(--hue-theme) 10% 10%);--c-bg-2:hsl(var(--hue-theme) 10% 14%);--c-bg-3:hsl(var(--hue-theme) 10% 18%);--c-bg-soft:hsl(var(--hue-theme) 100% 95%/15%);--c-border:hsl(var(--hue-theme) 10% 20%);--c-bg-a50:hsl(var(--hue-theme) 10% 10%/50%);--c-bg-a80:hsl(var(--hue-theme) 10% 10%/80%);--c-primary:hsl(var(--hue-theme) 100% 70%);--c-primary-soft:hsl(var(--hue-theme) 100% 60%/20%);--ld-bg-blur:var(--c-bg-a80);--ld-bg-card:var(--c-bg-3);--ld-bg-active:var(--c-primary-soft);--ld-shadow:var(--c-bg-a50);color-scheme:dark}:root{--font-basic:"InterVariable","Noto Sans SC-Local","sans-serif","PingFang SC","Noto Sans SC",system-ui,sans-serif;--font-serif:"Noto Serif SC-Local","Noto Serif SC",serif;--font-creative:"InterVariable","Noto Sans SC-Local","Noto Sans SC",system-ui,sans-serif;--font-stroke-free:"Inter","Lantinghei SC","Microsoft YaHei","MiSans",system-ui,sans-serif;--font-monospace:"JetBrains Mono","monospace","Cascadia Code","Consolas","Monaco",var(--font-basic),monospace}@media(max-resolution:1.2dppx){:root{--font-basic:"InterVariable",system-ui,sans-serif}}@supports (box-decoration-break:clone){@font-face{font-family:Noto Sans SC-Local;font-weight:100 900;src:local("Noto Sans SC")}@font-face{font-family:"Noto Serif SC-Local";font-weight:100 900;src:local("Noto Serif SC")}}:root{--start:left;--end:right;--transform-start-far:translateX(-100%);--transform-end-far:translateX(100%);--delay:.2s;--z-index-popover:100;background-color:var(--c-bg-1);font-family:sans-serif;font-family:var(--font-basic);font-synthesis:style;line-height:1.4;overflow-wrap:break-word;text-autospace:normal;-webkit-text-size-adjust:none;-moz-text-size-adjust:none;text-size-adjust:none;color:var(--c-text-1);font-variant-alternates:styleset(open-digits,disambiguation,round-quotes-and-commas);scroll-behavior:smooth;scroll-padding:2rem;scrollbar-color:var(--c-text-3) transparent;transition:color .1s,background-color .2s;-webkit-tap-highlight-color:var(--c-primary-soft)}:root:dir(rtl){--start:right;--end:left;--transform-start-far:translateX(100%);--transform-end-far:translateX(-100%)}@media(prefers-reduced-motion:reduce){:root{scroll-behavior:auto;transition:none}}*{border:none;margin:0;padding:0}*,:after,:before{box-sizing:border-box}::-moz-selection{background-color:var(--c-primary-soft)}::selection{background-color:var(--c-primary-soft)}a{color:currentcolor;text-decoration:none}code,pre{font-family:var(--font-monospace);text-autospace:no-autospace}menu,ol,ul{list-style:none}button{cursor:pointer}button>.iconify:only-child{display:block}button:disabled{cursor:auto}button,input,textarea{background:none;color:currentcolor;font:inherit}:where(.iconify){display:inline-block;flex-shrink:0;font-size:1.2em;vertical-align:sub}.rtl-flip:dir(rtl){transform:scaleX(-1)}.light [class^="iconify i-catppuccin:"]{filter:invert(.7) hue-rotate(180deg) saturate(4)}.i-simple-icons\:mdnwebdocs{transform:scale(.8)}img{contain:layout;display:inline-block;overflow:clip}img:before{background-color:var(--c-border);color:var(--c-bg-soft);content:attr(alt);display:grid;font:700 1.5rem/1.2 var(--font-serif);inset:0;overflow:visible;padding:.5em;place-content:center;position:absolute;text-align:center;text-shadow:none;word-break:normal}.tippy-box{animation:float-in .2s;background-color:var(--ld-bg-card);border-radius:.5em;box-shadow:0 0 1rem var(--ld-shadow);color:var(--c-text-2);font-size:.8rem;line-height:1.4;padding:.3em .6em}.tippy-box[data-state=hidden]{opacity:0}.tippy-box>.tippy-svg-arrow{fill:var(--ld-bg-card)}.shiki>.line>span{font-style:var(--shiki-light-font-style)}.dark .shiki>.line>span{background-color:var(--shiki-dark-bg)!important;color:var(--shiki-dark)!important;font-style:var(--shiki-dark-font-style)}.shiki>.line>.indent{background-image:linear-gradient(to right,var(--c-border) .1em,transparent .1em);display:inline-block}.shiki>.line>.space:before,.shiki>.line>.tab:before{display:inline-block;opacity:.3;pointer-events:none;width:0}.shiki>.line>.space+.space:before,.shiki>.line>.space:is(:first-child,:last-child):before,.shiki>.line>:not(.space)+.space:has(+.space):before{content:"·"}.shiki>.line>.tab:before{content:"⇥"}.card{background-color:var(--ld-bg-card);border-radius:.5em;box-shadow:0 .1em .2em var(--ld-shadow);display:block;overflow:hidden;overflow:clip;transition:all .2s}.card:hover{box-shadow:0 .5em 1em var(--ld-shadow);transform:translateY(-2px)}.gradient-card{border-radius:.5rem;position:relative;z-index:0}.gradient-card:before{background:linear-gradient(var(--c-bg-a80),var(--c-bg-a80)) padding-box,linear-gradient(45deg,var(--c-accent),var(--c-primary-soft)) border-box;border:2px solid transparent;border-radius:inherit;content:"";inset:0;opacity:0;position:absolute;transition:opacity .2s;z-index:-1}.gradient-card.active,.gradient-card:focus,.gradient-card:hover{color:var(--c-text-1)}.gradient-card.active:before,.gradient-card:focus:before,.gradient-card:hover:before{opacity:1}.scrollcheck-x,.scrollcheck-y{scrollbar-width:thin}.scrollcheck-x::-webkit-scrollbar,.scrollcheck-y::-webkit-scrollbar{background-color:var(--c-bg-2);cursor:default;height:6px;width:6px}.scrollcheck-x::-webkit-scrollbar-thumb,.scrollcheck-y::-webkit-scrollbar-thumb{background-color:var(--c-bg-soft);border-radius:4px;cursor:pointer}.scrollcheck-x{--start-offset:0px;--scrollbar-height:.5rem;--fadeout-width:2rem;animation:scrollcheck-x;animation-timeline:scroll(x self);overflow-x:auto}@keyframes scrollcheck-x{0%{-webkit-mask-image:linear-gradient(to var(--end),#fff calc(100% - var(--fadeout-width)),transparent),linear-gradient(to top,#fff var(--scrollbar-height),transparent var(--scrollbar-height));mask-image:linear-gradient(to var(--end),#fff calc(100% - var(--fadeout-width)),transparent),linear-gradient(to top,#fff var(--scrollbar-height),transparent var(--scrollbar-height))}0.01%,99.99%{-webkit-mask-image:linear-gradient(to var(--end),#fff var(--start-offset),transparent var(--start-offset),#fff calc(var(--start-offset) + var(--fadeout-width)),#fff calc(100% - var(--fadeout-width)),transparent),linear-gradient(to top,#fff var(--scrollbar-height),transparent var(--scrollbar-height));mask-image:linear-gradient(to var(--end),#fff var(--start-offset),transparent var(--start-offset),#fff calc(var(--start-offset) + var(--fadeout-width)),#fff calc(100% - var(--fadeout-width)),transparent),linear-gradient(to top,#fff var(--scrollbar-height),transparent var(--scrollbar-height))}to{-webkit-mask-image:linear-gradient(to var(--end),#fff var(--start-offset),transparent var(--start-offset),#fff calc(var(--start-offset) + var(--fadeout-width))),linear-gradient(to top,#fff var(--scrollbar-height),transparent var(--scrollbar-height));mask-image:linear-gradient(to var(--end),#fff var(--start-offset),transparent var(--start-offset),#fff calc(var(--start-offset) + var(--fadeout-width))),linear-gradient(to top,#fff var(--scrollbar-height),transparent var(--scrollbar-height))}}.scrollcheck-y{--top-offset:0px;--guessed-scrollbar-width:.5rem;--fadeout-height:2rem;animation:scrollcheck-y;animation-timeline:scroll(y self);overflow-y:auto}@keyframes scrollcheck-y{0%{-webkit-mask-image:linear-gradient(to bottom,#fff calc(100% - var(--fadeout-height)),transparent),linear-gradient(to var(--start),#fff var(--guessed-scrollbar-width),transparent var(--guessed-scrollbar-width));mask-image:linear-gradient(to bottom,#fff calc(100% - var(--fadeout-height)),transparent),linear-gradient(to var(--start),#fff var(--guessed-scrollbar-width),transparent var(--guessed-scrollbar-width))}0.01%,99.99%{-webkit-mask-image:linear-gradient(to bottom,#fff var(--top-offset),transparent var(--top-offset),#fff calc(var(--top-offset) + var(--fadeout-height)),#fff calc(100% - var(--fadeout-height)),transparent),linear-gradient(to var(--start),#fff var(--guessed-scrollbar-width),transparent var(--guessed-scrollbar-width));mask-image:linear-gradient(to bottom,#fff var(--top-offset),transparent var(--top-offset),#fff calc(var(--top-offset) + var(--fadeout-height)),#fff calc(100% - var(--fadeout-height)),transparent),linear-gradient(to var(--start),#fff var(--guessed-scrollbar-width),transparent var(--guessed-scrollbar-width))}to{-webkit-mask-image:linear-gradient(to bottom,#fff var(--top-offset),transparent var(--top-offset),#fff calc(var(--top-offset) + var(--fadeout-height))),linear-gradient(to var(--start),#fff var(--guessed-scrollbar-width),transparent var(--guessed-scrollbar-width));mask-image:linear-gradient(to bottom,#fff var(--top-offset),transparent var(--top-offset),#fff calc(var(--top-offset) + var(--fadeout-height))),linear-gradient(to var(--start),#fff var(--guessed-scrollbar-width),transparent var(--guessed-scrollbar-width))}}mark{animation:line-spread .5s;background:linear-gradient(var(--c-primary-soft),var(--c-primary-soft)) no-repeat 0 100%/100% .4em;color:var(--c-primary);text-decoration:none;transition:.2s}@keyframes line-spread{0%{background-size:0 .3em}}mark:hover{background-size:100% 50%}@media(min-width:528px){.phone-only{display:none!important}}@media(max-width:528px){.phone-hidden{display:none!important}}@media(min-width:768px){.mobile-only{display:none!important}}@media(max-width:768px){.mobile-hidden{display:none!important}}@media(min-width:1080px){.widescreen-only{display:none!important}}@media(max-width:1080px){.widescreen-hidden{display:none!important}}.proper-height{min-height:70vh}.text-center{text-align:center}.text-creative,.text-tech{font-family:var(--font-creative);font-weight:550}.text-story{font-family:var(--font-serif)}.text-repeat{text-shadow:.1em 0 var(--c-bg-soft),.2em 0 var(--c-bg-soft),.3em 0 var(--c-bg-soft),.4em 0 var(--c-bg-soft),.5em 0 var(--c-bg-soft)}.text-zoom{display:inline-block;transform-origin:left bottom}@supports (animation-timeline:view()){.text-zoom{animation:zoom 1s both;animation-timeline:view()}}@keyframes zoom{0%{transform:scale(.8)}to{transform:scale(1.25)}}.tippy-box[data-placement^=top]>.tippy-svg-arrow{bottom:0}.tippy-box[data-placement^=top]>.tippy-svg-arrow:after,.tippy-box[data-placement^=top]>.tippy-svg-arrow>svg{top:16px;transform:rotate(180deg)}.tippy-box[data-placement^=bottom]>.tippy-svg-arrow{top:0}.tippy-box[data-placement^=bottom]>.tippy-svg-arrow>svg{bottom:16px}.tippy-box[data-placement^=left]>.tippy-svg-arrow{right:0}.tippy-box[data-placement^=left]>.tippy-svg-arrow:after,.tippy-box[data-placement^=left]>.tippy-svg-arrow>svg{left:11px;top:calc(50% - 3px);transform:rotate(90deg)}.tippy-box[data-placement^=right]>.tippy-svg-arrow{left:0}.tippy-box[data-placement^=right]>.tippy-svg-arrow:after,.tippy-box[data-placement^=right]>.tippy-svg-arrow>svg{right:11px;top:calc(50% - 3px);transform:rotate(-90deg)}.tippy-svg-arrow{fill:#333;height:16px;text-align:initial;width:16px}.tippy-svg-arrow,.tippy-svg-arrow>svg{position:absolute}.vue-recycle-scroller{position:relative}.vue-recycle-scroller.direction-vertical:not(.page-mode){overflow-y:auto}.vue-recycle-scroller.direction-horizontal:not(.page-mode){overflow-x:auto}.vue-recycle-scroller.direction-horizontal{display:-webkit-box;display:-ms-flexbox;display:flex}.vue-recycle-scroller__slot{-webkit-box-flex:1;-ms-flex:auto 0 0px;flex:auto 0 0}.vue-recycle-scroller__item-wrapper{-webkit-box-flex:1;-webkit-box-sizing:border-box;box-sizing:border-box;-ms-flex:1;flex:1;overflow:hidden;position:relative}.vue-recycle-scroller.ready .vue-recycle-scroller__item-view{left:0;position:absolute;top:0;will-change:transform}.vue-recycle-scroller.direction-vertical .vue-recycle-scroller__item-wrapper{width:100%}.vue-recycle-scroller.direction-horizontal .vue-recycle-scroller__item-wrapper{height:100%}.vue-recycle-scroller.ready.direction-vertical .vue-recycle-scroller__item-view{width:100%}.vue-recycle-scroller.ready.direction-horizontal .vue-recycle-scroller__item-view{height:100%}.resize-observer[data-v-b329ee4c]{background-color:transparent;border:none;opacity:0}.resize-observer[data-v-b329ee4c],.resize-observer[data-v-b329ee4c] object{display:block;height:100%;left:0;overflow:hidden;pointer-events:none;position:absolute;top:0;width:100%;z-index:-1}.skip-link[data-v-bce074b1]{margin:1rem;padding:.5rem;position:fixed;text-align:center;top:-100%;width:80%;z-index:calc(infinity)}.skip-link[data-v-bce074b1]:focus{top:auto}.bg-mask[data-v-dcdc1b48]{-webkit-backdrop-filter:var(--bdfilter);backdrop-filter:var(--bdfilter);background-color:#0003;inset:0;position:fixed;z-index:var(--z-index-popover)}.v-enter-from[data-v-dcdc1b48],.v-leave-to[data-v-dcdc1b48]{opacity:0}.v-enter-active[data-v-dcdc1b48],.v-leave-active[data-v-dcdc1b48]{transition:all var(--delay)}.blog-header[data-v-19d3af70]{align-items:center;color:var(--c-text);contain:layout;display:flex;gap:.5em;line-height:1.4;margin:clamp(1rem,2rem,5vh) 1rem min(1rem,5vh);position:relative;-webkit-user-select:none;-moz-user-select:none;user-select:none}.blog-logo[data-v-19d3af70]{height:3em}.blog-logo.circle[data-v-19d3af70]{border-radius:2em;box-shadow:2px 4px 1rem var(--ld-shadow);width:3em}@font-face{font-family:AlimamaFangYuanTi;src:url(../fonts/AlimamaFangYuanTi.woff2)}.header-title[data-v-19d3af70]{font-family:AlimamaFangYuanTi,Noto Sans SC,sans-serif;font-size:1.5em;font-synthesis:none;font-variation-settings:"wght" 600,"BEVL" 100}.header-title>.split-char[data-v-19d3af70]{animation:vf-weight-19d3af70 3.14s infinite alternate,vf-bevel-19d3af70 2.72s infinite alternate;animation-delay:var(--delay);animation-play-state:paused}.header-subtitle[data-v-19d3af70]{font-size:.8em;opacity:.5}@keyframes vf-weight-19d3af70{0%{font-weight:600}38.2%{font-weight:300}to{font-weight:900}}@keyframes vf-bevel-19d3af70{0%{font-variation-settings:"BEVL" 100}to{font-variation-settings:"BEVL" 1}}.emoji-tail[data-v-19d3af70]{align-content:center;display:grid;filter:blur(2px);font-size:4rem;grid-template-columns:repeat(auto-fit,minmax(0,1fr));inset:0;justify-items:center;opacity:.2;pointer-events:none;position:absolute;transition:opacity 1s;z-index:-2}.emoji-tail>.split-char[data-v-19d3af70]{animation:emoji-floating-19d3af70 5s infinite alternate;animation-delay:var(--delay);animation-play-state:paused}.blog-header:hover .emoji-tail[data-v-19d3af70]{opacity:.5}.blog-header:hover .split-char[data-v-19d3af70]{animation-play-state:running}@keyframes emoji-floating-19d3af70{50%{filter:blur(4px);transform:translate(-12px,-4px) scale(1.2)}to{filter:blur(1px);transform:translate(-4px,-12px) scale(.9)}}kbd[data-v-c780abab]{background-color:var(--c-bg-soft);border-radius:.2em;box-shadow:inset 0 -.15em 0 var(--c-bg-soft);color:var(--c-text-2);display:inline-block;font-family:var(--font-monospace);font-size:.9em;letter-spacing:-.05em;line-height:1.4;margin:.1em;padding:0 .2em .1em;transition:all .1s;-webkit-user-select:none;-moz-user-select:none;user-select:none}kbd.active[data-v-c780abab],kbd[data-v-c780abab]:active{background-color:var(--c-primary-soft);box-shadow:inset 0 -.1em 0 var(--c-primary);color:var(--c-primary);transform:translateY(.05em)}.theme-toggle[data-v-df9620db]{background-color:var(--c-bg-2);border:1px solid var(--c-border);border-radius:1rem;display:flex;gap:3px;justify-content:center;margin:0 auto;padding:2px;width:-moz-fit-content;width:fit-content}.theme-toggle>button[data-v-df9620db]{border-radius:1rem;padding:4px 1rem;transition:all .1s}.theme-toggle>button[data-v-df9620db]:hover{background-color:var(--c-bg-soft);color:var(--c-text-1)}.theme-toggle>button.active[data-v-df9620db]{background-color:var(--ld-bg-card);box-shadow:.1em .2em .5rem var(--ld-shadow);color:var(--c-text-1);cursor:auto}menu[data-v-b08d7cdc]{display:flex;justify-content:center}menu a[data-v-b08d7cdc]{border-radius:2em;padding:.5em;transition:background-color .2s}menu a[data-v-b08d7cdc]:hover{background-color:var(--c-bg-soft)}menu a .iconify[data-v-b08d7cdc]{display:block}#blog-sidebar[data-v-01d4b4ba]{color:var(--c-text-2);display:flex;flex-direction:column}#blog-sidebar[data-v-01d4b4ba]:hover{color:currentcolor}@media(max-width:768px){#blog-sidebar[data-v-01d4b4ba]{-webkit-backdrop-filter:blur(.5rem);backdrop-filter:blur(.5rem);background-color:var(--ld-bg-blur);color:currentcolor;inset-inline-start:0;max-width:100%;position:fixed;transform:var(--transform-start-far);transition:transform .2s;width:320px;z-index:var(--z-index-popover)}#blog-sidebar.show[data-v-01d4b4ba]{box-shadow:0 0 1rem var(--ld-shadow);transform:none}}.sidebar-nav[data-v-01d4b4ba]{flex-grow:1;font-size:.9em;padding:0 5%}.sidebar-nav h3[data-v-01d4b4ba]{color:var(--c-text-2);font:inherit;margin:2em 0 1em 1em}.sidebar-nav li[data-v-01d4b4ba]{margin:.5em 0}.sidebar-nav-item[data-v-01d4b4ba]{align-items:center;border-radius:.5em;display:flex;gap:.5em;padding:.5em 1em;transition:all .2s}.sidebar-nav-item.router-link-active[data-v-01d4b4ba],.sidebar-nav-item[data-v-01d4b4ba]:hover{background-color:var(--c-bg-soft);color:var(--c-text)}.sidebar-nav-item.router-link-active[data-v-01d4b4ba]:after{color:var(--c-text-3);content:"⦁";text-align:center;width:1em}.sidebar-nav-item>.iconify[data-v-01d4b4ba]{font-size:1.5em}.sidebar-nav-item>.nav-text[data-v-01d4b4ba]{flex-grow:1}.sidebar-nav-item>.external-tip[data-v-01d4b4ba]{font-size:1em;opacity:.5}.search-btn[data-v-01d4b4ba]{cursor:text;margin:1rem 0;opacity:.5;outline:2px solid var(--c-border);outline-offset:-2px}.search-btn[data-v-01d4b4ba]:hover{background-color:transparent;opacity:1;outline-color:transparent}.sidebar-footer[data-v-01d4b4ba]{--gap:clamp(.5rem,3vh,1rem);color:var(--c-text-2);display:grid;font-size:.8em;gap:var(--gap);padding:var(--gap);text-align:center}.blog-footer[data-v-7c77d0d3]{color:var(--c-text-2);font-size:.9em;margin:3rem 1rem}.blog-footer .footer-nav[data-v-7c77d0d3]{display:flex;flex-wrap:wrap;gap:5vw clamp(2rem,5%,5vw);padding-block:3rem}.blog-footer .footer-nav h3[data-v-7c77d0d3]{font:inherit;margin:.5em}.blog-footer .footer-nav a[data-v-7c77d0d3]{align-items:center;border-radius:.5em;display:flex;font-size:.9em;gap:.3em;padding:.3em .5em;transition:background-color .2s,color .1s;width:-moz-fit-content;width:fit-content}.blog-footer .footer-nav a[data-v-7c77d0d3]:hover{background-color:var(--c-bg-soft);color:var(--c-text)}.blog-footer p[data-v-7c77d0d3]{margin:.5em}.dl-group>div[data-v-048a14d5]{padding:.2em 0}.dl-group>div>dt[data-v-048a14d5]{color:var(--c-text-2);font-size:.9em}.dl-group.small[data-v-048a14d5]{display:flex;flex-wrap:wrap;gap:.5em 1em;text-align:center}.dl-group.small>div[data-v-048a14d5]{flex:1;white-space:nowrap}.dl-group.medium[data-v-048a14d5]{display:grid;gap:.4em 8%;grid-template-columns:auto auto;padding:.2em 0}.dl-group.medium>div[data-v-048a14d5]{display:contents}.dl-group.medium>div>dt[data-v-048a14d5]{font-size:inherit;text-align:end}.blog-widget[data-v-aea32740]{font-size:.9em}.blog-widget+.blog-widget[data-v-aea32740]{margin-top:1rem}.blog-widget.dim[data-v-aea32740]{opacity:.3;transition:opacity .2s}#blog-aside.show .blog-widget.dim[data-v-aea32740],#blog-aside:hover .blog-widget.dim[data-v-aea32740],.blog-widget.dim[data-v-aea32740]:focus-within{opacity:1}.widget-title[data-v-aea32740]{align-items:center;color:var(--c-text-2);display:flex;gap:.5rem;justify-content:space-between;margin:.5rem}.widget-title a[data-v-aea32740]{transition:color .2s}.widget-title>[href][data-v-aea32740]:hover,.widget-title>[onclick][data-v-aea32740]:hover{color:var(--c-primary)}.widget-body.with-bg[data-v-aea32740]{overflow:hidden;overflow:clip;position:relative;z-index:0}.widget-body.with-bg>.bg-img[data-v-aea32740]{height:100%;inset:0;-o-object-fit:cover;object-fit:cover;opacity:.2;pointer-events:none;position:absolute;width:100%;z-index:-1}.widget-body.with-bg>.bg-img.bg-right[data-v-aea32740]{inset-inline-start:50%;-webkit-mask-image:linear-gradient(to var(--end),transparent,#fff 50%);mask-image:linear-gradient(to var(--end),transparent,#fff 50%);width:50%}.widget-body.widget-card[data-v-aea32740]{background-color:var(--c-bg-2);border-radius:.8rem;padding:.5rem .8rem}.widget-body.widget-card[data-v-aea32740] p{padding:.2em 0}.z-expand[data-v-ff3a4ba8]{display:flex;flex-direction:column}.toggle-btn[data-v-ff3a4ba8]{color:var(--c-text-2);display:block;font-size:.9em;margin:0 auto;padding:.3em;width:-moz-fit-content;width:fit-content}.toggle-btn.in-place[data-v-ff3a4ba8]{order:-1}.toggle-icon[data-v-ff3a4ba8]{transition:transform .2s}.toggle-icon.expand[data-v-ff3a4ba8]{transform:scaleY(-1)}.z-expand[data-v-89a31ad4]{margin-top:.2em}.dl-group[data-v-89a31ad4] img{height:1.2em;vertical-align:sub}.tip[data-v-e03fc3c4]{cursor:pointer;position:relative;-webkit-text-decoration:underline dashed var(--c-text-3);text-decoration:underline dashed var(--c-text-3);text-underline-offset:4px}.tip-icon[data-v-e03fc3c4]{display:inline-block;font-size:1em;vertical-align:top}.title[data-v-b3553d6e]{-webkit-background-clip:text;background-clip:text;background-image:linear-gradient(60deg,var(--c-accent) -30%,var(--c-primary),var(--c-text-1));background-position:100% 0;background-size:200%;color:transparent;font-size:1.8em;font-weight:800;letter-spacing:.05em;transition:background-position .2s}.blog-widget:hover .title[data-v-b3553d6e]{background-position:0 0}.tip[data-v-b3553d6e]{font-size:.9em;line-height:2}[data-v-b3553d6e] .bg-img.bg-img.bg-img{opacity:.5}.card[data-v-0db3bb4e]{padding:.5rem .8rem}.card .name[data-v-0db3bb4e]{margin:.2rem 0}.card .desc[data-v-0db3bb4e]{font-size:.8rem;opacity:.8}.z-codeblock[data-v-4cd927a3]{--line-height:1.4em;background-color:var(--c-bg-2);border-radius:.5em;font-size:.8125rem;line-height:var(--line-height);margin:.5em 0;overflow:clip;position:relative;-moz-tab-size:var(--tab-size,4);-o-tab-size:var(--tab-size,4);tab-size:var(--tab-size,4)}.z-codeblock.collapsed pre[data-v-4cd927a3]{animation:none;-webkit-mask-image:linear-gradient(0deg,transparent 2rem,#fff 4rem);mask-image:linear-gradient(0deg,transparent 2rem,#fff 4rem);max-height:calc(var(--line-height)*var(--collapsed-rows) + 3rem);overflow:hidden}.z-codeblock.collapsed .toggle-btn[data-v-4cd927a3]{margin:.5em}.z-codeblock.collapsible pre[data-v-4cd927a3]{padding-bottom:2rem}figcaption[data-v-4cd927a3]{display:flex;gap:1em;justify-content:space-between;padding:0 1em;position:sticky;top:0;z-index:2}figcaption>.filename[data-v-4cd927a3]{background-color:var(--c-border);border-radius:0 0 .5em .5em;padding:.2em .8em;word-break:break-all}figcaption>.language[data-v-4cd927a3]{height:0;opacity:.4;transform:translateY(.2em)}figcaption>.operations[data-v-4cd927a3]{background-color:var(--c-bg-2);border-end-start-radius:.5em;inset-inline-end:0;opacity:0;padding:0 .6em;position:absolute;transition:opacity .2s}:hover>figcaption>.operations[data-v-4cd927a3]{opacity:1}figcaption>.operations>button[data-v-4cd927a3]{opacity:.4;padding:.2em .4em;transition:opacity .2s}figcaption>.operations>button[data-v-4cd927a3]:hover{opacity:1}pre[data-v-4cd927a3]{--start-offset:4em;overflow:auto;padding:1rem;padding-inline-start:var(--start-offset)}pre.wrap[data-v-4cd927a3]{white-space:pre-wrap}[data-v-4cd927a3] .line:before{background-color:var(--c-bg-2);color:var(--c-text-3);content:attr(data-line);inset-inline-start:0;padding-inline-end:1em;position:absolute;text-align:end;width:var(--start-offset);z-index:1}[data-v-4cd927a3] .line.highlight:before{color:inherit}[data-v-4cd927a3] .line.highlight{background-color:var(--ld-bg-active);outline:.2em solid var(--ld-bg-active)}.toggle-btn[data-v-4cd927a3]{background-color:var(--c-bg-3);border-radius:.5em;color:var(--c-text-2);inset:auto 0 0;margin:.8em;padding:.2em;position:absolute;text-align:center}.toggle-icon[data-v-4cd927a3]{transition:all .2s}.toggle-icon.is-collapsed[data-v-4cd927a3]{transform:rotate(180deg)}:hover>.toggle-icon[data-v-4cd927a3]{opacity:0}.toggle-tip[data-v-4cd927a3]{inset:auto 0;opacity:0;position:absolute;transition:opacity .2s}:hover>.toggle-tip[data-v-4cd927a3]{opacity:1}.error[data-v-928363a5]{align-items:center;display:flex;flex-direction:column;gap:2rem;justify-content:center}.error>.error-icon[data-v-928363a5]{color:var(--c-text-3);font-size:5rem}.error>.error-title[data-v-928363a5]{color:var(--c-text-3);font-size:1.5rem;word-break:break-all}.error>.error-title[data-v-928363a5]>pre{font-size:1rem;white-space:pre-wrap}.error>.z-codeblock[data-v-928363a5]{max-width:100%}.error>.z-codeblock[data-v-928363a5] .shiki{background-color:transparent!important}.rc-list[data-v-5d9f0a6a],.rc-skeleton[data-v-5d9f0a6a]{display:grid;gap:.6rem}.rc-list[data-v-5d9f0a6a]{list-style:none;margin:0;padding:0}.rc-item[data-v-5d9f0a6a]{align-items:start;display:grid;gap:.6rem;grid-template-columns:32px 1fr}.skeleton[data-v-5d9f0a6a]{animation:skeleton-pulse-5d9f0a6a 1.5s ease-in-out infinite;background:var(--c-bg-mute);border-radius:.6rem;height:40px}.rc-avatar[data-v-5d9f0a6a]{border-radius:50%;height:32px;-o-object-fit:cover;object-fit:cover;width:32px}.rc-main[data-v-5d9f0a6a]{min-width:0}.rc-head[data-v-5d9f0a6a]{align-items:baseline;display:flex;gap:.5rem}.rc-nick[data-v-5d9f0a6a]{color:var(--c-text);font-weight:600}.rc-time[data-v-5d9f0a6a]{color:var(--c-text-3);font-size:.8em}.rc-text[data-v-5d9f0a6a]{display:-webkit-box;-webkit-box-orient:vertical;color:var(--c-text-1);-webkit-line-clamp:2;overflow:hidden;text-overflow:ellipsis}.rc-empty[data-v-5d9f0a6a]{color:var(--c-text-3)}@keyframes skeleton-pulse-5d9f0a6a{0%,to{opacity:.6}50%{opacity:.3}}.music-card[data-v-3e75dd1d]{background-color:var(--ld-bg-card);border-radius:.75rem;box-shadow:0 .1em .2em var(--ld-shadow);display:flex;flex-direction:column;gap:.75rem;padding:1rem}.track-info[data-v-3e75dd1d]{align-items:center;display:flex;gap:.75rem}.cover[data-v-3e75dd1d]{border-radius:.5rem;height:52px;-o-object-fit:cover;object-fit:cover;width:52px}.is-playing .cover[data-v-3e75dd1d]{animation:spin-3e75dd1d 8s linear infinite}@keyframes spin-3e75dd1d{to{transform:rotate(1turn)}}.info[data-v-3e75dd1d]{flex:1;min-width:0}.name[data-v-3e75dd1d]{color:var(--c-text-1);font-weight:600}.artist[data-v-3e75dd1d],.name[data-v-3e75dd1d]{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.artist[data-v-3e75dd1d]{color:var(--c-text-3);font-size:.8em}.controls[data-v-3e75dd1d]{align-items:center;display:flex;gap:1rem;justify-content:center}.ctrl[data-v-3e75dd1d]{color:var(--c-text-2);padding:.25rem;transition:color .2s,transform .2s}.ctrl[data-v-3e75dd1d]:hover{color:var(--c-primary);transform:scale(1.1)}.play-btn[data-v-3e75dd1d]{align-items:center;background-color:var(--c-primary);border-radius:50%;color:#fff;display:flex;font-size:.9em;height:1.8rem;justify-content:center;transition:transform .2s,background-color .2s;width:1.8rem}.play-btn[data-v-3e75dd1d]:hover{background-color:var(--c-primary-soft);transform:scale(1.08)}.progress-section[data-v-3e75dd1d]{display:flex;flex-direction:column;gap:.25rem}.progress-bar[data-v-3e75dd1d]{background-color:var(--c-border);border-radius:1.5px;cursor:pointer;height:3px;overflow:hidden}.progress-fill[data-v-3e75dd1d]{background-color:var(--c-primary);border-radius:1.5px;height:100%;transition:width .1s linear}.time[data-v-3e75dd1d]{color:var(--c-text-3);display:flex;font-size:.7em;justify-content:space-between}.skeleton[data-v-3e75dd1d]{animation:skeleton-pulse-3e75dd1d 1.4s ease-in-out infinite}.skeleton-block[data-v-3e75dd1d]{border-radius:.25rem;display:block}.skeleton-block[data-v-3e75dd1d],.skeleton-circle[data-v-3e75dd1d]{background-color:var(--c-bg-soft)}.skeleton-circle[data-v-3e75dd1d]{border-radius:999px}.track-info.skeleton .cover[data-v-3e75dd1d]{height:52px;width:52px}.track-info.skeleton .name[data-v-3e75dd1d]{height:.9rem;margin-bottom:.4rem}.track-info.skeleton .artist[data-v-3e75dd1d]{height:.7rem;width:60%}.skeleton-text[data-v-3e75dd1d]{height:.7rem;width:2.5rem}@keyframes skeleton-pulse-3e75dd1d{0%{opacity:.6}50%{opacity:1}to{opacity:.6}}[data-v-8a7037dc] .widget-body{position:relative}[data-v-8a7037dc] .widget-body:before{background-color:var(--c-bg-3);border-radius:1rem;content:"";inset:.3rem;position:absolute;width:3px}[data-v-8a7037dc] .widget-body li{color:var(--c-text);font-size:.94em;margin-inline-start:.8rem;opacity:.6;transition:opacity .2s}[data-v-8a7037dc] .widget-body li:hover{opacity:.94}[data-v-8a7037dc] .widget-body li.active,[data-v-8a7037dc] .widget-body li.has-active{font-size:1em;opacity:1}[data-v-8a7037dc] .widget-body li.active:before{background-color:var(--c-primary);border-radius:1rem;content:"";inset-inline-start:.3rem;margin:.2rem 0;padding:.6rem 1.5px;position:absolute}[data-v-8a7037dc] .widget-body li a{border-radius:.5em;display:block;overflow:hidden;padding:.2em .5em;text-overflow:ellipsis;transition:all .2s;white-space:nowrap}[data-v-8a7037dc] .widget-body li a:hover{background-color:var(--c-bg-soft)}.title[data-v-8a7037dc]{flex-grow:1}.no-toc[data-v-8a7037dc]{color:var(--c-text-3);padding:1em;text-align:center}.welcome-card[data-v-47658db6]{display:flex;flex-direction:column;gap:.4rem;outline:none;padding:.2rem 0}.welcome-card[data-v-47658db6]:focus-visible{border-radius:.6rem;box-shadow:0 0 0 .12rem var(--c-primary)}.detail-panel[data-v-47658db6]{background-color:var(--c-bg-soft);border-radius:.6rem;box-shadow:0 .2rem .6rem color-mix(in srgb,var(--c-primary) 15%,transparent);font-size:.85rem;line-height:1.5;margin-top:.4rem;padding:.4rem .6rem}.detail-row[data-v-47658db6]{align-items:flex-start;display:flex;font-family:inherit;gap:.4rem;margin:0}.detail-row+.detail-row[data-v-47658db6]{margin-top:.2rem}.detail-row .label[data-v-47658db6]{align-items:flex-start;color:var(--c-text-2);display:inline-flex;font-weight:600;min-width:3.2rem;position:relative}.detail-row .label[data-v-47658db6]:after{content:"：";margin-inline-start:.2rem}.detail-row .value[data-v-47658db6]{flex:1;font-family:inherit;overflow-wrap:anywhere}.detail-row-isp .value[data-v-47658db6]{opacity:.8}.tip[data-v-47658db6]{color:var(--c-text-3);font-size:.85rem}.greeting[data-v-47658db6]{font-weight:600;line-height:1.6;margin:0}.highlight[data-v-47658db6]{color:var(--c-primary)}.detail-expand[data-v-47658db6] .toggle-btn{cursor:pointer}#blog-aside[data-v-a33b5111]{overflow:auto;padding:.5rem;z-index:var(--z-index-popover)}@media(max-width:1080px){#blog-aside[data-v-a33b5111]{height:auto;inset-inline-end:0;max-height:100%;max-width:100%;position:fixed;top:0;transform:var(--transform-end-far);transition:transform .2s;width:320px}#blog-aside[data-v-a33b5111] .blog-widget{-webkit-backdrop-filter:blur(.5rem);backdrop-filter:blur(.5rem);background-color:var(--ld-bg-blur);border-radius:1rem;box-shadow:0 0 1rem var(--ld-shadow);padding:.5rem}#blog-aside.show[data-v-a33b5111]{transform:none}}#blog-panel[data-v-29e41f2c]{-webkit-backdrop-filter:blur(.5rem);backdrop-filter:blur(.5rem);background-color:var(--c-bg-a50);border-radius:.5rem;bottom:min(2rem,5%);font-size:1.4rem;inset-inline-end:min(1rem,5%);overflow:hidden;overflow:clip;position:fixed;transition:transform .1s;z-index:var(--z-index-popover)}@media(max-height:528px){#blog-panel[data-v-29e41f2c]{display:flex}}#blog-panel.has-active[data-v-29e41f2c]{box-shadow:0 0 .5rem var(--ld-shadow)}button[data-v-29e41f2c]{display:block;padding:.5rem;transition:all .2s}button[data-v-29e41f2c]:hover{background-color:var(--c-bg-a80);color:var(--c-primary)}button.active[data-v-29e41f2c]{background-color:var(--ld-bg-active);color:var(--c-primary)}#z-root{display:flex;gap:1rem;justify-content:center;min-width:0}#blog-aside,#blog-sidebar{flex-shrink:0;height:100vh;height:100dvh;position:sticky;scrollbar-width:thin;top:0;width:280px}@media(max-width:1080px){#blog-aside,#blog-sidebar{flex-shrink:.2}}#content{display:flex;gap:1rem;min-width:0;width:1080px}#content>#main-content{flex-grow:1;min-width:0}.button[data-v-c73aee28]{background-color:var(--ld-bg-card);border:1px solid var(--c-bg-soft);border-radius:.5em;box-shadow:0 2px .5em var(--ld-shadow);cursor:pointer;display:inline-block;line-height:1.2;padding:.4em .6em;transition:color .1s,background-color .2s;vertical-align:middle}.button.primary[data-v-c73aee28]{background-color:var(--c-primary);color:var(--c-bg)}.button[data-v-c73aee28]:hover{background-color:var(--c-bg-2);color:var(--c-text)}.button[data-v-c73aee28]:active{background-color:var(--ld-shadow)}.button[data-v-c73aee28]:disabled{background-color:var(--c-bg-1);color:var(--c-text-3);cursor:not-allowed}.button+.button[data-v-c73aee28]{margin-inline-start:.8em}.button-main[data-v-c73aee28]{align-items:center;display:flex;gap:.2em;justify-content:center}.button-desc[data-v-c73aee28]{color:var(--c-text-2);font-size:.75em;text-align:center}.app-error[data-v-4cb26870]{margin:1rem}.app-error pre[data-v-4cb26870]{text-align:start}.app-error .error-stack[data-v-4cb26870]{font-size:.9em;white-space:pre-wrap}
