.article-body>:first-child{margin-top:0}.article-body>:last-child{margin-bottom:0}.article-body :is(h1,h2,h3,h4){margin-top:2.8rem;margin-bottom:1rem;font-weight:600;line-height:1.15;letter-spacing:-.03em;text-wrap:balance}.article-body h1{font-size:clamp(2rem,1.6rem + 1.6vw,2.8rem)}.article-body h2{font-size:clamp(1.75rem,1.35rem + 1.4vw,2.35rem)}.article-body h3{font-size:clamp(1.4rem,1.2rem + .8vw,1.8rem)}.article-body :is(p,ul,ol,blockquote,table,hr){margin:1.4rem 0}.article-body p{color:var(--ab-text);overflow-wrap:anywhere}.article-body a{color:var(--ab-link);text-decoration:underline;text-decoration-thickness:1.5px;text-underline-offset:.18em}.article-body strong{font-weight:600;color:var(--ab-strong)}.article-body :is(ul,ol){padding-left:1.4rem}.article-body li+li{margin-top:.65rem}.article-body blockquote{border-left:4px solid var(--ab-blockquote-border);padding-left:1rem;color:var(--ab-blockquote-text)}.article-body :not(pre)>code{border:1px solid var(--ab-code-border);background:var(--ab-code-bg);border-radius:.5rem;padding:.12rem .35rem;font-size:.9em}.article-body .code-block{position:relative;margin:1.4rem 0}.article-body .code-copy-button{position:absolute;top:.85rem;right:.85rem;z-index:1;display:inline-flex;align-items:center;justify-content:center;width:2.25rem;height:2.25rem;border:1px solid rgba(248,244,236,.18);background:#fffcfc14;color:#f8f4ece6;backdrop-filter:blur(10px);transition:background-color .16s ease,border-color .16s ease,color .16s ease,transform .16s ease;cursor:pointer}.article-body .code-copy-button:hover{background:#fffcfc24;border-color:#f8f4ec4d;transform:translateY(-1px)}.article-body .code-copy-button.is-copied{color:#a6da95;border-color:#a6da9573}.article-body .code-copy-button.copy-failed{color:#f5a97f;border-color:#f5a97f73}.article-body .code-copy-icon{width:1rem;height:1rem;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.article-body .code-copy-icon-success,.article-body .code-copy-button.is-copied .code-copy-icon-copy{display:none}.article-body .code-copy-button.is-copied .code-copy-icon-success{display:block}.article-body .code-block pre{overflow-x:hidden;max-width:100%;border:1px solid var(--ab-border);background:var(--ab-pre-bg);color:var(--ab-pre-text);border-radius:0;padding:1.1rem 4rem 1.2rem 1.2rem;line-height:1.7;white-space:pre-wrap;word-break:break-word}.article-body .code-block[data-collapsible][data-collapsed] pre{max-height:calc(25.5em + 2.3rem);overflow-y:hidden;-webkit-mask-image:none;mask-image:none;position:relative}.article-body .code-block[data-collapsible][data-collapsed]:after{content:"";position:absolute;bottom:2.6rem;left:0;right:0;height:5rem;background:linear-gradient(to bottom,transparent,#282828);pointer-events:none}.article-body .code-expand-button{display:block;width:100%;padding:.55rem 1.2rem;background:#32302f;color:#ebdbb273;border:1px solid var(--ab-border);border-top:1px solid rgba(235,219,178,.07);font-size:.8rem;letter-spacing:.04em;text-align:center;cursor:pointer;transition:color .16s ease,background .16s ease}.article-body .code-expand-button:hover{background:#3c3836;color:#ebdbb2}.article-body .code-block pre code{background:transparent;border:0;padding:0;color:inherit;word-break:normal;overflow-wrap:normal}.article-body .mermaid-frame{margin:1.8rem 0;overflow:hidden;overscroll-behavior:contain;border:1px solid var(--ab-border);background:var(--ab-mermaid-bg);padding:1rem}.article-body .mermaid-frame svg{display:block;width:100%;max-width:100%;height:min(42rem,75vh);touch-action:none;cursor:grab}.article-body .mermaid-frame svg.svg-pan-zoom_dragging{cursor:grabbing}.article-body :is(video,iframe){display:block;max-width:100%;height:auto}.article-body .article-image{width:min(100%,42rem);margin:1.9rem auto}.article-body .article-image img{display:block;width:100%;max-width:100%;max-height:min(32rem,70vh);height:auto;margin:0 auto;object-fit:contain}.article-body .article-image a{display:block}.article-body .article-image-caption{margin-top:.75rem;text-align:center;font-size:.92rem;line-height:1.5;color:var(--ab-blockquote-text)}.article-body .hljs-keyword,.article-body .hljs-selector-tag,.article-body .hljs-literal{color:#fabd2f}.article-body .hljs-title.function_{color:#8ec07c}.article-body .hljs-string,.article-body .hljs-title,.article-body .hljs-section,.article-body .hljs-attribute{color:#b8bb26}.article-body .hljs-comment,.article-body .hljs-quote{color:#928374;font-style:italic}.article-body .hljs-number,.article-body .hljs-symbol{color:#d3869b}.article-body .hljs-variable,.article-body .hljs-template-variable{color:#fe8019}.article-body .hljs-built_in,.article-body .hljs-type,.article-body .hljs-link{color:#83a598}.article-body table{display:block;width:100%;overflow-x:auto;border-collapse:collapse}.article-body :is(th,td){border-bottom:1px solid var(--ab-border-mid);padding:.8rem .9rem;text-align:left;vertical-align:top}.article-body th{font-weight:600;color:var(--ab-th-text);background:var(--ab-th-bg)}.article-body hr{border:0;border-top:1px solid var(--ab-border-mid)}.toc-link.is-active{color:var(--ab-toc-active);transform:translate(2px)}@media(max-width:48rem){.article-body{font-size:1rem;line-height:1.9}.article-body :is(h1,h2,h3,h4){margin-top:2.25rem;margin-bottom:.85rem}.article-body :is(ul,ol){padding-left:1.15rem}.article-body .code-copy-button{top:.7rem;right:.7rem;width:2rem;height:2rem}.article-body .code-block pre{font-size:.88rem;padding:1rem 3.5rem 1.05rem 1rem}.article-body .mermaid-frame{padding:.75rem}.article-body .mermaid-frame svg{height:min(30rem,65vh)}}
