.toc-wrapper[data-astro-cid-xvrfupwn]{position:relative}.toc[data-astro-cid-xvrfupwn]{top:calc(var(--header-height,64px) + 1rem);background:var(--pico-card-background-color);border:1px solid var(--pico-muted-border-color);border-radius:var(--pico-border-radius);max-width:280px;max-height:calc(100vh - var(--header-height,64px) - 3rem);padding:0;font-size:.875rem;position:sticky;overflow:hidden}.toc-title[data-astro-cid-xvrfupwn]{color:var(--brand-dark);cursor:pointer;user-select:none;align-items:center;gap:.5rem;margin:0;padding:1rem 1.5rem;font-size:1rem;font-weight:600;list-style:none;transition:background .2s;display:flex}.toc-title[data-astro-cid-xvrfupwn]:hover{background:var(--brand-light-bg)}.toc-title[data-astro-cid-xvrfupwn]::marker{content:none}.toc-icon[data-astro-cid-xvrfupwn]{color:var(--brand-primary);flex-shrink:0}.toc-content[data-astro-cid-xvrfupwn]{max-height:calc(100vh - 8rem);padding:0 1.5rem 1.5rem;overflow-y:auto}.toc-list[data-astro-cid-xvrfupwn]{margin:0;padding:0;list-style:none}.toc-item[data-astro-cid-xvrfupwn]{margin-bottom:.5rem}.toc-link[data-astro-cid-xvrfupwn]{color:var(--brand-text);border-radius:4px;padding:.4rem .5rem;text-decoration:none;transition:all .2s;display:block}.toc-link[data-astro-cid-xvrfupwn]:hover{color:var(--brand-primary);background:var(--brand-light-bg);padding-left:.75rem}.toc-link[data-astro-cid-xvrfupwn].active{color:var(--brand-primary);background:var(--brand-light-bg);font-weight:600}@media (width>=1025px){.toc[data-astro-cid-xvrfupwn]{display:block}.toc[data-astro-cid-xvrfupwn] summary[data-astro-cid-xvrfupwn]{pointer-events:none;display:block}.toc[data-astro-cid-xvrfupwn] summary[data-astro-cid-xvrfupwn]:after,.toc[data-astro-cid-xvrfupwn] summary[data-astro-cid-xvrfupwn]::marker{display:none}.toc[data-astro-cid-xvrfupwn] summary[data-astro-cid-xvrfupwn]::-webkit-details-marker{display:none}.toc-content[data-astro-cid-xvrfupwn]{display:block!important}.toc-title[data-astro-cid-xvrfupwn]{cursor:default}}@media (width<=1024px){.toc-wrapper[data-astro-cid-xvrfupwn]{margin-bottom:2rem}.toc[data-astro-cid-xvrfupwn]{max-width:100%;max-height:none;position:static}.toc-content[data-astro-cid-xvrfupwn]{max-height:400px}.toc[data-astro-cid-xvrfupwn] summary[data-astro-cid-xvrfupwn]:after{content:"";float:none;background-image:none;border-top:6px solid;border-left:5px solid #0000;border-right:5px solid #0000;width:0;height:0;margin-left:auto;transition:transform .2s;display:inline-block}.toc[data-astro-cid-xvrfupwn][open] summary[data-astro-cid-xvrfupwn]:after{transform:rotate(180deg)}.toc-title[data-astro-cid-xvrfupwn]{border-bottom:1px solid var(--pico-muted-border-color)}}[data-astro-cid-xvrfupwn][data-theme=dark] .toc[data-astro-cid-xvrfupwn]{background:#7c3aed0d}[data-astro-cid-xvrfupwn][data-theme=dark] .toc-title[data-astro-cid-xvrfupwn]:hover,[data-astro-cid-xvrfupwn][data-theme=dark] .toc-link[data-astro-cid-xvrfupwn]:hover,[data-astro-cid-xvrfupwn][data-theme=dark] .toc-link[data-astro-cid-xvrfupwn].active{background:#7c3aed26}.article-header{border-bottom:1px solid var(--pico-muted-border-color);margin-bottom:3rem;padding-bottom:2rem}.article-meta{color:var(--pico-muted-color);flex-wrap:wrap;align-items:center;gap:1rem;margin-top:1rem;font-size:.875rem;display:flex}.meta-item{align-items:center;gap:.375rem;display:flex}.meta-item svg{opacity:.7;flex-shrink:0}.article-tags{flex-wrap:wrap;gap:.5rem;margin-top:1rem;display:flex}.article-tags .tag{background:var(--brand-light-bg);color:var(--brand-primary);border-radius:1rem;padding:.25rem .75rem;font-size:.875rem;display:inline-block}.content h2{margin-top:3rem;padding-bottom:.5rem;position:relative}.content h2:after{content:"";background:linear-gradient(90deg, var(--brand-primary) 0%, var(--brand-primary-light) 50%, transparent 100%);border-radius:2px;width:10%;height:3px;position:absolute;bottom:0;left:0}.content pre{border-left:4px solid var(--brand-primary)}.content blockquote{background:var(--brand-light-bg);border-left:4px solid var(--brand-primary)}[data-theme=dark] .content blockquote{background:#7c3aed26}.related-guides{border-top:2px solid var(--pico-muted-border-color);margin-top:4rem;padding-top:3rem}.related-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;margin-top:2rem;display:grid}.related-card{background:var(--pico-card-background-color);border-radius:var(--pico-border-radius);border:1px solid var(--pico-muted-border-color);color:inherit;flex-direction:column;text-decoration:none;transition:all .3s;display:flex;overflow:hidden}.related-card:hover{border-color:var(--brand-primary);transform:translateY(-4px);box-shadow:0 12px 24px #0000001a}[data-theme=dark] .related-card:hover{box-shadow:0 12px 24px #ffffff1a}.related-image{background:var(--pico-muted-border-color);width:100%;height:150px;overflow:hidden}.related-image img{object-fit:cover;width:100%;height:100%}.related-content{padding:1.25rem}.related-content h3{color:var(--brand-primary);margin:0 0 .5rem;font-size:1.1rem}.related-content p{margin:0;font-size:.9rem;line-height:1.5}@media (width<=768px){.related-grid{grid-template-columns:1fr}}.gc-widget{max-width:var(--gc-max-width,100%);border:none;margin-block:2rem;margin-inline:auto;padding:0}.gc-caption{color:var(--pico-muted-color);text-align:center;margin-top:.6rem;font-size:.85rem}.bas-widget{width:100%;max-width:var(--gc-max-width,100%);margin-inline:auto}.bas-container[role=group]{box-shadow:none;cursor:col-resize;user-select:none;touch-action:none;border:none;border-radius:.5rem;margin:0;padding:0;display:block;position:relative;overflow:hidden}.bas-container[role=group]:focus-within{outline:2px solid var(--pico-primary,#3b82f6);outline-offset:2px}.bas-after-img{pointer-events:none;width:100%;height:auto;display:block}.bas-container .bas-before-clip{will-change:clip-path;position:absolute;inset:0}.bas-before-img{object-fit:cover;pointer-events:none;width:100%;height:100%;display:block}.bas-container .bas-label{color:#fff;letter-spacing:.03em;pointer-events:none;backdrop-filter:blur(4px);background:#00000080;border-radius:.25rem;padding:.2rem .55rem;font-size:.78rem;font-weight:700;position:absolute;bottom:.75rem}.bas-label--before{left:.75rem}.bas-label--after{right:.75rem}.bas-container .bas-slider{pointer-events:none;will-change:left;background:#ffffffe6;width:2px;position:absolute;top:0;bottom:0;transform:translate(-50%);box-shadow:0 0 6px #00000059}.bas-slider .bas-handle{cursor:grab;pointer-events:all;border-radius:50%;outline:none;width:44px;height:44px;transition:transform .1s;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 2px 10px #0000004d}.bas-slider .bas-handle:focus-visible{outline:3px solid var(--pico-primary,#3b82f6);outline-offset:3px}.bas-slider .bas-handle:active{cursor:grabbing;transform:translate(-50%,-50%)scale(1.12)}.ctc-widget{width:100%;max-width:var(--gc-max-width,100%);margin-inline:auto}.ctc-inner{border-radius:.5rem;position:relative;overflow:hidden}.ctc-before[role=button]{--pico-background-color:transparent;--pico-border-color:transparent;box-shadow:none;color:inherit;font-size:inherit;line-height:inherit;text-align:inherit;cursor:pointer;background-color:#0000;border:none;border-radius:0;outline:none;padding:0;transition:filter .25s;display:block;position:relative}.ctc-before[role=button]:hover,.ctc-before[role=button]:focus,.ctc-before[role=button]:active{--pico-background-color:transparent;--pico-border-color:transparent;box-shadow:none;background-color:#0000;border:none}.ctc-before:hover{filter:brightness(.9)}.ctc-before:focus-visible{outline:3px solid var(--pico-primary,#3b82f6);outline-offset:2px}.ctc-after{opacity:0;pointer-events:none;transition:opacity .45s cubic-bezier(.16,1,.3,1),transform .45s cubic-bezier(.16,1,.3,1);position:absolute;inset:0;transform:scale(1.04)}.ctc-widget.is-revealed .ctc-before{pointer-events:none}.ctc-widget.is-revealed .ctc-tap-icon{display:none}.ctc-widget.is-revealed .ctc-after{opacity:1;pointer-events:all;transform:scale(1)}.ctc-img{pointer-events:none;width:100%;height:auto;display:block}.ctc-after .ctc-img{object-fit:cover;height:100%}.ctc-overlay{background:#00000038;justify-content:center;align-items:center;transition:background .25s;display:flex;position:absolute;inset:0}.ctc-before[role=button]:hover .ctc-overlay{background:#00000052}.ctc-hint{-webkit-backdrop-filter:blur(8px);color:#fff;text-shadow:0 1px 3px #0006;background:#ffffff24;border:1px solid #ffffff47;border-radius:1.25rem;flex-direction:column;align-items:center;gap:.6rem;padding:.85rem 1.4rem;display:flex}.ctc-hint-text{letter-spacing:.02em;white-space:nowrap;font-size:.85rem;font-weight:700}.ctc-tap-icon{justify-content:center;align-items:center;width:42px;height:42px;display:flex;position:relative}.ctc-tap-dot{z-index:1;background:#fff;border-radius:50%;width:14px;height:14px;animation:2s ease-in-out infinite ctc-dot-pulse;display:block;position:relative;box-shadow:0 0 0 3px #ffffff59}@keyframes ctc-dot-pulse{0%,to{transform:scale(1)}50%{transform:scale(.85)}}.ctc-tap-ring{border:2px solid #ffffffb3;border-radius:50%;animation:2s ease-out infinite ctc-ring-expand;position:absolute;inset:0}.ctc-tap-ring--delay{animation-delay:1s}@keyframes ctc-ring-expand{0%{opacity:1;transform:scale(.5)}80%{opacity:.1}to{opacity:0;transform:scale(1.2)}}.ctc-badge{color:#fff;letter-spacing:.03em;pointer-events:none;backdrop-filter:blur(4px);background:#00000080;border-radius:.25rem;padding:.2rem .55rem;font-size:.78rem;font-weight:700;position:absolute;bottom:.75rem}.ctc-badge--before{left:.75rem}.ctc-badge--after{right:.75rem}.ctc-back-btn{color:#fff;cursor:pointer;backdrop-filter:blur(4px);background:#00000080;border:none;border-radius:.25rem;align-items:center;gap:.35rem;padding:.3rem .7rem;font-size:.78rem;font-weight:700;transition:background .2s;display:inline-flex;position:absolute;top:.75rem;left:.75rem}.ctc-back-btn:hover{background:#000000b8}.ctc-back-btn:focus-visible{outline-offset:2px;outline:2px solid #fff}.gc-side-by-side-images{border-radius:.5rem;grid-template-columns:1fr 1fr;gap:.5rem;display:grid;overflow:hidden}.gc-side-by-side-images img{object-fit:cover;width:100%;height:auto;display:block}@media (width<=480px){.gc-side-by-side-images{grid-template-columns:1fr}}.gc-screenshot .zoomable-img{display:block}.gc-screenshot img{border:1px solid var(--pico-muted-border-color);border-radius:.5rem;width:100%;height:auto;display:block}.gc-cta-box{text-align:center;background:linear-gradient(135deg,#5102c7 0%,#7c3aed 100%);border:none;border-radius:1.25rem;max-width:640px;margin:2.5rem auto;padding:2.5rem 2.5rem 2rem;box-shadow:0 8px 32px #5102c747}@media (width<=640px){.gc-cta-box{border-radius:.875rem;max-width:100%}}.gc-cta-box h3{color:#fff;margin-top:0;margin-bottom:.5rem;font-size:1.3rem}.gc-cta-box p{color:#ffffffe0;margin-bottom:1.5rem}.gc-cta-box a{background:#fff;border-radius:.625rem;padding:.75rem 2rem;font-weight:700;transition:background .15s,transform .15s,box-shadow .15s;display:inline-block;box-shadow:0 2px 12px #0000002e;color:var(--brand-primary,#7c3aed)!important;text-decoration:none!important}.gc-cta-box a:hover{background:#f0ebff;transform:translateY(-2px);box-shadow:0 6px 20px #00000038}[data-theme=dark] .gc-cta-box{background:linear-gradient(135deg,#3a0099 0%,#5b21b6 100%);box-shadow:0 8px 32px #3a009973}.gc-pro-tip{background:var(--brand-light-bg,#f5f3ff);border-left:3px solid var(--brand-primary,#7c3aed);border-radius:.375rem;margin:1.75rem 0;padding:.9rem 1.25rem}.gc-pro-tip:before{content:"💡 Pro tip";color:var(--brand-primary,#7c3aed);margin-bottom:.35rem;font-size:.8rem;font-weight:600;display:block}.gc-pro-tip p:last-child{margin-bottom:0}@media (prefers-reduced-motion:reduce){.bas-slider .bas-handle{transition:none}.ctc-tap-dot{animation:none}.ctc-tap-ring{opacity:0;animation:none}.ctc-after{transition:opacity .1s;transform:none!important}.ctc-widget.is-revealed .ctc-after{transform:none!important}}@media (width<=768px){.gc-widget,.bas-widget,.ctc-widget{margin-inline:0;--gc-max-width:100%!important;max-width:100%!important}.gc-screenshot{max-width:100%!important}}.zoomable-img{cursor:zoom-in;border-radius:var(--pico-border-radius);max-width:100%;display:inline-block;position:relative;overflow:hidden}.content p>.zoomable-img{display:block}.zoomable-img img{width:100%;transition:transform .3s;display:block}.zoomable-img:hover img{transform:scale(1.02)}.zoomable-img .zoom-icon{opacity:0;pointer-events:none;background:#6938efa6;border-radius:50%;justify-content:center;align-items:center;width:3rem;height:3rem;transition:opacity .2s,transform .2s;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)scale(.8)}.zoomable-img:hover .zoom-icon{opacity:1;transform:translate(-50%,-50%)scale(1)}.zoomable-img .zoom-icon svg{color:#fff;fill:currentColor;width:1.5rem;height:1.5rem}#lb-overlay[data-astro-cid-fbflauxb]{z-index:9999;backdrop-filter:blur(4px);cursor:zoom-out;background:#000000d9;justify-content:center;align-items:center;padding:1rem;display:none;position:fixed;inset:0}#lb-overlay[data-astro-cid-fbflauxb].open{display:flex}#lb-container[data-astro-cid-fbflauxb]{cursor:default;max-width:min(90vw,1200px);max-height:90vh;animation:.2s lb-in;position:relative}@keyframes lb-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}#lb-img[data-astro-cid-fbflauxb]{object-fit:contain;border-radius:var(--pico-border-radius);max-width:100%;max-height:90vh;margin:0;display:block;box-shadow:0 24px 64px #0009}#lb-close[data-astro-cid-fbflauxb]{background:var(--pico-primary);cursor:pointer;z-index:1;border:none;border-radius:50%;justify-content:center;align-items:center;width:2.5rem;height:2.5rem;padding:0;transition:background .2s,transform .2s;display:flex;position:absolute;top:-1rem;right:-1rem}#lb-close[data-astro-cid-fbflauxb]:hover{background:var(--pico-primary-hover);transform:scale(1.1)}#lb-close[data-astro-cid-fbflauxb] svg[data-astro-cid-fbflauxb]{color:#fff;fill:currentColor;pointer-events:none;width:1.25rem;height:1.25rem}.hub-back-panel[data-astro-cid-zitfi3rb]{border:1px solid var(--pico-muted-border-color);border-left:4px solid var(--pico-primary);border-radius:0 .5rem .5rem 0;flex-direction:column;gap:.5rem;margin-top:2.5rem;padding:1.25rem 1.5rem;display:flex}.hub-back-eyebrow[data-astro-cid-zitfi3rb]{text-transform:uppercase;letter-spacing:.08em;color:var(--pico-primary);font-size:.7rem;font-weight:700}.hub-back-content[data-astro-cid-zitfi3rb]{align-items:center;gap:.625rem;display:flex}.hub-back-icon[data-astro-cid-zitfi3rb] svg{width:1.375rem;height:1.375rem;color:var(--pico-primary);flex-shrink:0}.hub-back-name[data-astro-cid-zitfi3rb]{color:var(--pico-color);font-size:1.1rem;font-weight:700}.hub-back-cta[data-astro-cid-zitfi3rb]{color:var(--pico-primary);align-items:center;gap:.375rem;margin-top:.125rem;font-size:.875rem;font-weight:600;text-decoration:none;display:inline-flex}.hub-back-cta[data-astro-cid-zitfi3rb]:hover{text-decoration:underline}.hub-back-cta[data-astro-cid-zitfi3rb] svg[data-astro-cid-zitfi3rb]{transition:transform .15s}.hub-back-cta[data-astro-cid-zitfi3rb]:hover svg[data-astro-cid-zitfi3rb]{transform:translate(3px)}
