@import"https://fonts.googleapis.com/css2?family=Google+Sans+Code:ital,wght@0,300..800;1,300..800&family=Outfit:wght@100..900&display=swap";:root{--gray-0: #fbfbfb;--gray-1: #eee;--gray-2: #e4e4e7;--gray-3: #d4d4d8;--gray-4: #c8c8cf;--gray-5: #a1a1a8;--gray-6: #4e4e55;--gray-7: #323239;--gray-8: #25252b;--gray-9: #1c1c20;--gray-10: #1d1d22;--gray-11: #16161a;--gray-12: #0d0d11;--beige-0: #fdf9ee;--beige-1: #f6f0df;--beige-2: #eee8d5;--beige-25: #e5dcbd;--beige-3: #ded4b2;--beige-4: #c6ba93;--yellow: #ffce64;--theme-yellow: #ac7c14;--theme-green: #2d922d;--theme-pink: #b12d6c;--theme-lavender: #a455be;--theme-blue: #2f71b4;--color-primary: var(--theme-pink);--bg: var(--beige-0);--surface: var(--beige-1);--text: var(--gray-8);--muted: var(--gray-6);--border: var(--beige-25);--soft: var(--beige-2);--blue: var(--color-primary);--color-background-code: var(--beige-2);--color-background-blockquote: var(--beige-1);--color-background-navbar-link-active: var(--beige-2);--font-family: -apple-system, BlinkMacSystemFont, Avenir, Helvetica, Arial, sans-serif;--font-family-heading: "Outfit", -apple-system, BlinkMacSystemFont, "DM Sans", Avenir, Helvetica, Arial, sans-serif;--font-family-monospace: Menlo, "Google Sans Code", monospace;--font-family-monospace2: "Google Sans Code", monospace;--border-radius: 6px;--h1: 2.2rem;--h2: 1.8rem;--h3: 1.6rem;--h4: 1.2rem;--max-reading: 760px;--max-wide: 1120px;--shadow-elevated: 0 10px 30px rgb(15 23 42 / 12%);color-scheme:light;font-family:var(--font-family)}html.is-dark{--yellow: #ffd479;--theme-yellow: #fcdc97;--theme-green: #92d192;--theme-pink: #fa91c2;--theme-lavender: #c892e7;--theme-blue: #6ab0f3;--bg: var(--gray-9);--surface: var(--gray-11);--text: var(--gray-3);--muted: var(--gray-5);--border: var(--gray-7);--soft: var(--gray-8);--color-background-code: var(--gray-10);--color-background-blockquote: var(--gray-11);--color-background-navbar-link-active: var(--gray-7);--shadow-elevated: 0 14px 36px rgb(0 0 0 / 32%);color-scheme:dark}*{box-sizing:border-box}html{min-width:320px;background:var(--bg)}html.nav-open{overflow:hidden}body{margin:0;color:var(--text);background:var(--bg);line-height:1.7;text-rendering:optimizeLegibility}a{color:inherit;text-decoration-color:color-mix(in srgb,var(--blue),transparent 68%);text-underline-offset:.2em}a:hover{color:var(--blue);text-decoration-color:var(--blue)}img,svg{max-width:100%}button,input{font:inherit}@media screen and (min-width:600px){:root{--h1: 2.8rem;--h2: 2.3rem;--h3: 1.9rem;--h4: 1.5rem}}.container{width:min(100% - 32px,var(--max-wide));margin-inline:auto}.reading{width:min(100% - 32px,var(--max-reading));margin-inline:auto}.layout{min-height:100vh;padding-top:68px}.navbar{position:fixed;top:0;right:0;left:0;z-index:20;display:flex;flex-direction:column;align-items:center;justify-content:space-between;min-height:68px;border-bottom:1px solid color-mix(in srgb,var(--border),transparent 35%);padding:0;background:color-mix(in srgb,var(--bg),transparent 8%);backdrop-filter:blur(14px)}.navbar-title{width:100%;min-width:0;padding:0 16px}.navbar-menu{display:none;align-items:center;justify-content:center;gap:13px;color:var(--muted);font-size:14px}.navbar-menu.active{display:flex}.navbar-menu.nav-items{position:fixed;top:68px;right:0;left:0;z-index:19;height:calc(100vh - 68px);flex-direction:column;gap:14px;border-bottom:1px solid var(--border);padding-bottom:34vh;background:var(--bg)}.navbar-menu a{display:flex;align-items:center;gap:8px;border-radius:8px;padding:7px 10px;color:var(--text);font-size:18px;font-weight:650;text-decoration:none}.navbar-menu a:hover,.navbar-menu a.active{background:var(--soft);color:var(--text)}.sidebar{display:none;position:sticky;top:0;width:260px;min-width:260px;height:100vh;overflow-y:auto;border-right:1px solid var(--border);background:var(--bg);scrollbar-width:thin}.sidebar-section{margin:20px 24px;border-bottom:1px solid var(--border);padding-bottom:24px}.sidebar-section:last-child{border-bottom:0;padding-bottom:48px}.sidebar-title-link,.navbar-title-row{display:flex;align-items:center;justify-content:space-between;gap:12px;min-height:68px;color:var(--text);text-decoration:none}.navbar-actions{display:flex;flex:0 0 auto;align-items:center;justify-content:flex-end}.sidebar-brand{min-width:0}.site-name{color:var(--text);font-size:18px;font-family:var(--font-family-heading);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-section h2{margin:0 0 12px;color:var(--text);font-size:17px;font-weight:720}.sidebar-content p{margin:0;color:var(--muted);font-size:15px;line-height:1.65}.sidebar-nav-links{display:flex;flex-direction:column;gap:2px;margin-left:-8px;margin-right:-8px}.sidebar-nav-links a{display:flex;align-items:center;gap:8px;overflow:hidden;border-radius:8px;padding:4px 8px;color:var(--text);font-size:16px;font-weight:500;text-decoration:none;text-overflow:ellipsis;white-space:nowrap}.sidebar-nav-links a:hover,.sidebar-nav-links a.active{background:var(--soft);color:var(--text)}.nav-icon{width:20px;height:20px;flex:0 0 auto}.sidebar-links{display:flex;flex-direction:column;align-items:flex-start;gap:6px;margin:0}.sidebar-links a,.sidebar-content a{color:var(--text);font-size:14px;font-weight:650;text-decoration:underline;text-decoration-color:var(--text);text-decoration-style:dotted;text-decoration-thickness:2px;text-underline-offset:4px}.sidebar-links a:hover,.sidebar-content a:hover{color:var(--blue);text-decoration-color:var(--blue)}.main-wrapper{min-height:calc(100vh - 68px)}.main-container{min-width:0}.main-content{flex-grow:1;max-width:calc(var(--max-reading) + 260px);margin-right:auto;margin-left:auto;padding:24px}.main-content.page{max-width:1020px}.brand{display:inline-flex;align-items:center;gap:10px;font-weight:760;letter-spacing:0;text-decoration:none}.brand-icon{display:inline-flex;flex:0 0 auto;align-items:center;justify-content:center}.navbar-logo{width:16px;height:16px;margin:0}.theme-controls{display:flex;flex:0 0 auto;align-items:center}button.navbar-button{display:flex;width:38px;height:38px;align-items:center;justify-content:center;border:1px solid transparent;border-radius:8px;padding:8px;background:transparent;box-shadow:none;color:var(--muted);cursor:pointer}button.navbar-button:hover{border-color:transparent;background:var(--soft);color:var(--text)}button.navbar-button.active,button.navbar-button.active:hover{border-color:var(--blue);background:var(--soft);box-shadow:0 0 0 1px var(--blue);color:var(--blue)}.theme-icon,.menu-icon{width:22px;height:22px}.menu-icon-close,.nav-menu-button.active .menu-icon-open{display:none}.nav-menu-button.active .menu-icon-close{display:block}.theme-icon-sun,html.is-dark .theme-icon-moon{display:none}html.is-dark .theme-icon-sun{display:block}.circle{display:block;width:18px;height:18px;border-radius:999px;background:var(--blue)}.dropdown{position:relative}.dropdown-results{position:absolute;top:calc(100% + 8px);right:0;z-index:30;border:1px solid var(--border);border-radius:8px;padding:7px;background:var(--surface);box-shadow:var(--shadow-elevated)}.dropdown-results[hidden]{display:none}.circles{display:flex;gap:4px}.dropdown-option{display:flex;width:32px;height:32px;align-items:center;justify-content:center;border:1px solid transparent;border-radius:8px;padding:0;background:transparent;cursor:pointer}.dropdown-option:hover{background:var(--soft)}.tooltip-container{position:relative}.tooltip{position:absolute;bottom:-40px;left:50%;z-index:40;display:block;border:1px solid var(--border);border-radius:8px;padding:6px 12px;background:var(--surface);box-shadow:var(--shadow-elevated);color:var(--text);font-size:13px;font-weight:650;line-height:1.2;opacity:0;pointer-events:none;transform:translate(-50%);transition:opacity .2s ease;white-space:nowrap}.tooltip-container:hover .tooltip{opacity:1}button.navbar-button.active+.dropdown-results+.tooltip{opacity:0}.lang-link{border:1px solid var(--border);border-radius:999px;padding:3px 10px;background:var(--surface);color:var(--text)!important;font-weight:680}.hero{padding:74px 0 48px}.hero.hero-index{margin-bottom:40px;padding:0}.hero.hero-index h1{margin:0 0 24px;font-size:2.2rem;font-weight:700;line-height:1.2}.hero-wrapper{display:flex;flex-direction:column-reverse;align-items:flex-start;gap:8px}.hero-description{max-width:600px;margin:0 0 20px;color:var(--text);font-size:1.1rem;line-height:1.6}.hero-image-container{position:relative}.hero-image{display:block;width:100px;max-width:100px}.large-links{display:flex;flex-wrap:wrap;gap:12px;margin:20px 0 0}.large-link,a.large-link{color:var(--blue);font-size:1.1rem;font-weight:700;text-decoration:underline;text-decoration-color:var(--text);text-decoration-style:dotted;text-decoration-thickness:2px;text-underline-offset:6px}.large-link:hover,a.large-link:hover{background:var(--color-background-navbar-link-active);color:var(--blue);text-decoration-color:var(--text)}.heading{gap:8px;margin-bottom:32px}.heading h2{display:flex;align-items:center;gap:16px;margin:0 0 12px}.heading-icon{width:28px;height:28px}.heading .description{color:var(--muted);font-size:1.2rem}.section-index{margin-bottom:16px;padding-bottom:32px}.eyebrow{margin:0 0 16px;color:var(--blue);font-size:13px;font-weight:720;text-transform:uppercase}h1,h2,h3{margin:0;color:var(--text);font-family:var(--font-family-heading);line-height:1.18;letter-spacing:0}h1{max-width:850px;font-size:clamp(38px,7vw,72px)}h2{font-size:clamp(25px,4vw,36px)}h3{font-size:20px}.lead{max-width:760px;margin:22px 0 0;color:var(--muted);font-size:clamp(18px,2vw,21px)}.actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:30px}.button{display:inline-flex;min-height:42px;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:8px;padding:9px 15px;background:var(--surface);color:var(--text);font-weight:680;text-decoration:none}.button.primary{border-color:transparent;background:var(--blue);color:#fff}.section{padding:34px 0}.section-head{display:flex;align-items:end;justify-content:space-between;gap:18px;margin-bottom:22px}.section-head p{max-width:620px;margin:8px 0 0;color:var(--muted)}.more-link{flex:0 0 auto;color:var(--blue);font-weight:680;text-decoration:none}.article-list{display:grid;gap:18px}.article-card{display:block;border-top:1px solid var(--border);padding:20px 0;text-decoration:none}.article-card:first-child{border-top:0}.article-card h3{margin-bottom:8px}.article-meta{display:flex;flex-wrap:wrap;gap:10px;color:var(--muted);font-size:14px}.article-card p{max-width:820px;margin:8px 0 0;color:var(--muted)}.tag-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.tag{border:1px solid color-mix(in srgb,var(--blue),transparent 78%);border-radius:999px;padding:3px 9px;color:color-mix(in srgb,var(--blue),#111827 18%);background:color-mix(in srgb,var(--blue),transparent 95%);font-size:12px;font-weight:650}.product-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.product-card{display:flex;min-height:260px;flex-direction:column;border:2px solid var(--border);border-radius:var(--border-radius);padding:20px;background:var(--surface);box-shadow:var(--shadow-elevated);text-decoration:none}.product-card:hover{border-color:var(--blue)}.product-card p{margin:10px 0 0;color:var(--muted)}.product-price{margin-top:auto;padding-top:18px;font-size:24px;font-weight:760}.status{width:fit-content;border-radius:999px;padding:3px 9px;color:#fff;background:var(--blue);font-size:12px;font-weight:700;text-transform:capitalize}.newsletter{border-top:1px solid var(--border);padding:48px 0}.newsletter-box{display:grid;grid-template-columns:1fr auto;gap:22px;align-items:center}.newsletter p{margin:8px 0 0;color:var(--muted)}.site-footer{border-top:1px solid var(--border);padding:34px 0;color:var(--muted);font-size:14px}.footer-inner{width:min(100% - 32px,var(--max-wide));margin-inline:auto;display:flex;flex-wrap:wrap;justify-content:space-between;gap:18px}.footer-links{display:flex;flex-wrap:wrap;gap:14px}.article-shell{--article-bg: var(--bg);--article-bg-soft: var(--color-background-blockquote);--article-bg-code: var(--color-background-code);--article-border: var(--border);--article-border-strong: var(--border);--article-text: var(--text);--article-text-strong: var(--text);--article-muted: var(--muted);--article-primary: var(--blue);--article-radius: var(--border-radius);--article-font: var(--font-family);--article-heading-font: var(--font-family-heading);--article-mono: var(--font-family-monospace);display:grid;grid-template-columns:minmax(0,760px);gap:32px;width:min(100% - 48px,1084px);margin-inline:auto;padding:32px 0 76px;color:var(--article-text);font-family:var(--article-font)}.article-main{min-width:0}.article-page{max-width:760px}.article-hero{margin-bottom:48px}.article-hero h1{max-width:760px;margin:8px 0 16px;color:var(--article-text-strong);font-family:var(--article-heading-font);font-size:var(--h1);font-weight:700;line-height:1.1}.article-meta a{color:var(--article-muted);font-weight:500;text-decoration:underline;text-decoration-color:var(--article-text);text-decoration-style:dotted;text-decoration-thickness:2px;text-underline-offset:4px}.article-meta a:hover{background:var(--color-background-navbar-link-active);color:var(--article-text-strong)}.divider{width:2px;height:12px;align-self:center;background:var(--article-border)}.article-hero .tag{border-color:var(--article-border-strong);border-radius:999px;padding:4px 8px;background:var(--article-bg-code);color:var(--article-text);font-size:13px;font-weight:600}.article-hero .tag:hover{border-color:var(--article-primary);color:var(--article-primary)}.comments{border-top:1px solid var(--article-border);margin-top:48px;padding-top:30px;scroll-margin-top:88px}.comments h2{color:var(--article-text-strong);font-family:var(--article-heading-font);font-size:24px}.comments p{margin:8px 0 16px;color:var(--article-muted);font-size:14px}.prose{color:var(--article-text);font-size:16px;line-height:1.6}.prose p,.prose ul,.prose ol,.prose blockquote,.prose pre,.prose table{margin:1.25rem 0}.prose p,.prose li,.prose blockquote,.prose table{-webkit-font-smoothing:antialiased}.prose ul,.prose ol{padding-left:1.15rem}.prose li{margin:.38rem 0;line-height:1.65}.prose h2,.prose h3,.prose h4{color:var(--article-text-strong);font-family:var(--article-heading-font);line-height:1.3;scroll-margin-top:32px}.prose h2:not(:first-child),.prose h3:not(:first-child),.prose h4:not(:first-child){margin-top:3rem}.prose h2+h3,.prose h3+h4{margin-top:0!important}.prose h2{border-bottom:1px solid var(--article-border);padding-bottom:.5rem;font-size:var(--h2);font-weight:600}.prose h3{color:var(--article-muted);font-size:var(--h3);font-weight:500}.prose h4{font-size:var(--h4);font-weight:600}.main-article a{border-radius:4px;color:var(--article-primary);font-weight:600;text-decoration:underline;text-decoration-color:var(--article-text);text-decoration-style:dotted;text-decoration-thickness:2px;text-underline-offset:4px}.main-article a:hover{background:var(--color-background-navbar-link-active);color:var(--article-primary);text-decoration-color:var(--article-text-strong)}.prose code{border:0;border-radius:5px;padding:.12em .32em;background:var(--article-bg-code);font-family:var(--article-mono);font-size:.88em}.prose pre{overflow-x:auto;border:1px solid var(--article-border);border-radius:var(--article-radius);padding:18px;background:var(--article-bg-code)}.prose pre code{border:0;padding:0;background:transparent}.prose blockquote{border-left:4px solid var(--article-primary);border-top-right-radius:var(--article-radius);border-bottom-right-radius:var(--article-radius);margin-left:0;padding:1rem 1.25rem;background:var(--color-background-blockquote);color:var(--article-text-strong);font-size:1rem;font-weight:400;line-height:1.6}.prose blockquote>*:first-child{margin-top:0}.prose blockquote>*:last-child{margin-bottom:0}.prose table{display:block;overflow-x:auto;border-collapse:collapse}.prose th,.prose td{border:1px solid var(--article-border);padding:8px 10px}.prose th{background:var(--article-bg-code);font-weight:720}.post-sidebar{display:none}.post-sidebar-content{position:sticky;top:0;width:260px;padding-top:170px}.post-sidebar-section{border-bottom:1px solid var(--article-border);padding-left:16px}.post-sidebar-card{max-height:calc(100vh - 68px);overflow-y:auto;scrollbar-width:none}.post-sidebar-card h2{margin:0 0 12px 12px;color:var(--article-text-strong);font-family:var(--article-heading-font);font-size:17px;font-weight:600}.table-of-contents ul{margin:0;padding:0}.table-of-contents li{list-style:none;line-height:1.2}.table-of-contents a{display:block;overflow:hidden;border-radius:var(--article-radius);padding:6px 12px;color:var(--article-muted);font-size:14px;font-weight:500;line-height:1;text-decoration:none;text-overflow:ellipsis;white-space:nowrap}.table-of-contents a:hover{background:var(--color-background-navbar-link-active);color:var(--article-text-strong)}.table-of-contents a.active{background:var(--color-background-navbar-link-active);color:var(--article-primary)}.table-of-contents ul ul a{border-left:1px solid var(--article-border);border-top-left-radius:0;border-bottom-left-radius:0;margin-left:32px}.table-of-contents ul ul a.active{border-color:var(--article-primary)}.page-title{padding:48px 0 24px}@media(max-width:799px){.hero{padding-top:46px}.section-head,.newsletter-box{align-items:start;grid-template-columns:1fr;flex-direction:column}.product-grid{grid-template-columns:1fr}.prose{font-size:16px}}@media(min-width:800px){.hero.hero-index{margin-top:32px;margin-bottom:64px}.hero.hero-index h1{font-size:3rem}.hero-description{font-size:1.2rem}.hero-wrapper{flex-direction:row;gap:48px}.hero-image-container{margin-top:64px}.hero-image-container:before{position:absolute;top:16px;left:0;width:200px;height:200px;border-radius:50%;background:var(--blue);content:""}.hero-image{position:relative;z-index:1;width:250px;max-width:250px}.layout{display:grid;grid-template-columns:260px minmax(0,1fr);max-width:1440px;margin:0 auto;padding-top:0}.navbar{display:none}.sidebar{display:block}.main-wrapper{min-height:100vh}.site-footer{padding-right:24px;padding-left:24px}.footer-inner{width:100%}}@media(min-width:1360px){.article-shell{grid-template-columns:minmax(0,var(--max-reading)) 260px;justify-content:center;align-items:start}.post-sidebar{display:block}}@media(min-width:800px){.prose{font-size:1.05rem}.prose blockquote{margin:2rem 0;padding:1rem 1.5rem}}
