.install-banner{touch-action:pan-y;background:0 0;flex-direction:column;justify-content:center;max-width:100vw;margin:0;padding:24px 0 0;display:flex}.install-banner__theme-split{background:linear-gradient(90deg,#f6f6f6 0 50%,#383838 50% 100%);border-radius:6px;grid-template-columns:minmax(0,1fr) minmax(0,1fr);width:100%;max-width:720px;min-height:258px;margin:16px 0;display:grid;position:relative;overflow:hidden;box-shadow:0 -1px #ffffff94,0 18px 42px #35415024}.install-banner__theme-pane{--codice-title-color:currentColor;--codice-caret-color:currentColor;min-width:0;font-size:var(--docs-code-font-size,15px);text-align:left;cursor:pointer;padding:0 16px 14px;line-height:1.5;transition:opacity .18s,background-color .18s;position:relative;overflow:hidden}.install-banner__theme-pane--light{color:#333;background:#f6f6f6}.install-banner__theme-pane--dark{color:#fff;background:#383838}.install-banner__theme-pane+.install-banner__theme-pane{border-left:1px solid #ffffff29}.install-banner__theme-pane:not(.install-banner__theme-pane--active){opacity:.78}.install-banner__theme-pane:hover,.install-banner__theme-pane:focus-visible,.install-banner__theme-pane--active{opacity:1}.install-banner__theme-pane:focus-visible{outline:2px solid var(--docs-ui-accent,#354150);outline-offset:-2px}.install-banner__theme-pane-label{height:34px;color:var(--codice-title-color);align-items:center;font-size:.78rem;font-weight:500;display:flex}.install-banner__theme-pane pre{margin:0;overflow:hidden}.install-banner__theme-copy{z-index:2;position:absolute;top:8px;right:8px}.install-banner__theme-copy .copy-button{color:#fff;background:#0000003d;border-radius:2px;justify-content:center;align-items:center;width:24px;height:24px;display:inline-flex}.install-banner__theme-copy .copy-button:hover{background:#00000057}.install-banner__code{--codice-title-color:#b0b0b0;--codice-caret-color:#ccc;font-size:var(--docs-code-font-size,15px);background-color:#383838;border-radius:4px;width:100%;max-width:600px;padding:0 16px;line-height:1.5;transition:background-color .3s,color .3s;position:relative;overflow:hidden}.install-banner__code pre{max-width:100%;overflow-x:auto}.install-banner__sample-grid{--install-banner-card-edge-spread:min(96px, 14vw);--install-banner-card-inner-spread:min(32px, 5vw);width:100%;max-width:720px;height:320px;margin:52px 0 78px;position:relative;overflow:visible}.install-banner__code.install-banner__code--sample{--install-banner-card-shift:0px;--install-banner-card-rotate:0deg;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);width:min(430px,100% - 40px);min-height:176px;transform:translateX(-50%) translateX(var(--install-banner-card-shift,0)) translateY(var(--install-banner-card-lift,0)) rotate(var(--install-banner-card-rotate,0deg));transform-origin:50% 100%;background-color:#383838e0;border:1px solid #ffffff1a;border-radius:6px;transition:background-color .3s,border-color .3s,box-shadow .22s,color .3s,transform .56s cubic-bezier(.16,1,.3,1);position:absolute;bottom:0;left:50%;box-shadow:0 -1px #ffffff14,0 12px 28px #00000029}.install-banner__sample-grid--spread .install-banner__code--sample{--install-banner-card-shift:var(--install-banner-card-final-shift,0px);--install-banner-card-rotate:var(--install-banner-card-final-rotate,0deg)}.install-banner__sample-grid .install-banner__code--sample:hover,.install-banner__sample-grid .install-banner__code--sample:focus-within{box-shadow:0 -1px #ffffff1a,0 22px 42px #00000038}.install-banner__sample-grid .install-banner__code--sample:first-child{--install-banner-card-final-shift:calc(var(--install-banner-card-edge-spread) * -1);--install-banner-card-final-rotate:-13deg;z-index:1}.install-banner__sample-grid .install-banner__code--sample:nth-child(2){--install-banner-card-final-shift:calc(var(--install-banner-card-inner-spread) * -1);--install-banner-card-final-rotate:-4deg;z-index:2}.install-banner__sample-grid .install-banner__code--sample:nth-child(3){--install-banner-card-final-shift:var(--install-banner-card-inner-spread);--install-banner-card-final-rotate:5deg;z-index:3}.install-banner__sample-grid .install-banner__code--sample:nth-child(4){--install-banner-card-final-shift:var(--install-banner-card-edge-spread);--install-banner-card-final-rotate:14deg;z-index:4}.install-banner__sample-grid .install-banner__code--sample.install-banner__code--sample-active{--install-banner-card-lift:-26px;z-index:10;box-shadow:0 -1px #ffffff1f,0 28px 52px #00000042}.install-banner__sample-grid .install-banner__code--sample.install-banner__code--sample-active:hover,.install-banner__sample-grid .install-banner__code--sample.install-banner__code--sample-active:focus-within{--install-banner-card-lift:-26px}.install-banner__code .sh__line--diff-add{background-color:#2da44e2e}.install-banner__code .sh__line--diff-remove{background-color:#cf222e2e}.install-banner__code .sh__line--diff-hunk,.install-banner__code .sh__line--diff-meta{color:var(--sh-comment)}.install-banner__code .sh__line--highlighted{background-color:#4998ff2e;transition:background-color .3s}.install-banner[data-install-theme=light] .install-banner__code{--codice-title-color:#707070;--codice-caret-color:#333;background-color:#f6f6f6}.install-banner[data-install-theme=light] .install-banner__code button{color:#333;background-color:#f6f6f6}.install-banner[data-install-theme=light] .install-banner__code button:hover{background-color:#eaeaea}.install-banner[data-install-theme=light] .install-banner__code .sh__line--highlighted{background-color:#4998ff1f}.install-banner[data-install-theme=light] .install-banner__code.install-banner__code--sample{background-color:#f6f6f6e0;border-color:#3541501a;box-shadow:0 -1px #ffffffb8,0 12px 28px #3541501f}.install-banner[data-install-theme=light] .install-banner__sample-grid .install-banner__code--sample:hover,.install-banner[data-install-theme=light] .install-banner__sample-grid .install-banner__code--sample:focus-within{box-shadow:0 -1px #ffffffd1,0 22px 42px #3541502e}.install-banner[data-install-theme=light] .install-banner__sample-grid .install-banner__code--sample.install-banner__code--sample-active{box-shadow:0 -1px #ffffffe0,0 28px 52px #35415038}.install-banner__block{width:100%;max-width:600px;color:var(--docs-ui-secondary,#5c6570);border-radius:2px;padding:8px 16px;font-size:1rem;position:relative}.install-banner__block h2{color:var(--docs-ui-primary,#354150);margin:0 0 .5rem;font-size:1.1rem;font-weight:600}.install-banner__block a{color:var(--docs-ui-link,#888)}.install-banner__block a:hover{color:var(--docs-ui-link-hover,#333)}.install-banner__code button{color:#fff;cursor:pointer;background-color:#383838;border:none;border-radius:2px;padding:4px 8px;font-size:.75rem;transition:background-color .3s,color .3s;position:absolute;top:8px;right:8px}@media screen and (max-width:640px){.install-banner{padding-top:12px}.install-banner .container-960{padding:0 12px 16px}.install-banner__theme-split{max-width:100%;min-height:224px;margin:12px 0}.install-banner__theme-pane{padding:0 8px 10px;font-size:11px}.install-banner__theme-pane-label{height:30px}.install-banner__sample-grid{--install-banner-card-edge-spread:0px;--install-banner-card-inner-spread:0px;max-width:100%;height:340px;margin-top:52px;margin-bottom:104px;overflow:visible}.install-banner__code.install-banner__code--sample{--install-banner-card-final-rotate:0deg;width:min(390px,100% - 24px)}}@media (prefers-reduced-motion:reduce){.install-banner__code.install-banner__code--sample{transition-duration:.01ms}.install-banner__sample-grid .install-banner__code--sample:hover,.install-banner__sample-grid .install-banner__code--sample:focus-within,.install-banner__sample-grid .install-banner__code--sample.install-banner__code--sample-active,.install-banner__sample-grid .install-banner__code--sample.install-banner__code--sample-active:hover,.install-banner__sample-grid .install-banner__code--sample.install-banner__code--sample-active:focus-within{--install-banner-card-lift:-8px}}
.code-animation-container{--sh-class:#2d5e9d;--sh-identifier:#354150;--sh-sign:#8996a3;--sh-property:#0550ae;--sh-entity:#249a97;--sh-jsxliterals:#6266d1;--sh-string:#00a99a;--sh-keyword:#f47067;--sh-comment:#a19595;--code-background:#f6f6f6;text-align:left;box-sizing:border-box;justify-content:center;width:100%;min-width:0;max-width:100%;display:flex}.code-block{box-sizing:border-box;border-radius:4px;width:auto;min-width:0;max-width:100%;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;line-height:1.6;position:relative;overflow:auto hidden}.code-block-hovered{opacity:1;filter:grayscale(0%)}.code-block-colored{opacity:.75;filter:grayscale();transition:opacity .3s,filter .7s}.code-block-colored.code-block-live{opacity:1;filter:grayscale(0%);overflow:hidden}.code-line{will-change:transform, opacity;white-space:pre;min-height:1.6em;font-family:inherit;font-size:.9rem;position:relative}.code-line-invisible{opacity:0;pointer-events:none;min-width:100%;display:inline-block}.code-line-encoded{color:#8996a3;width:100%;display:block;position:absolute;top:0;left:0}.code-line-colored{opacity:0;width:100%;transition:opacity .4s;display:block;position:absolute;top:0;left:0}.code-line-colored-visible{opacity:1}.code-block-colored .sh__token--class{color:var(--sh-class)}.code-block-colored .sh__token--identifier{color:var(--sh-identifier)}.code-block-colored .sh__token--sign{color:var(--sh-sign)}.code-block-colored .sh__token--property{color:var(--sh-property)}.code-block-colored .sh__token--entity{color:var(--sh-entity)}.code-block-colored .sh__token--jsxliterals{color:var(--sh-jsxliterals)}.code-block-colored .sh__token--string{color:var(--sh-string)}.code-block-colored .sh__token--keyword{color:var(--sh-keyword)}.code-block-colored .sh__token--comment{color:var(--sh-comment)}@keyframes slideUpLine{0%{transform:translateY(8px)}to{transform:translateY(0)}}
