:root{--font-ui:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Oxygen,Ubuntu,Cantarell,"Fira Sans","Droid Sans","Helvetica Neue",sans-serif;--font-prose:"Source Serif 4",Georgia,"Times New Roman",serif;--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--color-text:#1a1a1a;--color-muted:#666;--color-link:#1f5ca8;--color-link-hover:#174a85;--color-page-bg:#f9f7ef;--color-surface:#fff;--color-border:#e6e8eb;--color-code-bg:#f6f6f6;--radius-sm:8px;--radius-md:10px;--radius-lg:14px}body,html{padding:0;margin:0;line-height:1.6;font-size:16px;color:var(--color-text);background:var(--color-page-bg)}body,h1,h2,h3,h4,html{font-family:var(--font-ui);font-weight:400}h1{font-size:26px}b,strong{font-weight:800;letter-spacing:.01em;color:var(--color-text)}footer{margin-top:30px;font-size:14px;font-weight:400;text-align:center}*{box-sizing:border-box}a{color:var(--color-link);text-decoration:none}a:hover{color:var(--color-link-hover);text-decoration:underline}img{max-width:100%;height:auto;display:block}code,pre{font-family:var(--font-mono)}code{background:var(--color-code-bg)}pre{max-width:100%;overflow-x:auto}hr{margin:20px 0}.footnote{font-size:12px;color:var(--color-text)}.twitter-tweet{margin-left:auto;margin-right:auto}.demoContainer{display:flex;justify-content:center;width:100vw;margin:20px 0;position:relative;left:50%;transform:translateX(-50%)}.demoContainer>iframe,.demoContainer>img{width:80vw;border:2px solid var(--color-border);border-radius:var(--radius-sm);box-shadow:0 2px 8px rgba(0,0,0,.1)}@media screen and (max-width:768px){.demoContainer>iframe,.demoContainer>img{width:95vw}}.imageGallery{margin:1.35rem 0;padding:.9rem;width:100%;background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-md)}.imageGalleryGrid{display:grid;grid-gap:.75rem;gap:.75rem;align-items:start}.imageGallery[data-count="1"] .imageGalleryGrid{grid-template-columns:1fr}.imageGallery[data-count="2"] .imageGalleryGrid{grid-template-columns:repeat(2,minmax(0,1fr));align-items:center}.imageGallery[data-count="2"] .imageGalleryGrid>*{align-self:center}.imageGallery[data-count="3"] .imageGalleryGrid{grid-template-columns:repeat(3,minmax(0,1fr))}.imageGallery[data-count="4"] .imageGalleryGrid{grid-template-columns:repeat(2,minmax(0,1fr))}.imageGallery:not([data-count="1"]):not([data-count="2"]):not([data-count="3"]):not([data-count="4"]) .imageGalleryGrid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.imageGalleryGrid>*{width:100%;min-width:0;display:flex;justify-content:center}.imageGallery img{width:100%;height:auto;margin:0;border-radius:var(--radius-sm);object-fit:contain}.imageGalleryCaption{margin:.6rem 0 0;text-align:center;color:var(--color-muted);font-size:.86rem;line-height:1.4}.imageGalleryCaption a{color:inherit;text-decoration:underline}@media screen and (max-width:900px){.imageGallery{padding:1rem}.imageGalleryGrid{grid-template-columns:1fr!important}}pre code.hljs{display:block;overflow-x:auto;padding:1em}code.hljs{padding:3px 5px}/*!
  Theme: StackOverflow Light
  Description: Light theme as used on stackoverflow.com
  Author: stackoverflow.com
  Maintainer: @Hirse
  Website: https://github.com/StackExchange/Stacks
  License: MIT
  Updated: 2021-05-15

  Updated for @stackoverflow/stacks v0.64.0
  Code Blocks: /blob/v0.64.0/lib/css/components/_stacks-code-blocks.less
  Colors: /blob/v0.64.0/lib/css/exports/_stacks-constants-colors.less
*/.hljs{background:#f6f6f6}.hljs,.hljs-subst{color:#2f3337}.hljs-comment{color:#656e77}.hljs-attr,.hljs-doctag,.hljs-keyword,.hljs-meta .hljs-keyword,.hljs-section,.hljs-selector-tag{color:#015692}.hljs-attribute{color:#803378}.hljs-name,.hljs-number,.hljs-quote,.hljs-selector-id,.hljs-template-tag,.hljs-type{color:#b75501}.hljs-selector-class{color:#015692}.hljs-link,.hljs-regexp,.hljs-selector-attr,.hljs-string,.hljs-symbol,.hljs-template-variable,.hljs-variable{color:#54790d}.hljs-meta,.hljs-selector-pseudo{color:#015692}.hljs-built_in,.hljs-literal,.hljs-title{color:#b75501}.hljs-bullet,.hljs-code{color:#535a60}.hljs-meta .hljs-string{color:#54790d}.hljs-deletion{color:#c02d2e}.hljs-addition{color:#2f6f44}.hljs-emphasis{font-style:italic}.hljs-strong{font-weight:700}.post_socialHeader__QSFql{margin:0;padding:0;font-weight:300}.post_mdxContent__lizt2{width:100%;margin:1rem 0}.post_mdxContent__lizt2 :where(p,li){font-family:var(--font-prose);line-height:1.72}.post_mdxContent__lizt2 :where(h1,h2,h3,h4){font-family:var(--font-ui);font-weight:600;line-height:1.22;letter-spacing:-.01em}.post_mdxContent__lizt2 h1{margin:2.2rem 0 .55rem;font-size:2rem}.post_mdxContent__lizt2 h2{margin:1.9rem 0 .5rem;font-size:1.56rem}.post_mdxContent__lizt2 h3{margin:1.45rem 0 .4rem;font-size:1.28rem}.post_mdxContent__lizt2 h4{margin:1.2rem 0 .35rem;font-size:1.08rem}.post_mdxContent__lizt2 :where(h1,h2,h3,h4)+:where(h1,h2,h3,h4){margin-top:.7rem}.post_mdxContent__lizt2 :where(h1,h2,h3,h4)+:where(p,ul,ol,blockquote){margin-top:.4rem}.post_mdxContent__lizt2 p{margin:0 0 1rem}.post_mdxContent__lizt2 :where(ul,ol){margin:0 0 1rem;padding-left:1.3rem}.post_mdxContent__lizt2 a{color:var(--color-link);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:.12em}.post_mdxContent__lizt2 a:hover{color:var(--color-link-hover)}.post_mdxBlockquote__8IWyK{margin:1.45rem 0;padding:.95rem 1rem .95rem 1.25rem;border-left:4px solid #1f2937;border-radius:var(--radius-sm);background:transparent;color:#1e2630;font-family:var(--font-prose);font-style:italic;position:relative}.post_mdxBlockquote__8IWyK:before{content:'"';position:absolute;left:.35rem;top:.2rem;font-size:1.5rem;line-height:1;color:#94a3b8;font-style:normal}.post_mdxBlockquote__8IWyK p{margin:.25rem 0}.post_mdxBlockquote__8IWyK cite{display:block;margin-top:.6rem;font-size:.92rem;color:#5f6368;font-style:normal}.post_mdxCallout__KqB9X{margin:1.35rem 0;padding:1rem 1.1rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:rgba(15,23,42,.035)}.post_mdxCallout__KqB9X :where(ol,ul){margin:0;padding-left:1.3rem}.post_mdxCallout__KqB9X li{margin-bottom:1rem}.post_mdxCallout__KqB9X li:last-child{margin-bottom:0}.post_mdxCalloutNote__JekAE{margin-top:.4rem;color:var(--color-muted);font-style:italic}.post_mdxAttribution__jiLMF{margin:.4rem 0 1.5rem;padding:.5rem .8rem;text-align:center;color:var(--color-muted);font-size:.92rem;line-height:1.45;font-style:italic;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:rgba(15,23,42,.02)}.post_postNavigation__fF6wM{display:grid;grid-template-columns:1fr auto 1fr;margin:2rem 0;padding-top:1.5rem;border-top:1px solid var(--color-border);grid-gap:1rem;gap:1rem}.post_postNavigationPrevious__TCkCp{justify-self:start}.post_postNavigationNext___ugbB{justify-self:end;text-align:right}.post_postNavigationHome__RxiWV{display:flex;justify-content:center;align-items:center}.post_postNavigationLink__qi5GI{display:flex;flex-direction:column;text-decoration:none;color:inherit;padding:.5rem .6rem;border-radius:var(--radius-sm);transition:background-color .2s}.post_postNavigationLink__qi5GI:hover{background-color:rgba(31,92,168,.06);text-decoration:none}.post_postNavigationDirection__nzEjO{font-size:.78rem;letter-spacing:.02em;color:var(--color-muted);margin-bottom:.15rem}.post_postNavigationTitle__BGmOi{font-weight:500;line-height:1.35}.post_imageContainer__nC2PR{width:100%;margin:1.2rem auto;display:flex;flex-direction:column;align-items:center;gap:.45rem}.post_imageContainerInGallery__AB6SM{margin:0;gap:.45rem}.post_landscapeImageContainer__bK4k3{max-width:100%}.post_portraitImageContainer__om4Rk{max-width:min(100%,34rem)}.post_responsiveImage__i0PXq{display:block;width:100%;height:auto;margin:0 auto;object-fit:contain;background:transparent}.post_galleryImage__G6tKl,.post_responsiveImage__i0PXq{border-radius:var(--radius-sm)}.post_imageCaption__CQ9MT{display:block;width:100%;max-width:70ch;font-size:.86rem;color:#666;text-align:center;line-height:1.4}@media (max-width:600px){.post_postNavigation__fF6wM{display:flex;flex-direction:column;gap:1rem}.post_postNavigationHome__RxiWV,.post_postNavigationNext___ugbB,.post_postNavigationPrevious__TCkCp{max-width:100%}.post_postNavigationNext___ugbB{text-align:left;align-self:flex-start}.post_imageContainer__nC2PR{margin:1.25rem auto}.post_portraitImageContainer__om4Rk{max-width:100%}}