.reading-progress-container[data-astro-cid-mu6cnre2]{position:fixed;top:0;left:0;right:0;width:100%;height:3px;background:var(--reading-progress-track, rgba(12, 10, 17, .6));backdrop-filter:blur(6px);z-index:9996;pointer-events:none;opacity:0;transition:opacity .25s ease-out}.reading-progress-container[data-astro-cid-mu6cnre2].is-visible{opacity:1}.reading-progress-bar[data-astro-cid-mu6cnre2]{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--brand) 0%,color-mix(in srgb,var(--brand) 80%,var(--accent-foam) 20%) 100%);width:0%;opacity:0;transition:width .18s ease-out,opacity .2s ease-out;box-shadow:0 0 8px color-mix(in srgb,var(--brand) 40%,transparent)}.reading-progress-bar[data-astro-cid-mu6cnre2].is-visible{opacity:1}.reading-progress-bar[data-astro-cid-mu6cnre2].no-transition{transition:opacity .2s ease-out}@media (prefers-reduced-motion: reduce){.reading-progress-bar[data-astro-cid-mu6cnre2],.reading-progress-container[data-astro-cid-mu6cnre2]{transition:none}}.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:800;background:linear-gradient(135deg,var(--text-1) 0%,var(--brand) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:2rem}.blog-content h2{font-size:2rem;font-weight:700;position:relative;padding-left:1rem}.blog-content h2:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,var(--brand) 0%,var(--accent-iris) 100%);border-radius:2px}.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.6;color:var(--text-1);font-weight:500;padding:2rem;background:linear-gradient(135deg,var(--surface-0) 0%,var(--surface-1) 100%);border:1px solid var(--surface-2);border-radius:1rem;margin:2rem 0;position:relative;overflow:hidden}.blog-content p:first-of-type:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--brand) 0%,var(--accent-iris) 50%,var(--brand) 100%);background-size:200% 100%;animation:shimmer 2s ease-in-out 1}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 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:.5rem .9rem .4rem 2.9rem;background:var(--surface-0);border-radius:.5rem;border:1px solid var(--surface-2);position:relative;transition:background .2s ease,border-color .2s ease;color:var(--text-1)}.blog-content ul li:hover,.blog-content ol li:hover{background:var(--surface-1);border-color:var(--surface-3);transform:translate(4px)}.blog-content ul li:before{content:"▸";position:absolute;left:1rem;top:.75rem;color:var(--brand);font-weight:700;font-size:1.2rem}.blog-content ol{counter-reset:list-counter}.blog-content ol li:before{content:counter(list-counter);counter-increment:list-counter;position:absolute;left:.75rem;top:.6rem;width:1.65rem;height:1.65rem;background:linear-gradient(135deg,var(--accent-iris) 0%,var(--brand) 100%);color:var(--surface-0);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem}.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:none;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.5rem 0;padding:1.25rem 1.5rem;background:linear-gradient(135deg,color-mix(in srgb,var(--surface-0) 80%,transparent),color-mix(in srgb,var(--surface-1) 80%,transparent));border:1px solid color-mix(in srgb,var(--surface-2) 75%,transparent);border-radius:1rem;position:relative;overflow:hidden}.blog-content blockquote:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:linear-gradient(180deg,var(--brand) 0%,var(--accent-iris) 100%)}.blog-content blockquote p{margin:0;font-size:1rem;font-weight:500;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,var(--brand) 0%,var(--accent-iris) 50%,var(--brand) 100%);background-size:200% 100%;animation:shimmer 2s ease-in-out 1}.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 var(--surface-3);background:radial-gradient(circle at top left,var(--accent-iris),var(--brand));color:var(--surface-0);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}.blog-content .code-copy-btn.copied{background:radial-gradient(circle at top left,var(--surface-1),var(--surface-3));border-color:var(--surface-3)}.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 img:hover{transform:scale(1.02);box-shadow:0 25px 50px -12px #00000040}.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%);width:2rem;height:2rem;background:var(--brand);border-radius:50%;opacity:.5}.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(--text-1);font-weight:600;background:linear-gradient(135deg,var(--brand) 0%,var(--accent-iris) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.blog-content em{font-style:italic;color:var(--text-1);font-weight:500}.blog-content>*{animation:fadeInUp .6s 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;padding:1.5rem}.blog-content ul li,.blog-content ol li{padding:.6rem .9rem .5rem 2rem}.blog-content blockquote{padding:1.5rem}.blog-content pre{padding:1.1rem 2.4rem 1.1rem 1rem}.blog-content ol li{padding:.6rem .9rem .5rem 2.45rem}.blog-content ol li:before{left:.75rem;top:.65rem;width:1.6rem;height:1.6rem;font-size:.82rem}.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}}
