
:root {
    --vp-c-white: #ffffff;
    --vp-c-black: #000000;
    --vp-c-neutral: var(--vp-c-black);
    --vp-c-neutral-inverse: var(--vp-c-white);
}
.dark {
    --vp-c-neutral: var(--vp-c-white);
    --vp-c-neutral-inverse: var(--vp-c-black);
}
/**
 * Colors: Palette
 *
 * The primitive colors used for accent colors. These colors are referenced
 * by functional colors such as "Text", "Background", or "Brand".
 *
 * Each colors have exact same color scale system with 3 levels of solid
 * colors with different brightness, and 1 soft color.
 *
 * - `XXX-1`: The most solid color used mainly for colored text. It must
 *   satisfy the contrast ratio against when used on top of `XXX-soft`.
 *
 * - `XXX-2`: The color used mainly for hover state of the button.
 *
 * - `XXX-3`: The color for solid background, such as bg color of the button.
 *    It must satisfy the contrast ratio with pure white (#ffffff) text on
 *    top of it.
 *
 * - `XXX-soft`: The color used for subtle background such as custom container
 *    or badges. It must satisfy the contrast ratio when putting `XXX-1` colors
 *    on top of it.
 *
 *    The soft color must be semi transparent alpha channel. This is crucial
 *    because it allows adding multiple "soft" colors on top of each other
 *    to create a accent, such as when having inline code block inside
 *    custom containers.
 * -------------------------------------------------------------------------- */

:root {
    --vp-c-gray-1: #dddde3;
    --vp-c-gray-2: #e4e4e9;
    --vp-c-gray-3: #ebebef;
    --vp-c-gray-soft: rgba(142, 150, 170, 0.14);
    --vp-c-indigo-1: #3451b2;
    --vp-c-indigo-2: #3a5ccc;
    --vp-c-indigo-3: #5672cd;
    --vp-c-indigo-soft: rgba(100, 108, 255, 0.14);
    --vp-c-purple-1: #6f42c1;
    --vp-c-purple-2: #7e4cc9;
    --vp-c-purple-3: #8e5cd9;
    --vp-c-purple-soft: rgba(159, 122, 234, 0.14);
    --vp-c-green-1: #18794e;
    --vp-c-green-2: #299764;
    --vp-c-green-3: #30a46c;
    --vp-c-green-soft: rgba(16, 185, 129, 0.14);
    --vp-c-yellow-1: #915930;
    --vp-c-yellow-2: #946300;
    --vp-c-yellow-3: #9f6a00;
    --vp-c-yellow-soft: rgba(234, 179, 8, 0.14);
    --vp-c-red-1: #b8272c;
    --vp-c-red-2: #d5393e;
    --vp-c-red-3: #e0575b;
    --vp-c-red-soft: rgba(244, 63, 94, 0.14);
    --vp-c-sponsor: #db2777;
}
.dark {
    --vp-c-gray-1: #515c67;
    --vp-c-gray-2: #414853;
    --vp-c-gray-3: #32363f;
    --vp-c-gray-soft: rgba(101, 117, 133, 0.16);
    --vp-c-indigo-1: #a8b1ff;
    --vp-c-indigo-2: #5c73e7;
    --vp-c-indigo-3: #3e63dd;
    --vp-c-indigo-soft: rgba(100, 108, 255, 0.16);
    --vp-c-purple-1: #c8abfa;
    --vp-c-purple-2: #a879e6;
    --vp-c-purple-3: #8e5cd9;
    --vp-c-purple-soft: rgba(159, 122, 234, 0.16);
    --vp-c-green-1: #3dd68c;
    --vp-c-green-2: #30a46c;
    --vp-c-green-3: #298459;
    --vp-c-green-soft: rgba(16, 185, 129, 0.16);
    --vp-c-yellow-1: #f9b44e;
    --vp-c-yellow-2: #da8b17;
    --vp-c-yellow-3: #a46a0a;
    --vp-c-yellow-soft: rgba(234, 179, 8, 0.16);
    --vp-c-red-1: #f66f81;
    --vp-c-red-2: #f14158;
    --vp-c-red-3: #b62a3c;
    --vp-c-red-soft: rgba(244, 63, 94, 0.16);
}
/**
 * Colors: Background
 *
 * - `bg`: The bg color used for main screen.
 *
 * - `bg-alt`: The alternative bg color used in places such as "sidebar",
 *   or "code block".
 *
 * - `bg-elv`: The elevated bg color. This is used at parts where it "floats",
 *   such as "dialog".
 *
 * - `bg-soft`: The bg color to slightly distinguish some components from
 *   the page. Used for things like "carbon ads" or "table".
 * -------------------------------------------------------------------------- */

:root {
    --vp-c-bg: #ffffff;
    --vp-c-bg-alt: #f6f6f7;
    --vp-c-bg-elv: #ffffff;
    --vp-c-bg-soft: #f6f6f7;
}
.dark {
    --vp-c-bg: #1b1b1f;
    --vp-c-bg-alt: #161618;
    --vp-c-bg-elv: #202127;
    --vp-c-bg-soft: #202127;
}
/**
 * Colors: Borders
 *
 * - `divider`: This is used for separators. This is used to divide sections
 *   within the same components, such as having separator on "h2" heading.
 *
 * - `border`: This is designed for borders on interactive components.
 *   For example this should be used for a button outline.
 *
 * - `gutter`: This is used to divide components in the page. For example
 *   the header and the lest of the page.
 * -------------------------------------------------------------------------- */

:root {
    --vp-c-border: #c2c2c4;
    --vp-c-divider: #e2e2e3;
    --vp-c-gutter: #e2e2e3;
}
.dark {
    --vp-c-border: #3c3f44;
    --vp-c-divider: #2e2e32;
    --vp-c-gutter: #000000;
}
/**
 * Colors: Text
 *
 * - `text-1`: Used for primary text.
 *
 * - `text-2`: Used for muted texts, such as "inactive menu" or "info texts".
 *
 * - `text-3`: Used for subtle texts, such as "placeholders" or "caret icon".
 * -------------------------------------------------------------------------- */

:root {
    --vp-c-text-1: rgba(60, 60, 67);
    --vp-c-text-2: rgba(60, 60, 67, 0.78);
    --vp-c-text-3: rgba(60, 60, 67, 0.56);
}
.dark {
    --vp-c-text-1: rgba(255, 255, 245, 0.86);
    --vp-c-text-2: rgba(235, 235, 245, 0.6);
    --vp-c-text-3: rgba(235, 235, 245, 0.38);
}
/**
 * Colors: Function
 *
 * - `default`: The color used purely for subtle indication without any
 *   special meanings attached to it such as bg color for menu hover state.
 *
 * - `brand`: Used for primary brand colors, such as link text, button with
 *   brand theme, etc.
 *
 * - `tip`: Used to indicate useful information. The default theme uses the
 *   brand color for this by default.
 *
 * - `warning`: Used to indicate warning to the users. Used in custom
 *   container, badges, etc.
 *
 * - `danger`: Used to show error, or dangerous message to the users. Used
 *   in custom container, badges, etc.
 *
 * To understand the scaling system, refer to "Colors: Palette" section.
 * -------------------------------------------------------------------------- */

:root {
    --vp-c-default-1: var(--vp-c-gray-1);
    --vp-c-default-2: var(--vp-c-gray-2);
    --vp-c-default-3: var(--vp-c-gray-3);
    --vp-c-default-soft: var(--vp-c-gray-soft);
    --vp-c-brand-1: var(--vp-c-indigo-1);
    --vp-c-brand-2: var(--vp-c-indigo-2);
    --vp-c-brand-3: var(--vp-c-indigo-3);
    --vp-c-brand-soft: var(--vp-c-indigo-soft);
    /* DEPRECATED: Use `--vp-c-brand-1` instead. */
    --vp-c-brand: var(--vp-c-brand-1);
    --vp-c-tip-1: var(--vp-c-brand-1);
    --vp-c-tip-2: var(--vp-c-brand-2);
    --vp-c-tip-3: var(--vp-c-brand-3);
    --vp-c-tip-soft: var(--vp-c-brand-soft);
    --vp-c-note-1: var(--vp-c-brand-1);
    --vp-c-note-2: var(--vp-c-brand-2);
    --vp-c-note-3: var(--vp-c-brand-3);
    --vp-c-note-soft: var(--vp-c-brand-soft);
    --vp-c-success-1: var(--vp-c-green-1);
    --vp-c-success-2: var(--vp-c-green-2);
    --vp-c-success-3: var(--vp-c-green-3);
    --vp-c-success-soft: var(--vp-c-green-soft);
    --vp-c-important-1: var(--vp-c-purple-1);
    --vp-c-important-2: var(--vp-c-purple-2);
    --vp-c-important-3: var(--vp-c-purple-3);
    --vp-c-important-soft: var(--vp-c-purple-soft);
    --vp-c-warning-1: var(--vp-c-yellow-1);
    --vp-c-warning-2: var(--vp-c-yellow-2);
    --vp-c-warning-3: var(--vp-c-yellow-3);
    --vp-c-warning-soft: var(--vp-c-yellow-soft);
    --vp-c-danger-1: var(--vp-c-red-1);
    --vp-c-danger-2: var(--vp-c-red-2);
    --vp-c-danger-3: var(--vp-c-red-3);
    --vp-c-danger-soft: var(--vp-c-red-soft);
    --vp-c-caution-1: var(--vp-c-red-1);
    --vp-c-caution-2: var(--vp-c-red-2);
    --vp-c-caution-3: var(--vp-c-red-3);
    --vp-c-caution-soft: var(--vp-c-red-soft);
}
/**
 * Typography
 * -------------------------------------------------------------------------- */

:root {
    --vp-font-family-base: 'Inter', ui-sans-serif, system-ui, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol', 'Noto Color Emoji';
    --vp-font-family-mono: ui-monospace, 'Menlo', 'Monaco', 'Consolas', 'Liberation Mono', 'Courier New', monospace;
    font-optical-sizing: auto;
}
:root:where(:lang(zh)) {
    --vp-font-family-base: 'Punctuation SC', 'Inter', ui-sans-serif, system-ui, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol', 'Noto Color Emoji';
}
/**
 * Shadows
 * -------------------------------------------------------------------------- */

:root {
    --vp-shadow-1: 0 1px 2px rgba(0, 0, 0, 0.04), 0 1px 2px rgba(0, 0, 0, 0.06);
    --vp-shadow-2: 0 3px 12px rgba(0, 0, 0, 0.07), 0 1px 4px rgba(0, 0, 0, 0.07);
    --vp-shadow-3: 0 12px 32px rgba(0, 0, 0, 0.1), 0 2px 6px rgba(0, 0, 0, 0.08);
    --vp-shadow-4: 0 14px 44px rgba(0, 0, 0, 0.12), 0 3px 9px rgba(0, 0, 0, 0.12);
    --vp-shadow-5: 0 18px 56px rgba(0, 0, 0, 0.16), 0 4px 12px rgba(0, 0, 0, 0.16);
}
/**
 * Z-indexes
 * -------------------------------------------------------------------------- */

:root {
    --vp-z-index-footer: 10;
    --vp-z-index-local-nav: 20;
    --vp-z-index-nav: 30;
    --vp-z-index-layout-top: 40;
    --vp-z-index-backdrop: 50;
    --vp-z-index-sidebar: 60;
}
@media (min-width: 960px) {
    :root {
        --vp-z-index-sidebar: 25;
    }
}
/**
 * Layouts
 * -------------------------------------------------------------------------- */

:root {
    --vp-layout-max-width: 1440px;
}
/**
 * Component: Header Anchor
 * -------------------------------------------------------------------------- */

:root {
    --vp-header-anchor-symbol: '#';
}
/**
 * Component: Code
 * -------------------------------------------------------------------------- */

:root {
    --vp-code-line-height: 1.7;
    --vp-code-font-size: 0.875em;
    --vp-code-color: var(--vp-c-brand-1);
    --vp-code-link-color: var(--vp-c-brand-1);
    --vp-code-link-hover-color: var(--vp-c-brand-2);
    --vp-code-bg: var(--vp-c-default-soft);
    --vp-code-block-color: var(--vp-c-text-2);
    --vp-code-block-bg: var(--vp-c-bg-alt);
    --vp-code-block-divider-color: var(--vp-c-gutter);
    --vp-code-lang-color: var(--vp-c-text-3);
    --vp-code-line-highlight-color: var(--vp-c-default-soft);
    --vp-code-line-number-color: var(--vp-c-text-3);
    --vp-code-line-diff-add-color: var(--vp-c-success-soft);
    --vp-code-line-diff-add-symbol-color: var(--vp-c-success-1);
    --vp-code-line-diff-remove-color: var(--vp-c-danger-soft);
    --vp-code-line-diff-remove-symbol-color: var(--vp-c-danger-1);
    --vp-code-line-warning-color: var(--vp-c-warning-soft);
    --vp-code-line-error-color: var(--vp-c-danger-soft);
    --vp-code-copy-code-border-color: var(--vp-c-divider);
    --vp-code-copy-code-bg: var(--vp-c-bg-soft);
    --vp-code-copy-code-hover-border-color: var(--vp-c-divider);
    --vp-code-copy-code-hover-bg: var(--vp-c-bg);
    --vp-code-copy-code-active-text: var(--vp-c-text-2);
    --vp-code-copy-copied-text-content: 'Copied';
    --vp-code-tab-divider: var(--vp-code-block-divider-color);
    --vp-code-tab-text-color: var(--vp-c-text-2);
    --vp-code-tab-bg: var(--vp-code-block-bg);
    --vp-code-tab-hover-text-color: var(--vp-c-text-1);
    --vp-code-tab-active-text-color: var(--vp-c-text-1);
    --vp-code-tab-active-bar-color: var(--vp-c-brand-1);
}
/**
 * Component: Button
 * -------------------------------------------------------------------------- */

:root {
    --vp-button-brand-border: transparent;
    --vp-button-brand-text: var(--vp-c-white);
    --vp-button-brand-bg: var(--vp-c-brand-3);
    --vp-button-brand-hover-border: transparent;
    --vp-button-brand-hover-text: var(--vp-c-white);
    --vp-button-brand-hover-bg: var(--vp-c-brand-2);
    --vp-button-brand-active-border: transparent;
    --vp-button-brand-active-text: var(--vp-c-white);
    --vp-button-brand-active-bg: var(--vp-c-brand-1);
    --vp-button-alt-border: transparent;
    --vp-button-alt-text: var(--vp-c-text-1);
    --vp-button-alt-bg: var(--vp-c-default-3);
    --vp-button-alt-hover-border: transparent;
    --vp-button-alt-hover-text: var(--vp-c-text-1);
    --vp-button-alt-hover-bg: var(--vp-c-default-2);
    --vp-button-alt-active-border: transparent;
    --vp-button-alt-active-text: var(--vp-c-text-1);
    --vp-button-alt-active-bg: var(--vp-c-default-1);
    --vp-button-sponsor-border: var(--vp-c-text-2);
    --vp-button-sponsor-text: var(--vp-c-text-2);
    --vp-button-sponsor-bg: transparent;
    --vp-button-sponsor-hover-border: var(--vp-c-sponsor);
    --vp-button-sponsor-hover-text: var(--vp-c-sponsor);
    --vp-button-sponsor-hover-bg: transparent;
    --vp-button-sponsor-active-border: var(--vp-c-sponsor);
    --vp-button-sponsor-active-text: var(--vp-c-sponsor);
    --vp-button-sponsor-active-bg: transparent;
}
/**
 * Component: Custom Block
 * -------------------------------------------------------------------------- */

:root {
    --vp-custom-block-font-size: 14px;
    --vp-custom-block-code-font-size: 13px;
    --vp-custom-block-info-border: transparent;
    --vp-custom-block-info-text: var(--vp-c-text-1);
    --vp-custom-block-info-bg: var(--vp-c-default-soft);
    --vp-custom-block-info-code-bg: var(--vp-c-default-soft);
    --vp-custom-block-note-border: transparent;
    --vp-custom-block-note-text: var(--vp-c-text-1);
    --vp-custom-block-note-bg: var(--vp-c-default-soft);
    --vp-custom-block-note-code-bg: var(--vp-c-default-soft);
    --vp-custom-block-tip-border: transparent;
    --vp-custom-block-tip-text: var(--vp-c-text-1);
    --vp-custom-block-tip-bg: var(--vp-c-tip-soft);
    --vp-custom-block-tip-code-bg: var(--vp-c-tip-soft);
    --vp-custom-block-important-border: transparent;
    --vp-custom-block-important-text: var(--vp-c-text-1);
    --vp-custom-block-important-bg: var(--vp-c-important-soft);
    --vp-custom-block-important-code-bg: var(--vp-c-important-soft);
    --vp-custom-block-warning-border: transparent;
    --vp-custom-block-warning-text: var(--vp-c-text-1);
    --vp-custom-block-warning-bg: var(--vp-c-warning-soft);
    --vp-custom-block-warning-code-bg: var(--vp-c-warning-soft);
    --vp-custom-block-danger-border: transparent;
    --vp-custom-block-danger-text: var(--vp-c-text-1);
    --vp-custom-block-danger-bg: var(--vp-c-danger-soft);
    --vp-custom-block-danger-code-bg: var(--vp-c-danger-soft);
    --vp-custom-block-caution-border: transparent;
    --vp-custom-block-caution-text: var(--vp-c-text-1);
    --vp-custom-block-caution-bg: var(--vp-c-caution-soft);
    --vp-custom-block-caution-code-bg: var(--vp-c-caution-soft);
    --vp-custom-block-details-border: var(--vp-custom-block-info-border);
    --vp-custom-block-details-text: var(--vp-custom-block-info-text);
    --vp-custom-block-details-bg: var(--vp-custom-block-info-bg);
    --vp-custom-block-details-code-bg: var(--vp-custom-block-info-code-bg);
}
/**
 * Component: Input
 * -------------------------------------------------------------------------- */

:root {
    --vp-input-border-color: var(--vp-c-border);
    --vp-input-bg-color: var(--vp-c-bg-alt);
    --vp-input-switch-bg-color: var(--vp-c-default-soft);
}
/**
 * Component: Nav
 * -------------------------------------------------------------------------- */

:root {
    --vp-nav-height: 64px;
    --vp-nav-bg-color: var(--vp-c-bg);
    --vp-nav-screen-bg-color: var(--vp-c-bg);
    --vp-nav-logo-height: 24px;
}
.hide-nav {
    --vp-nav-height: 0px;
}
.hide-nav .VPSidebar {
    --vp-nav-height: 22px;
}
/**
 * Component: Local Nav
 * -------------------------------------------------------------------------- */

:root {
    --vp-local-nav-bg-color: var(--vp-c-bg);
}
/**
 * Component: Sidebar
 * -------------------------------------------------------------------------- */

:root {
    --vp-sidebar-width: 272px;
    --vp-sidebar-bg-color: var(--vp-c-bg-alt);
}
/**
 * Colors Backdrop
 * -------------------------------------------------------------------------- */

:root {
    --vp-backdrop-bg-color: rgba(0, 0, 0, 0.6);
}
/**
 * Component: Home
 * -------------------------------------------------------------------------- */

:root {
    --vp-home-hero-name-color: var(--vp-c-brand-1);
    --vp-home-hero-name-background: transparent;
    --vp-home-hero-image-background-image: none;
    --vp-home-hero-image-filter: none;
}
/**
 * Component: Badge
 * -------------------------------------------------------------------------- */

:root {
    --vp-badge-info-border: transparent;
    --vp-badge-info-text: var(--vp-c-text-2);
    --vp-badge-info-bg: var(--vp-c-default-soft);
    --vp-badge-tip-border: transparent;
    --vp-badge-tip-text: var(--vp-c-tip-1);
    --vp-badge-tip-bg: var(--vp-c-tip-soft);
    --vp-badge-warning-border: transparent;
    --vp-badge-warning-text: var(--vp-c-warning-1);
    --vp-badge-warning-bg: var(--vp-c-warning-soft);
    --vp-badge-danger-border: transparent;
    --vp-badge-danger-text: var(--vp-c-danger-1);
    --vp-badge-danger-bg: var(--vp-c-danger-soft);
}
/**
 * Component: Carbon Ads
 * -------------------------------------------------------------------------- */

:root {
    --vp-carbon-ads-text-color: var(--vp-c-text-1);
    --vp-carbon-ads-poweredby-color: var(--vp-c-text-2);
    --vp-carbon-ads-bg-color: var(--vp-c-bg-soft);
    --vp-carbon-ads-hover-text-color: var(--vp-c-brand-1);
    --vp-carbon-ads-hover-poweredby-color: var(--vp-c-text-1);
}
/**
 * Component: Local Search
 * -------------------------------------------------------------------------- */

:root {
    --vp-local-search-bg: var(--vp-c-bg);
    --vp-local-search-result-bg: var(--vp-c-bg);
    --vp-local-search-result-border: var(--vp-c-divider);
    --vp-local-search-result-selected-bg: var(--vp-c-bg);
    --vp-local-search-result-selected-border: var(--vp-c-brand-1);
    --vp-local-search-highlight-bg: var(--vp-c-brand-1);
    --vp-local-search-highlight-text: var(--vp-c-neutral-inverse);
}
@media (prefers-reduced-motion: reduce) {
    *, ::before, ::after {
        animation-delay: -1ms !important;
        animation-duration: 1ms !important;
        animation-iteration-count: 1 !important;
        background-attachment: initial !important;
        scroll-behavior: auto !important;
        transition-duration: 0s !important;
        transition-delay: 0s !important;
    }
}
*, ::before, ::after {
    box-sizing: border-box;
}
html {
    line-height: 1.4;
    font-size: 16px;
    -webkit-text-size-adjust: 100%;
}
html.dark {
    color-scheme: dark;
}
body {
    margin: 0;
    width: 100%;
    min-width: 320px;
    min-height: 100vh;
    line-height: 24px;
    font-family: var(--vp-font-family-base);
    font-size: 16px;
    font-weight: 400;
    color: var(--vp-c-text-1);
    background-color: var(--vp-c-bg);
    font-synthesis: style;
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
main {
    display: block;
}
h1, h2, h3, h4, h5, h6 {
    margin: 0;
    line-height: 24px;
    font-size: 16px;
    font-weight: 400;
}
p {
    margin: 0;
}
strong, b {
    font-weight: 600;
}
/**
 * Avoid 300ms click delay on touch devices that support the `touch-action`
 * CSS property.
 *
 * In particular, unlike most other browsers, IE11+Edge on Windows 10 on
 * touch devices and IE Mobile 10-11 DON'T remove the click delay when
 * `
 <meta name="viewport" content="width=device-width">
 ` is present.
 * However, they DO support removing the click delay via
 * `touch-action: manipulation`.
 *
 * See:
 * - http://v4-alpha.getbootstrap.com/content/reboot/#click-delay-optimization-for-touch
 * - http://caniuse.com/#feat=css-touch-action
 * - http://patrickhlauke.github.io/touch/tests/results/#suppressing-300ms-delay
 */

a, area, button, [role='button'], input, label, select, summary, textarea {
    touch-action: manipulation;
}
a {
    color: inherit;
    text-decoration: inherit;
}
ol, ul {
    list-style: none;
    margin: 0;
    padding: 0;
}
blockquote {
    margin: 0;
}
pre, code, kbd, samp {
    font-family: var(--vp-font-family-mono);
}
img, svg, video, canvas, audio, iframe, embed, object {
    display: block;
}
figure {
    margin: 0;
}
img, video {
    max-width: 100%;
    height: auto;
}
button, input, optgroup, select, textarea {
    border: 0;
    padding: 0;
    line-height: inherit;
    color: inherit;
}
button {
    padding: 0;
    font-family: inherit;
    background-color: transparent;
    background-image: none;
}
button:enabled, [role='button']:enabled {
    cursor: pointer;
}
button:focus, button:focus-visible {
    outline: 1px dotted;
    outline: 4px auto -webkit-focus-ring-color;
}
button:focus:not(:focus-visible) {
    outline: none !important;
}
input:focus, textarea:focus, select:focus {
    outline: none;
}
table {
    border-collapse: collapse;
}
input {
    background-color: transparent;
}
input:-ms-input-placeholder, textarea:-ms-input-placeholder {
    color: var(--vp-c-text-3);
}
input::-ms-input-placeholder, textarea::-ms-input-placeholder {
    color: var(--vp-c-text-3);
}
input::placeholder, textarea::placeholder {
    color: var(--vp-c-text-3);
}
input::-webkit-outer-spin-button, input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}
input[type='number'] {
    -moz-appearance: textfield;
}
textarea {
    resize: vertical;
}
select {
    -webkit-appearance: none;
}
fieldset {
    margin: 0;
    padding: 0;
}
h1, h2, h3, h4, h5, h6, li, p {
    overflow-wrap: break-word;
}
vite-error-overlay {
    z-index: 9999;
}
mjx-container {
    overflow-x: auto;
}
mjx-container>svg {
    display: inline-block;
    margin: auto;
}
[class^='vpi-'], [class*=' vpi-'], .vp-icon {
    width: 1em;
    height: 1em;
}
[class^='vpi-'].bg, [class*=' vpi-'].bg, .vp-icon.bg {
    background-size: 100% 100%;
    background-color: transparent;
}
[class^='vpi-']:not(.bg), [class*=' vpi-']:not(.bg), .vp-icon:not(.bg) {
    -webkit-mask: var(--icon) no-repeat;
    mask: var(--icon) no-repeat;
    -webkit-mask-size: 100% 100%;
    mask-size: 100% 100%;
    background-color: currentColor;
    color: inherit;
}
/* internal icons - used under ISC from https://lucide.dev/ */

.vpi-align-left {
    --icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpath d='M21 6H3M15 12H3M17 18H3'/%3E%3C/svg%3E");
}
.vpi-arrow-right, .vpi-arrow-down, .vpi-arrow-left, .vpi-arrow-up {
    --icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpath d='M5 12h14M12 5l7 7-7 7'/%3E%3C/svg%3E");
}
.vpi-chevron-right, .vpi-chevron-down, .vpi-chevron-left, .vpi-chevron-up {
    --icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpath d='m9 18 6-6-6-6'/%3E%3C/svg%3E");
}
.vpi-chevron-down, .vpi-arrow-down {
    transform: rotate(90deg);
}
.vpi-chevron-left, .vpi-arrow-left {
    transform: rotate(180deg);
}
.vpi-chevron-up, .vpi-arrow-up {
    transform: rotate(-90deg);
}
.vpi-square-pen {
    --icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpath d='M12 3H5a2 2 0 0 0-2 2v14a2 2 0 0 0 2 2h14a2 2 0 0 0 2-2v-7'/%3E%3Cpath d='M18.375 2.625a2.121 2.121 0 1 1 3 3L12 15l-4 1 1-4Z'/%3E%3C/svg%3E");
}
.vpi-plus {
    --icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpath d='M5 12h14M12 5v14'/%3E%3C/svg%3E");
}
.vpi-sun {
    --icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' viewBox='0 0 24 24'%3E%3Ccircle cx='12' cy='12' r='4'/%3E%3Cpath d='M12 2v2M12 20v2M4.93 4.93l1.41 1.41M17.66 17.66l1.41 1.41M2 12h2M20 12h2M6.34 17.66l-1.41 1.41M19.07 4.93l-1.41 1.41'/%3E%3C/svg%3E");
}
.vpi-moon {
    --icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpath d='M12 3a6 6 0 0 0 9 9 9 9 0 1 1-9-9Z'/%3E%3C/svg%3E");
}
.vpi-more-horizontal {
    --icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' viewBox='0 0 24 24'%3E%3Ccircle cx='12' cy='12' r='1'/%3E%3Ccircle cx='19' cy='12' r='1'/%3E%3Ccircle cx='5' cy='12' r='1'/%3E%3C/svg%3E");
}
.vpi-languages {
    --icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpath d='m5 8 6 6M4 14l6-6 2-3M2 5h12M7 2h1M22 22l-5-10-5 10M14 18h6'/%3E%3C/svg%3E");
}
.vpi-heart {
    --icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpath d='M19 14c1.49-1.46 3-3.21 3-5.5A5.5 5.5 0 0 0 16.5 3c-1.76 0-3 .5-4.5 2-1.5-1.5-2.74-2-4.5-2A5.5 5.5 0 0 0 2 8.5c0 2.3 1.5 4.05 3 5.5l7 7Z'/%3E%3C/svg%3E");
}
.vpi-search {
    --icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' viewBox='0 0 24 24'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.3-4.3'/%3E%3C/svg%3E");
}
.vpi-layout-list {
    --icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' viewBox='0 0 24 24'%3E%3Crect width='7' height='7' x='3' y='3' rx='1'/%3E%3Crect width='7' height='7' x='3' y='14' rx='1'/%3E%3Cpath d='M14 4h7M14 9h7M14 15h7M14 20h7'/%3E%3C/svg%3E");
}
.vpi-delete {
    --icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpath d='M20 5H9l-7 7 7 7h11a2 2 0 0 0 2-2V7a2 2 0 0 0-2-2ZM18 9l-6 6M12 9l6 6'/%3E%3C/svg%3E");
}
.vpi-corner-down-left {
    --icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpath d='m9 10-5 5 5 5'/%3E%3Cpath d='M20 4v7a4 4 0 0 1-4 4H4'/%3E%3C/svg%3E");
}
:root {
    /* clipboard */
    --vp-icon-copy: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' stroke='rgba(128,128,128,1)' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' viewBox='0 0 24 24'%3E%3Crect width='8' height='4' x='8' y='2' rx='1' ry='1'/%3E%3Cpath d='M16 4h2a2 2 0 0 1 2 2v14a2 2 0 0 1-2 2H6a2 2 0 0 1-2-2V6a2 2 0 0 1 2-2h2'/%3E%3C/svg%3E");
    /* clipboard-copy */
    --vp-icon-copied: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' stroke='rgba(128,128,128,1)' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' viewBox='0 0 24 24'%3E%3Crect width='8' height='4' x='8' y='2' rx='1' ry='1'/%3E%3Cpath d='M16 4h2a2 2 0 0 1 2 2v14a2 2 0 0 1-2 2H6a2 2 0 0 1-2-2V6a2 2 0 0 1 2-2h2'/%3E%3Cpath d='m9 14 2 2 4-4'/%3E%3C/svg%3E");
}
.visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    white-space: nowrap;
    clip: rect(0 0 0 0);
    clip-path: inset(50%);
    overflow: hidden;
}
.custom-block {
    border: 1px solid transparent;
    border-radius: 8px;
    padding: 16px 16px 8px;
    line-height: 24px;
    font-size: var(--vp-custom-block-font-size);
    color: var(--vp-c-text-2);
}
.custom-block.info {
    border-color: var(--vp-custom-block-info-border);
    color: var(--vp-custom-block-info-text);
    background-color: var(--vp-custom-block-info-bg);
}
.custom-block.info a, .custom-block.info code {
    color: var(--vp-c-brand-1);
}
.custom-block.info a:hover, .custom-block.info a:hover>code {
    color: var(--vp-c-brand-2);
}
.custom-block.info code {
    background-color: var(--vp-custom-block-info-code-bg);
}
.custom-block.note {
    border-color: var(--vp-custom-block-note-border);
    color: var(--vp-custom-block-note-text);
    background-color: var(--vp-custom-block-note-bg);
}
.custom-block.note a, .custom-block.note code {
    color: var(--vp-c-brand-1);
}
.custom-block.note a:hover, .custom-block.note a:hover>code {
    color: var(--vp-c-brand-2);
}
.custom-block.note code {
    background-color: var(--vp-custom-block-note-code-bg);
}
.custom-block.tip {
    border-color: var(--vp-custom-block-tip-border);
    color: var(--vp-custom-block-tip-text);
    background-color: var(--vp-custom-block-tip-bg);
}
.custom-block.tip a, .custom-block.tip code {
    color: var(--vp-c-tip-1);
}
.custom-block.tip a:hover, .custom-block.tip a:hover>code {
    color: var(--vp-c-tip-2);
}
.custom-block.tip code {
    background-color: var(--vp-custom-block-tip-code-bg);
}
.custom-block.important {
    border-color: var(--vp-custom-block-important-border);
    color: var(--vp-custom-block-important-text);
    background-color: var(--vp-custom-block-important-bg);
}
.custom-block.important a, .custom-block.important code {
    color: var(--vp-c-important-1);
}
.custom-block.important a:hover, .custom-block.important a:hover>code {
    color: var(--vp-c-important-2);
}
.custom-block.important code {
    background-color: var(--vp-custom-block-important-code-bg);
}
.custom-block.warning {
    border-color: var(--vp-custom-block-warning-border);
    color: var(--vp-custom-block-warning-text);
    background-color: var(--vp-custom-block-warning-bg);
}
.custom-block.warning a, .custom-block.warning code {
    color: var(--vp-c-warning-1);
}
.custom-block.warning a:hover, .custom-block.warning a:hover>code {
    color: var(--vp-c-warning-2);
}
.custom-block.warning code {
    background-color: var(--vp-custom-block-warning-code-bg);
}
.custom-block.danger {
    border-color: var(--vp-custom-block-danger-border);
    color: var(--vp-custom-block-danger-text);
    background-color: var(--vp-custom-block-danger-bg);
}
.custom-block.danger a, .custom-block.danger code {
    color: var(--vp-c-danger-1);
}
.custom-block.danger a:hover, .custom-block.danger a:hover>code {
    color: var(--vp-c-danger-2);
}
.custom-block.danger code {
    background-color: var(--vp-custom-block-danger-code-bg);
}
.custom-block.caution {
    border-color: var(--vp-custom-block-caution-border);
    color: var(--vp-custom-block-caution-text);
    background-color: var(--vp-custom-block-caution-bg);
}
.custom-block.caution a, .custom-block.caution code {
    color: var(--vp-c-caution-1);
}
.custom-block.caution a:hover, .custom-block.caution a:hover>code {
    color: var(--vp-c-caution-2);
}
.custom-block.caution code {
    background-color: var(--vp-custom-block-caution-code-bg);
}
.custom-block.details {
    border-color: var(--vp-custom-block-details-border);
    color: var(--vp-custom-block-details-text);
    background-color: var(--vp-custom-block-details-bg);
}
.custom-block.details a {
    color: var(--vp-c-brand-1);
}
.custom-block.details a:hover, .custom-block.details a:hover>code {
    color: var(--vp-c-brand-2);
}
.custom-block.details code {
    background-color: var(--vp-custom-block-details-code-bg);
}
.custom-block-title {
    font-weight: 600;
}
.custom-block p+p {
    margin: 8px 0;
}
.custom-block.details summary {
    margin: 0 0 8px;
    font-weight: 700;
    cursor: pointer;
    user-select: none;
}
.custom-block.details summary+p {
    margin: 8px 0;
}
.custom-block a {
    color: inherit;
    font-weight: 600;
    text-decoration: underline;
    text-underline-offset: 2px;
    transition: opacity 0.25s;
}
.custom-block a:hover {
    opacity: 0.75;
}
.custom-block code {
    font-size: var(--vp-custom-block-code-font-size);
}
.custom-block.custom-block th, .custom-block.custom-block blockquote>p {
    font-size: var(--vp-custom-block-font-size);
    color: inherit;
}
.dark .vp-code span {
    color: var(--shiki-dark, inherit);
}
html:not(.dark) .vp-code span {
    color: var(--shiki-light, inherit);
}
.vp-code-group {
    margin-top: 16px;
}
.vp-code-group .tabs {
    position: relative;
    display: flex;
    margin-right: -24px;
    margin-left: -24px;
    padding: 0 12px;
    background-color: var(--vp-code-tab-bg);
    overflow-x: auto;
    overflow-y: hidden;
    box-shadow: inset 0 -1px var(--vp-code-tab-divider);
}
@media (min-width: 640px) {
    .vp-code-group .tabs {
        margin-right: 0;
        margin-left: 0;
        border-radius: 8px 8px 0 0;
    }
}
.vp-code-group .tabs input {
    position: fixed;
    opacity: 0;
    pointer-events: none;
}
.vp-code-group .tabs label {
    position: relative;
    display: inline-block;
    border-bottom: 1px solid transparent;
    padding: 0 12px;
    line-height: 48px;
    font-size: 14px;
    font-weight: 500;
    color: var(--vp-code-tab-text-color);
    white-space: nowrap;
    cursor: pointer;
    transition: color 0.25s;
}
.vp-code-group .tabs label::after {
    position: absolute;
    right: 8px;
    bottom: -1px;
    left: 8px;
    z-index: 1;
    height: 2px;
    border-radius: 2px;
    content: '';
    background-color: transparent;
    transition: background-color 0.25s;
}
.vp-code-group label:hover {
    color: var(--vp-code-tab-hover-text-color);
}
.vp-code-group input:checked+label {
    color: var(--vp-code-tab-active-text-color);
}
.vp-code-group input:checked+label::after {
    background-color: var(--vp-code-tab-active-bar-color);
}
.vp-code-group div[class*='language-'], .vp-block {
    display: none;
    margin-top: 0 !important;
    border-top-left-radius: 0 !important;
    border-top-right-radius: 0 !important;
}
.vp-code-group div[class*='language-'].active, .vp-block.active {
    display: block;
}
.vp-block {
    padding: 20px 24px;
}
/**
 * Headings
 * -------------------------------------------------------------------------- */

.vp-doc h1, .vp-doc h2, .vp-doc h3, .vp-doc h4, .vp-doc h5, .vp-doc h6 {
    position: relative;
    font-weight: 600;
    outline: none;
}
.vp-doc h1 {
    letter-spacing: -0.02em;
    line-height: 40px;
    font-size: 28px;
}
.vp-doc h2 {
    margin: 48px 0 16px;
    border-top: 1px solid var(--vp-c-divider);
    padding-top: 24px;
    letter-spacing: -0.02em;
    line-height: 32px;
    font-size: 24px;
}
.vp-doc h3 {
    margin: 32px 0 0;
    letter-spacing: -0.01em;
    line-height: 28px;
    font-size: 20px;
}
.vp-doc h4 {
    margin: 24px 0 0;
    letter-spacing: -0.01em;
    line-height: 24px;
    font-size: 18px;
}
.vp-doc .header-anchor {
    position: absolute;
    top: 0;
    left: 0;
    margin-left: -0.87em;
    font-weight: 500;
    user-select: none;
    opacity: 0;
    text-decoration: none;
    transition: color 0.25s, opacity 0.25s;
}
.vp-doc .header-anchor:before {
    content: var(--vp-header-anchor-symbol);
}
.vp-doc h1:hover .header-anchor, .vp-doc h1 .header-anchor:focus, .vp-doc h2:hover .header-anchor, .vp-doc h2 .header-anchor:focus, .vp-doc h3:hover .header-anchor, .vp-doc h3 .header-anchor:focus, .vp-doc h4:hover .header-anchor, .vp-doc h4 .header-anchor:focus, .vp-doc h5:hover .header-anchor, .vp-doc h5 .header-anchor:focus, .vp-doc h6:hover .header-anchor, .vp-doc h6 .header-anchor:focus {
    opacity: 1;
}
@media (min-width: 768px) {
    .vp-doc h1 {
        letter-spacing: -0.02em;
        line-height: 40px;
        font-size: 32px;
    }
}
.vp-doc h2 .header-anchor {
    top: 24px;
}
/**
 * Paragraph and inline elements
 * -------------------------------------------------------------------------- */

.vp-doc p, .vp-doc summary {
    margin: 16px 0;
}
.vp-doc p {
    line-height: 28px;
}
.vp-doc blockquote {
    margin: 16px 0;
    border-left: 2px solid var(--vp-c-divider);
    padding-left: 16px;
    transition: border-color 0.5s;
    color: var(--vp-c-text-2);
}
.vp-doc blockquote>p {
    margin: 0;
    font-size: 16px;
    transition: color 0.5s;
}
.vp-doc a {
    font-weight: 500;
    color: var(--vp-c-brand-1);
    text-decoration: underline;
    text-underline-offset: 2px;
    transition: color 0.25s, opacity 0.25s;
}
.vp-doc a:hover {
    color: var(--vp-c-brand-2);
}
.vp-doc strong {
    font-weight: 600;
}
/**
 * Lists
 * -------------------------------------------------------------------------- */

.vp-doc ul, .vp-doc ol {
    padding-left: 1.25rem;
    margin: 16px 0;
}
.vp-doc ul {
    list-style: disc;
}
.vp-doc ol {
    list-style: decimal;
}
.vp-doc li+li {
    margin-top: 8px;
}
.vp-doc li>ol, .vp-doc li>ul {
    margin: 8px 0 0;
}
/**
 * Table
 * -------------------------------------------------------------------------- */

.vp-doc table {
    display: block;
    border-collapse: collapse;
    margin: 20px 0;
    overflow-x: auto;
}
.vp-doc tr {
    background-color: var(--vp-c-bg);
    border-top: 1px solid var(--vp-c-divider);
    transition: background-color 0.5s;
}
.vp-doc tr:nth-child(2n) {
    background-color: var(--vp-c-bg-soft);
}
.vp-doc th, .vp-doc td {
    border: 1px solid var(--vp-c-divider);
    padding: 8px 16px;
}
.vp-doc th {
    text-align: left;
    font-size: 14px;
    font-weight: 600;
    color: var(--vp-c-text-2);
    background-color: var(--vp-c-bg-soft);
}
.vp-doc td {
    font-size: 14px;
}
/**
 * Decorational elements
 * -------------------------------------------------------------------------- */

.vp-doc hr {
    margin: 16px 0;
    border: none;
    border-top: 1px solid var(--vp-c-divider);
}
/**
 * Custom Block
 * -------------------------------------------------------------------------- */

.vp-doc .custom-block {
    margin: 16px 0;
}
.vp-doc .custom-block p {
    margin: 8px 0;
    line-height: 24px;
}
.vp-doc .custom-block p:first-child {
    margin: 0;
}
.vp-doc .custom-block div[class*='language-'] {
    margin: 8px 0;
    border-radius: 8px;
}
.vp-doc .custom-block div[class*='language-'] code {
    font-weight: 400;
    background-color: transparent;
}
.vp-doc .custom-block .vp-code-group .tabs {
    margin: 0;
    border-radius: 8px 8px 0 0;
}
/**
 * Code
 * -------------------------------------------------------------------------- */

/* inline code */

.vp-doc :not(pre, h1, h2, h3, h4, h5, h6)>code {
    font-size: var(--vp-code-font-size);
    color: var(--vp-code-color);
}
.vp-doc :not(pre)>code {
    border-radius: 4px;
    padding: 3px 6px;
    background-color: var(--vp-code-bg);
    transition: color 0.25s, background-color 0.5s;
}
.vp-doc a>code {
    color: var(--vp-code-link-color);
}
.vp-doc a:hover>code {
    color: var(--vp-code-link-hover-color);
}
.vp-doc h1>code, .vp-doc h2>code, .vp-doc h3>code, .vp-doc h4>code {
    font-size: 0.9em;
}
.vp-doc div[class*='language-'], .vp-block {
    position: relative;
    margin: 16px -24px;
    background-color: var(--vp-code-block-bg);
    overflow-x: auto;
    transition: background-color 0.5s;
}
@media (min-width: 640px) {
    .vp-doc div[class*='language-'], .vp-block {
        border-radius: 8px;
        margin: 16px 0;
    }
}
@media (max-width: 639px) {
    .vp-doc li div[class*='language-'] {
        border-radius: 8px 0 0 8px;
    }
}
.vp-doc div[class*='language-']+div[class*='language-'], .vp-doc div[class$='-api']+div[class*='language-'], .vp-doc div[class*='language-']+div[class$='-api']>div[class*='language-'] {
    margin-top: -8px;
}
.vp-doc [class*='language-'] pre, .vp-doc [class*='language-'] code {
    /*rtl:ignore*/
    direction: ltr;
    /*rtl:ignore*/
    text-align: left;
    white-space: pre;
    word-spacing: normal;
    word-break: normal;
    word-wrap: normal;
    -moz-tab-size: 4;
    -o-tab-size: 4;
    tab-size: 4;
    -webkit-hyphens: none;
    -moz-hyphens: none;
    -ms-hyphens: none;
    hyphens: none;
}
.vp-doc [class*='language-'] pre {
    position: relative;
    z-index: 1;
    margin: 0;
    padding: 20px 0;
    background: transparent;
    overflow-x: auto;
}
.vp-doc [class*='language-'] code {
    display: block;
    padding: 0 24px;
    width: fit-content;
    min-width: 100%;
    line-height: var(--vp-code-line-height);
    font-size: var(--vp-code-font-size);
    color: var(--vp-code-block-color);
    transition: color 0.5s;
}
.vp-doc [class*='language-'] code .highlighted {
    background-color: var(--vp-code-line-highlight-color);
    transition: background-color 0.5s;
    margin: 0 -24px;
    padding: 0 24px;
    width: calc(100% + 2 * 24px);
    display: inline-block;
}
.vp-doc [class*='language-'] code .highlighted.error {
    background-color: var(--vp-code-line-error-color);
}
.vp-doc [class*='language-'] code .highlighted.warning {
    background-color: var(--vp-code-line-warning-color);
}
.vp-doc [class*='language-'] code .diff {
    transition: background-color 0.5s;
    margin: 0 -24px;
    padding: 0 24px;
    width: calc(100% + 2 * 24px);
    display: inline-block;
}
.vp-doc [class*='language-'] code .diff::before {
    position: absolute;
    left: 10px;
}
.vp-doc [class*='language-'] .has-focused-lines .line:not(.has-focus) {
    filter: blur(0.095rem);
    opacity: 0.4;
    transition: filter 0.35s, opacity 0.35s;
}
.vp-doc [class*='language-'] .has-focused-lines .line:not(.has-focus) {
    opacity: 0.7;
    transition: filter 0.35s, opacity 0.35s;
}
.vp-doc [class*='language-']:hover .has-focused-lines .line:not(.has-focus) {
    filter: blur(0);
    opacity: 1;
}
.vp-doc [class*='language-'] code .diff.remove {
    background-color: var(--vp-code-line-diff-remove-color);
    opacity: 0.7;
}
.vp-doc [class*='language-'] code .diff.remove::before {
    content: '-';
    color: var(--vp-code-line-diff-remove-symbol-color);
}
.vp-doc [class*='language-'] code .diff.add {
    background-color: var(--vp-code-line-diff-add-color);
}
.vp-doc [class*='language-'] code .diff.add::before {
    content: '+';
    color: var(--vp-code-line-diff-add-symbol-color);
}
.vp-doc div[class*='language-'].line-numbers-mode {
    /*rtl:ignore*/
    padding-left: 32px;
}
.vp-doc .line-numbers-wrapper {
    position: absolute;
    top: 0;
    bottom: 0;
    /*rtl:ignore*/
    left: 0;
    z-index: 3;
    /*rtl:ignore*/
    border-right: 1px solid var(--vp-code-block-divider-color);
    padding-top: 20px;
    width: 32px;
    text-align: center;
    font-family: var(--vp-font-family-mono);
    line-height: var(--vp-code-line-height);
    font-size: var(--vp-code-font-size);
    color: var(--vp-code-line-number-color);
    transition: border-color 0.5s, color 0.5s;
}
.vp-doc [class*='language-']>button.copy {
    /*rtl:ignore*/
    direction: ltr;
    position: absolute;
    top: 12px;
    /*rtl:ignore*/
    right: 12px;
    z-index: 3;
    border: 1px solid var(--vp-code-copy-code-border-color);
    border-radius: 4px;
    width: 40px;
    height: 40px;
    background-color: var(--vp-code-copy-code-bg);
    opacity: 0;
    cursor: pointer;
    background-image: var(--vp-icon-copy);
    background-position: 50%;
    background-size: 20px;
    background-repeat: no-repeat;
    transition: border-color 0.25s, background-color 0.25s, opacity 0.25s;
}
.vp-doc [class*='language-']:hover>button.copy, .vp-doc [class*='language-']>button.copy:focus {
    opacity: 1;
}
.vp-doc [class*='language-']>button.copy:hover, .vp-doc [class*='language-']>button.copy.copied {
    border-color: var(--vp-code-copy-code-hover-border-color);
    background-color: var(--vp-code-copy-code-hover-bg);
}
.vp-doc [class*='language-']>button.copy.copied, .vp-doc [class*='language-']>button.copy:hover.copied {
    /*rtl:ignore*/
    border-radius: 0 4px 4px 0;
    background-color: var(--vp-code-copy-code-hover-bg);
    background-image: var(--vp-icon-copied);
}
.vp-doc [class*='language-']>button.copy.copied::before, .vp-doc [class*='language-']>button.copy:hover.copied::before {
    position: relative;
    top: -1px;
    /*rtl:ignore*/
    transform: translateX(calc(-100% - 1px));
    display: flex;
    justify-content: center;
    align-items: center;
    border: 1px solid var(--vp-code-copy-code-hover-border-color);
    /*rtl:ignore*/
    border-right: 0;
    border-radius: 4px 0 0 4px;
    padding: 0 10px;
    width: fit-content;
    height: 40px;
    text-align: center;
    font-size: 12px;
    font-weight: 500;
    color: var(--vp-code-copy-code-active-text);
    background-color: var(--vp-code-copy-code-hover-bg);
    white-space: nowrap;
    content: var(--vp-code-copy-copied-text-content);
}
.vp-doc [class*='language-']>span.lang {
    position: absolute;
    top: 2px;
    /*rtl:ignore*/
    right: 8px;
    z-index: 2;
    font-size: 12px;
    font-weight: 500;
    user-select: none;
    color: var(--vp-code-lang-color);
    transition: color 0.4s, opacity 0.4s;
}
.vp-doc [class*='language-']:hover>button.copy+span.lang, .vp-doc [class*='language-']>button.copy:focus+span.lang {
    opacity: 0;
}
/**
 * Component: Team
 * -------------------------------------------------------------------------- */

.vp-doc .VPTeamMembers {
    margin-top: 24px;
}
.vp-doc .VPTeamMembers.small.count-1 .container {
    margin: 0 !important;
    max-width: calc((100% - 24px) / 2) !important;
}
.vp-doc .VPTeamMembers.small.count-2 .container, .vp-doc .VPTeamMembers.small.count-3 .container {
    max-width: 100% !important;
}
.vp-doc .VPTeamMembers.medium.count-1 .container {
    margin: 0 !important;
    max-width: calc((100% - 24px) / 2) !important;
}
/**
 * External links
 * -------------------------------------------------------------------------- */

/* prettier-ignore */

:is(.vp-external-link-icon, .vp-doc a[href*='://'], .vp-doc a[target='_blank']):not(.no-icon)::after {
    display: inline-block;
    margin-top: -1px;
    margin-left: 4px;
    width: 11px;
    height: 11px;
    background: currentColor;
    color: var(--vp-c-text-3);
    flex-shrink: 0;
    --icon: url("data:image/svg+xml, %3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' %3E%3Cpath d='M0 0h24v24H0V0z' fill='none' /%3E%3Cpath d='M9 5v2h6.59L4 18.59 5.41 20 17 8.41V15h2V5H9z' /%3E%3C/svg%3E");
    -webkit-mask-image: var(--icon);
    mask-image: var(--icon);
}
.vp-external-link-icon::after {
    content: '';
}
/* prettier-ignore */

.external-link-icon-enabled :is(.vp-doc a[href*='://'], .vp-doc a[target='_blank'])::after {
    content: '';
    color: currentColor;
}
/**
 * VPSponsors styles are defined as global because a new class gets
 * allied in onMounted` hook and we can't use scoped style.
 */

.vp-sponsor {
    border-radius: 16px;
    overflow: hidden;
}
.vp-sponsor.aside {
    border-radius: 12px;
}
.vp-sponsor-section+.vp-sponsor-section {
    margin-top: 4px;
}
.vp-sponsor-tier {
    margin: 0 0 4px !important;
    text-align: center;
    letter-spacing: 1px !important;
    line-height: 24px;
    width: 100%;
    font-weight: 600;
    color: var(--vp-c-text-2);
    background-color: var(--vp-c-bg-soft);
}
.vp-sponsor.normal .vp-sponsor-tier {
    padding: 13px 0 11px;
    font-size: 14px;
}
.vp-sponsor.aside .vp-sponsor-tier {
    padding: 9px 0 7px;
    font-size: 12px;
}
.vp-sponsor-grid+.vp-sponsor-tier {
    margin-top: 4px;
}
.vp-sponsor-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
}
.vp-sponsor-grid.xmini .vp-sponsor-grid-link {
    height: 64px;
}
.vp-sponsor-grid.xmini .vp-sponsor-grid-image {
    max-width: 64px;
    max-height: 22px;
}
.vp-sponsor-grid.mini .vp-sponsor-grid-link {
    height: 72px;
}
.vp-sponsor-grid.mini .vp-sponsor-grid-image {
    max-width: 96px;
    max-height: 24px;
}
.vp-sponsor-grid.small .vp-sponsor-grid-link {
    height: 96px;
}
.vp-sponsor-grid.small .vp-sponsor-grid-image {
    max-width: 96px;
    max-height: 24px;
}
.vp-sponsor-grid.medium .vp-sponsor-grid-link {
    height: 112px;
}
.vp-sponsor-grid.medium .vp-sponsor-grid-image {
    max-width: 120px;
    max-height: 36px;
}
.vp-sponsor-grid.big .vp-sponsor-grid-link {
    height: 184px;
}
.vp-sponsor-grid.big .vp-sponsor-grid-image {
    max-width: 192px;
    max-height: 56px;
}
.vp-sponsor-grid[data-vp-grid='2'] .vp-sponsor-grid-item {
    width: calc((100% - 4px) / 2);
}
.vp-sponsor-grid[data-vp-grid='3'] .vp-sponsor-grid-item {
    width: calc((100% - 4px * 2) / 3);
}
.vp-sponsor-grid[data-vp-grid='4'] .vp-sponsor-grid-item {
    width: calc((100% - 4px * 3) / 4);
}
.vp-sponsor-grid[data-vp-grid='5'] .vp-sponsor-grid-item {
    width: calc((100% - 4px * 4) / 5);
}
.vp-sponsor-grid[data-vp-grid='6'] .vp-sponsor-grid-item {
    width: calc((100% - 4px * 5) / 6);
}
.vp-sponsor-grid-item {
    flex-shrink: 0;
    width: 100%;
    background-color: var(--vp-c-bg-soft);
    transition: background-color 0.25s;
}
.vp-sponsor-grid-item:hover {
    background-color: var(--vp-c-default-soft);
}
.vp-sponsor-grid-item:hover .vp-sponsor-grid-image {
    filter: grayscale(0) invert(0);
}
.vp-sponsor-grid-item.empty:hover {
    background-color: var(--vp-c-bg-soft);
}
.dark .vp-sponsor-grid-item:hover {
    background-color: var(--vp-c-white);
}
.dark .vp-sponsor-grid-item.empty:hover {
    background-color: var(--vp-c-bg-soft);
}
.vp-sponsor-grid-link {
    display: flex;
}
.vp-sponsor-grid-box {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
}
.vp-sponsor-grid-image {
    max-width: 100%;
    filter: grayscale(1);
    transition: filter 0.25s;
}
.dark .vp-sponsor-grid-image {
    filter: grayscale(1) invert(1);
}
.VPBadge {
    display: inline-block;
    margin-left: 2px;
    border: 1px solid transparent;
    border-radius: 12px;
    padding: 0 10px;
    line-height: 22px;
    font-size: 12px;
    font-weight: 500;
    transform: translateY(-2px);
}
.VPBadge.small {
    padding: 0 6px;
    line-height: 18px;
    font-size: 10px;
    transform: translateY(-8px);
}
.VPDocFooter .VPBadge {
    display: none;
}
.vp-doc h1>.VPBadge {
    margin-top: 4px;
    vertical-align: top;
}
.vp-doc h2>.VPBadge {
    margin-top: 3px;
    padding: 0 8px;
    vertical-align: top;
}
.vp-doc h3>.VPBadge {
    vertical-align: middle;
}
.vp-doc h4>.VPBadge, .vp-doc h5>.VPBadge, .vp-doc h6>.VPBadge {
    vertical-align: middle;
    line-height: 18px;
}
.VPBadge.info {
    border-color: var(--vp-badge-info-border);
    color: var(--vp-badge-info-text);
    background-color: var(--vp-badge-info-bg);
}
.VPBadge.tip {
    border-color: var(--vp-badge-tip-border);
    color: var(--vp-badge-tip-text);
    background-color: var(--vp-badge-tip-bg);
}
.VPBadge.warning {
    border-color: var(--vp-badge-warning-border);
    color: var(--vp-badge-warning-text);
    background-color: var(--vp-badge-warning-bg);
}
.VPBadge.danger {
    border-color: var(--vp-badge-danger-border);
    color: var(--vp-badge-danger-text);
    background-color: var(--vp-badge-danger-bg);
}
.VPBackdrop[data-v-a003c59d] {
    position: fixed;
    top: 0;
    /*rtl:ignore*/
    right: 0;
    bottom: 0;
    /*rtl:ignore*/
    left: 0;
    z-index: var(--vp-z-index-backdrop);
    background: var(--vp-backdrop-bg-color);
    transition: opacity 0.5s;
}
.VPBackdrop.fade-enter-from[data-v-a003c59d], .VPBackdrop.fade-leave-to[data-v-a003c59d] {
    opacity: 0;
}
.VPBackdrop.fade-leave-active[data-v-a003c59d] {
    transition-duration: .25s;
}
@media (min-width: 1280px) {
    .VPBackdrop[data-v-a003c59d] {
        display: none;
    }
}
.NotFound[data-v-b6c78616] {
    padding: 64px 24px 96px;
    text-align: center;
}
@media (min-width: 768px) {
    .NotFound[data-v-b6c78616] {
        padding: 96px 32px 168px;
    }
}
.code[data-v-b6c78616] {
    line-height: 64px;
    font-size: 64px;
    font-weight: 600;
}
.title[data-v-b6c78616] {
    padding-top: 12px;
    letter-spacing: 2px;
    line-height: 20px;
    font-size: 20px;
    font-weight: 700;
}
.divider[data-v-b6c78616] {
    margin: 24px auto 18px;
    width: 64px;
    height: 1px;
    background-color: var(--vp-c-divider);
}
.quote[data-v-b6c78616] {
    margin: 0 auto;
    max-width: 256px;
    font-size: 14px;
    font-weight: 500;
    color: var(--vp-c-text-2);
}
.action[data-v-b6c78616] {
    padding-top: 20px;
}
.link[data-v-b6c78616] {
    display: inline-block;
    border: 1px solid var(--vp-c-brand-1);
    border-radius: 16px;
    padding: 3px 16px;
    font-size: 14px;
    font-weight: 500;
    color: var(--vp-c-brand-1);
    transition: border-color 0.25s, color 0.25s;
}
.link[data-v-b6c78616]:hover {
    border-color: var(--vp-c-brand-2);
    color: var(--vp-c-brand-2);
}
.root[data-v-baf05117] {
    position: relative;
    z-index: 1;
}
.nested[data-v-baf05117] {
    padding-right: 16px;
    padding-left: 16px;
}
.outline-link[data-v-baf05117] {
    display: block;
    line-height: 32px;
    font-size: 14px;
    font-weight: 400;
    color: var(--vp-c-text-2);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    transition: color 0.5s;
}
.outline-link[data-v-baf05117]:hover, .outline-link.active[data-v-baf05117] {
    color: var(--vp-c-text-1);
    transition: color 0.25s;
}
.outline-link.nested[data-v-baf05117] {
    padding-left: 13px;
}
.VPDocAsideOutline[data-v-778bae50] {
    display: none;
}
.VPDocAsideOutline.has-outline[data-v-778bae50] {
    display: block;
}
.content[data-v-778bae50] {
    position: relative;
    border-left: 1px solid var(--vp-c-divider);
    padding-left: 16px;
    font-size: 13px;
    font-weight: 500;
}
.outline-marker[data-v-778bae50] {
    position: absolute;
    top: 32px;
    left: -1px;
    z-index: 0;
    opacity: 0;
    width: 2px;
    border-radius: 2px;
    height: 18px;
    background-color: var(--vp-c-brand-1);
    transition: top 0.25s cubic-bezier(0, 1, 0.5, 1), background-color 0.5s, opacity 0.25s;
}
.outline-title[data-v-778bae50] {
    line-height: 32px;
    font-size: 14px;
    font-weight: 600;
}
.VPDocAside[data-v-d156f047] {
    display: flex;
    flex-direction: column;
    flex-grow: 1;
}
.spacer[data-v-d156f047] {
    flex-grow: 1;
}
.VPDocAside[data-v-d156f047] .spacer+.VPDocAsideSponsors, .VPDocAside[data-v-d156f047] .spacer+.VPDocAsideCarbonAds {
    margin-top: 24px;
}
.VPDocAside[data-v-d156f047] .VPDocAsideSponsors+.VPDocAsideCarbonAds {
    margin-top: 16px;
}
.VPLastUpdated[data-v-d1f71dd0] {
    line-height: 24px;
    font-size: 14px;
    font-weight: 500;
    color: var(--vp-c-text-2);
}
@media (min-width: 640px) {
    .VPLastUpdated[data-v-d1f71dd0] {
        line-height: 32px;
        font-size: 14px;
        font-weight: 500;
    }
}
.VPDocFooter[data-v-43384334] {
    margin-top: 64px;
}
.edit-info[data-v-43384334] {
    padding-bottom: 18px;
}
@media (min-width: 640px) {
    .edit-info[data-v-43384334] {
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding-bottom: 14px;
    }
}
.edit-link-button[data-v-43384334] {
    display: flex;
    align-items: center;
    border: 0;
    line-height: 32px;
    font-size: 14px;
    font-weight: 500;
    color: var(--vp-c-brand-1);
    transition: color 0.25s;
}
.edit-link-button[data-v-43384334]:hover {
    color: var(--vp-c-brand-2);
}
.edit-link-icon[data-v-43384334] {
    margin-right: 8px;
}
.prev-next[data-v-43384334] {
    border-top: 1px solid var(--vp-c-divider);
    padding-top: 24px;
    display: grid;
    grid-row-gap: 8px;
}
@media (min-width: 640px) {
    .prev-next[data-v-43384334] {
        grid-template-columns: repeat(2, 1fr);
        grid-column-gap: 16px;
    }
}
.pager-link[data-v-43384334] {
    display: block;
    border: 1px solid var(--vp-c-divider);
    border-radius: 8px;
    padding: 11px 16px 13px;
    width: 100%;
    height: 100%;
    transition: border-color 0.25s;
}
.pager-link[data-v-43384334]:hover {
    border-color: var(--vp-c-brand-1);
}
.pager-link.next[data-v-43384334] {
    margin-left: auto;
    text-align: right;
}
.desc[data-v-43384334] {
    display: block;
    line-height: 20px;
    font-size: 12px;
    font-weight: 500;
    color: var(--vp-c-text-2);
}
.title[data-v-43384334] {
    display: block;
    line-height: 20px;
    font-size: 14px;
    font-weight: 500;
    color: var(--vp-c-brand-1);
    transition: color 0.25s;
}
.VPDoc[data-v-343c73d6] {
    padding: 32px 24px 96px;
    width: 100%;
}
@media (min-width: 768px) {
    .VPDoc[data-v-343c73d6] {
        padding: 48px 32px 128px;
    }
}
@media (min-width: 960px) {
    .VPDoc[data-v-343c73d6] {
        padding: 48px 32px 0;
    }
    .VPDoc:not(.has-sidebar) .container[data-v-343c73d6] {
        display: flex;
        justify-content: center;
        max-width: 992px;
    }
    .VPDoc:not(.has-sidebar) .content[data-v-343c73d6] {
        max-width: 752px;
    }
}
@media (min-width: 1280px) {
    .VPDoc .container[data-v-343c73d6] {
        display: flex;
        justify-content: center;
    }
    .VPDoc .aside[data-v-343c73d6] {
        display: block;
    }
}
@media (min-width: 1440px) {
    .VPDoc:not(.has-sidebar) .content[data-v-343c73d6] {
        max-width: 784px;
    }
    .VPDoc:not(.has-sidebar) .container[data-v-343c73d6] {
        max-width: 1104px;
    }
}
.container[data-v-343c73d6] {
    margin: 0 auto;
    width: 100%;
}
.aside[data-v-343c73d6] {
    position: relative;
    display: none;
    order: 2;
    flex-grow: 1;
    padding-left: 32px;
    width: 100%;
    max-width: 256px;
}
.left-aside[data-v-343c73d6] {
    order: 1;
    padding-left: unset;
    padding-right: 32px;
}
.aside-container[data-v-343c73d6] {
    position: fixed;
    top: 0;
    padding-top: calc(var(--vp-nav-height) + var(--vp-layout-top-height, 0px) + var(--vp-doc-top-height, 0px) + 48px);
    width: 224px;
    height: 100vh;
    overflow-x: hidden;
    overflow-y: auto;
    scrollbar-width: none;
}
.aside-container[data-v-343c73d6]::-webkit-scrollbar {
    display: none;
}
.aside-curtain[data-v-343c73d6] {
    position: fixed;
    bottom: 0;
    z-index: 10;
    width: 224px;
    height: 32px;
    background: linear-gradient(transparent, var(--vp-c-bg) 70%);
}
.aside-content[data-v-343c73d6] {
    display: flex;
    flex-direction: column;
    min-height: calc(100vh - (var(--vp-nav-height) + var(--vp-layout-top-height, 0px) + 48px));
    padding-bottom: 32px;
}
.content[data-v-343c73d6] {
    position: relative;
    margin: 0 auto;
    width: 100%;
}
@media (min-width: 960px) {
    .content[data-v-343c73d6] {
        padding: 0 32px 128px;
    }
}
@media (min-width: 1280px) {
    .content[data-v-343c73d6] {
        order: 1;
        margin: 0;
        min-width: 640px;
    }
}
.content-container[data-v-343c73d6] {
    margin: 0 auto;
}
.VPDoc.has-aside .content-container[data-v-343c73d6] {
    max-width: 688px;
}
.VPButton[data-v-a6f37409] {
    display: inline-block;
    border: 1px solid transparent;
    text-align: center;
    font-weight: 600;
    white-space: nowrap;
    transition: color 0.25s, border-color 0.25s, background-color 0.25s;
}
.VPButton[data-v-a6f37409]:active {
    transition: color 0.1s, border-color 0.1s, background-color 0.1s;
}
.VPButton.medium[data-v-a6f37409] {
    border-radius: 20px;
    padding: 0 20px;
    line-height: 38px;
    font-size: 14px;
}
.VPButton.big[data-v-a6f37409] {
    border-radius: 24px;
    padding: 0 24px;
    line-height: 46px;
    font-size: 16px;
}
.VPButton.brand[data-v-a6f37409] {
    border-color: var(--vp-button-brand-border);
    color: var(--vp-button-brand-text);
    background-color: var(--vp-button-brand-bg);
}
.VPButton.brand[data-v-a6f37409]:hover {
    border-color: var(--vp-button-brand-hover-border);
    color: var(--vp-button-brand-hover-text);
    background-color: var(--vp-button-brand-hover-bg);
}
.VPButton.brand[data-v-a6f37409]:active {
    border-color: var(--vp-button-brand-active-border);
    color: var(--vp-button-brand-active-text);
    background-color: var(--vp-button-brand-active-bg);
}
.VPButton.alt[data-v-a6f37409] {
    border-color: var(--vp-button-alt-border);
    color: var(--vp-button-alt-text);
    background-color: var(--vp-button-alt-bg);
}
.VPButton.alt[data-v-a6f37409]:hover {
    border-color: var(--vp-button-alt-hover-border);
    color: var(--vp-button-alt-hover-text);
    background-color: var(--vp-button-alt-hover-bg);
}
.VPButton.alt[data-v-a6f37409]:active {
    border-color: var(--vp-button-alt-active-border);
    color: var(--vp-button-alt-active-text);
    background-color: var(--vp-button-alt-active-bg);
}
.VPButton.sponsor[data-v-a6f37409] {
    border-color: var(--vp-button-sponsor-border);
    color: var(--vp-button-sponsor-text);
    background-color: var(--vp-button-sponsor-bg);
}
.VPButton.sponsor[data-v-a6f37409]:hover {
    border-color: var(--vp-button-sponsor-hover-border);
    color: var(--vp-button-sponsor-hover-text);
    background-color: var(--vp-button-sponsor-hover-bg);
}
.VPButton.sponsor[data-v-a6f37409]:active {
    border-color: var(--vp-button-sponsor-active-border);
    color: var(--vp-button-sponsor-active-text);
    background-color: var(--vp-button-sponsor-active-bg);
}
html:not(.dark) .VPImage.dark[data-v-0c71c7f1] {
    display: none;
}
.dark .VPImage.light[data-v-0c71c7f1] {
    display: none;
}
.VPHero[data-v-89d2fc22] {
    margin-top: calc((var(--vp-nav-height) + var(--vp-layout-top-height, 0px)) * -1);
    padding: calc(var(--vp-nav-height) + var(--vp-layout-top-height, 0px) + 48px) 24px 48px;
}
@media (min-width: 640px) {
    .VPHero[data-v-89d2fc22] {
        padding: calc(var(--vp-nav-height) + var(--vp-layout-top-height, 0px) + 80px) 48px 64px;
    }
}
@media (min-width: 960px) {
    .VPHero[data-v-89d2fc22] {
        padding: calc(var(--vp-nav-height) + var(--vp-layout-top-height, 0px) + 80px) 64px 64px;
    }
}
.container[data-v-89d2fc22] {
    display: flex;
    flex-direction: column;
    margin: 0 auto;
    max-width: 1152px;
}
@media (min-width: 960px) {
    .container[data-v-89d2fc22] {
        flex-direction: row;
    }
}
.main[data-v-89d2fc22] {
    position: relative;
    z-index: 10;
    order: 2;
    flex-grow: 1;
    flex-shrink: 0;
}
.VPHero.has-image .container[data-v-89d2fc22] {
    text-align: center;
}
@media (min-width: 960px) {
    .VPHero.has-image .container[data-v-89d2fc22] {
        text-align: left;
    }
}
@media (min-width: 960px) {
    .main[data-v-89d2fc22] {
        order: 1;
        width: calc((100% / 3) * 2);
    }
    .VPHero.has-image .main[data-v-89d2fc22] {
        max-width: 592px;
    }
}
.name[data-v-89d2fc22], .text[data-v-89d2fc22] {
    max-width: 392px;
    letter-spacing: -0.4px;
    line-height: 40px;
    font-size: 32px;
    font-weight: 700;
    white-space: pre-wrap;
}
.VPHero.has-image .name[data-v-89d2fc22], .VPHero.has-image .text[data-v-89d2fc22] {
    margin: 0 auto;
}
.name[data-v-89d2fc22] {
    color: var(--vp-home-hero-name-color);
}
.clip[data-v-89d2fc22] {
    background: var(--vp-home-hero-name-background);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: var(--vp-home-hero-name-color);
}
@media (min-width: 640px) {
    .name[data-v-89d2fc22], .text[data-v-89d2fc22] {
        max-width: 576px;
        line-height: 56px;
        font-size: 48px;
    }
}
@media (min-width: 960px) {
    .name[data-v-89d2fc22], .text[data-v-89d2fc22] {
        line-height: 64px;
        font-size: 56px;
    }
    .VPHero.has-image .name[data-v-89d2fc22], .VPHero.has-image .text[data-v-89d2fc22] {
        margin: 0;
    }
}
.tagline[data-v-89d2fc22] {
    padding-top: 8px;
    max-width: 392px;
    line-height: 28px;
    font-size: 18px;
    font-weight: 500;
    white-space: pre-wrap;
    color: var(--vp-c-text-2);
}
.VPHero.has-image .tagline[data-v-89d2fc22] {
    margin: 0 auto;
}
@media (min-width: 640px) {
    .tagline[data-v-89d2fc22] {
        padding-top: 12px;
        max-width: 576px;
        line-height: 32px;
        font-size: 20px;
    }
}
@media (min-width: 960px) {
    .tagline[data-v-89d2fc22] {
        line-height: 36px;
        font-size: 24px;
    }
    .VPHero.has-image .tagline[data-v-89d2fc22] {
        margin: 0;
    }
}
.actions[data-v-89d2fc22] {
    display: flex;
    flex-wrap: wrap;
    margin: -6px;
    padding-top: 24px;
}
.VPHero.has-image .actions[data-v-89d2fc22] {
    justify-content: center;
}
@media (min-width: 640px) {
    .actions[data-v-89d2fc22] {
        padding-top: 32px;
    }
}
@media (min-width: 960px) {
    .VPHero.has-image .actions[data-v-89d2fc22] {
        justify-content: flex-start;
    }
}
.action[data-v-89d2fc22] {
    flex-shrink: 0;
    padding: 6px;
}
.image[data-v-89d2fc22] {
    order: 1;
    margin: -76px -24px -48px;
}
@media (min-width: 640px) {
    .image[data-v-89d2fc22] {
        margin: -108px -24px -48px;
    }
}
@media (min-width: 960px) {
    .image[data-v-89d2fc22] {
        flex-grow: 1;
        order: 2;
        margin: 0;
        min-height: 100%;
    }
}
.image-container[data-v-89d2fc22] {
    position: relative;
    margin: 0 auto;
    width: 320px;
    height: 320px;
}
@media (min-width: 640px) {
    .image-container[data-v-89d2fc22] {
        width: 392px;
        height: 392px;
    }
}
@media (min-width: 960px) {
    .image-container[data-v-89d2fc22] {
        display: flex;
        justify-content: center;
        align-items: center;
        width: 100%;
        height: 100%;
        /*rtl:ignore*/
        transform: translate(-32px, -32px);
    }
}
.image-bg[data-v-89d2fc22] {
    position: absolute;
    top: 50%;
    /*rtl:ignore*/
    left: 50%;
    border-radius: 50%;
    width: 192px;
    height: 192px;
    background-image: var(--vp-home-hero-image-background-image);
    filter: var(--vp-home-hero-image-filter);
    /*rtl:ignore*/
    transform: translate(-50%, -50%);
}
@media (min-width: 640px) {
    .image-bg[data-v-89d2fc22] {
        width: 256px;
        height: 256px;
    }
}
@media (min-width: 960px) {
    .image-bg[data-v-89d2fc22] {
        width: 320px;
        height: 320px;
    }
}
[data-v-89d2fc22] .image-src {
    position: absolute;
    top: 50%;
    /*rtl:ignore*/
    left: 50%;
    max-width: 192px;
    max-height: 192px;
    /*rtl:ignore*/
    transform: translate(-50%, -50%);
}
@media (min-width: 640px) {
    [data-v-89d2fc22] .image-src {
        max-width: 256px;
        max-height: 256px;
    }
}
@media (min-width: 960px) {
    [data-v-89d2fc22] .image-src {
        max-width: 320px;
        max-height: 320px;
    }
}
.VPFeature[data-v-e8895942] {
    display: block;
    border: 1px solid var(--vp-c-bg-soft);
    border-radius: 12px;
    height: 100%;
    background-color: var(--vp-c-bg-soft);
    transition: border-color 0.25s, background-color 0.25s;
}
.VPFeature.link[data-v-e8895942]:hover {
    border-color: var(--vp-c-brand-1);
}
.box[data-v-e8895942] {
    display: flex;
    flex-direction: column;
    padding: 24px;
    height: 100%;
}
.box[data-v-e8895942]>.VPImage {
    margin-bottom: 20px;
}
.icon[data-v-e8895942] {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: 20px;
    border-radius: 6px;
    background-color: var(--vp-c-default-soft);
    width: 48px;
    height: 48px;
    font-size: 24px;
    transition: background-color 0.25s;
}
.title[data-v-e8895942] {
    line-height: 24px;
    font-size: 16px;
    font-weight: 600;
}
.details[data-v-e8895942] {
    flex-grow: 1;
    padding-top: 8px;
    line-height: 24px;
    font-size: 14px;
    font-weight: 500;
    color: var(--vp-c-text-2);
}
.link-text[data-v-e8895942] {
    padding-top: 8px;
}
.link-text-value[data-v-e8895942] {
    display: flex;
    align-items: center;
    font-size: 14px;
    font-weight: 500;
    color: var(--vp-c-brand-1);
}
.link-text-icon[data-v-e8895942] {
    margin-left: 6px;
}
.VPFeatures[data-v-d6f3b7e5] {
    position: relative;
    padding: 0 24px;
}
@media (min-width: 640px) {
    .VPFeatures[data-v-d6f3b7e5] {
        padding: 0 48px;
    }
}
@media (min-width: 960px) {
    .VPFeatures[data-v-d6f3b7e5] {
        padding: 0 64px;
    }
}
.container[data-v-d6f3b7e5] {
    margin: 0 auto;
    max-width: 1152px;
}
.items[data-v-d6f3b7e5] {
    display: flex;
    flex-wrap: wrap;
    margin: -8px;
}
.item[data-v-d6f3b7e5] {
    padding: 8px;
    width: 100%;
}
@media (min-width: 640px) {
    .item.grid-2[data-v-d6f3b7e5], .item.grid-4[data-v-d6f3b7e5], .item.grid-6[data-v-d6f3b7e5] {
        width: calc(100% / 2);
    }
}
@media (min-width: 768px) {
    .item.grid-2[data-v-d6f3b7e5], .item.grid-4[data-v-d6f3b7e5] {
        width: calc(100% / 2);
    }
    .item.grid-3[data-v-d6f3b7e5], .item.grid-6[data-v-d6f3b7e5] {
        width: calc(100% / 3);
    }
}
@media (min-width: 960px) {
    .item.grid-4[data-v-d6f3b7e5] {
        width: calc(100% / 4);
    }
}
.container[data-v-86346a6a] {
    margin: auto;
    width: 100%;
    max-width: 1280px;
    padding: 0 24px;
}
@media (min-width: 640px) {
    .container[data-v-86346a6a] {
        padding: 0 48px;
    }
}
@media (min-width: 960px) {
    .container[data-v-86346a6a] {
        width: 100%;
        padding: 0 64px;
    }
}
.vp-doc[data-v-86346a6a] .VPHomeSponsors, .vp-doc[data-v-86346a6a] .VPTeamPage {
    margin-left: var(--vp-offset, calc(50% - 50vw));
    margin-right: var(--vp-offset, calc(50% - 50vw));
}
.vp-doc[data-v-86346a6a] .VPHomeSponsors h2 {
    border-top: none;
    letter-spacing: normal;
}
.vp-doc[data-v-86346a6a] .VPHomeSponsors a, .vp-doc[data-v-86346a6a] .VPTeamPage a {
    text-decoration: none;
}
.VPHome[data-v-441e4bfa] {
    margin-bottom: 96px;
}
@media (min-width: 768px) {
    .VPHome[data-v-441e4bfa] {
        margin-bottom: 128px;
    }
}
.VPContent[data-v-52f1cd35] {
    flex-grow: 1;
    flex-shrink: 0;
    margin: var(--vp-layout-top-height, 0px) auto 0;
    width: 100%;
}
.VPContent.is-home[data-v-52f1cd35] {
    width: 100%;
    max-width: 100%;
}
.VPContent.has-sidebar[data-v-52f1cd35] {
    margin: 0;
}
@media (min-width: 960px) {
    .VPContent[data-v-52f1cd35] {
        padding-top: var(--vp-nav-height);
    }
    .VPContent.has-sidebar[data-v-52f1cd35] {
        margin: var(--vp-layout-top-height, 0px) 0 0;
        padding-left: var(--vp-sidebar-width);
    }
}
@media (min-width: 1440px) {
    .VPContent.has-sidebar[data-v-52f1cd35] {
        padding-right: calc((100vw - var(--vp-layout-max-width)) / 2);
        padding-left: calc((100vw - var(--vp-layout-max-width)) / 2 + var(--vp-sidebar-width));
    }
}
.VPFooter[data-v-5bdef7ba] {
    position: relative;
    z-index: var(--vp-z-index-footer);
    border-top: 1px solid var(--vp-c-gutter);
    padding: 32px 24px;
    background-color: var(--vp-c-bg);
}
.VPFooter.has-sidebar[data-v-5bdef7ba] {
    display: none;
}
.VPFooter[data-v-5bdef7ba] a {
    text-decoration-line: underline;
    text-underline-offset: 2px;
    transition: color 0.25s;
}
.VPFooter[data-v-5bdef7ba] a:hover {
    color: var(--vp-c-text-1);
}
@media (min-width: 768px) {
    .VPFooter[data-v-5bdef7ba] {
        padding: 32px;
    }
}
.container[data-v-5bdef7ba] {
    margin: 0 auto;
    max-width: var(--vp-layout-max-width);
    text-align: center;
}
.message[data-v-5bdef7ba], .copyright[data-v-5bdef7ba] {
    line-height: 24px;
    font-size: 14px;
    font-weight: 500;
    color: var(--vp-c-text-2);
}
.VPLocalNavOutlineDropdown[data-v-2cc302b7] {
    padding: 12px 20px 11px;
}
@media (min-width: 960px) {
    .VPLocalNavOutlineDropdown[data-v-2cc302b7] {
        padding: 12px 36px 11px;
    }
}
.VPLocalNavOutlineDropdown button[data-v-2cc302b7] {
    display: block;
    font-size: 12px;
    font-weight: 500;
    line-height: 24px;
    color: var(--vp-c-text-2);
    transition: color 0.5s;
    position: relative;
}
.VPLocalNavOutlineDropdown button[data-v-2cc302b7]:hover {
    color: var(--vp-c-text-1);
    transition: color 0.25s;
}
.VPLocalNavOutlineDropdown button.open[data-v-2cc302b7] {
    color: var(--vp-c-text-1);
}
.icon[data-v-2cc302b7] {
    display: inline-block;
    vertical-align: middle;
    margin-left: 2px;
    font-size: 14px;
    transform: rotate(0deg);
    transition: transform 0.25s;
}
@media (min-width: 960px) {
    .VPLocalNavOutlineDropdown button[data-v-2cc302b7] {
        font-size: 14px;
    }
    .icon[data-v-2cc302b7] {
        font-size: 16px;
    }
}
.open>.icon[data-v-2cc302b7] {
    transform: rotate(90deg);
}
.items[data-v-2cc302b7] {
    position: absolute;
    top: 40px;
    right: 16px;
    left: 16px;
    display: grid;
    gap: 1px;
    border: 1px solid var(--vp-c-border);
    border-radius: 8px;
    background-color: var(--vp-c-gutter);
    max-height: calc(var(--vp-vh, 100vh) - 86px);
    overflow: hidden auto;
    box-shadow: var(--vp-shadow-3);
}
@media (min-width: 960px) {
    .items[data-v-2cc302b7] {
        right: auto;
        left: calc(var(--vp-sidebar-width) + 32px);
        width: 320px;
    }
}
.header[data-v-2cc302b7] {
    background-color: var(--vp-c-bg-soft);
}
.top-link[data-v-2cc302b7] {
    display: block;
    padding: 0 16px;
    line-height: 48px;
    font-size: 14px;
    font-weight: 500;
    color: var(--vp-c-brand-1);
}
.outline[data-v-2cc302b7] {
    padding: 8px 0;
    background-color: var(--vp-c-bg-soft);
}
.flyout-enter-active[data-v-2cc302b7] {
    transition: all 0.2s ease-out;
}
.flyout-leave-active[data-v-2cc302b7] {
    transition: all 0.15s ease-in;
}
.flyout-enter-from[data-v-2cc302b7], .flyout-leave-to[data-v-2cc302b7] {
    opacity: 0;
    transform: translateY(-16px);
}
.VPLocalNav[data-v-da48a524] {
    position: sticky;
    top: 0;
    /*rtl:ignore*/
    left: 0;
    z-index: var(--vp-z-index-local-nav);
    border-bottom: 1px solid var(--vp-c-gutter);
    padding-top: var(--vp-layout-top-height, 0px);
    width: 100%;
    background-color: rgba(255, 255, 255, 0.6);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
}
.VPLocalNav.fixed[data-v-da48a524] {
    position: fixed;
    background-color: rgba(255, 255, 255, 0.7);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
}
.dark .VPLocalNav[data-v-da48a524] {
    background-color: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
}
.dark .VPLocalNav.fixed[data-v-da48a524] {
    background-color: rgba(0, 0, 0, 0.7);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
}
@media (min-width: 960px) {
    .VPLocalNav[data-v-da48a524] {
        top: var(--vp-nav-height);
    }
    .VPLocalNav.has-sidebar[data-v-da48a524] {
        padding-left: var(--vp-sidebar-width);
    }
    .VPLocalNav.empty[data-v-da48a524] {
        display: none;
    }
}
@media (min-width: 1280px) {
    .VPLocalNav[data-v-da48a524] {
        display: none;
    }
}
@media (min-width: 1440px) {
    .VPLocalNav.has-sidebar[data-v-da48a524] {
        padding-left: calc((100vw - var(--vp-layout-max-width)) / 2 + var(--vp-sidebar-width));
    }
}
.container[data-v-da48a524] {
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.menu[data-v-da48a524] {
    display: flex;
    align-items: center;
    padding: 12px 24px 11px;
    line-height: 24px;
    font-size: 12px;
    font-weight: 500;
    color: var(--vp-c-text-2);
    transition: color 0.5s;
}
.menu[data-v-da48a524]:hover {
    color: var(--vp-c-text-1);
    transition: color 0.25s;
}
@media (min-width: 768px) {
    .menu[data-v-da48a524] {
        padding: 0 32px;
    }
}
@media (min-width: 960px) {
    .menu[data-v-da48a524] {
        display: none;
    }
}
.menu-icon[data-v-da48a524] {
    margin-right: 8px;
    font-size: 14px;
}
.VPOutlineDropdown[data-v-da48a524] {
    padding: 12px 24px 11px;
}
@media (min-width: 768px) {
    .VPOutlineDropdown[data-v-da48a524] {
        padding: 12px 32px 11px;
    }
}
.VPSwitch[data-v-5dcf7ba4] {
    position: relative;
    border-radius: 11px;
    display: block;
    width: 40px;
    height: 22px;
    flex-shrink: 0;
    border: 1px solid var(--vp-input-border-color);
    background-color: var(--vp-input-switch-bg-color);
    transition: border-color 0.25s !important;
}
.VPSwitch[data-v-5dcf7ba4]:hover {
    border-color: var(--vp-c-brand-1);
}
.check[data-v-5dcf7ba4] {
    position: absolute;
    top: 1px;
    /*rtl:ignore*/
    left: 1px;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background-color: var(--vp-c-neutral-inverse);
    box-shadow: var(--vp-shadow-1);
    transition: transform 0.25s !important;
}
.icon[data-v-5dcf7ba4] {
    position: relative;
    display: block;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    overflow: hidden;
}
.icon[data-v-5dcf7ba4] [class^='vpi-'] {
    position: absolute;
    top: 3px;
    left: 3px;
    width: 12px;
    height: 12px;
    color: var(--vp-c-text-2);
}
.dark .icon[data-v-5dcf7ba4] [class^='vpi-'] {
    color: var(--vp-c-text-1);
    transition: opacity 0.25s !important;
}
.sun[data-v-3c3cad28] {
    opacity: 1;
}
.moon[data-v-3c3cad28] {
    opacity: 0;
}
.dark .sun[data-v-3c3cad28] {
    opacity: 0;
}
.dark .moon[data-v-3c3cad28] {
    opacity: 1;
}
.dark .VPSwitchAppearance[data-v-3c3cad28] .check {
    /*rtl:ignore*/
    transform: translateX(18px);
}
.VPNavBarAppearance[data-v-bbc89006] {
    display: none;
}
@media (min-width: 1280px) {
    .VPNavBarAppearance[data-v-bbc89006] {
        display: flex;
        align-items: center;
    }
}
.VPMenuGroup+.VPMenuLink[data-v-19086799] {
    margin: 12px -12px 0;
    border-top: 1px solid var(--vp-c-divider);
    padding: 12px 12px 0;
}
.link[data-v-19086799] {
    display: block;
    border-radius: 6px;
    padding: 0 12px;
    line-height: 32px;
    font-size: 14px;
    font-weight: 500;
    color: var(--vp-c-text-1);
    white-space: nowrap;
    transition: background-color 0.25s, color 0.25s;
}
.link[data-v-19086799]:hover {
    color: var(--vp-c-brand-1);
    background-color: var(--vp-c-default-soft);
}
.link.active[data-v-19086799] {
    color: var(--vp-c-brand-1);
}
.VPMenuGroup[data-v-8eb43475] {
    margin: 12px -12px 0;
    border-top: 1px solid var(--vp-c-divider);
    padding: 12px 12px 0;
}
.VPMenuGroup[data-v-8eb43475]:first-child {
    margin-top: 0;
    border-top: 0;
    padding-top: 0;
}
.VPMenuGroup+.VPMenuGroup[data-v-8eb43475] {
    margin-top: 12px;
    border-top: 1px solid var(--vp-c-divider);
}
.title[data-v-8eb43475] {
    padding: 0 12px;
    line-height: 32px;
    font-size: 14px;
    font-weight: 600;
    color: var(--vp-c-text-2);
    white-space: nowrap;
    transition: color 0.25s;
}
.VPMenu[data-v-5ee69184] {
    border-radius: 12px;
    padding: 12px;
    min-width: 128px;
    border: 1px solid var(--vp-c-divider);
    background-color: var(--vp-c-bg-elv);
    box-shadow: var(--vp-shadow-3);
    transition: background-color 0.5s;
    max-height: calc(100vh - var(--vp-nav-height));
    overflow-y: auto;
}
.VPMenu[data-v-5ee69184] .group {
    margin: 0 -12px;
    padding: 0 12px 12px;
}
.VPMenu[data-v-5ee69184] .group+.group {
    border-top: 1px solid var(--vp-c-divider);
    padding: 11px 12px 12px;
}
.VPMenu[data-v-5ee69184] .group:last-child {
    padding-bottom: 0;
}
.VPMenu[data-v-5ee69184] .group+.item {
    border-top: 1px solid var(--vp-c-divider);
    padding: 11px 16px 0;
}
.VPMenu[data-v-5ee69184] .item {
    padding: 0 16px;
    white-space: nowrap;
}
.VPMenu[data-v-5ee69184] .label {
    flex-grow: 1;
    line-height: 28px;
    font-size: 12px;
    font-weight: 500;
    color: var(--vp-c-text-2);
    transition: color 0.5s;
}
.VPMenu[data-v-5ee69184] .action {
    padding-left: 24px;
}
.VPFlyout[data-v-ce7cea34] {
    position: relative;
}
.VPFlyout[data-v-ce7cea34]:hover {
    color: var(--vp-c-brand-1);
    transition: color 0.25s;
}
.VPFlyout:hover .text[data-v-ce7cea34] {
    color: var(--vp-c-text-2);
}
.VPFlyout:hover .icon[data-v-ce7cea34] {
    fill: var(--vp-c-text-2);
}
.VPFlyout.active .text[data-v-ce7cea34] {
    color: var(--vp-c-brand-1);
}
.VPFlyout.active:hover .text[data-v-ce7cea34] {
    color: var(--vp-c-brand-2);
}
.button[aria-expanded="false"]+.menu[data-v-ce7cea34] {
    opacity: 0;
    visibility: hidden;
    transform: translateY(0);
}
.VPFlyout:hover .menu[data-v-ce7cea34], .button[aria-expanded="true"]+.menu[data-v-ce7cea34] {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}
.button[data-v-ce7cea34] {
    display: flex;
    align-items: center;
    padding: 0 12px;
    height: var(--vp-nav-height);
    color: var(--vp-c-text-1);
    transition: color 0.5s;
}
.text[data-v-ce7cea34] {
    display: flex;
    align-items: center;
    line-height: var(--vp-nav-height);
    font-size: 14px;
    font-weight: 500;
    color: var(--vp-c-text-1);
    transition: color 0.25s;
}
.option-icon[data-v-ce7cea34] {
    margin-right: 0px;
    font-size: 16px;
}
.text-icon[data-v-ce7cea34] {
    margin-left: 4px;
    font-size: 14px;
}
.icon[data-v-ce7cea34] {
    font-size: 20px;
    transition: fill 0.25s;
}
.menu[data-v-ce7cea34] {
    position: absolute;
    top: calc(var(--vp-nav-height) / 2 + 20px);
    right: 0;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.25s, visibility 0.25s, transform 0.25s;
}
.VPSocialLink[data-v-67d207bd] {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 36px;
    height: 36px;
    color: var(--vp-c-text-2);
    transition: color 0.5s;
}
.VPSocialLink[data-v-67d207bd]:hover {
    color: var(--vp-c-text-1);
    transition: color 0.25s;
}
.VPSocialLink[data-v-67d207bd]>svg, .VPSocialLink[data-v-67d207bd]>[class^="vpi-social-"] {
    width: 20px;
    height: 20px;
    fill: currentColor;
}
.VPSocialLinks[data-v-9a809f43] {
    display: flex;
    justify-content: center;
}
.VPNavBarExtra[data-v-584350b7] {
    display: none;
    margin-right: -12px;
}
@media (min-width: 768px) {
    .VPNavBarExtra[data-v-584350b7] {
        display: block;
    }
}
@media (min-width: 1280px) {
    .VPNavBarExtra[data-v-584350b7] {
        display: none;
    }
}
.trans-title[data-v-584350b7] {
    padding: 0 24px 0 12px;
    line-height: 32px;
    font-size: 14px;
    font-weight: 700;
    color: var(--vp-c-text-1);
}
.item.appearance[data-v-584350b7], .item.social-links[data-v-584350b7] {
    display: flex;
    align-items: center;
    padding: 0 12px;
}
.item.appearance[data-v-584350b7] {
    min-width: 176px;
}
.appearance-action[data-v-584350b7] {
    margin-right: -2px;
}
.social-links-list[data-v-584350b7] {
    margin: -4px -8px;
}
.VPNavBarHamburger[data-v-701a5bf8] {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 48px;
    height: var(--vp-nav-height);
}
@media (min-width: 768px) {
    .VPNavBarHamburger[data-v-701a5bf8] {
        display: none;
    }
}
.container[data-v-701a5bf8] {
    position: relative;
    width: 16px;
    height: 14px;
    overflow: hidden;
}
.VPNavBarHamburger:hover .top[data-v-701a5bf8] {
    top: 0;
    left: 0;
    transform: translateX(4px);
}
.VPNavBarHamburger:hover .middle[data-v-701a5bf8] {
    top: 6px;
    left: 0;
    transform: translateX(0);
}
.VPNavBarHamburger:hover .bottom[data-v-701a5bf8] {
    top: 12px;
    left: 0;
    transform: translateX(8px);
}
.VPNavBarHamburger.active .top[data-v-701a5bf8] {
    top: 6px;
    transform: translateX(0) rotate(225deg);
}
.VPNavBarHamburger.active .middle[data-v-701a5bf8] {
    top: 6px;
    transform: translateX(16px);
}
.VPNavBarHamburger.active .bottom[data-v-701a5bf8] {
    top: 6px;
    transform: translateX(0) rotate(135deg);
}
.VPNavBarHamburger.active:hover .top[data-v-701a5bf8], .VPNavBarHamburger.active:hover .middle[data-v-701a5bf8], .VPNavBarHamburger.active:hover .bottom[data-v-701a5bf8] {
    background-color: var(--vp-c-text-2);
    transition: top .25s, background-color .25s, transform .25s;
}
.top[data-v-701a5bf8], .middle[data-v-701a5bf8], .bottom[data-v-701a5bf8] {
    position: absolute;
    width: 16px;
    height: 2px;
    background-color: var(--vp-c-text-1);
    transition: top .25s, background-color .5s, transform .25s;
}
.top[data-v-701a5bf8] {
    top: 0;
    left: 0;
    transform: translateX(0);
}
.middle[data-v-701a5bf8] {
    top: 6px;
    left: 0;
    transform: translateX(8px);
}
.bottom[data-v-701a5bf8] {
    top: 12px;
    left: 0;
    transform: translateX(4px);
}
.VPNavBarMenuLink[data-v-687a61d0] {
    display: flex;
    align-items: center;
    padding: 0 12px;
    line-height: var(--vp-nav-height);
    font-size: 14px;
    font-weight: 500;
    color: var(--vp-c-text-1);
    transition: color 0.25s;
}
.VPNavBarMenuLink.active[data-v-687a61d0] {
    color: var(--vp-c-brand-1);
}
.VPNavBarMenuLink[data-v-687a61d0]:hover {
    color: var(--vp-c-brand-1);
}
.VPNavBarMenu[data-v-15d0e968] {
    display: none;
}
@media (min-width: 768px) {
    .VPNavBarMenu[data-v-15d0e968] {
        display: flex;
    }
}
/*! @docsearch/css 3.7.0 | MIT License | © Algolia, Inc. and contributors | https://docsearch.algolia.com */

:root {
    --docsearch-primary-color: #5468ff;
    --docsearch-text-color: #1c1e21;
    --docsearch-spacing: 12px;
    --docsearch-icon-stroke-width: 1.4;
    --docsearch-highlight-color: var(--docsearch-primary-color);
    --docsearch-muted-color: #969faf;
    --docsearch-container-background: rgba(101, 108, 133, .8);
    --docsearch-logo-color: #5468ff;
    --docsearch-modal-width: 560px;
    --docsearch-modal-height: 600px;
    --docsearch-modal-background: #f5f6f7;
    --docsearch-modal-shadow: inset 1px 1px 0 0 hsla(0, 0%, 100%, .5), 0 3px 8px 0 #555a64;
    --docsearch-searchbox-height: 56px;
    --docsearch-searchbox-background: #ebedf0;
    --docsearch-searchbox-focus-background: #fff;
    --docsearch-searchbox-shadow: inset 0 0 0 2px var(--docsearch-primary-color);
    --docsearch-hit-height: 56px;
    --docsearch-hit-color: #444950;
    --docsearch-hit-active-color: #fff;
    --docsearch-hit-background: #fff;
    --docsearch-hit-shadow: 0 1px 3px 0 #d4d9e1;
    --docsearch-key-gradient: linear-gradient(-225deg, #d5dbe4, #f8f8f8);
    --docsearch-key-shadow: inset 0 -2px 0 0 #cdcde6, inset 0 0 1px 1px #fff, 0 1px 2px 1px rgba(30, 35, 90, .4);
    --docsearch-key-pressed-shadow: inset 0 -2px 0 0 #cdcde6, inset 0 0 1px 1px #fff, 0 1px 1px 0 rgba(30, 35, 90, .4);
    --docsearch-footer-height: 44px;
    --docsearch-footer-background: #fff;
    --docsearch-footer-shadow: 0 -1px 0 0 #e0e3e8, 0 -3px 6px 0 rgba(69, 98, 155, .12)
}
html[data-theme=dark] {
    --docsearch-text-color: #f5f6f7;
    --docsearch-container-background: rgba(9, 10, 17, .8);
    --docsearch-modal-background: #15172a;
    --docsearch-modal-shadow: inset 1px 1px 0 0 #2c2e40, 0 3px 8px 0 #000309;
    --docsearch-searchbox-background: #090a11;
    --docsearch-searchbox-focus-background: #000;
    --docsearch-hit-color: #bec3c9;
    --docsearch-hit-shadow: none;
    --docsearch-hit-background: #090a11;
    --docsearch-key-gradient: linear-gradient(-26.5deg, #565872, #31355b);
    --docsearch-key-shadow: inset 0 -2px 0 0 #282d55, inset 0 0 1px 1px #51577d, 0 2px 2px 0 rgba(3, 4, 9, .3);
    --docsearch-key-pressed-shadow: inset 0 -2px 0 0 #282d55, inset 0 0 1px 1px #51577d, 0 1px 1px 0 #0304094d;
    --docsearch-footer-background: #1e2136;
    --docsearch-footer-shadow: inset 0 1px 0 0 rgba(73, 76, 106, .5), 0 -4px 8px 0 rgba(0, 0, 0, .2);
    --docsearch-logo-color: #fff;
    --docsearch-muted-color: #7f8497
}
.DocSearch-Button {
    align-items: center;
    background: var(--docsearch-searchbox-background);
    border: 0;
    border-radius: 40px;
    color: var(--docsearch-muted-color);
    cursor: pointer;
    display: flex;
    font-weight: 500;
    height: 36px;
    justify-content: space-between;
    margin: 0 0 0 16px;
    padding: 0 8px;
    user-select: none
}
.DocSearch-Button:active, .DocSearch-Button:focus, .DocSearch-Button:hover {
    background: var(--docsearch-searchbox-focus-background);
    box-shadow: var(--docsearch-searchbox-shadow);
    color: var(--docsearch-text-color);
    outline: none
}
.DocSearch-Button-Container {
    align-items: center;
    display: flex
}
.DocSearch-Search-Icon {
    stroke-width: 1.6
}
.DocSearch-Button .DocSearch-Search-Icon {
    color: var(--docsearch-text-color)
}
.DocSearch-Button-Placeholder {
    font-size: 1rem;
    padding: 0 12px 0 6px
}
.DocSearch-Button-Keys {
    display: flex;
    min-width: calc(40px + .8em)
}
.DocSearch-Button-Key {
    align-items: center;
    background: var(--docsearch-key-gradient);
    border: 0;
    border-radius: 3px;
    box-shadow: var(--docsearch-key-shadow);
    color: var(--docsearch-muted-color);
    display: flex;
    height: 18px;
    justify-content: center;
    margin-right: .4em;
    padding: 0 0 2px;
    position: relative;
    top: -1px;
    width: 20px
}
.DocSearch-Button-Key--pressed {
    box-shadow: var(--docsearch-key-pressed-shadow);
    transform: translate3d(0, 1px, 0)
}
@media (max-width:768px) {
    .DocSearch-Button-Keys, .DocSearch-Button-Placeholder {
        display: none
    }
}
.DocSearch--active {
    overflow: hidden!important
}
.DocSearch-Container, .DocSearch-Container * {
    box-sizing: border-box
}
.DocSearch-Container {
    background-color: var(--docsearch-container-background);
    height: 100vh;
    left: 0;
    position: fixed;
    top: 0;
    width: 100vw;
    z-index: 200
}
.DocSearch-Container a {
    text-decoration: none
}
.DocSearch-Link {
    appearance: none;
    background: none;
    border: 0;
    color: var(--docsearch-highlight-color);
    cursor: pointer;
    font: inherit;
    margin: 0;
    padding: 0
}
.DocSearch-Modal {
    background: var(--docsearch-modal-background);
    border-radius: 6px;
    box-shadow: var(--docsearch-modal-shadow);
    flex-direction: column;
    margin: 60px auto auto;
    max-width: var(--docsearch-modal-width);
    position: relative
}
.DocSearch-SearchBar {
    display: flex;
    padding: var(--docsearch-spacing) var(--docsearch-spacing) 0
}
.DocSearch-Form {
    align-items: center;
    background: var(--docsearch-searchbox-focus-background);
    border-radius: 4px;
    box-shadow: var(--docsearch-searchbox-shadow);
    display: flex;
    height: var(--docsearch-searchbox-height);
    margin: 0;
    padding: 0 var(--docsearch-spacing);
    position: relative;
    width: 100%
}
.DocSearch-Input {
    appearance: none;
    background: transparent;
    border: 0;
    color: var(--docsearch-text-color);
    flex: 1;
    font: inherit;
    font-size: 1.2em;
    height: 100%;
    outline: none;
    padding: 0 0 0 8px;
    width: 80%
}
.DocSearch-Input::placeholder {
    color: var(--docsearch-muted-color);
    opacity: 1
}
.DocSearch-Input::-webkit-search-cancel-button, .DocSearch-Input::-webkit-search-decoration, .DocSearch-Input::-webkit-search-results-button, .DocSearch-Input::-webkit-search-results-decoration {
    display: none
}
.DocSearch-LoadingIndicator, .DocSearch-MagnifierLabel, .DocSearch-Reset {
    margin: 0;
    padding: 0
}
.DocSearch-MagnifierLabel, .DocSearch-Reset {
    align-items: center;
    color: var(--docsearch-highlight-color);
    display: flex;
    justify-content: center
}
.DocSearch-Container--Stalled .DocSearch-MagnifierLabel, .DocSearch-LoadingIndicator {
    display: none
}
.DocSearch-Container--Stalled .DocSearch-LoadingIndicator {
    align-items: center;
    color: var(--docsearch-highlight-color);
    display: flex;
    justify-content: center
}
@media screen and (prefers-reduced-motion:reduce) {
    .DocSearch-Reset {
        animation: none;
        appearance: none;
        background: none;
        border: 0;
        border-radius: 50%;
        color: var(--docsearch-icon-color);
        cursor: pointer;
        right: 0;
        stroke-width: var(--docsearch-icon-stroke-width)
    }
}
.DocSearch-Reset {
    animation: fade-in .1s ease-in forwards;
    appearance: none;
    background: none;
    border: 0;
    border-radius: 50%;
    color: var(--docsearch-icon-color);
    cursor: pointer;
    padding: 2px;
    right: 0;
    stroke-width: var(--docsearch-icon-stroke-width)
}
.DocSearch-Reset[hidden] {
    display: none
}
.DocSearch-Reset:hover {
    color: var(--docsearch-highlight-color)
}
.DocSearch-LoadingIndicator svg, .DocSearch-MagnifierLabel svg {
    height: 24px;
    width: 24px
}
.DocSearch-Cancel {
    display: none
}
.DocSearch-Dropdown {
    max-height: calc(var(--docsearch-modal-height) - var(--docsearch-searchbox-height) - var(--docsearch-spacing) - var(--docsearch-footer-height));
    min-height: var(--docsearch-spacing);
    overflow-y: auto;
    overflow-y: overlay;
    padding: 0 var(--docsearch-spacing);
    scrollbar-color: var(--docsearch-muted-color) var(--docsearch-modal-background);
    scrollbar-width: thin
}
.DocSearch-Dropdown::-webkit-scrollbar {
    width: 12px
}
.DocSearch-Dropdown::-webkit-scrollbar-track {
    background: transparent
}
.DocSearch-Dropdown::-webkit-scrollbar-thumb {
    background-color: var(--docsearch-muted-color);
    border: 3px solid var(--docsearch-modal-background);
    border-radius: 20px
}
.DocSearch-Dropdown ul {
    list-style: none;
    margin: 0;
    padding: 0
}
.DocSearch-Label {
    font-size: .75em;
    line-height: 1.6em
}
.DocSearch-Help, .DocSearch-Label {
    color: var(--docsearch-muted-color)
}
.DocSearch-Help {
    font-size: .9em;
    margin: 0;
    user-select: none
}
.DocSearch-Title {
    font-size: 1.2em
}
.DocSearch-Logo a {
    display: flex
}
.DocSearch-Logo svg {
    color: var(--docsearch-logo-color);
    margin-left: 8px
}
.DocSearch-Hits:last-of-type {
    margin-bottom: 24px
}
.DocSearch-Hits mark {
    background: none;
    color: var(--docsearch-highlight-color)
}
.DocSearch-HitsFooter {
    color: var(--docsearch-muted-color);
    display: flex;
    font-size: .85em;
    justify-content: center;
    margin-bottom: var(--docsearch-spacing);
    padding: var(--docsearch-spacing)
}
.DocSearch-HitsFooter a {
    border-bottom: 1px solid;
    color: inherit
}
.DocSearch-Hit {
    border-radius: 4px;
    display: flex;
    padding-bottom: 4px;
    position: relative
}
@media screen and (prefers-reduced-motion:reduce) {
    .DocSearch-Hit--deleting {
        transition: none
    }
}
.DocSearch-Hit--deleting {
    opacity: 0;
    transition: all .25s linear
}
@media screen and (prefers-reduced-motion:reduce) {
    .DocSearch-Hit--favoriting {
        transition: none
    }
}
.DocSearch-Hit--favoriting {
    transform: scale(0);
    transform-origin: top center;
    transition: all .25s linear;
    transition-delay: .25s
}
.DocSearch-Hit a {
    background: var(--docsearch-hit-background);
    border-radius: 4px;
    box-shadow: var(--docsearch-hit-shadow);
    display: block;
    padding-left: var(--docsearch-spacing);
    width: 100%
}
.DocSearch-Hit-source {
    background: var(--docsearch-modal-background);
    color: var(--docsearch-highlight-color);
    font-size: .85em;
    font-weight: 600;
    line-height: 32px;
    margin: 0 -4px;
    padding: 8px 4px 0;
    position: sticky;
    top: 0;
    z-index: 10
}
.DocSearch-Hit-Tree {
    color: var(--docsearch-muted-color);
    height: var(--docsearch-hit-height);
    opacity: .5;
    stroke-width: var(--docsearch-icon-stroke-width);
    width: 24px
}
.DocSearch-Hit[aria-selected=true] a {
    background-color: var(--docsearch-highlight-color)
}
.DocSearch-Hit[aria-selected=true] mark {
    text-decoration: underline
}
.DocSearch-Hit-Container {
    align-items: center;
    color: var(--docsearch-hit-color);
    display: flex;
    flex-direction: row;
    height: var(--docsearch-hit-height);
    padding: 0 var(--docsearch-spacing) 0 0
}
.DocSearch-Hit-icon {
    height: 20px;
    width: 20px
}
.DocSearch-Hit-action, .DocSearch-Hit-icon {
    color: var(--docsearch-muted-color);
    stroke-width: var(--docsearch-icon-stroke-width)
}
.DocSearch-Hit-action {
    align-items: center;
    display: flex;
    height: 22px;
    width: 22px
}
.DocSearch-Hit-action svg {
    display: block;
    height: 18px;
    width: 18px
}
.DocSearch-Hit-action+.DocSearch-Hit-action {
    margin-left: 6px
}
.DocSearch-Hit-action-button {
    appearance: none;
    background: none;
    border: 0;
    border-radius: 50%;
    color: inherit;
    cursor: pointer;
    padding: 2px
}
svg.DocSearch-Hit-Select-Icon {
    display: none
}
.DocSearch-Hit[aria-selected=true] .DocSearch-Hit-Select-Icon {
    display: block
}
.DocSearch-Hit-action-button:focus, .DocSearch-Hit-action-button:hover {
    background: rgba(0, 0, 0, .2);
    transition: background-color .1s ease-in
}
@media screen and (prefers-reduced-motion:reduce) {
    .DocSearch-Hit-action-button:focus, .DocSearch-Hit-action-button:hover {
        transition: none
    }
}
.DocSearch-Hit-action-button:focus path, .DocSearch-Hit-action-button:hover path {
    fill: #fff
}
.DocSearch-Hit-content-wrapper {
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
    font-weight: 500;
    justify-content: center;
    line-height: 1.2em;
    margin: 0 8px;
    overflow-x: hidden;
    position: relative;
    text-overflow: ellipsis;
    white-space: nowrap;
    width: 80%
}
.DocSearch-Hit-title {
    font-size: .9em
}
.DocSearch-Hit-path {
    color: var(--docsearch-muted-color);
    font-size: .75em
}
.DocSearch-Hit[aria-selected=true] .DocSearch-Hit-Tree, .DocSearch-Hit[aria-selected=true] .DocSearch-Hit-action, .DocSearch-Hit[aria-selected=true] .DocSearch-Hit-icon, .DocSearch-Hit[aria-selected=true] .DocSearch-Hit-path, .DocSearch-Hit[aria-selected=true] .DocSearch-Hit-text, .DocSearch-Hit[aria-selected=true] .DocSearch-Hit-title, .DocSearch-Hit[aria-selected=true] mark {
    color: var(--docsearch-hit-active-color)!important
}
@media screen and (prefers-reduced-motion:reduce) {
    .DocSearch-Hit-action-button:focus, .DocSearch-Hit-action-button:hover {
        background: rgba(0, 0, 0, .2);
        transition: none
    }
}
.DocSearch-ErrorScreen, .DocSearch-NoResults, .DocSearch-StartScreen {
    font-size: .9em;
    margin: 0 auto;
    padding: 36px 0;
    text-align: center;
    width: 80%
}
.DocSearch-Screen-Icon {
    color: var(--docsearch-muted-color);
    padding-bottom: 12px
}
.DocSearch-NoResults-Prefill-List {
    display: inline-block;
    padding-bottom: 24px;
    text-align: left
}
.DocSearch-NoResults-Prefill-List ul {
    display: inline-block;
    padding: 8px 0 0
}
.DocSearch-NoResults-Prefill-List li {
    list-style-position: inside;
    list-style-type: "» "
}
.DocSearch-Prefill {
    appearance: none;
    background: none;
    border: 0;
    border-radius: 1em;
    color: var(--docsearch-highlight-color);
    cursor: pointer;
    display: inline-block;
    font-size: 1em;
    font-weight: 700;
    padding: 0
}
.DocSearch-Prefill:focus, .DocSearch-Prefill:hover {
    outline: none;
    text-decoration: underline
}
.DocSearch-Footer {
    align-items: center;
    background: var(--docsearch-footer-background);
    border-radius: 0 0 8px 8px;
    box-shadow: var(--docsearch-footer-shadow);
    display: flex;
    flex-direction: row-reverse;
    flex-shrink: 0;
    height: var(--docsearch-footer-height);
    justify-content: space-between;
    padding: 0 var(--docsearch-spacing);
    position: relative;
    user-select: none;
    width: 100%;
    z-index: 300
}
.DocSearch-Commands {
    color: var(--docsearch-muted-color);
    display: flex;
    list-style: none;
    margin: 0;
    padding: 0
}
.DocSearch-Commands li {
    align-items: center;
    display: flex
}
.DocSearch-Commands li:not(:last-of-type) {
    margin-right: .8em
}
.DocSearch-Commands-Key {
    align-items: center;
    background: var(--docsearch-key-gradient);
    border: 0;
    border-radius: 2px;
    box-shadow: var(--docsearch-key-shadow);
    color: var(--docsearch-muted-color);
    display: flex;
    height: 18px;
    justify-content: center;
    margin-right: .4em;
    padding: 0 0 1px;
    width: 20px
}
.DocSearch-VisuallyHiddenForAccessibility {
    clip: rect(0 0 0 0);
    clip-path: inset(50%);
    height: 1px;
    overflow: hidden;
    position: absolute;
    white-space: nowrap;
    width: 1px
}
@media (max-width:768px) {
    :root {
        --docsearch-spacing: 10px;
        --docsearch-footer-height: 40px
    }
    .DocSearch-Dropdown {
        height: 100%
    }
    .DocSearch-Container {
        height: 100vh;
        height: -webkit-fill-available;
        height: calc(var(--docsearch-vh, 1vh)*100);
        position: absolute
    }
    .DocSearch-Footer {
        border-radius: 0;
        bottom: 0;
        position: absolute
    }
    .DocSearch-Hit-content-wrapper {
        display: flex;
        position: relative;
        width: 80%
    }
    .DocSearch-Modal {
        border-radius: 0;
        box-shadow: none;
        height: 100vh;
        height: -webkit-fill-available;
        height: calc(var(--docsearch-vh, 1vh)*100);
        margin: 0;
        max-width: 100%;
        width: 100%
    }
    .DocSearch-Dropdown {
        max-height: calc(var(--docsearch-vh, 1vh)*100 - var(--docsearch-searchbox-height) - var(--docsearch-spacing) - var(--docsearch-footer-height))
    }
    .DocSearch-Cancel {
        appearance: none;
        background: none;
        border: 0;
        color: var(--docsearch-highlight-color);
        cursor: pointer;
        display: inline-block;
        flex: none;
        font: inherit;
        font-size: 1em;
        font-weight: 500;
        margin-left: var(--docsearch-spacing);
        outline: none;
        overflow: hidden;
        padding: 0;
        user-select: none;
        white-space: nowrap
    }
    .DocSearch-Commands, .DocSearch-Hit-Tree {
        display: none
    }
}
@keyframes fade-in {
    0% {
        opacity: 0
    }
    to {
        opacity: 1
    }
}
[class*='DocSearch'] {
    --docsearch-primary-color: var(--vp-c-brand-1);
    --docsearch-highlight-color: var(--docsearch-primary-color);
    --docsearch-text-color: var(--vp-c-text-1);
    --docsearch-muted-color: var(--vp-c-text-2);
    --docsearch-searchbox-shadow: none;
    --docsearch-searchbox-background: transparent;
    --docsearch-searchbox-focus-background: transparent;
    --docsearch-key-gradient: transparent;
    --docsearch-key-shadow: none;
    --docsearch-modal-background: var(--vp-c-bg-soft);
    --docsearch-footer-background: var(--vp-c-bg);
}
.dark [class*='DocSearch'] {
    --docsearch-modal-shadow: none;
    --docsearch-footer-shadow: none;
    --docsearch-logo-color: var(--vp-c-text-2);
    --docsearch-hit-background: var(--vp-c-default-soft);
    --docsearch-hit-color: var(--vp-c-text-2);
    --docsearch-hit-shadow: none;
}
.DocSearch-Button {
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0;
    padding: 0;
    width: 48px;
    height: 55px;
    background: transparent;
    transition: border-color 0.25s;
}
.DocSearch-Button:hover {
    background: transparent;
}
.DocSearch-Button:focus {
    outline: 1px dotted;
    outline: 5px auto -webkit-focus-ring-color;
}
.DocSearch-Button-Key--pressed {
    transform: none;
    box-shadow: none;
}
.DocSearch-Button:focus:not(:focus-visible) {
    outline: none !important;
}
@media (min-width: 768px) {
    .DocSearch-Button {
        justify-content: flex-start;
        border: 1px solid transparent;
        border-radius: 8px;
        padding: 0 10px 0 12px;
        width: 100%;
        height: 40px;
        background-color: var(--vp-c-bg-alt);
    }
    .DocSearch-Button:hover {
        border-color: var(--vp-c-brand-1);
        background: var(--vp-c-bg-alt);
    }
}
.DocSearch-Button .DocSearch-Button-Container {
    display: flex;
    align-items: center;
}
.DocSearch-Button .DocSearch-Search-Icon {
    position: relative;
    width: 16px;
    height: 16px;
    color: var(--vp-c-text-1);
    fill: currentColor;
    transition: color 0.5s;
}
.DocSearch-Button:hover .DocSearch-Search-Icon {
    color: var(--vp-c-text-1);
}
@media (min-width: 768px) {
    .DocSearch-Button .DocSearch-Search-Icon {
        top: 1px;
        margin-right: 8px;
        width: 14px;
        height: 14px;
        color: var(--vp-c-text-2);
    }
}
.DocSearch-Button .DocSearch-Button-Placeholder {
    display: none;
    margin-top: 2px;
    padding: 0 16px 0 0;
    font-size: 13px;
    font-weight: 500;
    color: var(--vp-c-text-2);
    transition: color 0.5s;
}
.DocSearch-Button:hover .DocSearch-Button-Placeholder {
    color: var(--vp-c-text-1);
}
@media (min-width: 768px) {
    .DocSearch-Button .DocSearch-Button-Placeholder {
        display: inline-block;
    }
}
.DocSearch-Button .DocSearch-Button-Keys {
    /*rtl:ignore*/
    direction: ltr;
    display: none;
    min-width: auto;
}
@media (min-width: 768px) {
    .DocSearch-Button .DocSearch-Button-Keys {
        display: flex;
        align-items: center;
    }
}
.DocSearch-Button .DocSearch-Button-Key {
    display: block;
    margin: 2px 0 0 0;
    border: 1px solid var(--vp-c-divider);
    /*rtl:begin:ignore*/
    border-right: none;
    border-radius: 4px 0 0 4px;
    padding-left: 6px;
    /*rtl:end:ignore*/
    min-width: 0;
    width: auto;
    height: 22px;
    line-height: 22px;
    font-family: var(--vp-font-family-base);
    font-size: 12px;
    font-weight: 500;
    transition: color 0.5s, border-color 0.5s;
}
.DocSearch-Button .DocSearch-Button-Key+.DocSearch-Button-Key {
    /*rtl:begin:ignore*/
    border-right: 1px solid var(--vp-c-divider);
    border-left: none;
    border-radius: 0 4px 4px 0;
    padding-left: 2px;
    padding-right: 6px;
    /*rtl:end:ignore*/
}
.DocSearch-Button .DocSearch-Button-Key:first-child {
    font-size: 0 !important;
}
.DocSearch-Button .DocSearch-Button-Key:first-child:after {
    content: 'Ctrl';
    font-size: 12px;
    letter-spacing: normal;
    color: var(--docsearch-muted-color);
}
.mac .DocSearch-Button .DocSearch-Button-Key:first-child:after {
    content: '\2318';
}
.DocSearch-Button .DocSearch-Button-Key:first-child>* {
    display: none;
}
.DocSearch-Search-Icon {
    --icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' stroke-width='1.6' viewBox='0 0 20 20'%3E%3Cpath fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' d='m14.386 14.386 4.088 4.088-4.088-4.088A7.533 7.533 0 1 1 3.733 3.733a7.533 7.533 0 0 1 10.653 10.653z'/%3E%3C/svg%3E");
}
.VPNavBarSearch {
    display: flex;
    align-items: center;
}
@media (min-width: 768px) {
    .VPNavBarSearch {
        flex-grow: 1;
        padding-left: 24px;
    }
}
@media (min-width: 960px) {
    .VPNavBarSearch {
        padding-left: 32px;
    }
}
.dark .DocSearch-Footer {
    border-top: 1px solid var(--vp-c-divider);
}
.DocSearch-Form {
    border: 1px solid var(--vp-c-brand-1);
    background-color: var(--vp-c-white);
}
.dark .DocSearch-Form {
    background-color: var(--vp-c-default-soft);
}
.DocSearch-Screen-Icon>svg {
    margin: auto;
}
.VPNavBarSocialLinks[data-v-e36d8c48] {
    display: none;
}
@media (min-width: 1280px) {
    .VPNavBarSocialLinks[data-v-e36d8c48] {
        display: flex;
        align-items: center;
    }
}
.title[data-v-bf706f89] {
    display: flex;
    align-items: center;
    border-bottom: 1px solid transparent;
    width: 100%;
    height: var(--vp-nav-height);
    font-size: 16px;
    font-weight: 600;
    color: var(--vp-c-text-1);
    transition: opacity 0.25s;
}
@media (min-width: 960px) {
    .title[data-v-bf706f89] {
        flex-shrink: 0;
    }
    .VPNavBarTitle.has-sidebar .title[data-v-bf706f89] {
        border-bottom-color: var(--vp-c-divider);
    }
}
[data-v-bf706f89] .logo {
    margin-right: 8px;
    height: var(--vp-nav-logo-height);
}
.VPNavBarTranslations[data-v-d183260d] {
    display: none;
}
@media (min-width: 1280px) {
    .VPNavBarTranslations[data-v-d183260d] {
        display: flex;
        align-items: center;
    }
}
.title[data-v-d183260d] {
    padding: 0 24px 0 12px;
    line-height: 32px;
    font-size: 14px;
    font-weight: 700;
    color: var(--vp-c-text-1);
}
.VPNavBar[data-v-84a11e99] {
    position: relative;
    height: var(--vp-nav-height);
    pointer-events: none;
    white-space: nowrap;
    transition: background-color 0.25s;
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
}
.VPNavBar.screen-open[data-v-84a11e99] {
    transition: none;
    background-color: rgba(255, 255, 255, 0.8);
    border-bottom: 1px solid var(--vp-c-divider);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
}
.VPNavBar[data-v-84a11e99]:not(.home) {
    background-color: rgba(255, 255, 255, 0.7);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
}
.dark .VPNavBar[data-v-84a11e99]:not(.home) {
    background-color: rgba(0, 0, 0, 0.7);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
}
.dark .VPNavBar.screen-open[data-v-84a11e99] {
    background-color: rgba(0, 0, 0, 0.8);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
}
@media (min-width: 960px) {
    .VPNavBar[data-v-84a11e99]:not(.home) {
        background-color: rgba(255, 255, 255, 0.5);
        backdrop-filter: blur(20px);
        -webkit-backdrop-filter: blur(20px);
    }
    .dark .VPNavBar[data-v-84a11e99]:not(.home) {
        background-color: rgba(0, 0, 0, 0.5);
        backdrop-filter: blur(20px);
        -webkit-backdrop-filter: blur(20px);
    }
    .VPNavBar[data-v-84a11e99]:not(.has-sidebar):not(.home.top) {
        background-color: rgba(255, 255, 255, 0.7);
        backdrop-filter: blur(20px);
        -webkit-backdrop-filter: blur(20px);
    }
    .dark .VPNavBar[data-v-84a11e99]:not(.has-sidebar):not(.home.top) {
        background-color: rgba(0, 0, 0, 0.7);
        backdrop-filter: blur(20px);
        -webkit-backdrop-filter: blur(20px);
    }
}
.wrapper[data-v-84a11e99] {
    padding: 0 8px 0 24px;
}
@media (min-width: 768px) {
    .wrapper[data-v-84a11e99] {
        padding: 0 32px;
    }
}
@media (min-width: 960px) {
    .VPNavBar.has-sidebar .wrapper[data-v-84a11e99] {
        padding: 0;
    }
}
.container[data-v-84a11e99] {
    display: flex;
    justify-content: space-between;
    margin: 0 auto;
    max-width: calc(var(--vp-layout-max-width) - 64px);
    height: var(--vp-nav-height);
    pointer-events: none;
}
.container>.title[data-v-84a11e99], .container>.content[data-v-84a11e99] {
    pointer-events: none;
}
.container[data-v-84a11e99] * {
    pointer-events: auto;
}
@media (min-width: 960px) {
    .VPNavBar.has-sidebar .container[data-v-84a11e99] {
        max-width: 100%;
    }
}
.title[data-v-84a11e99] {
    flex-shrink: 0;
    height: calc(var(--vp-nav-height) - 1px);
    transition: background-color 0.5s;
}
@media (min-width: 960px) {
    .VPNavBar.has-sidebar .title[data-v-84a11e99] {
        position: absolute;
        top: 0;
        left: 0;
        z-index: 2;
        padding: 0 32px;
        width: var(--vp-sidebar-width);
        height: var(--vp-nav-height);
        background-color: transparent;
    }
}
@media (min-width: 1440px) {
    .VPNavBar.has-sidebar .title[data-v-84a11e99] {
        padding-left: max(32px, calc((100% - (var(--vp-layout-max-width) - 64px)) / 2));
        width: calc((100% - (var(--vp-layout-max-width) - 64px)) / 2 + var(--vp-sidebar-width) - 32px);
    }
}
.content[data-v-84a11e99] {
    flex-grow: 1;
}
@media (min-width: 960px) {
    .VPNavBar.has-sidebar .content[data-v-84a11e99] {
        position: relative;
        z-index: 1;
        padding-right: 32px;
        padding-left: var(--vp-sidebar-width);
    }
}
@media (min-width: 1440px) {
    .VPNavBar.has-sidebar .content[data-v-84a11e99] {
        padding-right: calc((100vw - var(--vp-layout-max-width)) / 2 + 32px);
        padding-left: calc((100vw - var(--vp-layout-max-width)) / 2 + var(--vp-sidebar-width));
    }
}
.content-body[data-v-84a11e99] {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    height: var(--vp-nav-height);
}
@media (min-width: 960px) {
    .VPNavBar:not(.home.top) .content-body[data-v-84a11e99] {
        position: relative;
        background-color: rgba(255, 255, 255, 0.7);
        backdrop-filter: blur(20px);
        -webkit-backdrop-filter: blur(20px);
    }
    .dark .VPNavBar:not(.home.top) .content-body[data-v-84a11e99] {
        background-color: rgba(0, 0, 0, 0.7);
        backdrop-filter: blur(20px);
        -webkit-backdrop-filter: blur(20px);
    }
    .VPNavBar:not(.has-sidebar):not(.home.top) .content-body[data-v-84a11e99] {
        background-color: rgba(255, 255, 255, 0.5);
        backdrop-filter: blur(20px);
        -webkit-backdrop-filter: blur(20px);
    }
    .dark .VPNavBar:not(.has-sidebar):not(.home.top) .content-body[data-v-84a11e99] {
        background-color: rgba(0, 0, 0, 0.5);
        backdrop-filter: blur(20px);
        -webkit-backdrop-filter: blur(20px);
    }
}
@media (max-width: 767px) {
    .content-body[data-v-84a11e99] {
        column-gap: 0.5rem;
    }
}
.menu+.translations[data-v-84a11e99]::before, .menu+.appearance[data-v-84a11e99]::before, .menu+.social-links[data-v-84a11e99]::before, .translations+.appearance[data-v-84a11e99]::before, .appearance+.social-links[data-v-84a11e99]::before {
    margin-right: 8px;
    margin-left: 8px;
    width: 1px;
    height: 24px;
    background-color: var(--vp-c-divider);
    content: "";
}
.menu+.appearance[data-v-84a11e99]::before, .translations+.appearance[data-v-84a11e99]::before {
    margin-right: 16px;
}
.appearance+.social-links[data-v-84a11e99]::before {
    margin-left: 16px;
}
.social-links[data-v-84a11e99] {
    margin-right: -8px;
}
.divider[data-v-84a11e99] {
    width: 100%;
    height: 1px;
    opacity: 0.2;
}
@media (min-width: 960px) {
    .VPNavBar.has-sidebar .divider[data-v-84a11e99] {
        padding-left: var(--vp-sidebar-width);
    }
}
@media (min-width: 1440px) {
    .VPNavBar.has-sidebar .divider[data-v-84a11e99] {
        padding-left: calc((100vw - var(--vp-layout-max-width)) / 2 + var(--vp-sidebar-width));
    }
}
.divider-line[data-v-84a11e99] {
    width: 100%;
    height: 1px;
    transition: background-color 0.5s;
}
.VPNavBar:not(.home) .divider-line[data-v-84a11e99] {
    background-color: var(--vp-c-gutter);
}
@media (min-width: 960px) {
    .VPNavBar:not(.home.top) .divider-line[data-v-84a11e99] {
        background-color: var(--vp-c-gutter);
    }
    .VPNavBar:not(.has-sidebar):not(.home.top) .divider[data-v-84a11e99] {
        background-color: var(--vp-c-gutter);
    }
}
.VPNavScreenAppearance[data-v-2525a03f] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-radius: 8px;
    padding: 12px 14px 12px 16px;
    background-color: var(--vp-c-bg-soft);
}
.text[data-v-2525a03f] {
    line-height: 24px;
    font-size: 12px;
    font-weight: 500;
    color: var(--vp-c-text-2);
}
.VPNavScreenMenuLink[data-v-09aa387a] {
    display: block;
    border-bottom: 1px solid var(--vp-c-divider);
    padding: 12px 0 11px;
    line-height: 24px;
    font-size: 14px;
    font-weight: 500;
    color: var(--vp-c-text-1);
    transition: border-color 0.25s, color 0.25s;
}
.VPNavScreenMenuLink[data-v-09aa387a]:hover {
    color: var(--vp-c-brand-1);
}
.VPNavScreenMenuGroupLink[data-v-39b07fbd] {
    display: block;
    margin-left: 12px;
    line-height: 32px;
    font-size: 14px;
    font-weight: 400;
    color: var(--vp-c-text-1);
    transition: color 0.25s;
}
.VPNavScreenMenuGroupLink[data-v-39b07fbd]:hover {
    color: var(--vp-c-brand-1);
}
.VPNavScreenMenuGroupSection[data-v-444959a7] {
    display: block;
}
.title[data-v-444959a7] {
    line-height: 32px;
    font-size: 13px;
    font-weight: 700;
    color: var(--vp-c-text-2);
    transition: color 0.25s;
}
.VPNavScreenMenuGroup[data-v-c0db8b53] {
    border-bottom: 1px solid var(--vp-c-divider);
    height: 48px;
    overflow: hidden;
    transition: border-color 0.5s;
}
.VPNavScreenMenuGroup .items[data-v-c0db8b53] {
    visibility: hidden;
}
.VPNavScreenMenuGroup.open .items[data-v-c0db8b53] {
    visibility: visible;
}
.VPNavScreenMenuGroup.open[data-v-c0db8b53] {
    padding-bottom: 10px;
    height: auto;
}
.VPNavScreenMenuGroup.open .button[data-v-c0db8b53] {
    padding-bottom: 6px;
    color: var(--vp-c-brand-1);
}
.VPNavScreenMenuGroup.open .button-icon[data-v-c0db8b53] {
    /*rtl:ignore*/
    transform: rotate(45deg);
}
.button[data-v-c0db8b53] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 4px 11px 0;
    width: 100%;
    line-height: 24px;
    font-size: 14px;
    font-weight: 500;
    color: var(--vp-c-text-1);
    transition: color 0.25s;
}
.button[data-v-c0db8b53]:hover {
    color: var(--vp-c-brand-1);
}
.button-icon[data-v-c0db8b53] {
    transition: transform 0.25s;
}
.group[data-v-c0db8b53]:first-child {
    padding-top: 0px;
}
.group+.group[data-v-c0db8b53], .group+.item[data-v-c0db8b53] {
    padding-top: 4px;
}
.VPNavScreenTranslations[data-v-c7d7af2f] {
    height: 24px;
    overflow: hidden;
}
.VPNavScreenTranslations.open[data-v-c7d7af2f] {
    height: auto;
}
.title[data-v-c7d7af2f] {
    display: flex;
    align-items: center;
    font-size: 14px;
    font-weight: 500;
    color: var(--vp-c-text-1);
}
.icon[data-v-c7d7af2f] {
    font-size: 16px;
}
.icon.lang[data-v-c7d7af2f] {
    margin-right: 8px;
}
.icon.chevron[data-v-c7d7af2f] {
    margin-left: 4px;
}
.list[data-v-c7d7af2f] {
    padding: 4px 0 0 24px;
}
.link[data-v-c7d7af2f] {
    line-height: 32px;
    font-size: 13px;
    color: var(--vp-c-text-1);
}
.VPNavScreen[data-v-e171555d] {
    position: fixed;
    top: calc(var(--vp-nav-height) + var(--vp-layout-top-height, 0px));
    /*rtl:ignore*/
    right: 0;
    bottom: 0;
    /*rtl:ignore*/
    left: 0;
    padding: 0 32px;
    width: 100%;
    background-color: var(--vp-nav-screen-bg-color);
    overflow-y: auto;
    transition: background-color 0.25s;
    pointer-events: auto;
}
.VPNavScreen.fade-enter-active[data-v-e171555d], .VPNavScreen.fade-leave-active[data-v-e171555d] {
    transition: opacity 0.25s;
}
.VPNavScreen.fade-enter-active .container[data-v-e171555d], .VPNavScreen.fade-leave-active .container[data-v-e171555d] {
    transition: transform 0.25s ease;
}
.VPNavScreen.fade-enter-from[data-v-e171555d], .VPNavScreen.fade-leave-to[data-v-e171555d] {
    opacity: 0;
}
.VPNavScreen.fade-enter-from .container[data-v-e171555d], .VPNavScreen.fade-leave-to .container[data-v-e171555d] {
    transform: translateY(-8px);
}
@media (min-width: 768px) {
    .VPNavScreen[data-v-e171555d] {
        display: none;
    }
}
.container[data-v-e171555d] {
    margin: 0 auto;
    padding: 24px 0 96px;
    max-width: 288px;
}
.menu+.translations[data-v-e171555d], .menu+.appearance[data-v-e171555d], .translations+.appearance[data-v-e171555d] {
    margin-top: 24px;
}
.menu+.social-links[data-v-e171555d] {
    margin-top: 16px;
}
.appearance+.social-links[data-v-e171555d] {
    margin-top: 16px;
}
.VPNav[data-v-14f22a90] {
    position: relative;
    top: var(--vp-layout-top-height, 0px);
    /*rtl:ignore*/
    left: 0;
    z-index: var(--vp-z-index-nav);
    width: 100%;
    pointer-events: none;
    transition: background-color 0.5s;
}
@media (min-width: 960px) {
    .VPNav[data-v-14f22a90] {
        position: fixed;
    }
}
.VPSidebarItem.level-0[data-v-64d7ab74] {
    padding-bottom: 24px;
}
.VPSidebarItem.collapsed.level-0[data-v-64d7ab74] {
    padding-bottom: 10px;
}
.item[data-v-64d7ab74] {
    position: relative;
    display: flex;
    width: 100%;
}
.VPSidebarItem.collapsible>.item[data-v-64d7ab74] {
    cursor: pointer;
}
.indicator[data-v-64d7ab74] {
    position: absolute;
    top: 6px;
    bottom: 6px;
    left: -17px;
    width: 2px;
    border-radius: 2px;
    transition: background-color 0.25s;
}
.VPSidebarItem.level-2.is-active>.item>.indicator[data-v-64d7ab74], .VPSidebarItem.level-3.is-active>.item>.indicator[data-v-64d7ab74], .VPSidebarItem.level-4.is-active>.item>.indicator[data-v-64d7ab74], .VPSidebarItem.level-5.is-active>.item>.indicator[data-v-64d7ab74] {
    background-color: var(--vp-c-brand-1);
}
.link[data-v-64d7ab74] {
    display: flex;
    align-items: center;
    flex-grow: 1;
}
.text[data-v-64d7ab74] {
    flex-grow: 1;
    padding: 4px 0;
    line-height: 24px;
    font-size: 14px;
    transition: color 0.25s;
}
.VPSidebarItem.level-0 .text[data-v-64d7ab74] {
    font-weight: 700;
    color: var(--vp-c-text-1);
}
.VPSidebarItem.level-1 .text[data-v-64d7ab74], .VPSidebarItem.level-2 .text[data-v-64d7ab74], .VPSidebarItem.level-3 .text[data-v-64d7ab74], .VPSidebarItem.level-4 .text[data-v-64d7ab74], .VPSidebarItem.level-5 .text[data-v-64d7ab74] {
    font-weight: 500;
    color: var(--vp-c-text-2);
}
.VPSidebarItem.level-0.is-link>.item>.link:hover .text[data-v-64d7ab74], .VPSidebarItem.level-1.is-link>.item>.link:hover .text[data-v-64d7ab74], .VPSidebarItem.level-2.is-link>.item>.link:hover .text[data-v-64d7ab74], .VPSidebarItem.level-3.is-link>.item>.link:hover .text[data-v-64d7ab74], .VPSidebarItem.level-4.is-link>.item>.link:hover .text[data-v-64d7ab74], .VPSidebarItem.level-5.is-link>.item>.link:hover .text[data-v-64d7ab74] {
    color: var(--vp-c-brand-1);
}
.VPSidebarItem.level-0.has-active>.item>.text[data-v-64d7ab74], .VPSidebarItem.level-1.has-active>.item>.text[data-v-64d7ab74], .VPSidebarItem.level-2.has-active>.item>.text[data-v-64d7ab74], .VPSidebarItem.level-3.has-active>.item>.text[data-v-64d7ab74], .VPSidebarItem.level-4.has-active>.item>.text[data-v-64d7ab74], .VPSidebarItem.level-5.has-active>.item>.text[data-v-64d7ab74], .VPSidebarItem.level-0.has-active>.item>.link>.text[data-v-64d7ab74], .VPSidebarItem.level-1.has-active>.item>.link>.text[data-v-64d7ab74], .VPSidebarItem.level-2.has-active>.item>.link>.text[data-v-64d7ab74], .VPSidebarItem.level-3.has-active>.item>.link>.text[data-v-64d7ab74], .VPSidebarItem.level-4.has-active>.item>.link>.text[data-v-64d7ab74], .VPSidebarItem.level-5.has-active>.item>.link>.text[data-v-64d7ab74] {
    color: var(--vp-c-text-1);
}
.VPSidebarItem.level-0.is-active>.item .link>.text[data-v-64d7ab74], .VPSidebarItem.level-1.is-active>.item .link>.text[data-v-64d7ab74], .VPSidebarItem.level-2.is-active>.item .link>.text[data-v-64d7ab74], .VPSidebarItem.level-3.is-active>.item .link>.text[data-v-64d7ab74], .VPSidebarItem.level-4.is-active>.item .link>.text[data-v-64d7ab74], .VPSidebarItem.level-5.is-active>.item .link>.text[data-v-64d7ab74] {
    color: var(--vp-c-brand-1);
}
.caret[data-v-64d7ab74] {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-right: -7px;
    width: 32px;
    height: 32px;
    color: var(--vp-c-text-3);
    cursor: pointer;
    transition: color 0.25s;
    flex-shrink: 0;
}
.item:hover .caret[data-v-64d7ab74] {
    color: var(--vp-c-text-2);
}
.item:hover .caret[data-v-64d7ab74]:hover {
    color: var(--vp-c-text-1);
}
.caret-icon[data-v-64d7ab74] {
    font-size: 18px;
    transform: rotate(90deg);
    transition: transform 0.25s;
}
.VPSidebarItem.collapsed .caret-icon[data-v-64d7ab74] {
    transform: rotate(0);
}
.VPSidebarItem.level-1 .items[data-v-64d7ab74], .VPSidebarItem.level-2 .items[data-v-64d7ab74], .VPSidebarItem.level-3 .items[data-v-64d7ab74], .VPSidebarItem.level-4 .items[data-v-64d7ab74], .VPSidebarItem.level-5 .items[data-v-64d7ab74] {
    border-left: 1px solid var(--vp-c-divider);
    padding-left: 16px;
}
.VPSidebarItem.collapsed .items[data-v-64d7ab74] {
    display: none;
}
.no-transition[data-v-76ae14df] .caret-icon {
    transition: none;
}
.group+.group[data-v-76ae14df] {
    border-top: 1px solid var(--vp-c-divider);
    padding-top: 10px;
}
@media (min-width: 960px) {
    .group[data-v-76ae14df] {
        padding-top: 10px;
        width: calc(var(--vp-sidebar-width) - 64px);
    }
}
.VPSidebar[data-v-8f603b0e] {
    position: fixed;
    top: var(--vp-layout-top-height, 0px);
    bottom: 0;
    left: 0;
    z-index: var(--vp-z-index-sidebar);
    padding: 32px 32px 96px;
    width: calc(100vw - 64px);
    max-width: 320px;
    background-color: var(--vp-sidebar-bg-color);
    opacity: 0;
    box-shadow: var(--vp-c-shadow-3);
    overflow-x: hidden;
    overflow-y: auto;
    transform: translateX(-100%);
    transition: opacity 0.5s, transform 0.25s ease;
    overscroll-behavior: contain;
    display: none;
}
.VPSidebar.open[data-v-8f603b0e] {
    opacity: 1;
    visibility: visible;
    transform: translateX(0);
    transition: opacity 0.25s, transform 0.5s cubic-bezier(0.19, 1, 0.22, 1);
    display: block;
}
.dark .VPSidebar[data-v-8f603b0e] {
    box-shadow: var(--vp-shadow-1);
}
@media (min-width: 960px) {
    .VPSidebar[data-v-8f603b0e] {
        padding-top: var(--vp-nav-height);
        width: var(--vp-sidebar-width);
        max-width: 100%;
        background-color: var(--vp-sidebar-bg-color);
        opacity: 1;
        visibility: visible;
        box-shadow: none;
        transform: translateX(0);
    }
}
@media (min-width: 1440px) {
    .VPSidebar[data-v-8f603b0e] {
        padding-left: max(32px, calc((100% - (var(--vp-layout-max-width) - 64px)) / 2));
        width: calc((100% - (var(--vp-layout-max-width) - 64px)) / 2 + var(--vp-sidebar-width) - 32px);
    }
}
@media (min-width: 960px) {
    .curtain[data-v-8f603b0e] {
        position: sticky;
        top: -64px;
        left: 0;
        z-index: 1;
        margin-top: calc(var(--vp-nav-height) * -1);
        margin-right: -32px;
        margin-left: -32px;
        height: var(--vp-nav-height);
        background-color: var(--vp-sidebar-bg-color);
    }
}
.nav[data-v-8f603b0e] {
    outline: 0;
}
.VPSkipLink[data-v-e400f712] {
    top: 8px;
    left: 8px;
    padding: 8px 16px;
    z-index: 999;
    border-radius: 8px;
    font-size: 12px;
    font-weight: bold;
    text-decoration: none;
    color: var(--vp-c-brand-1);
    box-shadow: var(--vp-shadow-3);
    background-color: var(--vp-c-bg);
}
.VPSkipLink[data-v-e400f712]:focus {
    height: auto;
    width: auto;
    clip: auto;
    clip-path: none;
}
@media (min-width: 1280px) {
    .VPSkipLink[data-v-e400f712] {
        top: 14px;
        left: 16px;
    }
}
.Layout[data-v-702a693e] {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}
.VPHomeSponsors[data-v-03a0255c] {
    border-top: 1px solid var(--vp-c-gutter);
    padding-top: 88px !important;
}
.VPHomeSponsors[data-v-03a0255c] {
    margin: 96px 0;
}
@media (min-width: 768px) {
    .VPHomeSponsors[data-v-03a0255c] {
        margin: 128px 0;
    }
}
.VPHomeSponsors[data-v-03a0255c] {
    padding: 0 24px;
}
@media (min-width: 768px) {
    .VPHomeSponsors[data-v-03a0255c] {
        padding: 0 48px;
    }
}
@media (min-width: 960px) {
    .VPHomeSponsors[data-v-03a0255c] {
        padding: 0 64px;
    }
}
.container[data-v-03a0255c] {
    margin: 0 auto;
    max-width: 1152px;
}
.love[data-v-03a0255c] {
    margin: 0 auto;
    width: fit-content;
    font-size: 28px;
    color: var(--vp-c-text-3);
}
.icon[data-v-03a0255c] {
    display: inline-block;
}
.message[data-v-03a0255c] {
    margin: 0 auto;
    padding-top: 10px;
    max-width: 320px;
    text-align: center;
    line-height: 24px;
    font-size: 16px;
    font-weight: 500;
    color: var(--vp-c-text-2);
}
.sponsors[data-v-03a0255c] {
    padding-top: 32px;
}
.action[data-v-03a0255c] {
    padding-top: 40px;
    text-align: center;
}
.VPTeamPage[data-v-411e7cee] {
    margin: 96px 0;
}
@media (min-width: 768px) {
    .VPTeamPage[data-v-411e7cee] {
        margin: 128px 0;
    }
}
.VPHome .VPTeamPageTitle[data-v-411e7cee-s] {
    border-top: 1px solid var(--vp-c-gutter);
    padding-top: 88px !important;
}
.VPTeamPageSection+.VPTeamPageSection[data-v-411e7cee-s], .VPTeamMembers+.VPTeamPageSection[data-v-411e7cee-s] {
    margin-top: 64px;
}
.VPTeamMembers+.VPTeamMembers[data-v-411e7cee-s] {
    margin-top: 24px;
}
@media (min-width: 768px) {
    .VPTeamPageTitle+.VPTeamPageSection[data-v-411e7cee-s] {
        margin-top: 16px;
    }
    .VPTeamPageSection+.VPTeamPageSection[data-v-411e7cee-s], .VPTeamMembers+.VPTeamPageSection[data-v-411e7cee-s] {
        margin-top: 96px;
    }
}
.VPTeamMembers[data-v-411e7cee-s] {
    padding: 0 24px;
}
@media (min-width: 768px) {
    .VPTeamMembers[data-v-411e7cee-s] {
        padding: 0 48px;
    }
}
@media (min-width: 960px) {
    .VPTeamMembers[data-v-411e7cee-s] {
        padding: 0 64px;
    }
}
.VPTeamPageTitle[data-v-f3b658bb] {
    padding: 48px 32px;
    text-align: center;
}
@media (min-width: 768px) {
    .VPTeamPageTitle[data-v-f3b658bb] {
        padding: 64px 48px 48px;
    }
}
@media (min-width: 960px) {
    .VPTeamPageTitle[data-v-f3b658bb] {
        padding: 80px 64px 48px;
    }
}
.title[data-v-f3b658bb] {
    letter-spacing: 0;
    line-height: 44px;
    font-size: 36px;
    font-weight: 500;
}
@media (min-width: 768px) {
    .title[data-v-f3b658bb] {
        letter-spacing: -0.5px;
        line-height: 56px;
        font-size: 48px;
    }
}
.lead[data-v-f3b658bb] {
    margin: 0 auto;
    max-width: 512px;
    padding-top: 12px;
    line-height: 24px;
    font-size: 16px;
    font-weight: 500;
    color: var(--vp-c-text-2);
}
@media (min-width: 768px) {
    .lead[data-v-f3b658bb] {
        max-width: 592px;
        letter-spacing: 0.15px;
        line-height: 28px;
        font-size: 20px;
    }
}
.VPTeamPageSection[data-v-b6e10b03] {
    padding: 0 32px;
}
@media (min-width: 768px) {
    .VPTeamPageSection[data-v-b6e10b03] {
        padding: 0 48px;
    }
}
@media (min-width: 960px) {
    .VPTeamPageSection[data-v-b6e10b03] {
        padding: 0 64px;
    }
}
.title[data-v-b6e10b03] {
    position: relative;
    margin: 0 auto;
    max-width: 1152px;
    text-align: center;
    color: var(--vp-c-text-2);
}
.title-line[data-v-b6e10b03] {
    position: absolute;
    top: 16px;
    left: 0;
    width: 100%;
    height: 1px;
    background-color: var(--vp-c-divider);
}
.title-text[data-v-b6e10b03] {
    position: relative;
    display: inline-block;
    padding: 0 24px;
    letter-spacing: 0;
    line-height: 32px;
    font-size: 20px;
    font-weight: 500;
    background-color: var(--vp-c-bg);
}
.lead[data-v-b6e10b03] {
    margin: 0 auto;
    max-width: 480px;
    padding-top: 12px;
    text-align: center;
    line-height: 24px;
    font-size: 16px;
    font-weight: 500;
    color: var(--vp-c-text-2);
}
.members[data-v-b6e10b03] {
    padding-top: 40px;
}
.VPTeamMembersItem[data-v-c214abfa] {
    display: flex;
    flex-direction: column;
    gap: 2px;
    border-radius: 12px;
    width: 100%;
    height: 100%;
    overflow: hidden;
}
.VPTeamMembersItem.small .profile[data-v-c214abfa] {
    padding: 32px;
}
.VPTeamMembersItem.small .data[data-v-c214abfa] {
    padding-top: 20px;
}
.VPTeamMembersItem.small .avatar[data-v-c214abfa] {
    width: 64px;
    height: 64px;
}
.VPTeamMembersItem.small .name[data-v-c214abfa] {
    line-height: 24px;
    font-size: 16px;
}
.VPTeamMembersItem.small .affiliation[data-v-c214abfa] {
    padding-top: 4px;
    line-height: 20px;
    font-size: 14px;
}
.VPTeamMembersItem.small .desc[data-v-c214abfa] {
    padding-top: 12px;
    line-height: 20px;
    font-size: 14px;
}
.VPTeamMembersItem.small .links[data-v-c214abfa] {
    margin: 0 -16px -20px;
    padding: 10px 0 0;
}
.VPTeamMembersItem.medium .profile[data-v-c214abfa] {
    padding: 48px 32px;
}
.VPTeamMembersItem.medium .data[data-v-c214abfa] {
    padding-top: 24px;
    text-align: center;
}
.VPTeamMembersItem.medium .avatar[data-v-c214abfa] {
    width: 96px;
    height: 96px;
}
.VPTeamMembersItem.medium .name[data-v-c214abfa] {
    letter-spacing: 0.15px;
    line-height: 28px;
    font-size: 20px;
}
.VPTeamMembersItem.medium .affiliation[data-v-c214abfa] {
    padding-top: 4px;
    font-size: 16px;
}
.VPTeamMembersItem.medium .desc[data-v-c214abfa] {
    padding-top: 16px;
    max-width: 288px;
    font-size: 16px;
}
.VPTeamMembersItem.medium .links[data-v-c214abfa] {
    margin: 0 -16px -12px;
    padding: 16px 12px 0;
}
.profile[data-v-c214abfa] {
    flex-grow: 1;
    background-color: var(--vp-c-bg-soft);
}
.data[data-v-c214abfa] {
    text-align: center;
}
.avatar[data-v-c214abfa] {
    position: relative;
    flex-shrink: 0;
    margin: 0 auto;
    border-radius: 50%;
    box-shadow: var(--vp-shadow-3);
}
.avatar-img[data-v-c214abfa] {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    border-radius: 50%;
    object-fit: cover;
}
.name[data-v-c214abfa] {
    margin: 0;
    font-weight: 600;
}
.affiliation[data-v-c214abfa] {
    margin: 0;
    font-weight: 500;
    color: var(--vp-c-text-2);
}
.org.link[data-v-c214abfa] {
    color: var(--vp-c-text-2);
    transition: color 0.25s;
}
.org.link[data-v-c214abfa]:hover {
    color: var(--vp-c-brand-1);
}
.desc[data-v-c214abfa] {
    margin: 0 auto;
}
.desc[data-v-c214abfa] a {
    font-weight: 500;
    color: var(--vp-c-brand-1);
    text-decoration-style: dotted;
    transition: color 0.25s;
}
.links[data-v-c214abfa] {
    display: flex;
    justify-content: center;
    height: 56px;
}
.sp-link[data-v-c214abfa] {
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    padding: 16px;
    font-size: 14px;
    font-weight: 500;
    color: var(--vp-c-sponsor);
    background-color: var(--vp-c-bg-soft);
    transition: color 0.25s, background-color 0.25s;
}
.sp .sp-link.link[data-v-c214abfa]:hover, .sp .sp-link.link[data-v-c214abfa]:focus {
    outline: none;
    color: var(--vp-c-white);
    background-color: var(--vp-c-sponsor);
}
.sp-icon[data-v-c214abfa] {
    margin-right: 8px;
    font-size: 16px;
}
.VPTeamMembers.small .container[data-v-1aee4fb2] {
    grid-template-columns: repeat(auto-fit, minmax(224px, 1fr));
}
.VPTeamMembers.small.count-1 .container[data-v-1aee4fb2] {
    max-width: 276px;
}
.VPTeamMembers.small.count-2 .container[data-v-1aee4fb2] {
    max-width: calc(276px * 2 + 24px);
}
.VPTeamMembers.small.count-3 .container[data-v-1aee4fb2] {
    max-width: calc(276px * 3 + 24px * 2);
}
.VPTeamMembers.medium .container[data-v-1aee4fb2] {
    grid-template-columns: repeat(auto-fit, minmax(256px, 1fr));
}
@media (min-width: 375px) {
    .VPTeamMembers.medium .container[data-v-1aee4fb2] {
        grid-template-columns: repeat(auto-fit, minmax(288px, 1fr));
    }
}
.VPTeamMembers.medium.count-1 .container[data-v-1aee4fb2] {
    max-width: 368px;
}
.VPTeamMembers.medium.count-2 .container[data-v-1aee4fb2] {
    max-width: calc(368px * 2 + 24px);
}
.container[data-v-1aee4fb2] {
    display: grid;
    gap: 24px;
    margin: 0 auto;
    max-width: 1152px;
}
:root {
    --vp-c-brand-1: #209ce9;
    --vp-c-brand-2: #209ce9;
    --vp-c-brand-3: #209ce9;
    --vp-home-hero-name-color: transparent;
    --vp-home-hero-name-background: -webkit-linear-gradient(120deg, #209ce9 30%, #9C27B0);
    --vp-home-hero-image-background-image: linear-gradient(-45deg, rgb(16 61 141 / 20%) 40%, rgb(0 139 255 / 20%) 40%);
    --vp-home-hero-image-filter: blur(44px);
}
@media (min-width: 640px) {
    :root {
        --vp-home-hero-image-filter: blur(56px);
    }
}
@media (min-width: 960px) {
    :root {
        --vp-home-hero-image-filter: blur(68px);
    }
}
.hidden {
    display: none;
}
.iframe {
    width: 100%;
    border: none;
}
.VPHomeHero .VPImage {
    max-width: 160px;
}
.video {
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.2), 0 6px 20px 0 rgba(0, 0, 0, 0.19);
}
.package {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}
.package h3 {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    font-weight: bold;
    font-size: 1rem;
}
.package h3 img {
    width: 2rem;
}
.package p {
    margin-left: 1rem;
    padding-left: 1rem;
    border-left: 1px solid var(--vp-c-divider);
}
.schema {
    margin: 3rem auto;
    width: 100%;
}
.schema-stitcher {
    max-width: 400px;
}
.schema-dashboard {
    max-width: 300px;
}
.details.minimal {
    background-color: transparent;
    padding: 0;
}























.VPNavBarSearch {
    display: flex;
    align-items: center
}
@media (min-width: 768px) {
    .VPNavBarSearch {
        flex-grow: 1;
        padding-left: 24px
    }
}
@media (min-width: 960px) {
    .VPNavBarSearch {
        padding-left: 32px
    }
}
.dark .DocSearch-Footer {
    border-top: 1px solid var(--vp-c-divider)
}
.DocSearch-Form {
    border: 1px solid var(--vp-c-brand-1);
    background-color: var(--vp-c-white)
}
.dark .DocSearch-Form {
    background-color: var(--vp-c-default-soft)
}
.DocSearch-Screen-Icon>svg {
    margin: auto
}
.VPNavBarSocialLinks[data-v-331b41bb] {
    display: none
}
@media (min-width: 1280px) {
    .VPNavBarSocialLinks[data-v-331b41bb] {
        display: flex;
        align-items: center
    }
}
.title[data-v-ab8df553] {
    display: flex;
    align-items: center;
    border-bottom: 1px solid transparent;
    width: 100%;
    height: var(--vp-nav-height);
    font-size: 16px;
    font-weight: 600;
    color: var(--vp-c-text-1);
    transition: opacity .25s
}
@media (min-width: 960px) {
    .title[data-v-ab8df553] {
        flex-shrink: 0
    }
    .VPNavBarTitle.has-sidebar .title[data-v-ab8df553] {
        border-bottom-color: var(--vp-c-divider)
    }
}
[data-v-ab8df553] .logo {
    margin-right: 8px;
    height: var(--vp-nav-logo-height)
}
.VPNavBarTranslations[data-v-492a0c8e] {
    display: none
}
@media (min-width: 1280px) {
    .VPNavBarTranslations[data-v-492a0c8e] {
        display: flex;
        align-items: center
    }
}
.title[data-v-492a0c8e] {
    padding: 0 24px 0 12px;
    line-height: 32px;
    font-size: 14px;
    font-weight: 700;
    color: var(--vp-c-text-1)
}
.VPNavBar[data-v-2e8dfb4b] {
    position: relative;
    height: var(--vp-nav-height);
    pointer-events: none;
    white-space: nowrap;
    transition: background-color .25s
}
.VPNavBar.screen-open[data-v-2e8dfb4b] {
    transition: none;
    background-color: var(--vp-nav-bg-color);
    border-bottom: 1px solid var(--vp-c-divider)
}
.VPNavBar[data-v-2e8dfb4b]:not(.home) {
    background-color: var(--vp-nav-bg-color)
}
@media (min-width: 960px) {
    .VPNavBar[data-v-2e8dfb4b]:not(.home) {
        background-color: transparent
    }
    .VPNavBar[data-v-2e8dfb4b]:not(.has-sidebar):not(.home.top) {
        background-color: var(--vp-nav-bg-color)
    }
}
.wrapper[data-v-2e8dfb4b] {
    padding: 0 8px 0 24px
}
@media (min-width: 768px) {
    .wrapper[data-v-2e8dfb4b] {
        padding: 0 32px
    }
}
@media (min-width: 960px) {
    .VPNavBar.has-sidebar .wrapper[data-v-2e8dfb4b] {
        padding: 0
    }
}
.container[data-v-2e8dfb4b] {
    display: flex;
    justify-content: space-between;
    margin: 0 auto;
    max-width: calc(var(--vp-layout-max-width) - 64px);
    height: var(--vp-nav-height);
    pointer-events: none
}
.container>.title[data-v-2e8dfb4b], .container>.content[data-v-2e8dfb4b] {
    pointer-events: none
}
.container[data-v-2e8dfb4b] * {
    pointer-events: auto
}
@media (min-width: 960px) {
    .VPNavBar.has-sidebar .container[data-v-2e8dfb4b] {
        max-width: 100%
    }
}
.title[data-v-2e8dfb4b] {
    flex-shrink: 0;
    height: calc(var(--vp-nav-height) - 1px);
    transition: background-color .5s
}
@media (min-width: 960px) {
    .VPNavBar.has-sidebar .title[data-v-2e8dfb4b] {
        position: absolute;
        top: 0;
        left: 0;
        z-index: 2;
        padding: 0 32px;
        width: var(--vp-sidebar-width);
        height: var(--vp-nav-height);
        background-color: transparent
    }
}
@media (min-width: 1440px) {
    .VPNavBar.has-sidebar .title[data-v-2e8dfb4b] {
        padding-left: max(32px, calc((100% - (var(--vp-layout-max-width) - 64px)) / 2));
        width: calc((100% - (var(--vp-layout-max-width) - 64px)) / 2 + var(--vp-sidebar-width) - 32px)
    }
}
.content[data-v-2e8dfb4b] {
    flex-grow: 1
}
@media (min-width: 960px) {
    .VPNavBar.has-sidebar .content[data-v-2e8dfb4b] {
        position: relative;
        z-index: 1;
        padding-right: 32px;
        padding-left: var(--vp-sidebar-width)
    }
}
@media (min-width: 1440px) {
    .VPNavBar.has-sidebar .content[data-v-2e8dfb4b] {
        padding-right: calc((100vw - var(--vp-layout-max-width)) / 2 + 32px);
        padding-left: calc((100vw - var(--vp-layout-max-width)) / 2 + var(--vp-sidebar-width))
    }
}
.content-body[data-v-2e8dfb4b] {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    height: var(--vp-nav-height);
    transition: background-color .5s
}
@media (min-width: 960px) {
    .VPNavBar:not(.home.top) .content-body[data-v-2e8dfb4b] {
        position: relative;
        background-color: var(--vp-nav-bg-color)
    }
    .VPNavBar:not(.has-sidebar):not(.home.top) .content-body[data-v-2e8dfb4b] {
        background-color: transparent
    }
}
@media (max-width: 767px) {
    .content-body[data-v-2e8dfb4b] {
        column-gap: .5rem
    }
}
.menu+.translations[data-v-2e8dfb4b]:before, .menu+.appearance[data-v-2e8dfb4b]:before, .menu+.social-links[data-v-2e8dfb4b]:before, .translations+.appearance[data-v-2e8dfb4b]:before, .appearance+.social-links[data-v-2e8dfb4b]:before {
    margin-right: 8px;
    margin-left: 8px;
    width: 1px;
    height: 24px;
    background-color: var(--vp-c-divider);
    content: ""
}
.menu+.appearance[data-v-2e8dfb4b]:before, .translations+.appearance[data-v-2e8dfb4b]:before {
    margin-right: 16px
}
.appearance+.social-links[data-v-2e8dfb4b]:before {
    margin-left: 16px
}
.social-links[data-v-2e8dfb4b] {
    margin-right: -8px
}
.divider[data-v-2e8dfb4b] {
    width: 100%;
    height: 1px
}
@media (min-width: 960px) {
    .VPNavBar.has-sidebar .divider[data-v-2e8dfb4b] {
        padding-left: var(--vp-sidebar-width)
    }
}
@media (min-width: 1440px) {
    .VPNavBar.has-sidebar .divider[data-v-2e8dfb4b] {
        padding-left: calc((100vw - var(--vp-layout-max-width)) / 2 + var(--vp-sidebar-width))
    }
}
.divider-line[data-v-2e8dfb4b] {
    width: 100%;
    height: 1px;
    transition: background-color .5s
}
.VPNavBar:not(.home) .divider-line[data-v-2e8dfb4b] {
    background-color: var(--vp-c-gutter)
}
@media (min-width: 960px) {
    .VPNavBar:not(.home.top) .divider-line[data-v-2e8dfb4b] {
        background-color: var(--vp-c-gutter)
    }
    .VPNavBar:not(.has-sidebar):not(.home.top) .divider[data-v-2e8dfb4b] {
        background-color: var(--vp-c-gutter)
    }
}
.VPNavScreenAppearance[data-v-0a6f6206] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-radius: 8px;
    padding: 12px 14px 12px 16px;
    background-color: var(--vp-c-bg-soft)
}
.text[data-v-0a6f6206] {
    line-height: 24px;
    font-size: 12px;
    font-weight: 500;
    color: var(--vp-c-text-2)
}
.VPNavScreenMenuLink[data-v-5e10110c] {
    display: block;
    border-bottom: 1px solid var(--vp-c-divider);
    padding: 12px 0 11px;
    line-height: 24px;
    font-size: 14px;
    font-weight: 500;
    color: var(--vp-c-text-1);
    transition: border-color .25s, color .25s
}
.VPNavScreenMenuLink[data-v-5e10110c]:hover {
    color: var(--vp-c-brand-1)
}
.VPNavScreenMenuGroupLink[data-v-c2543e07] {
    display: block;
    margin-left: 12px;
    line-height: 32px;
    font-size: 14px;
    font-weight: 400;
    color: var(--vp-c-text-1);
    transition: color .25s
}
.VPNavScreenMenuGroupLink[data-v-c2543e07]:hover {
    color: var(--vp-c-brand-1)
}
.VPNavScreenMenuGroupSection[data-v-5e9ff4e1] {
    display: block
}
.title[data-v-5e9ff4e1] {
    line-height: 32px;
    font-size: 13px;
    font-weight: 700;
    color: var(--vp-c-text-2);
    transition: color .25s
}
.VPNavScreenMenuGroup[data-v-1dabfab8] {
    border-bottom: 1px solid var(--vp-c-divider);
    height: 48px;
    overflow: hidden;
    transition: border-color .5s
}
.VPNavScreenMenuGroup .items[data-v-1dabfab8] {
    visibility: hidden
}
.VPNavScreenMenuGroup.open .items[data-v-1dabfab8] {
    visibility: visible
}
.VPNavScreenMenuGroup.open[data-v-1dabfab8] {
    padding-bottom: 10px;
    height: auto
}
.VPNavScreenMenuGroup.open .button[data-v-1dabfab8] {
    padding-bottom: 6px;
    color: var(--vp-c-brand-1)
}
.VPNavScreenMenuGroup.open .button-icon[data-v-1dabfab8] {
    transform: rotate(45deg)
}
.button[data-v-1dabfab8] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 4px 11px 0;
    width: 100%;
    line-height: 24px;
    font-size: 14px;
    font-weight: 500;
    color: var(--vp-c-text-1);
    transition: color .25s
}
.button[data-v-1dabfab8]:hover {
    color: var(--vp-c-brand-1)
}
.button-icon[data-v-1dabfab8] {
    transition: transform .25s
}
.group[data-v-1dabfab8]:first-child {
    padding-top: 0
}
.group+.group[data-v-1dabfab8], .group+.item[data-v-1dabfab8] {
    padding-top: 4px
}
.VPNavScreenTranslations[data-v-9984abf6] {
    height: 24px;
    overflow: hidden
}
.VPNavScreenTranslations.open[data-v-9984abf6] {
    height: auto
}
.title[data-v-9984abf6] {
    display: flex;
    align-items: center;
    font-size: 14px;
    font-weight: 500;
    color: var(--vp-c-text-1)
}
.icon[data-v-9984abf6] {
    font-size: 16px
}
.icon.lang[data-v-9984abf6] {
    margin-right: 8px
}
.icon.chevron[data-v-9984abf6] {
    margin-left: 4px
}
.list[data-v-9984abf6] {
    padding: 4px 0 0 24px
}
.link[data-v-9984abf6] {
    line-height: 32px;
    font-size: 13px;
    color: var(--vp-c-text-1)
}


.VPNavScreen[data-v-1e3d9e14] {
    position: fixed;
    top: calc(var(--vp-nav-height) + var(--vp-layout-top-height, 0px));
    right: 0;
    bottom: 0;
    left: 0;
    padding: 0 32px;
    width: 100%;
    background-color: var(--vp-nav-screen-bg-color);
    overflow-y: auto;
    transition: background-color .25s;
    pointer-events: auto;
    z-index: 99;
    display: none;
}

.VPNavScreen[data-v-1e3d9e14].active {
    display: block;
}

.VPNavScreen.fade-enter-active[data-v-1e3d9e14], .VPNavScreen.fade-leave-active[data-v-1e3d9e14] {
    transition: opacity .25s
}
.VPNavScreen.fade-enter-active .container[data-v-1e3d9e14], .VPNavScreen.fade-leave-active .container[data-v-1e3d9e14] {
    transition: transform .25s ease
}
.VPNavScreen.fade-enter-from[data-v-1e3d9e14], .VPNavScreen.fade-leave-to[data-v-1e3d9e14] {
    opacity: 0
}
.VPNavScreen.fade-enter-from .container[data-v-1e3d9e14], .VPNavScreen.fade-leave-to .container[data-v-1e3d9e14] {
    transform: translateY(-8px)
}
@media (min-width: 768px) {
    .VPNavScreen[data-v-1e3d9e14] {
        display: none
    }
}


.container[data-v-1e3d9e14] {
    margin: 0 auto;
    padding: 24px 0 96px;
    max-width: 288px
}
.menu+.translations[data-v-1e3d9e14], .menu+.appearance[data-v-1e3d9e14], .translations+.appearance[data-v-1e3d9e14] {
    margin-top: 24px
}
.menu+.social-links[data-v-1e3d9e14] {
    margin-top: 16px
}
.appearance+.social-links[data-v-1e3d9e14] {
    margin-top: 16px
}
.VPNav[data-v-a3bfa20d] {
    position: relative;
    top: var(--vp-layout-top-height, 0px);
    left: 0;
    z-index: var(--vp-z-index-nav);
    width: 100%;
    pointer-events: none;
    transition: background-color .5s
}
@media (min-width: 960px) {
    .VPNav[data-v-a3bfa20d] {
        position: fixed
    }
}
.VPSidebarItem.level-0[data-v-2ad1f62a] {
    padding-bottom: 24px
}
.VPSidebarItem.collapsed.level-0[data-v-2ad1f62a] {
    padding-bottom: 10px
}
.item[data-v-2ad1f62a] {
    position: relative;
    display: flex;
    width: 100%
}
.VPSidebarItem.collapsible>.item[data-v-2ad1f62a] {
    cursor: pointer
}
.indicator[data-v-2ad1f62a] {
    position: absolute;
    top: 6px;
    bottom: 6px;
    left: -17px;
    width: 2px;
    border-radius: 2px;
    transition: background-color .25s
}
.VPSidebarItem.level-2.is-active>.item>.indicator[data-v-2ad1f62a], .VPSidebarItem.level-3.is-active>.item>.indicator[data-v-2ad1f62a], .VPSidebarItem.level-4.is-active>.item>.indicator[data-v-2ad1f62a], .VPSidebarItem.level-5.is-active>.item>.indicator[data-v-2ad1f62a] {
    background-color: var(--vp-c-brand-1)
}
.link[data-v-2ad1f62a] {
    display: flex;
    align-items: center;
    flex-grow: 1
}
.text[data-v-2ad1f62a] {
    flex-grow: 1;
    padding: 4px 0;
    line-height: 24px;
    font-size: 14px;
    transition: color .25s
}
.VPSidebarItem.level-0 .text[data-v-2ad1f62a] {
    font-weight: 700;
    color: var(--vp-c-text-1)
}
.VPSidebarItem.level-1 .text[data-v-2ad1f62a], .VPSidebarItem.level-2 .text[data-v-2ad1f62a], .VPSidebarItem.level-3 .text[data-v-2ad1f62a], .VPSidebarItem.level-4 .text[data-v-2ad1f62a], .VPSidebarItem.level-5 .text[data-v-2ad1f62a] {
    font-weight: 500;
    color: var(--vp-c-text-2)
}
.VPSidebarItem.level-0.is-link>.item>.link:hover .text[data-v-2ad1f62a], .VPSidebarItem.level-1.is-link>.item>.link:hover .text[data-v-2ad1f62a], .VPSidebarItem.level-2.is-link>.item>.link:hover .text[data-v-2ad1f62a], .VPSidebarItem.level-3.is-link>.item>.link:hover .text[data-v-2ad1f62a], .VPSidebarItem.level-4.is-link>.item>.link:hover .text[data-v-2ad1f62a], .VPSidebarItem.level-5.is-link>.item>.link:hover .text[data-v-2ad1f62a] {
    color: var(--vp-c-brand-1)
}
.VPSidebarItem.level-0.has-active>.item>.text[data-v-2ad1f62a], .VPSidebarItem.level-1.has-active>.item>.text[data-v-2ad1f62a], .VPSidebarItem.level-2.has-active>.item>.text[data-v-2ad1f62a], .VPSidebarItem.level-3.has-active>.item>.text[data-v-2ad1f62a], .VPSidebarItem.level-4.has-active>.item>.text[data-v-2ad1f62a], .VPSidebarItem.level-5.has-active>.item>.text[data-v-2ad1f62a], .VPSidebarItem.level-0.has-active>.item>.link>.text[data-v-2ad1f62a], .VPSidebarItem.level-1.has-active>.item>.link>.text[data-v-2ad1f62a], .VPSidebarItem.level-2.has-active>.item>.link>.text[data-v-2ad1f62a], .VPSidebarItem.level-3.has-active>.item>.link>.text[data-v-2ad1f62a], .VPSidebarItem.level-4.has-active>.item>.link>.text[data-v-2ad1f62a], .VPSidebarItem.level-5.has-active>.item>.link>.text[data-v-2ad1f62a] {
    color: var(--vp-c-text-1)
}
.VPSidebarItem.level-0.is-active>.item .link>.text[data-v-2ad1f62a], .VPSidebarItem.level-1.is-active>.item .link>.text[data-v-2ad1f62a], .VPSidebarItem.level-2.is-active>.item .link>.text[data-v-2ad1f62a], .VPSidebarItem.level-3.is-active>.item .link>.text[data-v-2ad1f62a], .VPSidebarItem.level-4.is-active>.item .link>.text[data-v-2ad1f62a], .VPSidebarItem.level-5.is-active>.item .link>.text[data-v-2ad1f62a] {
    color: var(--vp-c-brand-1)
}
.caret[data-v-2ad1f62a] {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-right: -7px;
    width: 32px;
    height: 32px;
    color: var(--vp-c-text-3);
    cursor: pointer;
    transition: color .25s;
    flex-shrink: 0
}
.item:hover .caret[data-v-2ad1f62a] {
    color: var(--vp-c-text-2)
}
.item:hover .caret[data-v-2ad1f62a]:hover {
    color: var(--vp-c-text-1)
}
.caret-icon[data-v-2ad1f62a] {
    font-size: 18px;
    transform: rotate(90deg);
    transition: transform .25s
}
.VPSidebarItem.collapsed .caret-icon[data-v-2ad1f62a] {
    transform: rotate(0)
}
.VPSidebarItem.level-1 .items[data-v-2ad1f62a], .VPSidebarItem.level-2 .items[data-v-2ad1f62a], .VPSidebarItem.level-3 .items[data-v-2ad1f62a], .VPSidebarItem.level-4 .items[data-v-2ad1f62a], .VPSidebarItem.level-5 .items[data-v-2ad1f62a] {
    border-left: 1px solid var(--vp-c-divider);
    padding-left: 16px
}
.VPSidebarItem.collapsed .items[data-v-2ad1f62a] {
    display: none
}
.no-transition[data-v-0d029714] .caret-icon {
    transition: none
}
.group+.group[data-v-0d029714] {
    border-top: 1px solid var(--vp-c-divider);
    padding-top: 10px
}
@media (min-width: 960px) {
    .group[data-v-0d029714] {
        padding-top: 10px;
        width: calc(var(--vp-sidebar-width) - 64px)
    }
}
.VPSidebar[data-v-38fc5113] {
    position: fixed;
    top: var(--vp-layout-top-height, 0px);
    bottom: 0;
    left: 0;
    z-index: var(--vp-z-index-sidebar);
    padding: 32px 32px 96px;
    width: calc(100vw - 64px);
    max-width: 320px;
    background-color: var(--vp-sidebar-bg-color);
    opacity: 0;
    box-shadow: var(--vp-c-shadow-3);
    overflow-x: hidden;
    overflow-y: auto;
    transform: translate(-100%);
    transition: opacity .5s, transform .25s ease;
    overscroll-behavior: contain
}
.VPSidebar.open[data-v-38fc5113] {
    opacity: 1;
    visibility: visible;
    transform: translate(0);
    transition: opacity .25s, transform .5s cubic-bezier(.19, 1, .22, 1)
}
.dark .VPSidebar[data-v-38fc5113] {
    box-shadow: var(--vp-shadow-1)
}
@media (min-width: 960px) {
    .VPSidebar[data-v-38fc5113] {
        padding-top: var(--vp-nav-height);
        width: var(--vp-sidebar-width);
        max-width: 100%;
        background-color: var(--vp-sidebar-bg-color);
        opacity: 1;
        visibility: visible;
        box-shadow: none;
        transform: translate(0)
    }
}
@media (min-width: 1440px) {
    .VPSidebar[data-v-38fc5113] {
        padding-left: max(32px, calc((100% - (var(--vp-layout-max-width) - 64px)) / 2));
        width: calc((100% - (var(--vp-layout-max-width) - 64px)) / 2 + var(--vp-sidebar-width) - 32px)
    }
}
@media (min-width: 960px) {
    .curtain[data-v-38fc5113] {
        position: sticky;
        top: -64px;
        left: 0;
        z-index: 1;
        margin-top: calc(var(--vp-nav-height) * -1);
        margin-right: -32px;
        margin-left: -32px;
        height: var(--vp-nav-height);
        background-color: var(--vp-sidebar-bg-color)
    }
}
.nav[data-v-38fc5113] {
    outline: 0
}
.VPSkipLink[data-v-0898fcf2] {
    top: 8px;
    left: 8px;
    padding: 8px 16px;
    z-index: 999;
    border-radius: 8px;
    font-size: 12px;
    font-weight: 700;
    text-decoration: none;
    color: var(--vp-c-brand-1);
    box-shadow: var(--vp-shadow-3);
    background-color: var(--vp-c-bg)
}
.VPSkipLink[data-v-0898fcf2]:focus {
    height: auto;
    width: auto;
    clip: auto;
    clip-path: none
}
@media (min-width: 1280px) {
    .VPSkipLink[data-v-0898fcf2] {
        top: 14px;
        left: 16px
    }
}
.Layout[data-v-24d6a1ec] {
    display: flex;
    flex-direction: column;
    min-height: 100vh
}
.VPHomeSponsors[data-v-bbb9440e] {
    border-top: 1px solid var(--vp-c-gutter);
    padding-top: 88px!important
}
.VPHomeSponsors[data-v-bbb9440e] {
    margin: 96px 0
}
@media (min-width: 768px) {
    .VPHomeSponsors[data-v-bbb9440e] {
        margin: 128px 0
    }
}
.VPHomeSponsors[data-v-bbb9440e] {
    padding: 0 24px
}
@media (min-width: 768px) {
    .VPHomeSponsors[data-v-bbb9440e] {
        padding: 0 48px
    }
}
@media (min-width: 960px) {
    .VPHomeSponsors[data-v-bbb9440e] {
        padding: 0 64px
    }
}
.container[data-v-bbb9440e] {
    margin: 0 auto;
    max-width: 1152px
}
.love[data-v-bbb9440e] {
    margin: 0 auto;
    width: fit-content;
    font-size: 28px;
    color: var(--vp-c-text-3)
}
.icon[data-v-bbb9440e] {
    display: inline-block
}
.message[data-v-bbb9440e] {
    margin: 0 auto;
    padding-top: 10px;
    max-width: 320px;
    text-align: center;
    line-height: 24px;
    font-size: 16px;
    font-weight: 500;
    color: var(--vp-c-text-2)
}
.sponsors[data-v-bbb9440e] {
    padding-top: 32px
}
.action[data-v-bbb9440e] {
    padding-top: 40px;
    text-align: center
}
.VPTeamPage[data-v-653ecf30] {
    margin: 96px 0
}
@media (min-width: 768px) {
    .VPTeamPage[data-v-653ecf30] {
        margin: 128px 0
    }
}
.VPHome .VPTeamPageTitle[data-v-653ecf30-s] {
    border-top: 1px solid var(--vp-c-gutter);
    padding-top: 88px!important
}
.VPTeamPageSection+.VPTeamPageSection[data-v-653ecf30-s], .VPTeamMembers+.VPTeamPageSection[data-v-653ecf30-s] {
    margin-top: 64px
}
.VPTeamMembers+.VPTeamMembers[data-v-653ecf30-s] {
    margin-top: 24px
}
@media (min-width: 768px) {
    .VPTeamPageTitle+.VPTeamPageSection[data-v-653ecf30-s] {
        margin-top: 16px
    }
    .VPTeamPageSection+.VPTeamPageSection[data-v-653ecf30-s], .VPTeamMembers+.VPTeamPageSection[data-v-653ecf30-s] {
        margin-top: 96px
    }
}
.VPTeamMembers[data-v-653ecf30-s] {
    padding: 0 24px
}
@media (min-width: 768px) {
    .VPTeamMembers[data-v-653ecf30-s] {
        padding: 0 48px
    }
}
@media (min-width: 960px) {
    .VPTeamMembers[data-v-653ecf30-s] {
        padding: 0 64px
    }
}
.VPTeamPageTitle[data-v-8d5a6ea3] {
    padding: 48px 32px;
    text-align: center
}
@media (min-width: 768px) {
    .VPTeamPageTitle[data-v-8d5a6ea3] {
        padding: 64px 48px 48px
    }
}
@media (min-width: 960px) {
    .VPTeamPageTitle[data-v-8d5a6ea3] {
        padding: 80px 64px 48px
    }
}
.title[data-v-8d5a6ea3] {
    letter-spacing: 0;
    line-height: 44px;
    font-size: 36px;
    font-weight: 500
}
@media (min-width: 768px) {
    .title[data-v-8d5a6ea3] {
        letter-spacing: -.5px;
        line-height: 56px;
        font-size: 48px
    }
}
.lead[data-v-8d5a6ea3] {
    margin: 0 auto;
    max-width: 512px;
    padding-top: 12px;
    line-height: 24px;
    font-size: 16px;
    font-weight: 500;
    color: var(--vp-c-text-2)
}
@media (min-width: 768px) {
    .lead[data-v-8d5a6ea3] {
        max-width: 592px;
        letter-spacing: .15px;
        line-height: 28px;
        font-size: 20px
    }
}
.VPTeamPageSection[data-v-b708baa9] {
    padding: 0 32px
}
@media (min-width: 768px) {
    .VPTeamPageSection[data-v-b708baa9] {
        padding: 0 48px
    }
}
@media (min-width: 960px) {
    .VPTeamPageSection[data-v-b708baa9] {
        padding: 0 64px
    }
}
.title[data-v-b708baa9] {
    position: relative;
    margin: 0 auto;
    max-width: 1152px;
    text-align: center;
    color: var(--vp-c-text-2)
}
.title-line[data-v-b708baa9] {
    position: absolute;
    top: 16px;
    left: 0;
    width: 100%;
    height: 1px;
    background-color: var(--vp-c-divider)
}
.title-text[data-v-b708baa9] {
    position: relative;
    display: inline-block;
    padding: 0 24px;
    letter-spacing: 0;
    line-height: 32px;
    font-size: 20px;
    font-weight: 500;
    background-color: var(--vp-c-bg)
}
.lead[data-v-b708baa9] {
    margin: 0 auto;
    max-width: 480px;
    padding-top: 12px;
    text-align: center;
    line-height: 24px;
    font-size: 16px;
    font-weight: 500;
    color: var(--vp-c-text-2)
}
.members[data-v-b708baa9] {
    padding-top: 40px
}
.VPTeamMembersItem[data-v-93d0b33a] {
    display: flex;
    flex-direction: column;
    gap: 2px;
    border-radius: 12px;
    width: 100%;
    height: 100%;
    overflow: hidden
}
.VPTeamMembersItem.small .profile[data-v-93d0b33a] {
    padding: 32px
}
.VPTeamMembersItem.small .data[data-v-93d0b33a] {
    padding-top: 20px
}
.VPTeamMembersItem.small .avatar[data-v-93d0b33a] {
    width: 64px;
    height: 64px
}
.VPTeamMembersItem.small .name[data-v-93d0b33a] {
    line-height: 24px;
    font-size: 16px
}
.VPTeamMembersItem.small .affiliation[data-v-93d0b33a] {
    padding-top: 4px;
    line-height: 20px;
    font-size: 14px
}
.VPTeamMembersItem.small .desc[data-v-93d0b33a] {
    padding-top: 12px;
    line-height: 20px;
    font-size: 14px
}
.VPTeamMembersItem.small .links[data-v-93d0b33a] {
    margin: 0 -16px -20px;
    padding: 10px 0 0
}
.VPTeamMembersItem.medium .profile[data-v-93d0b33a] {
    padding: 48px 32px
}
.VPTeamMembersItem.medium .data[data-v-93d0b33a] {
    padding-top: 24px;
    text-align: center
}
.VPTeamMembersItem.medium .avatar[data-v-93d0b33a] {
    width: 96px;
    height: 96px
}
.VPTeamMembersItem.medium .name[data-v-93d0b33a] {
    letter-spacing: .15px;
    line-height: 28px;
    font-size: 20px
}
.VPTeamMembersItem.medium .affiliation[data-v-93d0b33a] {
    padding-top: 4px;
    font-size: 16px
}
.VPTeamMembersItem.medium .desc[data-v-93d0b33a] {
    padding-top: 16px;
    max-width: 288px;
    font-size: 16px
}
.VPTeamMembersItem.medium .links[data-v-93d0b33a] {
    margin: 0 -16px -12px;
    padding: 16px 12px 0
}
.profile[data-v-93d0b33a] {
    flex-grow: 1;
    background-color: var(--vp-c-bg-soft)
}
.data[data-v-93d0b33a] {
    text-align: center
}
.avatar[data-v-93d0b33a] {
    position: relative;
    flex-shrink: 0;
    margin: 0 auto;
    border-radius: 50%;
    box-shadow: var(--vp-shadow-3)
}
.avatar-img[data-v-93d0b33a] {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    border-radius: 50%;
    object-fit: cover
}
.name[data-v-93d0b33a] {
    margin: 0;
    font-weight: 600
}
.affiliation[data-v-93d0b33a] {
    margin: 0;
    font-weight: 500;
    color: var(--vp-c-text-2)
}
.org.link[data-v-93d0b33a] {
    color: var(--vp-c-text-2);
    transition: color .25s
}
.org.link[data-v-93d0b33a]:hover {
    color: var(--vp-c-brand-1)
}
.desc[data-v-93d0b33a] {
    margin: 0 auto
}
.desc[data-v-93d0b33a] a {
    font-weight: 500;
    color: var(--vp-c-brand-1);
    text-decoration-style: dotted;
    transition: color .25s
}
.links[data-v-93d0b33a] {
    display: flex;
    justify-content: center;
    height: 56px
}
.sp-link[data-v-93d0b33a] {
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    padding: 16px;
    font-size: 14px;
    font-weight: 500;
    color: var(--vp-c-sponsor);
    background-color: var(--vp-c-bg-soft);
    transition: color .25s, background-color .25s
}
.sp .sp-link.link[data-v-93d0b33a]:hover, .sp .sp-link.link[data-v-93d0b33a]:focus {
    outline: none;
    color: var(--vp-c-white);
    background-color: var(--vp-c-sponsor)
}
.sp-icon[data-v-93d0b33a] {
    margin-right: 8px;
    font-size: 16px
}
.VPTeamMembers.small .container[data-v-414412a7] {
    grid-template-columns: repeat(auto-fit, minmax(224px, 1fr))
}
.VPTeamMembers.small.count-1 .container[data-v-414412a7] {
    max-width: 276px
}
.VPTeamMembers.small.count-2 .container[data-v-414412a7] {
    max-width: 576px
}
.VPTeamMembers.small.count-3 .container[data-v-414412a7] {
    max-width: 876px
}
.VPTeamMembers.medium .container[data-v-414412a7] {
    grid-template-columns: repeat(auto-fit, minmax(256px, 1fr))
}
@media (min-width: 375px) {
    .VPTeamMembers.medium .container[data-v-414412a7] {
        grid-template-columns: repeat(auto-fit, minmax(288px, 1fr))
    }
}
.VPTeamMembers.medium.count-1 .container[data-v-414412a7] {
    max-width: 368px
}
.VPTeamMembers.medium.count-2 .container[data-v-414412a7] {
    max-width: 760px
}

