.blog-content{color:var(--text-1);line-height:1.6;font-size:1rem;font-weight:400;--tw-prose-body: var(--text-1);--tw-prose-headings: var(--text-1);--tw-prose-lead: var(--text-1);--tw-prose-links: var(--accent-iris);--tw-prose-bold: var(--text-1);--tw-prose-quotes: var(--text-1);--tw-prose-code: var(--text-1);--tw-prose-bullets: var(--brand);--tw-prose-counters: var(--brand)}.blog-content h1,.blog-content h2,.blog-content h3,.blog-content h4,.blog-content h5,.blog-content h6{color:var(--text-1);font-weight:700;line-height:1.2;margin-top:3rem;margin-bottom:1.5rem;scroll-margin-top:2rem;letter-spacing:-.02em}.blog-content h1{font-size:2.5rem;font-weight:700;font-family:var(--font-display);color:var(--text-1);margin-bottom:2rem}.blog-content h2{font-size:2rem;font-weight:700;font-family:var(--font-display);position:relative;padding-left:1.1rem}.blog-content h2:before{content:"";position:absolute;left:0;top:.18em;bottom:.18em;width:1px;background:linear-gradient(180deg,color-mix(in srgb,var(--accent-gold) 55%,transparent),color-mix(in srgb,var(--accent-iris) 30%,transparent),transparent)}.blog-content h2:after{content:"";position:absolute;left:-.135rem;top:.18em;width:.3rem;height:.3rem;border:1px solid color-mix(in srgb,var(--accent-gold) 48%,transparent);transform:rotate(45deg);border-radius:.06rem}.blog-content h3{font-size:1.5rem;font-weight:600;color:var(--text-1)}.blog-content h4{font-size:1.25rem;font-weight:600}.blog-content p{margin-bottom:1.5rem;font-size:1.0625rem;line-height:1.7;color:var(--text-1)}.blog-content .callout .callout-body>:first-child{margin-top:0}.blog-content .callout .callout-body>:last-child{margin-bottom:0}.blog-content>p:first-of-type{font-size:1.25rem;line-height:1.65;color:var(--text-emphasis);margin:2rem 0}.blog-content ul,.blog-content ol{margin-bottom:1.5rem;padding-left:0}.blog-content ul li,.blog-content ol li{margin-bottom:.5rem;padding:.1rem 0 .1rem 1.9rem;position:relative;color:var(--text-1)}.blog-content ul li:before{content:"";position:absolute;left:.45rem;top:.62em;width:.4rem;height:.4rem;border:1px solid color-mix(in srgb,var(--accent-gold) 62%,transparent);transform:rotate(45deg);border-radius:.08rem}.blog-content ol{counter-reset:list-counter}.blog-content ol li{padding-left:2.4rem}.blog-content ol li:before{content:counter(list-counter);counter-increment:list-counter;position:absolute;left:.2rem;top:.18em;width:1.5rem;height:1.5rem;border:1px solid color-mix(in srgb,var(--accent-gold) 48%,transparent);color:var(--brand);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem}.blog-content details{margin:.4rem 0 .75rem;padding:.5rem .75rem;border-radius:.75rem;border:1px solid var(--surface-2);background:var(--surface-0);transition:background .2s ease,border-color .2s ease,transform .15s ease}.blog-content details[open]{background:var(--surface-1);border-color:var(--surface-3);transform:translateY(-1px)}.blog-content details+details{margin-top:.5rem}.blog-content details summary{list-style:none;cursor:pointer;font-weight:600;color:var(--accent-iris);display:flex;align-items:center;gap:.5rem;text-decoration:none;transition:color .18s ease,transform .14s ease}.blog-content details summary::-webkit-details-marker{display:none}.blog-content details summary:before{content:"▸";font-size:.9rem;color:var(--accent-iris);transition:transform .2s ease}.blog-content details[open] summary:before{transform:rotate(90deg)}.blog-content details summary:hover{color:var(--brand);transform:translate(2px);text-decoration-color:currentColor}.blog-content details[open] summary{color:var(--brand)}.blog-content details summary:focus-visible{outline:2px solid transparent;outline-offset:2px;box-shadow:0 0 0 2px color-mix(in srgb,var(--accent-iris) 60%,transparent);border-radius:.5rem}.blog-content details>*:not(summary){margin-top:.5rem}.blog-content blockquote{margin:1.125rem 0;padding:.95rem 1.15rem;background:linear-gradient(135deg,color-mix(in srgb,var(--surface-0) 70%,transparent),color-mix(in srgb,var(--surface-1) 70%,transparent));border:1px solid color-mix(in srgb,var(--surface-2) 58%,transparent);border-radius:.8rem;position:relative;overflow:hidden}.blog-content blockquote:before{content:"";position:absolute;top:0;left:0;width:3px;height:100%;background:linear-gradient(180deg,var(--brand) 0%,var(--accent-iris) 100%)}.blog-content blockquote p{margin:0;font-size:.98rem;font-weight:400;line-height:1.6;font-style:normal;color:var(--text-1)}.blog-content code{background:var(--surface-1);color:var(--accent-rose);padding:.15rem .25rem;border-radius:.375rem;font-size:.875em;font-family:JetBrains Mono,Fira Code,SF Mono,monospace;border:1px solid var(--surface-3);font-weight:500}.blog-content :not(pre)>code{margin-right:-.18em}.blog-content pre{background:var(--surface-0);border:1px solid var(--surface-2);border-radius:.75rem;padding:2.25rem 3.25rem 1.5rem 1.5rem;overflow-x:auto;margin:2rem 0;position:relative;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.blog-content pre:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--brand) 55%,transparent) 30%,color-mix(in srgb,var(--brand) 55%,transparent) 70%,transparent)}.blog-content pre code{background:transparent;color:var(--text-1);padding:0;border:none;font-size:.875rem;line-height:1.5;white-space:pre-wrap;word-break:break-word}.blog-content .code-copy-btn{position:absolute;top:.4rem;right:.75rem;padding:.3rem .7rem;border-radius:999px;border:1px solid color-mix(in srgb,var(--accent-gold) 38%,transparent);background:var(--surface-chip);color:var(--brand);font-size:.75rem;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:.25rem;box-shadow:0 4px 10px #00000040;transition:transform .15s ease,box-shadow .15s ease,background .2s ease,border-color .2s ease}.blog-content .code-copy-btn:hover{transform:translateY(-1px);box-shadow:0 6px 16px #0000004d}@keyframes copy-pulse{0%{box-shadow:0 0 color-mix(in srgb,var(--status-success) 45%,transparent)}to{box-shadow:0 0 0 9px transparent}}.blog-content .code-copy-btn.copied{background:color-mix(in srgb,var(--status-success) 16%,transparent);border-color:color-mix(in srgb,var(--status-success) 45%,transparent);color:var(--status-success);animation:copy-pulse .48s ease-out}@media(prefers-reduced-motion:reduce){.blog-content .code-copy-btn.copied{animation:none}}.blog-content img{border-radius:1rem;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;margin:2rem auto;display:block;max-width:100%;height:auto;border:1px solid var(--surface-2);transition:transform .3s ease,filter .3s ease}.blog-content table{width:100%;border-collapse:separate;border-spacing:0;margin:2rem 0;background:var(--surface-0);border-radius:.75rem;overflow:hidden;box-shadow:0 4px 6px -1px #0000001a;border:1px solid var(--surface-2)}.blog-content th,.blog-content td{padding:1rem;text-align:left;border-bottom:1px solid var(--surface-2)}.blog-content th{background:linear-gradient(135deg,var(--surface-1) 0%,var(--surface-2) 100%);font-weight:600;color:var(--text-1);font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.blog-content tr:last-child td{border-bottom:none}.blog-content tr:hover{background:var(--surface-1)}.blog-content hr{border:none;height:1px;background:linear-gradient(90deg,transparent,var(--surface-3),transparent);margin:3rem 0;position:relative}.blog-content hr:before{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%) rotate(45deg);width:.5rem;height:.5rem;background:var(--bg-0);border:1px solid color-mix(in srgb,var(--accent-gold) 55%,transparent);border-radius:.08rem}.blog-content a{color:var(--accent-iris);text-decoration:none;font-weight:500;position:relative;transition:color .2s ease}.blog-content a:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent-iris) 0%,var(--brand) 100%);transform:scaleX(0);transition:transform .2s ease;transform-origin:left}.blog-content a:hover{color:var(--brand)}.blog-content a:hover:after{transform:scaleX(1)}.blog-content strong{color:var(--brand);font-weight:700}.blog-content em{font-style:italic;color:var(--text-1);font-weight:500}@media(prefers-reduced-motion:no-preference){.blog-content>:not(nav):not(script):nth-child(-n+7){animation:fadeInUp .5s ease-out}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.blog-content{font-size:.9375rem}.blog-content h1{font-size:2rem}.blog-content h2{font-size:1.75rem}.blog-content h3{font-size:1.375rem}.blog-content p{font-size:1rem}.blog-content p:first-of-type{font-size:1.125rem}.blog-content ul li{padding-left:1.7rem}.blog-content blockquote{margin:1rem 0;padding:.9rem 1rem}.blog-content pre{padding:1.1rem 2.4rem 1.1rem 1rem}.blog-content ol li{padding-left:2.2rem}.blog-content ol li:before{width:1.4rem;height:1.4rem;font-size:.78rem}.blog-content .code-copy-btn{top:.55rem;right:.65rem;padding:.26rem .62rem;font-size:.72rem}}@media print{.blog-content{color:#000;font-size:12pt;line-height:1.5}.blog-content h1,.blog-content h2,.blog-content h3{color:#000;page-break-after:avoid;background:none;-webkit-text-fill-color:#000}.blog-content img{page-break-inside:avoid;max-width:100%}.blog-content a{color:#000;text-decoration:underline}.blog-content a:after{display:none}}#mainmenu[popover],nav[popover],aside[popover]{padding:.5rem 1rem;border-radius:.75rem;background:color-mix(in oklch,var(--bg) 85%,black);border:1px solid color-mix(in oklch,var(--fg) 25%,transparent)}@supports (inset: anchor(top)){#mainmenu{position:fixed;inset:anchor(bottom) auto auto anchor(right);margin:.5rem}}.post-page .share-anchor{position:relative;z-index:1001}@media(min-width:640px){.post-page .share-anchor{margin-left:auto}}.post-page .post-title{margin-top:0}.post-page.glass-panel{overflow:visible;position:relative}.post-page .share-popover{display:none;position:fixed;flex-direction:column;gap:.3rem;padding:.55rem;width:min(22rem,calc(100vw - 1.5rem));min-width:12.5rem;max-width:min(92vw,22rem);max-height:min(70vh,30rem);overflow-y:auto;border-radius:var(--radius-md);background:radial-gradient(120% 120% at 100% 0%,color-mix(in srgb,var(--brand) 12%,transparent),var(--palette-bg)),var(--palette-bg);border:1px solid var(--palette-border);backdrop-filter:blur(var(--blur-chip));-webkit-backdrop-filter:blur(var(--blur-chip));box-shadow:0 12px 32px #02050880;z-index:1002}.post-page .share-popover[hidden]{display:none!important}@keyframes share-pop-in{0%{opacity:0;transform:scale(.95) translateY(-5px)}}.post-page .share-popover[data-open=true]{display:flex;animation:share-pop-in .19s var(--ease-spring);transform-origin:top right}@media(prefers-reduced-motion:reduce){.post-page .share-popover[data-open=true]{animation:none}}.post-page .share-item{display:flex;align-items:center;gap:1rem;padding:.6rem .75rem;border-radius:.6rem;color:var(--text-1);text-decoration:none;border:1px solid transparent;background:transparent;cursor:pointer}.post-page .share-item:hover,.post-page .share-item:focus-visible{background:var(--surface-chip-hover);border-color:color-mix(in srgb,var(--accent-foam) 45%,transparent);outline:2px solid transparent}.post-page .share-item .icon-box{width:2.75rem;height:2.75rem;display:inline-grid;place-items:center;border-radius:var(--radius-md);background:var(--surface-chip);border:1px solid var(--surface-chip-border);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);box-shadow:0 4px 16px #02050859;box-sizing:border-box;flex:0 0 2.75rem}.post-page .share-glyph{font-size:.95rem;font-weight:700;letter-spacing:.02em}.post-page .share-item:hover .icon-box,.post-page .share-item:focus-visible .icon-box{background:var(--surface-chip-hover);border-color:color-mix(in srgb,var(--accent-foam) 48%,transparent)}.post-page .share-item .label{font-weight:600}@media(max-width:640px){.post-page .share-popover{gap:.2rem;padding:.45rem}.post-page .post-title{padding-right:5.5rem}.post-page .share-item{padding:.55rem .65rem;gap:.8rem}.post-page .share-item .icon-box{width:2.5rem;height:2.5rem;flex-basis:2.5rem}}@media(prefers-reduced-motion:reduce){.post-page .share-item{transition:none}}.post-page .sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
