.article-prose{color:var(--foreground);font-size:1.0625rem;line-height:1.76;letter-spacing:0}@media(min-width:640px){.article-prose{font-size:1.125rem;line-height:1.78}}.article-prose>:first-child{margin-top:0}.article-prose h2+p,.article-prose h3+p{margin-top:0}.article-prose p+p{margin-top:1.1rem}.article-prose pre,.project-detail-mdx pre{margin:1.5rem 0;overflow-x:auto;border-radius:1rem;background:var(--code-background);padding:1rem;white-space:pre}.article-prose pre code,.project-detail-mdx pre code,.article-code-block code{display:block;white-space:pre;word-break:normal;overflow-wrap:normal;border-radius:0;background:transparent;padding:0;font-size:.92rem;line-height:1.45}.article-prose pre code.hljs,.project-detail-mdx pre code.hljs,.article-code-block code.hljs{color:var(--foreground)}.article-prose :not(pre)>code,.project-detail-mdx :not(pre)>code{border-radius:.25rem;background:var(--surface-raised);padding:.25rem .5rem;color:var(--primary);font-family:var(--font-code-text);font-size:.92em}.article-prose .hljs-comment,.article-code-block .hljs-comment{color:var(--muted-subtle);font-style:italic}.article-prose .hljs-keyword,.article-prose .hljs-selector-tag,.article-prose .hljs-title,.article-prose .hljs-section,.article-prose .hljs-built_in,.article-prose .hljs-type,.article-code-block .hljs-keyword,.article-code-block .hljs-selector-tag,.article-code-block .hljs-title,.article-code-block .hljs-section,.article-code-block .hljs-built_in,.article-code-block .hljs-type{color:var(--primary);font-weight:700}.article-prose .hljs-string,.article-prose .hljs-attr,.article-prose .hljs-template-tag,.article-prose .hljs-template-variable,.article-code-block .hljs-string,.article-code-block .hljs-attr,.article-code-block .hljs-template-tag,.article-code-block .hljs-template-variable{color:var(--success)}.article-prose .hljs-number,.article-prose .hljs-literal,.article-prose .hljs-symbol,.article-code-block .hljs-number,.article-code-block .hljs-literal,.article-code-block .hljs-symbol{color:var(--warning)}.article-prose .hljs-variable,.article-prose .hljs-params,.article-prose .hljs-title.class_,.article-code-block .hljs-variable,.article-code-block .hljs-params,.article-code-block .hljs-title.class_,.article-prose .hljs-function,.article-prose .hljs-title.function_,.article-prose .hljs-class .hljs-title,.article-code-block .hljs-function,.article-code-block .hljs-title.function_,.article-code-block .hljs-class .hljs-title{color:var(--info)}.article-prose .hljs-meta,.article-prose .hljs-meta .hljs-keyword,.article-code-block .hljs-meta,.article-code-block .hljs-meta .hljs-keyword{color:var(--muted-subtle)}.article-prose .hljs-operator,.article-prose .hljs-punctuation,.article-code-block .hljs-operator,.article-code-block .hljs-punctuation{color:var(--muted)}.article-prose .hljs-property,.article-prose .hljs-attribute,.article-code-block .hljs-property,.article-code-block .hljs-attribute{color:var(--foreground)}.article-prose .hljs-regexp,.article-code-block .hljs-regexp{color:var(--warning)}.article-prose .hljs-name,.article-prose .hljs-tag,.article-code-block .hljs-name,.article-code-block .hljs-tag{color:var(--primary)}.article-prose .hljs-subst,.article-code-block .hljs-subst{color:var(--foreground)}.project-detail-mdx .hljs-comment{color:var(--muted-subtle);font-style:italic}.project-detail-mdx .hljs-keyword,.project-detail-mdx .hljs-selector-tag,.project-detail-mdx .hljs-title,.project-detail-mdx .hljs-section,.project-detail-mdx .hljs-built_in,.project-detail-mdx .hljs-type,.project-detail-mdx .hljs-name,.project-detail-mdx .hljs-tag{color:var(--primary);font-weight:700}.project-detail-mdx .hljs-string,.project-detail-mdx .hljs-attr,.project-detail-mdx .hljs-template-tag,.project-detail-mdx .hljs-template-variable{color:var(--success)}.project-detail-mdx .hljs-number,.project-detail-mdx .hljs-literal,.project-detail-mdx .hljs-symbol,.project-detail-mdx .hljs-regexp{color:var(--warning)}.project-detail-mdx .hljs-variable,.project-detail-mdx .hljs-params,.project-detail-mdx .hljs-title.class_,.project-detail-mdx .hljs-function,.project-detail-mdx .hljs-title.function_,.project-detail-mdx .hljs-class .hljs-title{color:var(--info)}.project-detail-mdx .hljs-meta,.project-detail-mdx .hljs-meta .hljs-keyword{color:var(--muted-subtle)}.project-detail-mdx .hljs-operator,.project-detail-mdx .hljs-punctuation{color:var(--muted)}.project-detail-mdx .hljs-property,.project-detail-mdx .hljs-attribute,.project-detail-mdx .hljs-subst{color:var(--foreground)}.article-index{position:fixed;right:1.5rem;bottom:1.5rem;z-index:30}.article-index-button{list-style:none;cursor:pointer;min-width:5rem;height:3rem;display:flex;align-items:center;justify-content:center;border:1px solid var(--border-default);background:var(--surface-raised);color:var(--foreground-strong);padding:0 1.25rem;font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;box-shadow:0 12px 24px -8px #00000080,inset 0 1px 1px #ffffff0d;transition:all .3s cubic-bezier(.16,1,.3,1);backdrop-filter:blur(8px)}@media(hover:hover){.article-index-button:hover{background:var(--surface-interactive);border-color:var(--primary);transform:translateY(-2px);box-shadow:0 16px 32px -8px #0009,inset 0 1px 1px #ffffff1a}}.article-index-button:active{transform:translateY(0)}.article-index-panel{position:absolute;right:0;bottom:4rem;width:20rem;max-height:calc(100dvh - 7rem);min-height:0;display:flex;flex-direction:column;gap:1rem;border:1px solid var(--border-default);background:color-mix(in srgb,var(--surface-raised) 85%,transparent);padding:1.5rem;box-shadow:0 24px 48px -12px #0009;backdrop-filter:blur(16px)}.article-index-panel-title{margin:0 0 .5rem;flex-shrink:0;color:var(--muted-subtle);font-size:.7rem;font-weight:800;letter-spacing:.15em;text-transform:uppercase}.article-index-sidebar{display:flex;flex-direction:column;gap:.15rem;position:relative;flex:1;min-height:0;padding-left:.25rem;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.article-index-sidebar:before{display:none}.article-index-tree-row{position:relative;display:flex;align-items:flex-start;gap:.4rem;padding:.5rem .75rem;border-radius:0;transition:all .2s ease;cursor:pointer}.article-index-tree-row-desktop[data-depth="0"]{padding-left:.75rem}.article-index-tree-row-desktop[data-depth="1"]{padding-left:1.5rem}.article-index-tree-row-desktop[data-depth="2"]{padding-left:2.25rem}.article-index-tree-row-desktop[data-depth="3"]{padding-left:3rem}.article-index-tree-row-desktop[data-depth="4"]{padding-left:3.75rem}.article-index-tree-row-mobile[data-depth="0"]{padding-left:.75rem}.article-index-tree-row-mobile[data-depth="1"]{padding-left:1.5rem}.article-index-tree-row-mobile[data-depth="2"]{padding-left:2.25rem}.article-index-tree-row-mobile[data-depth="3"]{padding-left:3rem}.article-index-tree-row-mobile[data-depth="4"]{padding-left:3.75rem}.article-index-tree-row-link{color:var(--muted-subtle)}.article-index-tree-row-link:hover{background:var(--surface-interactive);color:var(--foreground-strong)}.article-index-tree-row-current{color:var(--primary)!important;background:color-mix(in srgb,var(--primary) 6%,transparent)}.article-index-tree-row-current:before{content:"";position:absolute;left:0;top:.75rem;bottom:.75rem;width:2px;background:var(--primary);border-radius:0}.article-index-tree-number{flex:0 0 auto;min-width:1.4rem;font-family:var(--font-body-text);font-size:.75rem;font-weight:500;opacity:.6;margin-top:.2rem}.article-index-tree-row-current .article-index-tree-number{opacity:1;font-weight:700}.article-index-tree-content{flex:1;min-width:0;display:flex;flex-direction:column}.article-index-tree-label{font-size:.925rem;line-height:1.4;transition:color .2s ease}.article-index-tree-label-group{font-family:var(--font-headline-text);font-weight:700;color:var(--foreground-strong);font-size:.95rem}.article-index-tree-label-heading{font-size:.875rem}.lex-order-example,.lex-reorder-diagram{--lex-order-node-size: 2.6rem;--lex-order-label-size: 1rem;color:var(--foreground)}.lex-order-example{--lex-order-duration: 3s;margin:1.25rem 0 1.75rem}.lex-reorder-diagram{--lex-order-duration: 5.4s;margin:1.5rem 0 2.5rem}.lex-order-example .lex-order-visual{--lex-order-duration: 3s}.lex-order-example .lex-order-node--moved{animation-name:lex-order-front-sweep-fast}.lex-order-example .lex-order-node--placeholder{animation-name:lex-order-placeholder-hide-fast}.lex-order-example .lex-order-node--moved .lex-order-node-circle{animation:lex-order-node-flash-fast var(--lex-order-duration) ease-in-out infinite,lex-order-moved-pop-fast var(--lex-order-duration) ease-in-out infinite}.lex-order-example .lex-order-node--moved .lex-order-node-label--before{animation-name:lex-order-label-before-fast}.lex-order-example .lex-order-node--moved .lex-order-node-label--after{animation-name:lex-order-label-after-fast}@keyframes lex-order-front-sweep-fast{0%,10%{left:var(--from-left);transform:translateY(-50%)}25%,92%{left:var(--to-left);transform:translateY(-50%)}to{left:var(--from-left);transform:translateY(-50%)}}@keyframes lex-order-placeholder-hide-fast{0%,24%{opacity:1}25%,92%{opacity:0}to{opacity:1}}@keyframes lex-order-node-flash-fast{0%,25%,92%,to{background:var(--surface-muted)}40%,85%{background:color-mix(in srgb,var(--warning) 20%,var(--surface-muted))}}@keyframes lex-order-moved-pop-fast{0%,10%,92%,to{transform:scale(1)}15%,23%{transform:scale(1.15)}}@keyframes lex-order-label-before-fast{0%,25%,to{opacity:1}40%,92%{opacity:0}}@keyframes lex-order-label-after-fast{0%,25%,to{opacity:0}40%,92%{opacity:1}}.lex-reorder-grid{display:grid;grid-template-columns:minmax(0,1fr);gap:.85rem}.lex-reorder-panel{position:relative;min-width:0;border-radius:1rem;background:var(--surface-muted);padding:.8rem}.lex-reorder-panel-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;min-height:1.75rem;margin-bottom:.5rem}.lex-reorder-panel-title{color:var(--foreground-strong);font-family:var(--font-headline-text);font-size:.98rem;font-weight:800;line-height:1.2;letter-spacing:0}.lex-reorder-track,.lex-order-example-diagram{position:relative;height:calc(var(--lex-order-node-size) + 1rem);min-height:calc(var(--lex-order-node-size) + 1rem);margin:0;overflow:visible}.lex-reorder-caption{margin:.45rem 0 0 .15rem;color:var(--muted-subtle);font-size:.8rem;font-weight:650;line-height:1.35;letter-spacing:0}@media(max-width:768px){.article-index-panel{width:min(20rem,calc(100vw - 2rem))}}@media(max-width:560px){.lex-order-example,.lex-reorder-diagram{--lex-order-node-size: 2rem;--lex-order-label-size: .9rem}.lex-reorder-grid{gap:.6rem}.lex-reorder-panel{padding:.62rem}.lex-reorder-panel-heading{gap:.45rem;min-height:1.35rem;margin-bottom:.32rem}.lex-reorder-caption{margin-top:.38rem;margin-left:.05rem;font-size:.74rem}}.reorder-demo{--reorder-duration: 4.2s;--item-height: 2.6rem;--item-gap: .4rem;margin:1.25rem 0 1.75rem;background:transparent;overflow:visible}.reorder-demo-body{padding:.25rem 0;background:transparent}.reorder-demo-list-wrapper{position:relative;height:calc((var(--item-height) + var(--item-gap)) * 4 - var(--item-gap));overflow:visible}.reorder-demo-list{list-style:none;padding:0;margin:0;position:relative;width:100%;height:100%}.reorder-demo-item{position:absolute;left:0;width:100%;height:var(--item-height);background:var(--surface-raised);border:1px solid var(--border-default);border-radius:.5rem;padding:0 1rem;display:flex;align-items:center;justify-content:flex-start;box-shadow:0 1px 3px #00000005;transition:border-color .3s,box-shadow .3s,transform .3s}.reorder-demo-number{position:relative;width:1.2rem;height:1.2rem;display:flex;align-items:center;justify-content:center;font-family:var(--font-headline-text);font-weight:800;font-size:.9rem;color:var(--foreground-strong)}.reorder-demo-number .num-before,.reorder-demo-number .num-after{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.reorder-demo-text{font-weight:600;color:var(--foreground-strong);font-size:.9rem;flex:1;margin-left:.75rem}.reorder-demo-cursor{position:absolute;width:1.25rem;height:1.25rem;color:var(--foreground-strong);z-index:10;pointer-events:none;filter:drop-shadow(0 2px 4px rgba(0,0,0,.15))}.reorder-demo-cursor svg{width:100%;height:100%}.reorder-demo-caption{margin:.5rem 0 0 .15rem;color:var(--muted-subtle);font-size:.8rem;font-weight:650;line-height:1.35}.item-planning{top:0}.item-design{top:calc(var(--item-height) + var(--item-gap));animation:reorder-item-design var(--reorder-duration) ease-in-out infinite}.item-design .num-before{animation:reorder-num-before var(--reorder-duration) steps(1,end) infinite}.item-design .num-after{animation:reorder-num-after var(--reorder-duration) steps(1,end) infinite}.item-development{top:calc((var(--item-height) + var(--item-gap)) * 2);animation:reorder-item-development var(--reorder-duration) ease-in-out infinite}.item-development .num-before{animation:reorder-num-before var(--reorder-duration) steps(1,end) infinite}.item-development .num-after{animation:reorder-num-after var(--reorder-duration) steps(1,end) infinite}.item-deploy{top:calc((var(--item-height) + var(--item-gap)) * 3);animation:reorder-item-deploy var(--reorder-duration) ease-in-out infinite}.item-deploy .num-before{animation:reorder-num-before var(--reorder-duration) steps(1,end) infinite}.item-deploy .num-after{animation:reorder-num-after var(--reorder-duration) steps(1,end) infinite}.reorder-demo-cursor{animation:reorder-cursor-move var(--reorder-duration) ease-in-out infinite}@keyframes reorder-cursor-move{0%{top:80%;left:85%;opacity:0;transform:scale(1)}14%{top:75%;left:85%;opacity:1;transform:scale(1)}23%{top:75%;left:85%;transform:scale(.8)}35%{top:75%;left:85%;transform:scale(.8)}48%{top:25%;left:85%;transform:scale(.8)}56%{top:25%;left:85%;transform:scale(1)}76%{top:75%;left:90%;opacity:0}to{top:80%;left:85%;opacity:0}}@keyframes reorder-item-deploy{0%,23%{top:calc((var(--item-height) + var(--item-gap)) * 3);z-index:1;box-shadow:0 1px 3px #00000005;border-color:var(--border-default);transform:scale(1)}29%{box-shadow:0 8px 16px #0000001a;border-color:var(--primary);z-index:5;transform:scale(1.02)}35%{top:calc((var(--item-height) + var(--item-gap)) * 3);box-shadow:0 8px 16px #0000001a;border-color:var(--primary);z-index:5;transform:scale(1.02)}48%{top:calc(var(--item-height) + var(--item-gap));box-shadow:0 8px 16px #0000001a;border-color:var(--primary);z-index:5;transform:scale(1.02)}56%,85%{top:calc(var(--item-height) + var(--item-gap));box-shadow:0 1px 3px #00000005;border-color:var(--border-default);z-index:1;transform:scale(1)}92%,to{top:calc((var(--item-height) + var(--item-gap)) * 3);z-index:1}}@keyframes reorder-item-design{0%,35%{top:calc(var(--item-height) + var(--item-gap))}48%,85%{top:calc((var(--item-height) + var(--item-gap)) * 2)}92%,to{top:calc(var(--item-height) + var(--item-gap))}}@keyframes reorder-item-development{0%,35%{top:calc((var(--item-height) + var(--item-gap)) * 2)}48%,85%{top:calc((var(--item-height) + var(--item-gap)) * 3)}92%,to{top:calc((var(--item-height) + var(--item-gap)) * 2)}}@keyframes reorder-num-before{0%,48%{opacity:1}48.01%,to{opacity:0}}@keyframes reorder-num-after{0%,48%{opacity:0}48.01%,to{opacity:1}}@media(max-width:560px){.reorder-demo{--item-height: 2.2rem;--item-gap: .3rem}.reorder-demo-text,.reorder-demo-number{font-size:.85rem}}@media(prefers-reduced-motion:reduce){.reorder-demo-item,.reorder-demo-number .num-before,.reorder-demo-number .num-after,.reorder-demo-cursor{animation:none!important}.reorder-demo-cursor{display:none}.item-design{top:calc((var(--item-height) + var(--item-gap)) * 2)}.item-design .num-before{opacity:0}.item-design .num-after{opacity:1}.item-development{top:calc((var(--item-height) + var(--item-gap)) * 3)}.item-development .num-before{opacity:0}.item-development .num-after{opacity:1}.item-deploy{top:calc(var(--item-height) + var(--item-gap))}.item-deploy .num-before{opacity:0}.item-deploy .num-after{opacity:1}}
