@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600&display=swap";header-component:where(.astro-b5wftkml){transition:padding .3s,transform .3s,margin-inline .3s,border .15s,background-color .15s;&.not-top{--un-border-opacity: 1;border-color:hsl(var(--border) / var(--un-border-opacity));--un-bg-opacity: 1;background-color:hsl(var(--background) / var(--un-bg-opacity));padding-left:.375rem;padding-right:.375rem;box-shadow:#fff 0 0,#18181b14 0 0 0 1px,#27272a14 0 10px 15px -3px,#27272a14 0 4px 6px -4px}&[data-show=false]:not(.expanded){transform:translateY(-5rem)}}@media(min-width:800px){header-component:where(.astro-b5wftkml).not-top{margin-inline:8%}}.dark header-component:where(.astro-b5wftkml).not-top{background-color:hsl(var(--muted) / var(--un-bg-opacity))}@media(max-width:640px){#headerExpandContent:where(.astro-b5wftkml){grid-template-rows:0fr;visibility:hidden;pointer-events:none;transition:opacity .3s,padding .3s,border-color .15s,grid-template-rows .3s,visibility .3s}.expanded:where(.astro-b5wftkml) #headerExpandContent:where(.astro-b5wftkml){grid-template-rows:1fr;visibility:visible;pointer-events:auto}.expanded:where(.astro-b5wftkml).not-top #headerExpandContent:where(.astro-b5wftkml){box-shadow:#fff 0 0,#18181b14 0 0 0 1px,#27272a14 0 10px 15px -3px,#27272a14 0 4px 6px -4px}header-component:where(.astro-b5wftkml) #headerExpandContent:where(.astro-b5wftkml):after{box-sizing:content-box;content:"";position:absolute;inset-inline:calc(-1rem - 1px);bottom:0;top:-5rem;z-index:-1;transition:.3s;visibility:hidden;opacity:0;border-bottom:1px solid transparent}header-component:where(.astro-b5wftkml):not(.not-top).expanded #headerExpandContent:where(.astro-b5wftkml):after{visibility:visible;bottom:-1rem;opacity:1;background-color:hsl(var(--muted) / var(--un-bg-opacity, 1));border-bottom-color:hsl(var(--border) / var(--un-border-opacity, 1))}}#toggleDarkMode:where(.astro-b5wftkml){&[data-theme=dark]{.system:where(.astro-b5wftkml){display:none}.dark:where(.astro-b5wftkml){display:block}}&[data-theme=light]{.system:where(.astro-b5wftkml){display:none}.light{display:block}}}body{font-family:var(--font-satoshi)}:root{--font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-heading: "Inter", sans-serif;--font-mono: "JetBrains Mono", "Courier New", monospace}body{font-family:var(--font-body);font-weight:400;letter-spacing:-.011em;overflow-x:hidden;width:100%}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:700;letter-spacing:-.02em}code{font-family:var(--font-mono)}@keyframes fade-in-up{0%{transform:translateY(2rem);opacity:0}to{transform:translateY(0);opacity:1}}.animate{opacity:0;animation:.3s fade-in-up;animation-fill-mode:forwards}@media(prefers-reduced-motion){.animate{opacity:0;animation:.1s fade-in-up;animation-fill-mode:forwards}}#content-header{animation-delay:50ms}#content{animation-delay:.1s}#sidebar{animation-delay:.15s}span.katex-display{overflow-y:scroll;padding:.5rem}.katex-html{overflow:auto hidden;padding:3px}.katex-html .base{margin-block:0;margin-inline:auto}.katex-html .tag{position:relative!important;display:inline-block;padding-inline-start:.5rem}.astro-code{margin-top:.5rem;margin-bottom:.5rem;border-radius:.75rem;background-color:hsl(var(--muted) / var(--un-bg-opacity, 1))!important;display:flex;flex-direction:column;& pre{margin:0;padding-top:.85rem;padding-bottom:.85rem;padding-inline:0;background:none;overflow-x:auto;max-width:100%;& code{display:block;width:fit-content;min-width:100%;min-height:1.5rem;counter-reset:step;counter-increment:step 0;&:before{position:absolute;inset-inline-start:0;width:2.75rem;top:.8571429em;bottom:0;content:"";display:block;background-color:hsl(var(--muted) / var(--un-bg-opacity, 1));z-index:1}.line{padding-inline-end:3rem;&:before{position:sticky;content:counter(step);counter-increment:step;color:hsl(var(--muted-foreground) / .6);background-color:hsl(var(--muted) / var(--un-bg-opacity, 1));inset-inline-start:0;justify-content:end;display:inline-flex;width:2rem;padding-inline-end:.75rem;box-sizing:content-box;z-index:2}&:last-child:empty,&:last-child:has(>span:empty:only-child){display:none}}}}}.dark{.astro-code pre span{color:var(--shiki-dark)!important}}@media(max-width:479px){body{font-size:15px}.post-preview{margin-bottom:.5rem}a,button{min-height:44px;display:inline-flex;align-items:center}h1{font-size:1.75rem!important;line-height:1.2}h2{font-size:1.375rem}.glass-card{padding:1rem}}@media(min-width:480px)and (max-width:639px){body{font-size:15px}h1{font-size:2rem!important}}@media(min-width:640px)and (max-width:767px){.blog-grid{gap:1.5rem}}@media(hover:none)and (pointer:coarse){.post-preview a{-webkit-tap-highlight-color:transparent}.tag-list a,nav a{padding:.5rem .75rem;min-height:44px}}@media(max-width:639px){.pagination{flex-direction:column;gap:.75rem}.pagination a{width:100%;justify-content:center;padding:.875rem 1rem;min-height:48px}}details summary{-webkit-tap-highlight-color:transparent}details summary::-webkit-details-marker{display:none}details[open] summary{margin-bottom:0}details[open]>*:not(summary){animation:details-open .2s ease-out}@keyframes details-open{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.astro-code{&:has(code){position:relative}&:has(div.title){padding-top:2rem;& code:before{top:calc(2rem + .8571429em)}}.title{position:absolute;top:0;left:0;margin:.5rem}.language{transition:opacity .3s;position:absolute;top:.75rem;right:0}& button.copy{transition:opacity .3s;opacity:0;position:absolute;top:.75rem;right:.75rem;user-select:none;.success:before{content:"Copied!";position:absolute;right:100%;top:0;bottom:0;display:flex;justify-content:center;align-items:center;font-size:.75rem;padding:.5rem;margin-right:.5rem;border-radius:.25rem;color:hsl(var(--muted-foreground) / var(--un-text-opacity, 1));background-color:hsl(var(--card) / var(--un-bg-opacity, 1));border:1px solid hsl(var(--border) / var(--un-border-opacity, 1))}&.copied{.success{display:block}.ready{display:none}}}&:hover,&:focus-within{& button.copy{opacity:1}.language{opacity:0}}.highlighted,.diff{min-width:100%;display:inline-block}.highlighted,.highlighted:before{background-color:#95a6b752!important}.diff{&.remove{background-color:#f43f5e29;&:before{background-color:#f43f5e29;content:"-"}}&.add{background-color:#10b98129;&:before{background-color:#10b98129;content:"+"}}}.collapse-toggle{z-index:3;padding:.25rem;user-select:none;display:flex;justify-content:center;align-items:center;column-gap:.3rem;box-sizing:border-box;margin:0;border-top:1px solid hsl(var(--border) / var(--un-border-opacity, 1));.desc:before{content:"Collapse"}& svg{transition:transform .2s ease;transform:rotate(180deg)}}&.collapsed{& pre{max-height:15rem;overflow:hidden}.collapse-toggle{margin:.5rem;border:1px solid hsl(var(--border) / var(--un-border-opacity, 1));.desc:before{content:"Show all"}& svg{transform:rotate(0)}}.collapse-fade{z-index:2;user-select:none;pointer-events:none;position:absolute;bottom:0;left:0;right:0;height:8rem;background:linear-gradient(to bottom,transparent 0%,hsl(var(--muted) / var(--un-bg-opacity, 1)) 60%)}}}:root{--primary: 208 40% 35%;--accent: 354 86% 70%;--highlight: 17 88% 78%;--secondary: 343 35% 59%;--tertiary: 261 15% 42%;--foreground: 222 47% 11%;--muted-foreground: 215 16% 47%;--background: 210 20% 98%;--background-alt: 210 40% 96%;--muted: 210 40% 96%;--card: 0 0% 100%;--border: 214 32% 91%;--input: 214 32% 91%;--ring: 199 89% 48%;--radius: .75rem}.dark{--primary: 208 40% 55%;--accent: 354 86% 75%;--highlight: 17 88% 85%;--secondary: 343 35% 65%;--tertiary: 261 15% 55%;--foreground: 210 40% 98%;--muted-foreground: 217 33% 70%;--background: 222 47% 11%;--background-alt: 217 33% 17%;--muted: 217 33% 17%;--card: 222 47% 15%;--border: 217 33% 23%;--input: 217 33% 20%;--ring: 199 89% 58%}:root{--un-default-border-color: hsl(var(--border) / 1)}html.dark{color-scheme:dark}a{transition:color .2s ease;&:hover{color:hsl(var(--primary) / var(--un-text-opacity, 1))}}header{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid hsl(var(--border) / .5);background:hsl(var(--background) / .8)!important;position:sticky;top:0;z-index:50;transition:all .3s ease}footer{border-top:1px solid hsl(var(--border) / .5);background:hsl(var(--background-alt) / .5);margin-top:5rem;padding-top:2rem;padding-bottom:2rem}header nav a{position:relative;font-weight:500}header nav a:after{content:"";position:absolute;bottom:-4px;left:0;width:0;height:2px;background:hsl(var(--primary));transition:width .3s ease}header nav a:hover:after{width:100%}@media(max-width:639px){header{padding-top:.5rem;padding-bottom:.5rem}header nav a{padding:.75rem .5rem;min-height:44px;font-size:.9375rem}header.scrolled{padding-top:.375rem;padding-bottom:.375rem}}@media(max-width:479px){header nav a{display:flex;width:100%;padding:.875rem 1rem;border-radius:var(--radius)}header nav a:active{background-color:hsl(var(--muted))}}@media(max-width:639px){footer{margin-top:3rem;padding-bottom:2.5rem}}@media(max-width:479px){.btn-primary,.btn-secondary{width:100%;justify-content:center;padding:1rem 1.5rem;font-size:1rem}}@keyframes gradient-shift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.animate-gradient{background-size:200% 200%;animation:gradient-shift 15s ease infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.animate-float{animation:float 3s ease-in-out infinite}.btn-primary{position:relative;background:linear-gradient(135deg,hsl(var(--primary)),hsl(var(--accent)));color:#fff;padding:.875rem 1.75rem;border-radius:var(--radius);font-weight:600;font-size:.9375rem;box-shadow:0 4px 6px -1px hsl(var(--primary) / .3),0 10px 15px -3px hsl(var(--primary) / .2);transition:all .3s cubic-bezier(.4,0,.2,1);border:none;cursor:pointer;overflow:hidden}.btn-primary:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,hsl(var(--accent)),hsl(var(--primary)));opacity:0;transition:opacity .3s}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px hsl(var(--primary) / .4),0 20px 25px -5px hsl(var(--primary) / .3)}.btn-primary:hover:before{opacity:1}.btn-primary span{position:relative;z-index:1}.btn-secondary{position:relative;background:hsl(var(--card));color:hsl(var(--foreground));padding:.875rem 1.75rem;border-radius:var(--radius);font-weight:600;font-size:.9375rem;border:2px solid hsl(var(--border));box-shadow:0 2px 4px hsl(var(--foreground) / .05);transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer}.btn-secondary:hover{transform:translateY(-2px);border-color:hsl(var(--primary));box-shadow:0 8px 16px hsl(var(--primary) / .15)}.glass-card{position:relative;background:hsl(var(--card) / .7);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid hsl(var(--border) / .5);border-radius:calc(1.5 * var(--radius));padding:1.5rem;transition:all .4s cubic-bezier(.4,0,.2,1)}.glass-card:hover{background:hsl(var(--card) / .9);border-color:hsl(var(--primary) / .6);transform:translateY(-4px);box-shadow:0 20px 25px -5px hsl(var(--primary) / .1),0 10px 10px -5px hsl(var(--primary) / .04)}.glass-card:after{content:"";position:absolute;inset:-2px;border-radius:inherit;background:linear-gradient(135deg,hsl(var(--primary) / .3),hsl(var(--accent) / .3));opacity:0;z-index:-1;transition:opacity .4s;filter:blur(20px)}.glass-card:hover:after{opacity:1}.gradient-text{background:linear-gradient(135deg,hsl(var(--primary)),hsl(var(--accent)));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.highlight-gradient{background:linear-gradient(135deg,hsl(var(--primary)),hsl(var(--accent)));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:600}@keyframes float-shapes{0%,to{transform:translate(0) rotate(0)}33%{transform:translate(50px,-50px) rotate(120deg)}66%{transform:translate(-30px,30px) rotate(240deg)}}.floating-shapes{position:fixed;inset:0;pointer-events:none;z-index:-1;overflow:hidden}.shape{position:absolute;border-radius:50%;filter:blur(80px);opacity:.3;animation:float-shapes 20s ease-in-out infinite}.shape-1{width:400px;height:400px;background:hsl(var(--primary) / .2);top:10%;left:-10%;animation-delay:0s}.shape-2{width:300px;height:300px;background:hsl(var(--accent) / .2);bottom:20%;right:-5%;animation-delay:7s}.shape-3{width:250px;height:250px;background:hsl(var(--highlight) / .15);top:50%;left:50%;animation-delay:14s}img{max-width:100%;height:auto}*{transition-property:background-color,border-color,color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}*:focus-visible{outline:2px solid hsl(var(--primary));outline-offset:2px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.highlight{--highlight-fg: color-mix( in srgb, var(--highlightColor) 40%, hsl(var(--foreground)/var(--un-text-opacity, 1)) );color:var(--highlight-fg, hsl(var(--primary) / var(--un-text-opacity)))!important}.highlight-bg{background-color:var( --highlightColor, hsl(var(--primary) / var(--un-text-opacity)) )!important}
