﻿/*@font-face {*/
/*    font-family: Inter var;*/
/*    font-weight: 100 900;*/
/*    font-display: swap;*/
/*    font-style: normal;*/
/*    font-named-instance:"Regular";src: url(/assets/inter-roman-cyrillic.5f2c6c8c.woff2) format("woff2");*/
/*    unicode-range: U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116*/
/*}*/

/*@font-face {*/
/*    font-family: Inter var;*/
/*    font-weight: 100 900;*/
/*    font-display: swap;*/
/*    font-style: normal;*/
/*    font-named-instance:"Regular";src: url(/assets/inter-roman-cyrillic-ext.e75737ce.woff2) format("woff2");*/
/*    unicode-range: U+0460-052F,U+1C80-1C88,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F*/
/*}*/

/*@font-face {*/
/*    font-family: Inter var;*/
/*    font-weight: 100 900;*/
/*    font-display: swap;*/
/*    font-style: normal;*/
/*    font-named-instance:"Regular";src: url(/assets/inter-roman-greek.d5a6d92a.woff2) format("woff2");*/
/*    unicode-range: U+0370-03FF*/
/*}*/

/*@font-face {*/
/*    font-family: Inter var;*/
/*    font-weight: 100 900;*/
/*    font-display: swap;*/
/*    font-style: normal;*/
/*    font-named-instance:"Regular";src: url(/assets/inter-roman-greek-ext.ab0619bc.woff2) format("woff2");*/
/*    unicode-range: U+1F00-1FFF*/
/*}*/

/*@font-face {*/
/*    font-family: Inter var;*/
/*    font-weight: 100 900;*/
/*    font-display: swap;*/
/*    font-style: normal;*/
/*    font-named-instance:"Regular";src: url(/inter-roman-latin.2ed14f66.woff2) format("woff2");*/
/*    unicode-range: U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD*/
/*}*/

/*@font-face {*/
/*    font-family: Inter var;*/
/*    font-weight: 100 900;*/
/*    font-display: swap;*/
/*    font-style: normal;*/
/*    font-named-instance:"Regular";src: url(/assets/inter-roman-latin-ext.0030eebd.woff2) format("woff2");*/
/*    unicode-range: U+0100-024F,U+0259,U+1E00-1EFF,U+2020,U+20A0-20AB,U+20AD-20CF,U+2113,U+2C60-2C7F,U+A720-A7FF*/
/*}*/

/*@font-face {*/
/*    font-family: Inter var;*/
/*    font-weight: 100 900;*/
/*    font-display: swap;*/
/*    font-style: normal;*/
/*    font-named-instance:"Regular";src: url(/assets/inter-roman-vietnamese.14ce25a6.woff2) format("woff2");*/
/*    unicode-range: U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+1EA0-1EF9,U+20AB*/
/*}*/

/*@font-face {*/
/*    font-family: Inter var;*/
/*    font-weight: 100 900;*/
/*    font-display: swap;*/
/*    font-style: italic;*/
/*    font-named-instance:"Italic";src: url(/assets/inter-italic-cyrillic.ea42a392.woff2) format("woff2");*/
/*    unicode-range: U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116*/
/*}*/

/*@font-face {*/
/*    font-family: Inter var;*/
/*    font-weight: 100 900;*/
/*    font-display: swap;*/
/*    font-style: italic;*/
/*    font-named-instance:"Italic";src: url(/assets/inter-italic-cyrillic-ext.33bd5a8e.woff2) format("woff2");*/
/*    unicode-range: U+0460-052F,U+1C80-1C88,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F*/
/*}*/

/*@font-face {*/
/*    font-family: Inter var;*/
/*    font-weight: 100 900;*/
/*    font-display: swap;*/
/*    font-style: italic;*/
/*    font-named-instance:"Italic";src: url(/assets/inter-italic-greek.8f4463c4.woff2) format("woff2");*/
/*    unicode-range: U+0370-03FF*/
/*}*/

/*@font-face {*/
/*    font-family: Inter var;*/
/*    font-weight: 100 900;*/
/*    font-display: swap;*/
/*    font-style: italic;*/
/*    font-named-instance:"Italic";src: url(/assets/inter-italic-greek-ext.4fbe9427.woff2) format("woff2");*/
/*    unicode-range: U+1F00-1FFF*/
/*}*/

/*@font-face {*/
/*    font-family: Inter var;*/
/*    font-weight: 100 900;*/
/*    font-display: swap;*/
/*    font-style: italic;*/
/*    font-named-instance:"Italic";src: url(/assets/inter-italic-latin.bd3b6f56.woff2) format("woff2");*/
/*    unicode-range: U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD*/
/*}*/

/*@font-face {*/
/*    font-family: Inter var;*/
/*    font-weight: 100 900;*/
/*    font-display: swap;*/
/*    font-style: italic;*/
/*    font-named-instance:"Italic";src: url(/assets/inter-italic-latin-ext.bd8920cc.woff2) format("woff2");*/
/*    unicode-range: U+0100-024F,U+0259,U+1E00-1EFF,U+2020,U+20A0-20AB,U+20AD-20CF,U+2113,U+2C60-2C7F,U+A720-A7FF*/
/*}*/

/*@font-face {*/
/*    font-family: Inter var;*/
/*    font-weight: 100 900;*/
/*    font-display: swap;*/
/*    font-style: italic;*/
/*    font-named-instance:"Italic";src: url(/assets/inter-italic-vietnamese.6ce511fb.woff2) format("woff2");*/
/*    unicode-range: U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+1EA0-1EF9,U+20AB*/
/*}*/

@font-face {
    font-family: Chinese Quotes;
    src: local("PingFang SC Regular"),local("PingFang SC"),local("SimHei"),local("Source Han Sans SC");
    unicode-range: U+2018,U+2019,U+201C,U+201D
}

:root {
    --vp-c-white: #ffffff;
    --vp-c-black: #000000;
    --vp-c-gray: #8e8e93;
    --vp-c-text-light-1: rgba(60, 60, 67);
    --vp-c-text-light-2: rgba(60, 60, 67, .75);
    --vp-c-text-light-3: rgba(60, 60, 67, .33);
    --vp-c-text-dark-1: rgba(255, 255, 245, .86);
    --vp-c-text-dark-2: rgba(235, 235, 245, .6);
    --vp-c-text-dark-3: rgba(235, 235, 245, .38);
    --vp-c-green: #1a73e8;
    --vp-c-green-light: #34d399;
    --vp-c-green-lighter: #6ee7b7;
    --vp-c-green-dark: #059669;
    --vp-c-green-darker: #047857;
    --vp-c-green-dimm-1: rgba(16, 185, 129, .05);
    --vp-c-green-dimm-2: rgba(16, 185, 129, .2);
    --vp-c-green-dimm-3: rgba(16, 185, 129, .5);
    --vp-c-yellow: #d97706;
    --vp-c-yellow-light: #f59e0b;
    --vp-c-yellow-lighter: #fbbf24;
    --vp-c-yellow-dark: #b45309;
    --vp-c-yellow-darker: #92400e;
    --vp-c-yellow-dimm-1: rgba(234, 179, 8, .05);
    --vp-c-yellow-dimm-2: rgba(234, 179, 8, .2);
    --vp-c-yellow-dimm-3: rgba(234, 179, 8, .5);
    --vp-c-red: #f43f5e;
    --vp-c-red-light: #fb7185;
    --vp-c-red-lighter: #fda4af;
    --vp-c-red-dark: #e11d48;
    --vp-c-red-darker: #be123c;
    --vp-c-red-dimm-1: rgba(244, 63, 94, .05);
    --vp-c-red-dimm-2: rgba(244, 63, 94, .2);
    --vp-c-red-dimm-3: rgba(244, 63, 94, .5);
    --vp-c-sponsor: #db2777
}

:root {
    --vp-c-bg: #ffffff;
    --vp-c-bg-elv: #ffffff;
    --vp-c-bg-elv-up: #ffffff;
    --vp-c-bg-elv-down: #f6f6f7;
    --vp-c-bg-elv-mute: #f6f6f7;
    --vp-c-bg-soft: #f6f6f7;
    --vp-c-bg-soft-up: #f9f9fa;
    --vp-c-bg-soft-down: #e3e3e5;
    --vp-c-bg-soft-mute: #e3e3e5;
    --vp-c-bg-alt: #f6f6f7;
    --vp-c-border: rgba(60, 60, 67, .29);
    --vp-c-divider: rgba(60, 60, 67, .12);
    --vp-c-gutter: rgba(60, 60, 67, .12);
    --vp-c-neutral: var(--vp-c-black);
    --vp-c-neutral-inverse: var(--vp-c-white);
    --vp-c-text-1: var(--vp-c-text-light-1);
    --vp-c-text-2: var(--vp-c-text-light-2);
    --vp-c-text-3: var(--vp-c-text-light-3);
    --vp-c-text-inverse-1: var(--vp-c-text-dark-1);
    --vp-c-text-inverse-2: var(--vp-c-text-dark-2);
    --vp-c-text-inverse-3: var(--vp-c-text-dark-3);
    --vp-c-text-code: #476582;
    --vp-c-brand: var(--vp-c-green);
    --vp-c-brand-light: var(--vp-c-green-light);
    --vp-c-brand-lighter: var(--vp-c-green-lighter);
    --vp-c-brand-dark: var(--vp-c-green-dark);
    --vp-c-brand-darker: var(--vp-c-green-darker);
    --vp-c-mute: #f6f6f7;
    --vp-c-mute-light: #f9f9fc;
    --vp-c-mute-lighter: #ffffff;
    --vp-c-mute-dark: #e3e3e5;
    --vp-c-mute-darker: #d7d7d9
}

.dark {
    --vp-c-bg: #1e1e20;
    --vp-c-bg-elv: #252529;
    --vp-c-bg-elv-up: #313136;
    --vp-c-bg-elv-down: #1e1e20;
    --vp-c-bg-elv-mute: #313136;
    --vp-c-bg-soft: #252529;
    --vp-c-bg-soft-up: #313136;
    --vp-c-bg-soft-down: #1e1e20;
    --vp-c-bg-soft-mute: #313136;
    --vp-c-bg-alt: #161618;
    --vp-c-border: rgba(82, 82, 89, .68);
    --vp-c-divider: rgba(82, 82, 89, .32);
    --vp-c-gutter: #000000;
    --vp-c-neutral: var(--vp-c-white);
    --vp-c-neutral-inverse: var(--vp-c-black);
    --vp-c-text-1: var(--vp-c-text-dark-1);
    --vp-c-text-2: var(--vp-c-text-dark-2);
    --vp-c-text-3: var(--vp-c-text-dark-3);
    --vp-c-text-inverse-1: var(--vp-c-text-light-1);
    --vp-c-text-inverse-2: var(--vp-c-text-light-2);
    --vp-c-text-inverse-3: var(--vp-c-text-light-3);
    --vp-c-text-code: #c9def1;
    --vp-c-mute: #313136;
    --vp-c-mute-light: #3a3a3c;
    --vp-c-mute-lighter: #505053;
    --vp-c-mute-dark: #2c2c30;
    --vp-c-mute-darker: #252529
}

:root {
    --vp-font-family-base: "Chinese Quotes", "Inter var", "Inter", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Helvetica, Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
    --vp-font-family-mono: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace
}

:root {
    --vp-shadow-1: 0 1px 2px rgba(0, 0, 0, .04), 0 1px 2px rgba(0, 0, 0, .06);
    --vp-shadow-2: 0 3px 12px rgba(0, 0, 0, .07), 0 1px 4px rgba(0, 0, 0, .07);
    --vp-shadow-3: 0 12px 32px rgba(0, 0, 0, .1), 0 2px 6px rgba(0, 0, 0, .08);
    --vp-shadow-4: 0 14px 44px rgba(0, 0, 0, .12), 0 3px 9px rgba(0, 0, 0, .12);
    --vp-shadow-5: 0 18px 56px rgba(0, 0, 0, .16), 0 4px 12px rgba(0, 0, 0, .16)
}

:root {
    --vp-z-index-local-nav: 10;
    --vp-z-index-nav: 20;
    --vp-z-index-layout-top: 30;
    --vp-z-index-backdrop: 40;
    --vp-z-index-sidebar: 50;
    --vp-z-index-footer: 60
}

:root {
    --vp-icon-copy: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' height='20' width='20' stroke='rgba(128,128,128,1)' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M9 5H7a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h10a2 2 0 0 0 2-2V7a2 2 0 0 0-2-2h-2M9 5a2 2 0 0 0 2 2h2a2 2 0 0 0 2-2M9 5a2 2 0 0 1 2-2h2a2 2 0 0 1 2 2'/%3E%3C/svg%3E");
    --vp-icon-copied: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' height='20' width='20' stroke='rgba(128,128,128,1)' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M9 5H7a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h10a2 2 0 0 0 2-2V7a2 2 0 0 0-2-2h-2M9 5a2 2 0 0 0 2 2h2a2 2 0 0 0 2-2M9 5a2 2 0 0 1 2-2h2a2 2 0 0 1 2 2m-6 9 2 2 4-4'/%3E%3C/svg%3E")
}

:root {
    --vp-layout-max-width: 1440px
}

:root {
    --vp-header-anchor-symbol: "#"
}

:root {
    --vp-code-line-height: 1.7;
    --vp-code-font-size: .875em;
    --vp-c-code-dimm: var(--vp-c-text-dark-3);
    --vp-code-block-color: var(--vp-c-text-dark-1);
    --vp-code-block-bg: #292b30;
    --vp-code-block-bg-light: #1e1e20;
    --vp-code-block-divider-color: #000000;
    --vp-code-line-highlight-color: rgba(0, 0, 0, .5);
    --vp-code-line-number-color: var(--vp-c-code-dimm);
    --vp-code-line-diff-add-color: var(--vp-c-green-dimm-2);
    --vp-code-line-diff-add-symbol-color: var(--vp-c-green);
    --vp-code-line-diff-remove-color: var(--vp-c-red-dimm-2);
    --vp-code-line-diff-remove-symbol-color: var(--vp-c-red);
    --vp-code-line-warning-color: var(--vp-c-yellow-dimm-2);
    --vp-code-line-error-color: var(--vp-c-red-dimm-2);
    --vp-code-copy-code-border-color: transparent;
    --vp-code-copy-code-bg: var(--vp-code-block-bg-light);
    --vp-code-copy-code-hover-border-color: var(--vp-c-divider);
    --vp-code-copy-code-hover-bg: var(--vp-code-block-bg-light);
    --vp-code-copy-code-active-text: var(--vp-c-text-dark-2);
    --vp-code-tab-divider: var(--vp-code-block-divider-color);
    --vp-code-tab-text-color: var(--vp-c-text-dark-2);
    --vp-code-tab-bg: var(--vp-code-block-bg);
    --vp-code-tab-hover-text-color: var(--vp-c-text-dark-1);
    --vp-code-tab-active-text-color: var(--vp-c-text-dark-1);
    --vp-code-tab-active-bar-color: var(--vp-c-brand)
}

.dark {
    --vp-code-block-bg: #161618
}

:root:not(.dark) .vp-adaptive-theme {
    --vp-c-code-dimm: var(--vp-c-text-2);
    --vp-code-block-color: var(--vp-c-text-1);
    --vp-code-block-bg: #f8f8f8;
    --vp-code-block-divider-color: var(--vp-c-divider);
    --vp-code-line-highlight-color: #ececec;
    --vp-code-line-number-color: var(--vp-c-code-dimm);
    --vp-code-copy-code-bg: #e2e2e2;
    --vp-code-copy-code-hover-bg: #dcdcdc;
    --vp-code-copy-code-active-text: var(--vp-c-text-2);
    --vp-code-tab-divider: var(--vp-c-divider);
    --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)
}

:root {
    --vp-button-brand-border: var(--vp-c-brand-lighter);
    --vp-button-brand-text: var(--vp-c-white);
    --vp-button-brand-bg: var(--vp-c-brand);
    --vp-button-brand-hover-border: var(--vp-c-brand-lighter);
    --vp-button-brand-hover-text: var(--vp-c-white);
    --vp-button-brand-hover-bg: var(--vp-c-brand-dark);
    --vp-button-brand-active-border: var(--vp-c-brand-lighter);
    --vp-button-brand-active-text: var(--vp-c-white);
    --vp-button-brand-active-bg: var(--vp-c-brand-darker);
    --vp-button-alt-border: var(--vp-c-border);
    --vp-button-alt-text: var(--vp-c-neutral);
    --vp-button-alt-bg: var(--vp-c-mute);
    --vp-button-alt-hover-border: var(--vp-c-border);
    --vp-button-alt-hover-text: var(--vp-c-neutral);
    --vp-button-alt-hover-bg: var(--vp-c-mute-dark);
    --vp-button-alt-active-border: var(--vp-c-border);
    --vp-button-alt-active-text: var(--vp-c-neutral);
    --vp-button-alt-active-bg: var(--vp-c-mute-darker);
    --vp-button-sponsor-border: var(--vp-c-gray-light-3);
    --vp-button-sponsor-text: var(--vp-c-text-light-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
}

.dark {
    --vp-button-sponsor-border: var(--vp-c-gray-dark-1);
    --vp-button-sponsor-text: var(--vp-c-text-dark-2)
}

:root {
    --vp-custom-block-font-size: 14px;
    --vp-custom-block-code-font-size: 13px;
    --vp-custom-block-info-border: var(--vp-c-border);
    --vp-custom-block-info-text: var(--vp-c-text-2);
    --vp-custom-block-info-bg: var(--vp-c-bg-soft-up);
    --vp-custom-block-info-code-bg: var(--vp-c-bg-soft);
    --vp-custom-block-tip-border: var(--vp-c-green);
    --vp-custom-block-tip-text: var(--vp-c-green-dark);
    --vp-custom-block-tip-bg: var(--vp-c-bg-soft-up);
    --vp-custom-block-tip-code-bg: var(--vp-c-bg-soft);
    --vp-custom-block-warning-border: var(--vp-c-yellow);
    --vp-custom-block-warning-text: var(--vp-c-yellow);
    --vp-custom-block-warning-bg: var(--vp-c-bg-soft-up);
    --vp-custom-block-warning-code-bg: var(--vp-c-bg-soft);
    --vp-custom-block-danger-border: var(--vp-c-red);
    --vp-custom-block-danger-text: var(--vp-c-red);
    --vp-custom-block-danger-bg: var(--vp-c-bg-soft-up);
    --vp-custom-block-danger-code-bg: var(--vp-c-bg-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-details-bg)
}

:root {
    --vp-input-border-color: var(--vp-c-border);
    --vp-input-bg-color: var(--vp-c-bg-alt);
    --vp-input-hover-border-color: var(--vp-c-gray);
    --vp-input-switch-bg-color: var(--vp-c-mute)
}

:root {
    --vp-nav-height: 80px;
    --vp-nav-bg-color: var(--vp-c-bg);
    --vp-nav-screen-bg-color: var(--vp-c-bg)
}

:root {
    --vp-local-nav-bg-color: var(--vp-c-bg)
}

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

:root {
    --vp-backdrop-bg-color: rgba(0, 0, 0, .6)
}

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

:root {
    --vp-badge-info-border: var(--vp-c-border);
    --vp-badge-info-text: var(--vp-c-text-2);
    --vp-badge-info-bg: var(--vp-c-bg-soft-up);
    --vp-badge-tip-border: var(--vp-c-green-dark);
    --vp-badge-tip-text: var(--vp-c-green);
    --vp-badge-tip-bg: var(--vp-c-green-dimm-1);
    --vp-badge-warning-border: var(--vp-c-yellow-dark);
    --vp-badge-warning-text: var(--vp-c-yellow);
    --vp-badge-warning-bg: var(--vp-c-yellow-dimm-1);
    --vp-badge-danger-border: var(--vp-c-red-dark);
    --vp-badge-danger-text: var(--vp-c-red);
    --vp-badge-danger-bg: var(--vp-c-red-dimm-1)
}

: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);
    --vp-carbon-ads-hover-poweredby-color: var(--vp-c-text-1)
}

: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);
    --vp-local-search-highlight-bg: var(--vp-c-green-lighter);
    --vp-local-search-highlight-text: var(--vp-c-black)
}

*,: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: #333333;
    background-color: rgb(241 245 249);
    direction: ltr;
    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
}

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
}

.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.custom-block th,.custom-block.custom-block blockquote>p {
    font-size: var(--vp-custom-block-font-size);
    color: inherit
}

.custom-block.info code {
    background-color: var(--vp-custom-block-info-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 code {
    background-color: var(--vp-custom-block-tip-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 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 code {
    background-color: var(--vp-custom-block-danger-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 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
}

.custom-block.details summary+p {
    margin: 8px 0
}

.custom-block a {
    color: inherit;
    font-weight: 600
}

.custom-block a:hover {
    text-decoration: underline
}

.custom-block code {
    font-size: var(--vp-custom-block-code-font-size)
}

.dark .vp-code-light {
    display: none
}

html:not(.dark) .vp-code-dark {
    display: none
}

.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
}

.vp-code-group .tabs:after {
    position: absolute;
    right: 0;
    bottom: 0;
    left: 0;
    height: 1px;
    background-color: var(--vp-code-tab-divider);
    content: ""
}

@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: absolute;
    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 .25s
}

.vp-code-group .tabs label:after {
    position: absolute;
    right: 8px;
    bottom: -1px;
    left: 8px;
    z-index: 1;
    height: 1px;
    content: "";
    background-color: transparent;
    transition: background-color .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-] {
    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 {
    display: block
}

.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: -.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: -.02em;
    line-height: 32px;
    font-size: 24px
}

.vp-doc h3 {
    margin: 32px 0 0;
    letter-spacing: -.01em;
    line-height: 28px;
    font-size: 20px
}

.vp-doc .header-anchor {
    float: left;
    margin-left: -.87em;
    padding-right: .23em;
    font-weight: 500;
    user-select: none;
    opacity: 0;
    transition: color .25s,opacity .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:-.02em;
        line-height: 40px;
        font-size: 32px
    }
}

.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 .5s
}

.vp-doc blockquote>p {
    margin: 0;
    font-size: 16px;
    color: var(--vp-c-text-2);
    transition: color .5s
}

.vp-doc a {
    font-weight: 500;
    color: var(--vp-c-brand);
    text-decoration-style: dotted;
    transition: color .25s
}

.vp-doc a:hover {
    text-decoration: underline
}

.vp-doc strong {
    font-weight: 600
}

.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
}

.vp-doc table {
    display: block;
    border-collapse: collapse;
    margin: 20px 0;
    overflow-x: auto
}

.vp-doc tr {
    border-top: 1px solid var(--vp-c-divider);
    transition: background-color .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
}

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

.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 a {
    color: inherit;
    font-weight: 600
}

.vp-doc .custom-block a:hover {
    text-decoration: underline
}

.vp-doc .custom-block code {
    font-size: var(--vp-custom-block-code-font-size);
    font-weight: 700;
    color: inherit
}

.vp-doc .custom-block div[class*=language-] {
    margin: 8px 0
}

.vp-doc .custom-block div[class*=language-] code {
    font-weight: 400;
    background-color: transparent
}

.vp-doc :not(pre,h1,h2,h3,h4,h5,h6)>code {
    font-size: var(--vp-code-font-size)
}

.vp-doc :not(pre)>code {
    border-radius: 4px;
    padding: 3px 6px;
    color: var(--vp-c-text-code);
    background-color: var(--vp-c-mute);
    transition: color .5s,background-color .5s
}

.vp-doc h1>code,.vp-doc h2>code,.vp-doc h3>code {
    font-size: .9em
}

.vp-doc a>code {
    color: var(--vp-c-brand);
    transition: color .25s
}

.vp-doc a:hover>code {
    color: var(--vp-c-brand-dark)
}

.vp-doc div[class*=language-] {
    position: relative;
    margin: 16px -24px;
    background-color: var(--vp-code-block-bg);
    overflow-x: auto;
    transition: background-color .5s
}

@media (min-width: 640px) {
    .vp-doc div[class*=language-] {
        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 {
    direction: ltr;
    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 .5s
}

.vp-doc [class*=language-] code .highlighted {
    background-color: var(--vp-code-line-highlight-color);
    transition: background-color .5s;
    margin: 0 -24px;
    padding: 0 24px;
    width: calc(100% + 48px);
    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 .5s;
    margin: 0 -24px;
    padding: 0 24px;
    width: calc(100% + 48px);
    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(.095rem);
    opacity: .4;
    transition: filter .35s,opacity .35s
}

.vp-doc [class*=language-] .has-focused-lines .line:not(.has-focus) {
    opacity: .7;
    transition: filter .35s,opacity .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: .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 {
    padding-left: 32px
}

.vp-doc .line-numbers-wrapper {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    z-index: 3;
    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 .5s,color .5s
}

.vp-doc [class*=language-]>button.copy {
    direction: ltr;
    position: absolute;
    top: 12px;
    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 .25s,background-color .25s,opacity .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 {
    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;
    left: -65px;
    display: flex;
    justify-content: center;
    align-items: center;
    border: 1px solid var(--vp-code-copy-code-hover-border-color);
    border-right: 0;
    border-radius: 4px 0 0 4px;
    width: 64px;
    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: "Copied"
}

.vp-doc [class*=language-]>span.lang {
    position: absolute;
    top: 2px;
    right: 8px;
    z-index: 2;
    font-size: 12px;
    font-weight: 500;
    color: var(--vp-c-code-dimm);
    transition: color .4s,opacity .4s
}

.vp-doc [class*=language-]:hover>button.copy+span.lang,.vp-doc [class*=language-]>button.copy:focus+span.lang {
    opacity: 0
}

.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
}

.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-bottom: 4px;
    text-align: center;
    letter-spacing: 1px;
    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% - 12px)/4)
}

.vp-sponsor-grid[data-vp-grid="5"] .vp-sponsor-grid-item {
    width: calc((100% - 16px)/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 .25s
}

.vp-sponsor-grid-item:hover {
    background-color: var(--vp-c-bg-soft-down)
}

.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 .25s
}

.dark .vp-sponsor-grid-image {
    filter: grayscale(1) invert(1)
}

.VPBadge[data-v-350d3852] {
    display: inline-block;
    margin-left: 2px;
    border: 1px solid transparent;
    border-radius: 10px;
    padding: 0 8px;
    line-height: 18px;
    font-size: 12px;
    font-weight: 600;
    transform: translateY(-2px)
}

h1 .VPBadge[data-v-350d3852],h2 .VPBadge[data-v-350d3852],h3 .VPBadge[data-v-350d3852],h4 .VPBadge[data-v-350d3852],h5 .VPBadge[data-v-350d3852],h6 .VPBadge[data-v-350d3852] {
    vertical-align: top
}

h2 .VPBadge[data-v-350d3852] {
    border-radius: 11px;
    line-height: 20px
}

.VPBadge.info[data-v-350d3852] {
    border-color: var(--vp-badge-info-border);
    color: var(--vp-badge-info-text);
    background-color: var(--vp-badge-info-bg)
}

.VPBadge.tip[data-v-350d3852] {
    border-color: var(--vp-badge-tip-border);
    color: var(--vp-badge-tip-text);
    background-color: var(--vp-badge-tip-bg)
}

.VPBadge.warning[data-v-350d3852] {
    border-color: var(--vp-badge-warning-border);
    color: var(--vp-badge-warning-text);
    background-color: var(--vp-badge-warning-bg)
}

.VPBadge.danger[data-v-350d3852] {
    border-color: var(--vp-badge-danger-border);
    color: var(--vp-badge-danger-text);
    background-color: var(--vp-badge-danger-bg)
}

.VPSkipLink[data-v-b8b11faa] {
    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);
    box-shadow: var(--vp-shadow-3);
    background-color: var(--vp-c-bg)
}

.VPSkipLink[data-v-b8b11faa]:focus {
    height: auto;
    width: auto;
    clip: auto;
    clip-path: none
}

@media (min-width: 1280px) {
    .VPSkipLink[data-v-b8b11faa] {
        top:14px;
        left: 16px
    }
}

.VPBackdrop[data-v-c79a1216] {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: var(--vp-z-index-backdrop);
    background: var(--vp-backdrop-bg-color);
    transition: opacity .5s
}

.VPBackdrop.fade-enter-from[data-v-c79a1216],.VPBackdrop.fade-leave-to[data-v-c79a1216] {
    opacity: 0
}

.VPBackdrop.fade-leave-active[data-v-c79a1216] {
    transition-duration: .25s
}

@media (min-width: 1280px) {
    .VPBackdrop[data-v-c79a1216] {
        display:none
    }
}

html:not(.dark) .VPImage.dark[data-v-6db2186b] {
    display: none
}

.dark .VPImage.light[data-v-6db2186b] {
    display: none
}

.title[data-v-4d981103] {
    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-4d981103] {
        flex-shrink:0
    }

    .VPNavBarTitle.has-sidebar .title[data-v-4d981103] {
        border-bottom-color: var(--vp-c-divider)
    }
}

[data-v-4d981103] .logo {
    height: 60px
}

/*! @docsearch/css 3.5.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-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-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-radius: 3px;
    box-shadow: var(--docsearch-key-shadow);
    color: var(--docsearch-muted-color);
    display: flex;
    height: 18px;
    justify-content: center;
    margin-right: .4em;
    position: relative;
    padding: 0 0 2px;
    border: 0;
    top: -1px;
    width: 20px
}

@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-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] .DocSearch-Hit-Tree,.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-radius: 2px;
    box-shadow: var(--docsearch-key-shadow);
    display: flex;
    height: 18px;
    justify-content: center;
    margin-right: .4em;
    padding: 0 0 1px;
    color: var(--docsearch-muted-color);
    border: 0;
    width: 20px
}

@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
    }
}

.DocSearch {
    --docsearch-primary-color: var(--vp-c-brand);
    --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-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 .DocSearch {
    --docsearch-modal-shadow: none;
    --docsearch-footer-shadow: none;
    --docsearch-logo-color: var(--vp-c-text-2);
    --docsearch-hit-background: var(--vp-c-bg-soft-mute);
    --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 .25s
}

.DocSearch-Button:hover {
    background: transparent
}

.DocSearch-Button:focus {
    outline: 1px dotted;
    outline: 5px auto -webkit-focus-ring-color
}

.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);
        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 .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 .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 {
    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;
    border: 1px solid var(--vp-c-divider);
    border-right: none;
    border-radius: 4px 0 0 4px;
    padding-left: 6px;
    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 .5s,border-color .5s
}

.DocSearch-Button .DocSearch-Button-Key+.DocSearch-Button-Key {
    border-right: 1px solid var(--vp-c-divider);
    border-left: none;
    border-radius: 0 4px 4px 0;
    padding-left: 2px;
    padding-right: 6px
}

.DocSearch-Button .DocSearch-Button-Key:first-child {
    font-size: 1px;
    letter-spacing: -12px;
    color: transparent
}

.DocSearch-Button .DocSearch-Button-Key:first-child:after {
    content: var(--vp-meta-key);
    font-size: 12px;
    letter-spacing: normal;
    color: var(--docsearch-muted-color)
}

.DocSearch-Button .DocSearch-Button-Key:first-child>* {
    display: none
}

.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);
    background-color: var(--vp-c-white)
}

.dark .DocSearch-Form {
    background-color: var(--vp-c-bg-soft-mute)
}

.DocSearch-Screen-Icon>svg {
    margin: auto
}

.icon[data-v-8f4dc553] {
    display: inline-block;
    margin-top: -1px;
    margin-left: 4px;
    width: 11px;
    height: 11px;
    fill: var(--vp-c-text-3);
    transition: fill .25s;
    flex-shrink: 0
}

.VPNavBarMenuLink[data-v-5e623618] {
    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 .25s
}

.VPNavBarMenuLink.active[data-v-5e623618],.VPNavBarMenuLink[data-v-5e623618]:hover {
    color: var(--vp-c-brand)
}

.VPMenuGroup+.VPMenuLink[data-v-2f2cfafc] {
    margin: 12px -12px 0;
    border-top: 1px solid var(--vp-c-divider);
    padding: 12px 12px 0
}

.link[data-v-2f2cfafc] {
    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 .25s,color .25s
}

.link[data-v-2f2cfafc]:hover {
    color: var(--vp-c-brand);
    background-color: var(--vp-c-bg-elv-mute)
}

.link.active[data-v-2f2cfafc] {
    color: var(--vp-c-brand)
}

.VPMenuGroup[data-v-69e747b5] {
    margin: 12px -12px 0;
    border-top: 1px solid var(--vp-c-divider);
    padding: 12px 12px 0
}

.VPMenuGroup[data-v-69e747b5]:first-child {
    margin-top: 0;
    border-top: 0;
    padding-top: 0
}

.VPMenuGroup+.VPMenuGroup[data-v-69e747b5] {
    margin-top: 12px;
    border-top: 1px solid var(--vp-c-divider)
}

.title[data-v-69e747b5] {
    padding: 0 12px;
    line-height: 32px;
    font-size: 14px;
    font-weight: 600;
    color: var(--vp-c-text-2);
    white-space: nowrap;
    transition: color .25s
}

.VPMenu[data-v-e7ea1737] {
    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 .5s;
    max-height: calc(100vh - var(--vp-nav-height));
    overflow-y: auto
}

.VPMenu[data-v-e7ea1737] .group {
    margin: 0 -12px;
    padding: 0 12px 12px
}

.VPMenu[data-v-e7ea1737] .group+.group {
    border-top: 1px solid var(--vp-c-divider);
    padding: 11px 12px 12px
}

.VPMenu[data-v-e7ea1737] .group:last-child {
    padding-bottom: 0
}

.VPMenu[data-v-e7ea1737] .group+.item {
    border-top: 1px solid var(--vp-c-divider);
    padding: 11px 16px 0
}

.VPMenu[data-v-e7ea1737] .item {
    padding: 0 16px;
    white-space: nowrap
}

.VPMenu[data-v-e7ea1737] .label {
    flex-grow: 1;
    line-height: 28px;
    font-size: 12px;
    font-weight: 500;
    color: var(--vp-c-text-2);
    transition: color .5s
}

.VPMenu[data-v-e7ea1737] .action {
    padding-left: 24px
}

.VPFlyout[data-v-764effdf] {
    position: relative
}

.VPFlyout[data-v-764effdf]:hover {
    color: var(--vp-c-brand);
    transition: color .25s
}

.VPFlyout:hover .text[data-v-764effdf] {
    color: var(--vp-c-text-2)
}

.VPFlyout:hover .icon[data-v-764effdf] {
    fill: var(--vp-c-text-2)
}

.VPFlyout.active .text[data-v-764effdf] {
    color: var(--vp-c-brand)
}

.VPFlyout.active:hover .text[data-v-764effdf] {
    color: var(--vp-c-brand-dark)
}

.VPFlyout:hover .menu[data-v-764effdf],.button[aria-expanded=true]+.menu[data-v-764effdf] {
    opacity: 1;
    visibility: visible;
    transform: translateY(0)
}

.button[data-v-764effdf] {
    display: flex;
    align-items: center;
    padding: 0 12px;
    height: var(--vp-nav-height);
    color: var(--vp-c-text-1);
    transition: color .5s
}

.text[data-v-764effdf] {
    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 .25s
}

.option-icon[data-v-764effdf] {
    margin-right: 0;
    width: 16px;
    height: 16px;
    fill: currentColor
}

.text-icon[data-v-764effdf] {
    margin-left: 4px;
    width: 14px;
    height: 14px;
    fill: currentColor
}

.icon[data-v-764effdf] {
    width: 20px;
    height: 20px;
    fill: currentColor;
    transition: fill .25s
}

.menu[data-v-764effdf] {
    position: absolute;
    top: calc(var(--vp-nav-height) / 2 + 20px);
    right: 0;
    opacity: 0;
    visibility: hidden;
    transition: opacity .25s,visibility .25s,transform .25s
}

.VPNavBarMenu[data-v-7f418b0f] {
    display: none
}

@media (min-width: 768px) {
    .VPNavBarMenu[data-v-7f418b0f] {
        display:flex
    }
}

.VPNavBarTranslations[data-v-74abcbb9] {
    display: none
}

@media (min-width: 1280px) {
    .VPNavBarTranslations[data-v-74abcbb9] {
        display:flex;
        align-items: center
    }
}

.title[data-v-74abcbb9] {
    padding: 0 24px 0 12px;
    line-height: 32px;
    font-size: 14px;
    font-weight: 700;
    color: var(--vp-c-text-1)
}

.VPSwitch[data-v-f3c41672] {
    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 .25s
}

.VPSwitch[data-v-f3c41672]:hover {
    border-color: var(--vp-input-hover-border-color)
}

.check[data-v-f3c41672] {
    position: absolute;
    top: 1px;
    left: 1px;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background-color: var(--vp-c-neutral-inverse);
    box-shadow: var(--vp-shadow-1);
    transition: transform .25s
}

.icon[data-v-f3c41672] {
    position: relative;
    display: block;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    overflow: hidden
}

.icon[data-v-f3c41672] svg {
    position: absolute;
    top: 3px;
    left: 3px;
    width: 12px;
    height: 12px;
    fill: var(--vp-c-text-2)
}

.dark .icon[data-v-f3c41672] svg {
    fill: var(--vp-c-text-1);
    transition: opacity .25s
}

.sun[data-v-82b282f1] {
    opacity: 1
}

.moon[data-v-82b282f1],.dark .sun[data-v-82b282f1] {
    opacity: 0
}

.dark .moon[data-v-82b282f1] {
    opacity: 1
}

.dark .VPSwitchAppearance[data-v-82b282f1] .check {
    transform: translate(18px)
}

.VPNavBarAppearance[data-v-f6a63727] {
    display: none
}

@media (min-width: 1280px) {
    .VPNavBarAppearance[data-v-f6a63727] {
        display:flex;
        align-items: center
    }
}

.VPSocialLink[data-v-36371990] {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 36px;
    height: 36px;
    color: var(--vp-c-text-2);
    transition: color .5s
}

.VPSocialLink[data-v-36371990]:hover {
    color: var(--vp-c-text-1);
    transition: color .25s
}

.VPSocialLink[data-v-36371990]>svg {
    width: 20px;
    height: 20px;
    fill: currentColor
}

.VPSocialLinks[data-v-7bc22406] {
    display: flex;
    justify-content: center
}

.VPNavBarSocialLinks[data-v-0394ad82] {
    display: none
}

@media (min-width: 1280px) {
    .VPNavBarSocialLinks[data-v-0394ad82] {
        display:flex;
        align-items: center
    }
}

.VPNavBarExtra[data-v-40855f84] {
    display: none;
    margin-right: -12px
}

@media (min-width: 768px) {
    .VPNavBarExtra[data-v-40855f84] {
        display:block
    }
}

@media (min-width: 1280px) {
    .VPNavBarExtra[data-v-40855f84] {
        display:none
    }
}

.trans-title[data-v-40855f84] {
    padding: 0 24px 0 12px;
    line-height: 32px;
    font-size: 14px;
    font-weight: 700;
    color: var(--vp-c-text-1)
}

.item.appearance[data-v-40855f84],.item.social-links[data-v-40855f84] {
    display: flex;
    align-items: center;
    padding: 0 12px
}

.item.appearance[data-v-40855f84] {
    min-width: 176px
}

.appearance-action[data-v-40855f84] {
    margin-right: -2px
}

.social-links-list[data-v-40855f84] {
    margin: -4px -8px
}

.VPNavBarHamburger[data-v-e5dd9c1c] {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 48px;
    height: var(--vp-nav-height)
}

@media (min-width: 768px) {
    .VPNavBarHamburger[data-v-e5dd9c1c] {
        display:none
    }
}

.container[data-v-e5dd9c1c] {
    position: relative;
    width: 16px;
    height: 14px;
    overflow: hidden
}

.VPNavBarHamburger:hover .top[data-v-e5dd9c1c] {
    top: 0;
    left: 0;
    transform: translate(4px)
}

.VPNavBarHamburger:hover .middle[data-v-e5dd9c1c] {
    top: 6px;
    left: 0;
    transform: translate(0)
}

.VPNavBarHamburger:hover .bottom[data-v-e5dd9c1c] {
    top: 12px;
    left: 0;
    transform: translate(8px)
}

.VPNavBarHamburger.active .top[data-v-e5dd9c1c] {
    top: 6px;
    transform: translate(0) rotate(225deg)
}

.VPNavBarHamburger.active .middle[data-v-e5dd9c1c] {
    top: 6px;
    transform: translate(16px)
}

.VPNavBarHamburger.active .bottom[data-v-e5dd9c1c] {
    top: 6px;
    transform: translate(0) rotate(135deg)
}

.VPNavBarHamburger.active:hover .top[data-v-e5dd9c1c],.VPNavBarHamburger.active:hover .middle[data-v-e5dd9c1c],.VPNavBarHamburger.active:hover .bottom[data-v-e5dd9c1c] {
    background-color: var(--vp-c-text-2);
    transition: top .25s,background-color .25s,transform .25s
}

.top[data-v-e5dd9c1c],.middle[data-v-e5dd9c1c],.bottom[data-v-e5dd9c1c] {
    position: absolute;
    width: 16px;
    height: 2px;
    background-color: var(--vp-c-text-1);
    transition: top .25s,background-color .5s,transform .25s
}

.top[data-v-e5dd9c1c] {
    top: 0;
    left: 0;
    transform: translate(0)
}

.middle[data-v-e5dd9c1c] {
    top: 6px;
    left: 0;
    transform: translate(8px)
}

.bottom[data-v-e5dd9c1c] {
    top: 12px;
    left: 0;
    transform: translate(4px)
}

.VPNavBar[data-v-7683ced7] {
    position: relative;
    border-bottom: 1px solid transparent;
    padding: 0 8px 0 24px;
    height: var(--vp-nav-height);
    pointer-events: none;
    white-space: nowrap
}

@media (min-width: 768px) {
    .VPNavBar[data-v-7683ced7] {
        padding:0 32px;
    }
}

@media (min-width: 960px) {
    .VPNavBar.has-sidebar[data-v-7683ced7] {
        padding:0
    }

    .VPNavBar.fill[data-v-7683ced7]:not(.has-sidebar) {
        border-bottom-color: var(--vp-c-gutter);
        background-color: var(--vp-nav-bg-color)
    }
}

.container[data-v-7683ced7] {
    display: flex;
    margin: 0 auto;
    max-width: calc(var(--vp-layout-max-width) - 60px);
    height: var(--vp-nav-height);
    pointer-events: none;
}

.container>.title[data-v-7683ced7],.container>.content[data-v-7683ced7] {
    pointer-events: none
}

.container[data-v-7683ced7] * {
    pointer-events: auto
}

@media (min-width: 960px) {
    .VPNavBar.has-sidebar .container[data-v-7683ced7] {
        max-width:100%
    }
}

.title[data-v-7683ced7] {
    flex-shrink: 0;
    height: calc(var(--vp-nav-height) - 1px);
    transition: background-color .5s
}

@media (min-width: 960px) {
    .VPNavBar.has-sidebar .title[data-v-7683ced7] {
        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-7683ced7] {
        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-7683ced7] {
    flex-grow: 1
}

@media (min-width: 960px) {
    .VPNavBar.has-sidebar .content[data-v-7683ced7] {
        position:relative;
        z-index: 1;
        padding-right: 32px;
        padding-left: var(--vp-sidebar-width)
    }
}

@media (min-width: 1440px) {
    .VPNavBar.has-sidebar .content[data-v-7683ced7] {
        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-7683ced7] {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    height: calc(var(--vp-nav-height) - 1px);
    transition: background-color .5s
}

@media (min-width: 960px) {
    .VPNavBar.has-sidebar .content-body[data-v-7683ced7],.VPNavBar.fill .content-body[data-v-7683ced7] {
        position:relative;
        background-color: var(--vp-nav-bg-color)
    }
}

@media (max-width: 768px) {
    .content-body[data-v-7683ced7] {
        column-gap:.5rem
    }
}

.menu+.translations[data-v-7683ced7]:before,.menu+.appearance[data-v-7683ced7]:before,.menu+.social-links[data-v-7683ced7]:before,.translations+.appearance[data-v-7683ced7]:before,.appearance+.social-links[data-v-7683ced7]:before {
    margin-right: 8px;
    margin-left: 8px;
    width: 1px;
    height: 24px;
    background-color: var(--vp-c-divider);
    content: ""
}

.menu+.appearance[data-v-7683ced7]:before,.translations+.appearance[data-v-7683ced7]:before {
    margin-right: 16px
}

.appearance+.social-links[data-v-7683ced7]:before {
    margin-left: 16px
}

.social-links[data-v-7683ced7] {
    margin-right: -8px
}

@media (min-width: 960px) {
    .VPNavBar.has-sidebar .curtain[data-v-7683ced7] {
        position:absolute;
        right: 0;
        bottom: -31px;
        width: calc(100% - var(--vp-sidebar-width));
        height: 32px
    }

    .VPNavBar.has-sidebar .curtain[data-v-7683ced7]:before {
        display: block;
        width: 100%;
        height: 32px;
        background: linear-gradient(var(--vp-c-bg),transparent 70%);
        content: ""
    }
}

@media (min-width: 1440px) {
    .VPNavBar.has-sidebar .curtain[data-v-7683ced7] {
        width:calc(100% - ((100vw - var(--vp-layout-max-width)) / 2 + var(--vp-sidebar-width)))
    }
}

.VPNavScreenMenuLink[data-v-30be0acb] {
    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-30be0acb]:hover {
    color: var(--vp-c-brand)
}

.VPNavScreenMenuGroupLink[data-v-6656c42a] {
    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-6656c42a]:hover {
    color: var(--vp-c-brand)
}

.VPNavScreenMenuGroupSection[data-v-8133b170] {
    display: block
}

.title[data-v-8133b170] {
    line-height: 32px;
    font-size: 13px;
    font-weight: 700;
    color: var(--vp-c-text-2);
    transition: color .25s
}

.VPNavScreenMenuGroup[data-v-338a1689] {
    border-bottom: 1px solid var(--vp-c-divider);
    height: 48px;
    overflow: hidden;
    transition: border-color .5s
}

.VPNavScreenMenuGroup .items[data-v-338a1689] {
    visibility: hidden
}

.VPNavScreenMenuGroup.open .items[data-v-338a1689] {
    visibility: visible
}

.VPNavScreenMenuGroup.open[data-v-338a1689] {
    padding-bottom: 10px;
    height: auto
}

.VPNavScreenMenuGroup.open .button[data-v-338a1689] {
    padding-bottom: 6px;
    color: var(--vp-c-brand)
}

.VPNavScreenMenuGroup.open .button-icon[data-v-338a1689] {
    transform: rotate(45deg)
}

.button[data-v-338a1689] {
    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-338a1689]:hover {
    color: var(--vp-c-brand)
}

.button-icon[data-v-338a1689] {
    width: 14px;
    height: 14px;
    fill: var(--vp-c-text-2);
    transition: fill .5s,transform .25s
}

.group[data-v-338a1689]:first-child {
    padding-top: 0
}

.group+.group[data-v-338a1689],.group+.item[data-v-338a1689] {
    padding-top: 4px
}

.VPNavScreenAppearance[data-v-add8f686] {
    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-add8f686] {
    line-height: 24px;
    font-size: 12px;
    font-weight: 500;
    color: var(--vp-c-text-2)
}

.VPNavScreenTranslations[data-v-d72aa483] {
    height: 24px;
    overflow: hidden
}

.VPNavScreenTranslations.open[data-v-d72aa483] {
    height: auto
}

.title[data-v-d72aa483] {
    display: flex;
    align-items: center;
    font-size: 14px;
    font-weight: 500;
    color: var(--vp-c-text-1)
}

.icon[data-v-d72aa483] {
    width: 16px;
    height: 16px;
    fill: currentColor
}

.icon.lang[data-v-d72aa483] {
    margin-right: 8px
}

.icon.chevron[data-v-d72aa483] {
    margin-left: 4px
}

.list[data-v-d72aa483] {
    padding: 4px 0 0 24px
}

.link[data-v-d72aa483] {
    line-height: 32px;
    font-size: 13px;
    color: var(--vp-c-text-1)
}

.VPNavScreen[data-v-724636ae] {
    position: fixed;
    top: calc(var(--vp-nav-height) + var(--vp-layout-top-height, 0px) + 1px);
    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 .5s;
    pointer-events: auto
}

.VPNavScreen.fade-enter-active[data-v-724636ae],.VPNavScreen.fade-leave-active[data-v-724636ae] {
    transition: opacity .25s
}

.VPNavScreen.fade-enter-active .container[data-v-724636ae],.VPNavScreen.fade-leave-active .container[data-v-724636ae] {
    transition: transform .25s ease
}

.VPNavScreen.fade-enter-from[data-v-724636ae],.VPNavScreen.fade-leave-to[data-v-724636ae] {
    opacity: 0
}

.VPNavScreen.fade-enter-from .container[data-v-724636ae],.VPNavScreen.fade-leave-to .container[data-v-724636ae] {
    transform: translateY(-8px)
}

@media (min-width: 768px) {
    .VPNavScreen[data-v-724636ae] {
        display:none
    }
}

.container[data-v-724636ae] {
    margin: 0 auto;
    padding: 24px 0 96px;
    max-width: 288px
}

.menu+.translations[data-v-724636ae],.menu+.appearance[data-v-724636ae],.translations+.appearance[data-v-724636ae] {
    margin-top: 24px
}

.menu+.social-links[data-v-724636ae] {
    margin-top: 16px
}

.appearance+.social-links[data-v-724636ae] {
    margin-top: 16px
}

.VPNav[data-v-7e5bc4a5] {
      background-color: #ffffff;
      box-shadow: 0 2px 4px rgba(0,0,0,0.05);
      z-index: 100;
    position: fixed;
    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
}

.root[data-v-9a431c33] {
    position: relative;
    z-index: 1
}

.nested[data-v-9a431c33] {
    padding-left: 13px
}

.outline-link[data-v-9a431c33] {
    display: block;
    line-height: 28px;
    color: var(--vp-c-text-2);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    transition: color .5s;
    font-weight: 500
}

.outline-link[data-v-9a431c33]:hover,.outline-link.active[data-v-9a431c33] {
    color: var(--vp-c-text-1);
    transition: color .25s
}

.outline-link.nested[data-v-9a431c33] {
    padding-left: 13px
}

.VPLocalNavOutlineDropdown[data-v-687955bc] {
    padding: 12px 20px 11px
}

.VPLocalNavOutlineDropdown button[data-v-687955bc] {
    display: block;
    font-size: 12px;
    font-weight: 500;
    line-height: 24px;
    color: var(--vp-c-text-2);
    transition: color .5s;
    position: relative
}

.VPLocalNavOutlineDropdown button[data-v-687955bc]:hover {
    color: var(--vp-c-text-1);
    transition: color .25s
}

.VPLocalNavOutlineDropdown button.open[data-v-687955bc] {
    color: var(--vp-c-text-1)
}

.icon[data-v-687955bc] {
    display: inline-block;
    vertical-align: middle;
    margin-left: 2px;
    width: 14px;
    height: 14px;
    fill: currentColor
}

[data-v-687955bc] .outline-link {
    font-size: 14px;
    padding: 2px 0
}

.open>.icon[data-v-687955bc] {
    transform: rotate(90deg)
}

.items[data-v-687955bc] {
    position: absolute;
    left: 20px;
    right: 20px;
    top: 64px;
    background-color: var(--vp-local-nav-bg-color);
    padding: 4px 10px 16px;
    border: 1px solid var(--vp-c-divider);
    border-radius: 8px;
    max-height: calc(var(--vp-vh, 100vh) - 86px);
    overflow: hidden auto;
    box-shadow: var(--vp-shadow-3)
}

.top-link[data-v-687955bc] {
    display: block;
    color: var(--vp-c-brand);
    font-size: 13px;
    font-weight: 500;
    padding: 6px 0;
    margin: 0 13px 10px;
    border-bottom: 1px solid var(--vp-c-divider)
}

.flyout-enter-active[data-v-687955bc] {
    transition: all .2s ease-out
}

.flyout-leave-active[data-v-687955bc] {
    transition: all .15s ease-in
}

.flyout-enter-from[data-v-687955bc],.flyout-leave-to[data-v-687955bc] {
    opacity: 0;
    transform: translateY(-16px)
}

.VPLocalNav[data-v-9074c407] {
    position: sticky;
    top: 0;
    left: 0;
    z-index: var(--vp-z-index-local-nav);
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-top: 1px solid var(--vp-c-gutter);
    border-bottom: 1px solid var(--vp-c-gutter);
    padding-top: var(--vp-layout-top-height, 0px);
    width: 100%;
    background-color: var(--vp-local-nav-bg-color)
}

.VPLocalNav.fixed[data-v-9074c407] {
    position: fixed
}

.VPLocalNav.reached-top[data-v-9074c407] {
    border-top-color: transparent
}

@media (min-width: 960px) {
    .VPLocalNav[data-v-9074c407] {
        display:none
    }
}

.menu[data-v-9074c407] {
    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 .5s
}

.menu[data-v-9074c407]:hover {
    color: var(--vp-c-text-1);
    transition: color .25s
}

@media (min-width: 768px) {
    .menu[data-v-9074c407] {
        padding:0 32px
    }
}

.menu-icon[data-v-9074c407] {
    margin-right: 8px;
    width: 16px;
    height: 16px;
    fill: currentColor
}

.VPOutlineDropdown[data-v-9074c407] {
    padding: 12px 24px 11px
}

@media (min-width: 768px) {
    .VPOutlineDropdown[data-v-9074c407] {
        padding:12px 32px 11px
    }
}

.VPSidebarItem.level-0[data-v-c4656e6d] {
    padding-bottom: 24px
}

.VPSidebarItem.collapsed.level-0[data-v-c4656e6d] {
    padding-bottom: 10px
}

.item[data-v-c4656e6d] {
    position: relative;
    display: flex;
    width: 100%
}

.VPSidebarItem.collapsible>.item[data-v-c4656e6d] {
    cursor: pointer
}

.indicator[data-v-c4656e6d] {
    position: absolute;
    top: 6px;
    bottom: 6px;
    left: -17px;
    width: 1px;
    transition: background-color .25s
}

.VPSidebarItem.level-2.is-active>.item>.indicator[data-v-c4656e6d],.VPSidebarItem.level-3.is-active>.item>.indicator[data-v-c4656e6d],.VPSidebarItem.level-4.is-active>.item>.indicator[data-v-c4656e6d],.VPSidebarItem.level-5.is-active>.item>.indicator[data-v-c4656e6d] {
    background-color: var(--vp-c-brand)
}

.link[data-v-c4656e6d] {
    display: flex;
    align-items: center;
    flex-grow: 1
}

.text[data-v-c4656e6d] {
    flex-grow: 1;
    padding: 4px 0;
    line-height: 24px;
    font-size: 14px;
    transition: color .25s
}

.VPSidebarItem.level-0 .text[data-v-c4656e6d] {
    font-weight: 700;
    color: var(--vp-c-text-1)
}

.VPSidebarItem.level-1 .text[data-v-c4656e6d],.VPSidebarItem.level-2 .text[data-v-c4656e6d],.VPSidebarItem.level-3 .text[data-v-c4656e6d],.VPSidebarItem.level-4 .text[data-v-c4656e6d],.VPSidebarItem.level-5 .text[data-v-c4656e6d] {
    font-weight: 500;
    color: var(--vp-c-text-2)
}

.VPSidebarItem.level-0.is-link>.item>.link:hover .text[data-v-c4656e6d],.VPSidebarItem.level-1.is-link>.item>.link:hover .text[data-v-c4656e6d],.VPSidebarItem.level-2.is-link>.item>.link:hover .text[data-v-c4656e6d],.VPSidebarItem.level-3.is-link>.item>.link:hover .text[data-v-c4656e6d],.VPSidebarItem.level-4.is-link>.item>.link:hover .text[data-v-c4656e6d],.VPSidebarItem.level-5.is-link>.item>.link:hover .text[data-v-c4656e6d] {
    color: var(--vp-c-brand)
}

.VPSidebarItem.level-0.has-active>.item>.link>.text[data-v-c4656e6d],.VPSidebarItem.level-1.has-active>.item>.link>.text[data-v-c4656e6d],.VPSidebarItem.level-2.has-active>.item>.link>.text[data-v-c4656e6d],.VPSidebarItem.level-3.has-active>.item>.link>.text[data-v-c4656e6d],.VPSidebarItem.level-4.has-active>.item>.link>.text[data-v-c4656e6d],.VPSidebarItem.level-5.has-active>.item>.link>.text[data-v-c4656e6d] {
    color: var(--vp-c-text-1)
}

.VPSidebarItem.level-0.is-active>.item .link>.text[data-v-c4656e6d],.VPSidebarItem.level-1.is-active>.item .link>.text[data-v-c4656e6d],.VPSidebarItem.level-2.is-active>.item .link>.text[data-v-c4656e6d],.VPSidebarItem.level-3.is-active>.item .link>.text[data-v-c4656e6d],.VPSidebarItem.level-4.is-active>.item .link>.text[data-v-c4656e6d],.VPSidebarItem.level-5.is-active>.item .link>.text[data-v-c4656e6d] {
    color: var(--vp-c-brand)
}

.caret[data-v-c4656e6d] {
    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
}

.item:hover .caret[data-v-c4656e6d] {
    color: var(--vp-c-text-2)
}

.item:hover .caret[data-v-c4656e6d]:hover {
    color: var(--vp-c-text-1)
}

.caret-icon[data-v-c4656e6d] {
    width: 18px;
    height: 18px;
    fill: currentColor;
    transform: rotate(90deg);
    transition: transform .25s
}

.VPSidebarItem.collapsed .caret-icon[data-v-c4656e6d] {
    transform: rotate(0)
}

.VPSidebarItem.level-1 .items[data-v-c4656e6d],.VPSidebarItem.level-2 .items[data-v-c4656e6d],.VPSidebarItem.level-3 .items[data-v-c4656e6d],.VPSidebarItem.level-4 .items[data-v-c4656e6d],.VPSidebarItem.level-5 .items[data-v-c4656e6d] {
    border-left: 1px solid var(--vp-c-divider);
    padding-left: 16px
}

.VPSidebarItem.collapsed .items[data-v-c4656e6d] {
    display: none
}

.VPSidebar[data-v-af16598e] {
    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-af16598e] {
    opacity: 1;
    visibility: visible;
    transform: translate(0);
    transition: opacity .25s,transform .5s cubic-bezier(.19,1,.22,1)
}

.dark .VPSidebar[data-v-af16598e] {
    box-shadow: var(--vp-shadow-1)
}

@media (min-width: 960px) {
    .VPSidebar[data-v-af16598e] {
        z-index:1;
        padding-top: var(--vp-nav-height);
        padding-bottom: 128px;
        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-af16598e] {
        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-af16598e] {
        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-af16598e] {
    outline: 0
}

.group+.group[data-v-af16598e] {
    border-top: 1px solid var(--vp-c-divider);
    padding-top: 10px
}

@media (min-width: 960px) {
    .group[data-v-af16598e] {
        padding-top:10px;
        width: calc(var(--vp-sidebar-width) - 64px)
    }
}

.VPButton[data-v-567ba664] {
    display: inline-block;
    border: 1px solid transparent;
    text-align: center;
    font-weight: 600;
    white-space: nowrap;
    transition: color .25s,border-color .25s,background-color .25s
}

.VPButton[data-v-567ba664]:active {
    transition: color .1s,border-color .1s,background-color .1s
}

.VPButton.medium[data-v-567ba664] {
    border-radius: 10px;
    padding: 5px 20px;
    line-height: 38px;
    font-size: 20px
}

.VPButton.big[data-v-567ba664] {
    border-radius: 24px;
    padding: 0 24px;
    line-height: 46px;
    font-size: 16px
}

.VPButton.brand[data-v-567ba664] {
    color: var(--vp-button-brand-text);
    background-color: #8b3dff
}

.VPButton.brand[data-v-567ba664]:hover {
    border-color: #AD41A4;
    color: var(--vp-button-brand-hover-text);
    background-color: #AD41A4
}

.VPButton.brand[data-v-567ba664]:active {
    border-color: #AD41A4;
    color: var(--vp-button-brand-active-text);
    background-color: #AD41A4
}

.VPButton.alt[data-v-567ba664] {
    border-color: var(--vp-button-alt-border);
    color: var(--vp-button-alt-text);
    background-color: var(--vp-button-alt-bg)
}

.VPButton.alt[data-v-567ba664]: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-567ba664]: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-567ba664] {
    border-color: var(--vp-button-sponsor-border);
    color: var(--vp-button-sponsor-text);
    background-color: var(--vp-button-sponsor-bg)
}

.VPButton.sponsor[data-v-567ba664]: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-567ba664]:active {
    border-color: var(--vp-button-sponsor-active-border);
    color: var(--vp-button-sponsor-active-text);
    background-color: var(--vp-button-sponsor-active-bg)
}

.VPHero[data-v-fd2650d5] {
    background: #fff;
    margin-bottom: 20px;
    /*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-fd2650d5] {
        padding:calc(var(--vp-nav-height) + var(--vp-layout-top-height, 0px) + 48px) 48px 64px
    }
}

@media (min-width: 960px) {
    .VPHero[data-v-fd2650d5] {
        padding:calc(var(--vp-nav-height) + var(--vp-layout-top-height, 0px)) 64px 64px
    }
}

.container[data-v-fd2650d5] {
    display: flex;
    flex-direction: column;
    margin: 0 auto;
    max-width: 1100px
}

@media (min-width: 960px) {
    .container[data-v-fd2650d5] {
        flex-direction:row
    }
}

.main[data-v-fd2650d5] {
    position: relative;
    z-index: 10;
    order: 2;
    flex-grow: 1;
    flex-shrink: 0
}

.VPHero.has-image .container[data-v-fd2650d5] {
    text-align: center
}

@media (min-width: 960px) {
    .VPHero.has-image .container[data-v-fd2650d5] {
        text-align:left
    }
}

@media (min-width: 960px) {
    .main[data-v-fd2650d5] {
        order:1;
        width: calc((100% / 3) * 2)
    }

    .VPHero.has-image .main[data-v-fd2650d5] {
        max-width: 592px
    }
}

.name[data-v-fd2650d5],.text[data-v-fd2650d5] {
    max-width: 392px;
    letter-spacing: -.4px;
    line-height: 40px;
    font-size: 32px;
    font-weight: 700;
}

.VPHero.has-image .name[data-v-fd2650d5],.VPHero.has-image .text[data-v-fd2650d5] {
    margin: 0 auto
}

.name[data-v-fd2650d5] {
    color: var(--vp-home-hero-name-color)
}

.clip[data-v-fd2650d5] {
    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-fd2650d5],.text[data-v-fd2650d5] {
        max-width:576px;
        line-height: 56px;
        font-size: 48px
    }
}

@media (min-width: 960px) {
    .name[data-v-fd2650d5],.text[data-v-fd2650d5] {
        line-height:40px;
        font-size: 56px
    }

    .VPHero.has-image .name[data-v-fd2650d5],.VPHero.has-image .text[data-v-fd2650d5] {
        margin: 0
    }
}

.tagline[data-v-fd2650d5] {
    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-fd2650d5] {
    margin: 0 auto
}

@media (min-width: 640px) {
    .tagline[data-v-fd2650d5] {
        padding-top:12px;
        max-width: 576px;
        line-height: 32px;
        font-size: 20px
    }
}

@media (min-width: 960px) {
    .tagline[data-v-fd2650d5] {
        line-height:36px;
        font-size: 24px
    }

    .VPHero.has-image .tagline[data-v-fd2650d5] {
        margin: 0
    }
}

.actions[data-v-fd2650d5] {
    display: flex;
    flex-wrap: wrap;
    margin: -6px;
    padding-top: 24px
}

.VPHero.has-image .actions[data-v-fd2650d5] {
    justify-content: center
}

@media (min-width: 640px) {
    .actions[data-v-fd2650d5] {
        padding-top:20px
    }
}

@media (min-width: 960px) {
    .VPHero.has-image .actions[data-v-fd2650d5] {
        justify-content:flex-start
    }
}

.action[data-v-fd2650d5] {
    flex-shrink: 0;
    padding: 6px
}

.image[data-v-fd2650d5] {
    order: 1;
    margin: -76px -24px -48px
}

@media (min-width: 640px) {
    .image[data-v-fd2650d5] {
        margin:-108px -24px -48px
    }
}

@media (min-width: 960px) {
    .image[data-v-fd2650d5] {
        flex-grow:1;
        order: 2;
        margin: 0;
        min-height: 100%
    }
}

.image-container[data-v-fd2650d5] {
    position: relative;
    margin: 0 auto;
    width: 320px;
    height: 320px
}

@media (min-width: 640px) {
    .image-container[data-v-fd2650d5] {
        width:392px;
        height: 392px
    }
}

@media (min-width: 960px) {
    .image-container[data-v-fd2650d5] {
        display:flex;
        justify-content: center;
        align-items: center;
        width: 100%;
        height: 100%;
        transform: translate(-32px,0)
    }
}

.image-bg[data-v-fd2650d5] {
    position: absolute;
    top: 50%;
    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);
    transform: translate(-50%,-50%)
}

@media (min-width: 640px) {
    .image-bg[data-v-fd2650d5] {
        width:256px;
        height: 256px
    }
}

@media (min-width: 960px) {
    .image-bg[data-v-fd2650d5] {
        width:320px;
        height: 320px
    }
}

[data-v-fd2650d5] .image-src {
    position: absolute;
    top: 50%;
    left: 50%;
    max-width: 350px;
    max-height: 200px;
    transform: translate(-50%,-50%)
}

@media (min-width: 640px) {
    [data-v-fd2650d5] .image-src {
        max-width:400px;
        max-height: 256px
    }
}

@media (min-width: 960px) {
    [data-v-fd2650d5] .image-src {
        max-width:450px;
        max-height: 320px
    }
}

.VPFeature[data-v-837f6cca] {
    display: block;
    border-radius: 12px;
    height: 100%;
    border: 1px solid #e5e7eb;
    background-color: #ffffff;
    transition: border-color .25s,background-color .25s
}

.VPFeature.link[data-v-837f6cca]:hover {
    border-color: var(--vp-c-brand);
    background-color: var(--vp-c-bg-soft-up)
}

.box[data-v-837f6cca] {
    display: flex;
    flex-direction: column;
    padding: 24px;
    height: 100%
}

.VPFeature[data-v-837f6cca] .VPImage {
    width: 48px;
    height: 48px;
    margin-bottom: 20px
}

.icon[data-v-837f6cca] {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: 20px;
    border-radius: 6px;
    background-color: var(--vp-c-bg-soft-down);
    width: 48px;
    height: 48px;
    font-size: 24px;
    transition: background-color .25s
}

.title[data-v-837f6cca] {
    line-height: 24px;
    font-size: 16px;
    font-weight: 600
}

.details[data-v-837f6cca] {
    flex-grow: 1;
    padding-top: 8px;
    line-height: 24px;
    font-size: 14px;
    font-weight: 500;
    color: #666666
}

.link-text[data-v-837f6cca] {
    padding-top: 8px
}

.link-text-value[data-v-837f6cca] {
    display: flex;
    align-items: center;
    font-size: 14px;
    font-weight: 500;
    color: var(--vp-c-brand)
}

.link-text-icon[data-v-837f6cca] {
    display: inline-block;
    margin-left: 6px;
    width: 14px;
    height: 14px;
    fill: currentColor
}

.VPFeatures[data-v-ba861f23] {
    position: relative;
    padding: 0 24px
}

@media (min-width: 640px) {
    .VPFeatures[data-v-ba861f23] {
        padding:0 48px
    }
}

@media (min-width: 960px) {
    .VPFeatures[data-v-ba861f23] {
        padding:0 64px
    }
}

.container[data-v-ba861f23] {
    margin: 0 auto;
    max-width: 1152px
}

.items[data-v-ba861f23] {
    display: flex;
    flex-wrap: wrap;
    margin: -8px
}

.item[data-v-ba861f23] {
    padding: 8px;
    width: 100%
}

@media (min-width: 640px) {
    .item.grid-2[data-v-ba861f23],.item.grid-4[data-v-ba861f23],.item.grid-6[data-v-ba861f23] {
        width:50%
    }
}

@media (min-width: 768px) {
    .item.grid-2[data-v-ba861f23],.item.grid-4[data-v-ba861f23] {
        width:50%
    }

    .item.grid-3[data-v-ba861f23],.item.grid-6[data-v-ba861f23] {
        width: calc(100% / 3)
    }
}

@media (min-width: 960px) {
    .item.grid-4[data-v-ba861f23] {
        width:25%
    }
}

.VPHome[data-v-d82743a8] {
    padding-bottom: 96px
}

.VPHome[data-v-d82743a8] .VPHomeSponsors {
    margin-top: 112px;
    margin-bottom: -128px
}

.VPDocAsideOutline[data-v-ff0f39c8] {
    display: none
}

.VPDocAsideOutline.has-outline[data-v-ff0f39c8] {
    display: block
}

.content[data-v-ff0f39c8] {
    position: relative;
    border-left: 1px solid var(--vp-c-divider);
    padding-left: 16px;
    font-size: 13px;
    font-weight: 500
}

.outline-marker[data-v-ff0f39c8] {
    position: absolute;
    top: 32px;
    left: -1px;
    z-index: 0;
    opacity: 0;
    width: 1px;
    height: 18px;
    background-color: var(--vp-c-brand);
    transition: top .25s cubic-bezier(0,1,.5,1),background-color .5s,opacity .25s
}

.outline-title[data-v-ff0f39c8] {
    letter-spacing: .4px;
    line-height: 28px;
    font-size: 13px;
    font-weight: 600
}

.VPDocAside[data-v-3f215769] {
    display: flex;
    flex-direction: column;
    flex-grow: 1
}

.spacer[data-v-3f215769] {
    flex-grow: 1
}

.VPDocAside[data-v-3f215769] .spacer+.VPDocAsideSponsors,.VPDocAside[data-v-3f215769] .spacer+.VPDocAsideCarbonAds {
    margin-top: 24px
}

.VPDocAside[data-v-3f215769] .VPDocAsideSponsors+.VPDocAsideCarbonAds {
    margin-top: 16px
}

.VPLastUpdated[data-v-7b3ebfe1] {
    line-height: 24px;
    font-size: 14px;
    font-weight: 500;
    color: var(--vp-c-text-2)
}

@media (min-width: 640px) {
    .VPLastUpdated[data-v-7b3ebfe1] {
        line-height:32px;
        font-size: 14px;
        font-weight: 500
    }
}

.VPDocFooter[data-v-face870a] {
    margin-top: 64px
}

.edit-info[data-v-face870a] {
    padding-bottom: 18px
}

@media (min-width: 640px) {
    .edit-info[data-v-face870a] {
        display:flex;
        justify-content: space-between;
        align-items: center;
        padding-bottom: 14px
    }
}

.edit-link-button[data-v-face870a] {
    display: flex;
    align-items: center;
    border: 0;
    line-height: 32px;
    font-size: 14px;
    font-weight: 500;
    color: var(--vp-c-brand);
    transition: color .25s
}

.edit-link-button[data-v-face870a]:hover {
    color: var(--vp-c-brand-dark)
}

.edit-link-icon[data-v-face870a] {
    margin-right: 8px;
    width: 14px;
    height: 14px;
    fill: currentColor
}

.prev-next[data-v-face870a] {
    border-top: 1px solid var(--vp-c-divider);
    padding-top: 24px
}

@media (min-width: 640px) {
    .prev-next[data-v-face870a] {
        display:flex
    }
}

.pager.has-prev[data-v-face870a] {
    padding-top: 8px
}

@media (min-width: 640px) {
    .pager[data-v-face870a] {
        display:flex;
        flex-direction: column;
        flex-shrink: 0;
        width: 50%
    }

    .pager.has-prev[data-v-face870a] {
        padding-top: 0;
        padding-left: 16px
    }
}

.pager-link[data-v-face870a] {
    display: block;
    border: 1px solid var(--vp-c-divider);
    border-radius: 8px;
    padding: 11px 16px 13px;
    width: 100%;
    height: 100%;
    transition: border-color .25s
}

.pager-link[data-v-face870a]:hover {
    border-color: var(--vp-c-brand)
}

.pager-link.next[data-v-face870a] {
    margin-left: auto;
    text-align: right
}

.desc[data-v-face870a] {
    display: block;
    line-height: 20px;
    font-size: 12px;
    font-weight: 500;
    color: var(--vp-c-text-2)
}

.title[data-v-face870a] {
    display: block;
    line-height: 20px;
    font-size: 14px;
    font-weight: 500;
    color: var(--vp-c-brand);
    transition: color .25s
}

.VPDocOutlineDropdown[data-v-2edece88] {
    margin-bottom: 42px
}

.VPDocOutlineDropdown button[data-v-2edece88] {
    display: block;
    font-size: 14px;
    font-weight: 500;
    line-height: 24px;
    color: var(--vp-c-text-2);
    transition: color .5s;
    border: 1px solid var(--vp-c-border);
    padding: 4px 12px;
    border-radius: 8px
}

.VPDocOutlineDropdown button[data-v-2edece88]:hover {
    color: var(--vp-c-text-1);
    transition: color .25s
}

.VPDocOutlineDropdown button.open[data-v-2edece88] {
    color: var(--vp-c-text-1)
}

.icon[data-v-2edece88] {
    display: inline-block;
    vertical-align: middle;
    margin-left: 2px;
    width: 14px;
    height: 14px;
    fill: currentColor
}

[data-v-2edece88] .outline-link {
    font-size: 13px
}

.open>.icon[data-v-2edece88] {
    transform: rotate(90deg)
}

.items[data-v-2edece88] {
    margin-top: 10px;
    border-left: 1px solid var(--vp-c-divider)
}

.VPDoc[data-v-c4b0d3cf] {
    padding: 32px 24px 96px;
    width: 100%
}

.VPDoc .VPDocOutlineDropdown[data-v-c4b0d3cf] {
    display: none
}

@media (min-width: 960px) and (max-width: 1280px) {
    .VPDoc .VPDocOutlineDropdown[data-v-c4b0d3cf] {
        display:block
    }
}

@media (min-width: 768px) {
    .VPDoc[data-v-c4b0d3cf] {
        padding:48px 32px 128px
    }
}

@media (min-width: 960px) {
    .VPDoc[data-v-c4b0d3cf] {
        padding:32px 32px 0
    }

    .VPDoc:not(.has-sidebar) .container[data-v-c4b0d3cf] {
        display: flex;
        justify-content: center;
        max-width: 992px
    }

    .VPDoc:not(.has-sidebar) .content[data-v-c4b0d3cf] {
        max-width: 752px
    }
}

@media (min-width: 1280px) {
    .VPDoc .container[data-v-c4b0d3cf] {
        display:flex;
        justify-content: center
    }

    .VPDoc .aside[data-v-c4b0d3cf] {
        display: block
    }
}

@media (min-width: 1440px) {
    .VPDoc:not(.has-sidebar) .content[data-v-c4b0d3cf] {
        max-width:784px
    }

    .VPDoc:not(.has-sidebar) .container[data-v-c4b0d3cf] {
        max-width: 1104px
    }
}

.container[data-v-c4b0d3cf] {
    margin: 0 auto;
    width: 100%
}

.aside[data-v-c4b0d3cf] {
    position: relative;
    display: none;
    order: 2;
    flex-grow: 1;
    padding-left: 32px;
    width: 100%;
    max-width: 256px
}

.left-aside[data-v-c4b0d3cf] {
    order: 1;
    padding-left: unset;
    padding-right: 32px
}

.aside-container[data-v-c4b0d3cf] {
    position: fixed;
    top: 0;
    padding-top: calc(var(--vp-nav-height) + var(--vp-layout-top-height, 0px) + var(--vp-doc-top-height, 0px) + 32px);
    width: 224px;
    height: 100vh;
    overflow-x: hidden;
    overflow-y: auto;
    scrollbar-width: none
}

.aside-container[data-v-c4b0d3cf]::-webkit-scrollbar {
    display: none
}

.aside-curtain[data-v-c4b0d3cf] {
    position: fixed;
    bottom: 0;
    z-index: 10;
    width: 224px;
    height: 32px;
    background: linear-gradient(transparent,var(--vp-c-bg) 70%)
}

.aside-content[data-v-c4b0d3cf] {
    display: flex;
    flex-direction: column;
    min-height: calc(100vh - (var(--vp-nav-height) + var(--vp-layout-top-height, 0px) + 32px));
    padding-bottom: 32px
}

.content[data-v-c4b0d3cf] {
    position: relative;
    margin: 0 auto;
    width: 100%
}

@media (min-width: 960px) {
    .content[data-v-c4b0d3cf] {
        padding:0 32px 128px
    }
}

@media (min-width: 1280px) {
    .content[data-v-c4b0d3cf] {
        order:1;
        margin: 0;
        min-width: 640px
    }
}

.content-container[data-v-c4b0d3cf] {
    margin: 0 auto
}

.VPDoc.has-aside .content-container[data-v-c4b0d3cf] {
    max-width: 688px
}

.NotFound[data-v-c70503b8] {
    padding: 64px 24px 96px;
    text-align: center
}

@media (min-width: 768px) {
    .NotFound[data-v-c70503b8] {
        padding:96px 32px 168px
    }
}

.code[data-v-c70503b8] {
    line-height: 64px;
    font-size: 64px;
    font-weight: 600
}

.title[data-v-c70503b8] {
    padding-top: 12px;
    letter-spacing: 2px;
    line-height: 20px;
    font-size: 20px;
    font-weight: 700
}

.divider[data-v-c70503b8] {
    margin: 24px auto 18px;
    width: 64px;
    height: 1px;
    background-color: var(--vp-c-divider)
}

.quote[data-v-c70503b8] {
    margin: 0 auto;
    max-width: 256px;
    font-size: 14px;
    font-weight: 500;
    color: var(--vp-c-text-2)
}

.action[data-v-c70503b8] {
    padding-top: 20px
}

.link[data-v-c70503b8] {
    display: inline-block;
    border: 1px solid var(--vp-c-brand);
    border-radius: 16px;
    padding: 3px 16px;
    font-size: 14px;
    font-weight: 500;
    color: var(--vp-c-brand);
    transition: border-color .25s,color .25s
}

.link[data-v-c70503b8]:hover {
    border-color: var(--vp-c-brand-dark);
    color: var(--vp-c-brand-dark)
}

.VPContent[data-v-a494bd1d] {
    flex-grow: 1;
    flex-shrink: 0;
    margin: var(--vp-layout-top-height, 0px) auto 0;
    width: 100%
}

.VPContent.is-home[data-v-a494bd1d] {
    width: 100%;
    max-width: 100%
}

.VPContent.has-sidebar[data-v-a494bd1d] {
    margin: 0
}

@media (min-width: 960px) {
    .VPContent[data-v-a494bd1d] {
        padding-top:var(--vp-nav-height)
    }

    .VPContent.has-sidebar[data-v-a494bd1d] {
        margin: var(--vp-layout-top-height, 0px) 0 0;
        padding-left: var(--vp-sidebar-width)
    }
}

@media (min-width: 1440px) {
    .VPContent.has-sidebar[data-v-a494bd1d] {
        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-f7fc41f4] {
    position: relative;
    z-index: var(--vp-z-index-footer);
    border-top: 1px solid 1px solid #e5e7eb;
    padding: 32px 24px;
    background-color: #fff
}

.VPFooter.has-sidebar[data-v-f7fc41f4] {
    display: none
}

@media (min-width: 768px) {
    .VPFooter[data-v-f7fc41f4] {
        padding:32px
    }
}

.container[data-v-f7fc41f4] {
    margin: 0 auto;
    max-width: var(--vp-layout-max-width);
    text-align: center
}

.message[data-v-f7fc41f4],.copyright[data-v-f7fc41f4] {
    line-height: 24px;
    font-size: 14px;
    font-weight: 500;
    color: #666666
}

.Layout[data-v-b2cf3e0b] {
    display: flex;
    flex-direction: column;
    min-height: 100vh
}

.VPHomeSponsors[data-v-3c6e61c2] {
    border-top: 1px solid var(--vp-c-gutter);
    padding: 88px 24px 96px;
    background-color: var(--vp-c-bg)
}

.container[data-v-3c6e61c2] {
    margin: 0 auto;
    max-width: 1152px
}

.love[data-v-3c6e61c2] {
    margin: 0 auto;
    width: 28px;
    height: 28px;
    color: var(--vp-c-text-3)
}

.icon[data-v-3c6e61c2] {
    width: 28px;
    height: 28px;
    fill: currentColor
}

.message[data-v-3c6e61c2] {
    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-3c6e61c2] {
    padding-top: 32px
}

.action[data-v-3c6e61c2] {
    padding-top: 40px;
    text-align: center
}

.VPTeamPage[data-v-10b00018] {
    padding-bottom: 96px
}

@media (min-width: 768px) {
    .VPTeamPage[data-v-10b00018] {
        padding-bottom:128px
    }
}

.VPTeamPageSection+.VPTeamPageSection[data-v-10b00018-s],.VPTeamMembers+.VPTeamPageSection[data-v-10b00018-s] {
    margin-top: 64px
}

.VPTeamMembers+.VPTeamMembers[data-v-10b00018-s] {
    margin-top: 24px
}

@media (min-width: 768px) {
    .VPTeamPageTitle+.VPTeamPageSection[data-v-10b00018-s] {
        margin-top:16px
    }

    .VPTeamPageSection+.VPTeamPageSection[data-v-10b00018-s],.VPTeamMembers+.VPTeamPageSection[data-v-10b00018-s] {
        margin-top: 96px
    }
}

.VPTeamMembers[data-v-10b00018-s] {
    padding: 0 24px
}

@media (min-width: 768px) {
    .VPTeamMembers[data-v-10b00018-s] {
        padding:0 48px
    }
}

@media (min-width: 960px) {
    .VPTeamMembers[data-v-10b00018-s] {
        padding:0 64px
    }
}

.VPTeamPageTitle[data-v-bf2cbdac] {
    padding: 48px 32px;
    text-align: center
}

@media (min-width: 768px) {
    .VPTeamPageTitle[data-v-bf2cbdac] {
        padding:64px 48px 48px
    }
}

@media (min-width: 960px) {
    .VPTeamPageTitle[data-v-bf2cbdac] {
        padding:80px 64px 48px
    }
}

.title[data-v-bf2cbdac] {
    letter-spacing: 0;
    line-height: 44px;
    font-size: 36px;
    font-weight: 500
}

@media (min-width: 768px) {
    .title[data-v-bf2cbdac] {
        letter-spacing:-.5px;
        line-height: 56px;
        font-size: 48px
    }
}

.lead[data-v-bf2cbdac] {
    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-bf2cbdac] {
        max-width:592px;
        letter-spacing: .15px;
        line-height: 28px;
        font-size: 20px
    }
}

.VPTeamPageSection[data-v-b1a88750] {
    padding: 0 32px
}

@media (min-width: 768px) {
    .VPTeamPageSection[data-v-b1a88750] {
        padding:0 48px
    }
}

@media (min-width: 960px) {
    .VPTeamPageSection[data-v-b1a88750] {
        padding:0 64px
    }
}

.title[data-v-b1a88750] {
    position: relative;
    margin: 0 auto;
    max-width: 1152px;
    text-align: center;
    color: var(--vp-c-text-2)
}

.title-line[data-v-b1a88750] {
    position: absolute;
    top: 16px;
    left: 0;
    width: 100%;
    height: 1px;
    background-color: var(--vp-c-divider)
}

.title-text[data-v-b1a88750] {
    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-b1a88750] {
    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-b1a88750] {
    padding-top: 40px
}

.VPTeamMembersItem[data-v-a3462077] {
    display: flex;
    flex-direction: column;
    gap: 2px;
    border-radius: 12px;
    width: 100%;
    height: 100%;
    overflow: hidden
}

.VPTeamMembersItem.small .profile[data-v-a3462077] {
    padding: 32px
}

.VPTeamMembersItem.small .data[data-v-a3462077] {
    padding-top: 20px
}

.VPTeamMembersItem.small .avatar[data-v-a3462077] {
    width: 64px;
    height: 64px
}

.VPTeamMembersItem.small .name[data-v-a3462077] {
    line-height: 24px;
    font-size: 16px
}

.VPTeamMembersItem.small .affiliation[data-v-a3462077] {
    padding-top: 4px;
    line-height: 20px;
    font-size: 14px
}

.VPTeamMembersItem.small .desc[data-v-a3462077] {
    padding-top: 12px;
    line-height: 20px;
    font-size: 14px
}

.VPTeamMembersItem.small .links[data-v-a3462077] {
    margin: 0 -16px -20px;
    padding: 10px 0 0
}

.VPTeamMembersItem.medium .profile[data-v-a3462077] {
    padding: 48px 32px
}

.VPTeamMembersItem.medium .data[data-v-a3462077] {
    padding-top: 24px;
    text-align: center
}

.VPTeamMembersItem.medium .avatar[data-v-a3462077] {
    width: 96px;
    height: 96px
}

.VPTeamMembersItem.medium .name[data-v-a3462077] {
    letter-spacing: .15px;
    line-height: 28px;
    font-size: 20px
}

.VPTeamMembersItem.medium .affiliation[data-v-a3462077] {
    padding-top: 4px;
    font-size: 16px
}

.VPTeamMembersItem.medium .desc[data-v-a3462077] {
    padding-top: 16px;
    max-width: 288px;
    font-size: 16px
}

.VPTeamMembersItem.medium .links[data-v-a3462077] {
    margin: 0 -16px -12px;
    padding: 16px 12px 0
}

.profile[data-v-a3462077] {
    flex-grow: 1;
    background-color: var(--vp-c-bg-soft)
}

.data[data-v-a3462077] {
    text-align: center
}

.avatar[data-v-a3462077] {
    position: relative;
    flex-shrink: 0;
    margin: 0 auto;
    border-radius: 50%;
    box-shadow: var(--vp-shadow-3)
}

.avatar-img[data-v-a3462077] {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    border-radius: 50%;
    object-fit: cover
}

.name[data-v-a3462077] {
    margin: 0;
    font-weight: 600
}

.affiliation[data-v-a3462077] {
    margin: 0;
    font-weight: 500;
    color: var(--vp-c-text-2)
}

.org.link[data-v-a3462077] {
    color: var(--vp-c-text-2);
    transition: color .25s
}

.org.link[data-v-a3462077]:hover {
    color: var(--vp-c-brand)
}

.desc[data-v-a3462077] {
    margin: 0 auto
}

.desc[data-v-a3462077] a {
    font-weight: 500;
    color: var(--vp-c-brand);
    text-decoration-style: dotted;
    transition: color .25s
}

.links[data-v-a3462077] {
    display: flex;
    justify-content: center;
    height: 56px
}

.sp-link[data-v-a3462077] {
    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-a3462077]:hover,.sp .sp-link.link[data-v-a3462077]:focus {
    outline: none;
    color: var(--vp-c-white);
    background-color: var(--vp-c-sponsor)
}

.sp-icon[data-v-a3462077] {
    margin-right: 8px;
    width: 16px;
    height: 16px;
    fill: currentColor
}

.VPTeamMembers.small .container[data-v-04685dce] {
    grid-template-columns: repeat(auto-fit,minmax(224px,1fr))
}

.VPTeamMembers.small.count-1 .container[data-v-04685dce] {
    max-width: 276px
}

.VPTeamMembers.small.count-2 .container[data-v-04685dce] {
    max-width: 576px
}

.VPTeamMembers.small.count-3 .container[data-v-04685dce] {
    max-width: 876px
}

.VPTeamMembers.medium .container[data-v-04685dce] {
    grid-template-columns: repeat(auto-fit,minmax(256px,1fr))
}

@media (min-width: 375px) {
    .VPTeamMembers.medium .container[data-v-04685dce] {
        grid-template-columns:repeat(auto-fit,minmax(288px,1fr))
    }
}

.VPTeamMembers.medium.count-1 .container[data-v-04685dce] {
    max-width: 368px
}

.VPTeamMembers.medium.count-2 .container[data-v-04685dce] {
    max-width: 760px
}

.container[data-v-04685dce] {
    display: grid;
    gap: 24px;
    margin: 0 auto;
    max-width: 1152px
}

.VPLocalSearchBox[data-v-36d7e60a] {
    position: fixed;
    z-index: 100;
    inset: 0;
    display: flex
}

.backdrop[data-v-36d7e60a] {
    position: absolute;
    inset: 0;
    background: var(--vp-backdrop-bg-color);
    transition: opacity .5s
}

.shell[data-v-36d7e60a] {
    position: relative;
    padding: 12px;
    margin: 64px auto;
    display: flex;
    flex-direction: column;
    gap: 16px;
    background: var(--vp-local-search-bg);
    width: min(100vw - 60px,900px);
    height: min-content;
    max-height: min(100vh - 128px,900px);
    border-radius: 6px
}

@media (max-width: 768px) {
    .shell[data-v-36d7e60a] {
        margin:0;
        width: 100vw;
        height: 100vh;
        max-height: none;
        border-radius: 0
    }
}

.search-bar[data-v-36d7e60a] {
    border: 1px solid var(--vp-c-divider);
    border-radius: 4px;
    display: flex;
    align-items: center;
    padding: 0 12px;
    cursor: text
}

@media (max-width: 768px) {
    .search-bar[data-v-36d7e60a] {
        padding:0 8px
    }
}

.search-bar[data-v-36d7e60a]:focus-within {
    border-color: var(--vp-c-brand)
}

.search-icon[data-v-36d7e60a] {
    margin: 8px
}

@media (max-width: 768px) {
    .search-icon[data-v-36d7e60a] {
        display:none
    }
}

.search-input[data-v-36d7e60a] {
    padding: 6px 12px;
    font-size: inherit;
    width: 100%
}

@media (max-width: 768px) {
    .search-input[data-v-36d7e60a] {
        padding:6px 4px
    }
}

.search-actions[data-v-36d7e60a] {
    display: flex;
    gap: 4px
}

@media (any-pointer: coarse) {
    .search-actions[data-v-36d7e60a] {
        gap:8px
    }
}

@media (min-width: 769px) {
    .search-actions.before[data-v-36d7e60a] {
        display:none
    }
}

.search-actions button[data-v-36d7e60a] {
    padding: 8px
}

.search-actions button[data-v-36d7e60a]:not([disabled]):hover,.toggle-layout-button.detailed-list[data-v-36d7e60a] {
    color: var(--vp-c-brand)
}

.search-actions button.clear-button[data-v-36d7e60a]:disabled {
    opacity: .37
}

.search-keyboard-shortcuts[data-v-36d7e60a] {
    font-size: .8rem;
    opacity: 75%;
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    line-height: 14px
}

.search-keyboard-shortcuts span[data-v-36d7e60a] {
    display: flex;
    align-items: center;
    gap: 4px
}

@media (max-width: 768px) {
    .search-keyboard-shortcuts[data-v-36d7e60a] {
        display:none
    }
}

.search-keyboard-shortcuts kbd[data-v-36d7e60a] {
    background: rgba(128,128,128,.1);
    border-radius: 4px;
    padding: 3px 6px;
    min-width: 24px;
    display: inline-block;
    text-align: center;
    vertical-align: middle;
    border: 1px solid rgba(128,128,128,.15);
    box-shadow: 0 2px 2px #0000001a
}

.results[data-v-36d7e60a] {
    display: flex;
    flex-direction: column;
    gap: 6px;
    overflow-x: hidden;
    overflow-y: auto;
    overscroll-behavior: contain
}

.result[data-v-36d7e60a] {
    display: flex;
    align-items: center;
    gap: 8px;
    border-radius: 4px;
    transition: none;
    line-height: 1rem;
    border: solid 2px var(--vp-local-search-result-border);
    outline: none
}

.result>div[data-v-36d7e60a] {
    margin: 12px;
    width: 100%;
    overflow: hidden
}

@media (max-width: 768px) {
    .result>div[data-v-36d7e60a] {
        margin:8px
    }
}

.titles[data-v-36d7e60a] {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    position: relative;
    z-index: 1001;
    padding: 2px 0
}

.title[data-v-36d7e60a] {
    display: flex;
    align-items: center;
    gap: 4px
}

.title.main[data-v-36d7e60a] {
    font-weight: 500
}

.title-icon[data-v-36d7e60a] {
    opacity: .5;
    font-weight: 500;
    color: var(--vp-c-brand)
}

.title svg[data-v-36d7e60a] {
    opacity: .5
}

.result.selected[data-v-36d7e60a] {
    --vp-local-search-result-bg: var(--vp-local-search-result-selected-bg);
    border-color: var(--vp-local-search-result-selected-border)
}

.excerpt-wrapper[data-v-36d7e60a] {
    position: relative
}

.excerpt[data-v-36d7e60a] {
    opacity: 75%;
    pointer-events: none;
    max-height: 140px;
    overflow: hidden;
    position: relative;
    opacity: .5;
    margin-top: 4px
}

.result.selected .excerpt[data-v-36d7e60a] {
    opacity: 1
}

.excerpt[data-v-36d7e60a] * {
    font-size: .8rem!important;
    line-height: 130%!important
}

.titles[data-v-36d7e60a] mark,.excerpt[data-v-36d7e60a] mark {
    background-color: var(--vp-local-search-highlight-bg);
    color: var(--vp-local-search-highlight-text);
    border-radius: 2px;
    padding: 0 2px
}

.excerpt[data-v-36d7e60a] .vp-code-group .tabs {
    display: none
}

.excerpt[data-v-36d7e60a] .vp-code-group div[class*=language-] {
    border-radius: 8px!important
}

.excerpt-gradient-bottom[data-v-36d7e60a] {
    position: absolute;
    bottom: -1px;
    left: 0;
    width: 100%;
    height: 8px;
    background: linear-gradient(transparent,var(--vp-local-search-result-bg));
    z-index: 1000
}

.excerpt-gradient-top[data-v-36d7e60a] {
    position: absolute;
    top: -1px;
    left: 0;
    width: 100%;
    height: 8px;
    background: linear-gradient(var(--vp-local-search-result-bg),transparent);
    z-index: 1000
}

.result.selected .titles[data-v-36d7e60a],.result.selected .title-icon[data-v-36d7e60a] {
    color: var(--vp-c-brand)!important
}

.no-results[data-v-36d7e60a] {
    font-size: .9rem;
    text-align: center;
    padding: 12px
}

svg[data-v-36d7e60a] {
    flex: none
}

header {
  position: fixed !important;
}
main {
  padding-top: 96px !important;
  box-sizing: border-box;
}
h1 {
  font-size: 1.5rem !important;
}
/* 桌面菜单样式 */
.desktop-menu {
  display: none;
}

@media (min-width: 768px) {
  .desktop-menu {
    display: flex;
    gap: 24px;
    margin-left: 60px;
  }
}

.menu-item {
  position: relative;
  padding: 24px 0;
  color: #64748b;
  text-decoration: none;
  transition: all 0.2s;
  font-size: 16px;
  font-weight: 400;
}

.menu-item:hover {
  color: #4ade80;
}

.menu-item.active {
  color: #16a34a;
  font-weight: 500;
}

.menu-item.active::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 2px;
  background: linear-gradient(90deg, #4ade80 0%, #16a34a 100%);
  border-radius: 2px;
}

/* 移动端菜单按钮 */
.mobile-menu-button {
  display: block;
  border: none;
  background: none;
  cursor: pointer;
  padding: 8px;
}

@media (min-width: 768px) {
  .mobile-menu-button {
    display: none;
  }
}

.mobile-menu-icon {
  display: block;
  width: 24px;
  height: 2px;
  background-color: #1e293b;
  margin: 4px 0;
  transition: transform 0.3s, opacity 0.3s;
}

.mobile-menu-button.active .mobile-menu-icon:nth-child(1) {
  transform: translateY(6px) rotate(45deg);
}

.mobile-menu-button.active .mobile-menu-icon:nth-child(2) {
  opacity: 0;
}

.mobile-menu-button.active .mobile-menu-icon:nth-child(3) {
  transform: translateY(-6px) rotate(-45deg);
}

/* 移动端菜单 */
.mobile-menu {
  display: none;
  border-top: 1px solid #f1f5f9;
  padding: 16px 0;
}

.mobile-menu.active {
  display: block;
}

.mobile-menu-item {
  display: block;
  padding: 16px 0;
  color: #64748b;
  text-decoration: none;
  border-bottom: 1px solid #f1f5f9;
  font-size: 16px;
}

.mobile-menu-item.active {
  color: #16a34a;
  font-weight: 500;
}

.documents-container {
  max-width: 1920px; /* 增大最大宽度，适应更大屏幕 */
  margin: 40px auto;
  padding: 0 24px; /* 增加左右间距 */
}

.section-title {
  font-size: 28px; /* 增大标题字体 */
  font-weight: bold;
  color: #1e293b;
  margin-bottom: 32px; /* 增加底部间距 */
  padding-bottom: 10px;
  border-bottom: 2px solid #4ade80;
  display: inline-block;
}

.cards-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 28px; /* 增加卡片间距 */
}

/* 响应式布局：主要针对PC端不同分辨率 */
@media (min-width: 768px) {
  /* 平板及以上 */
  .cards-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  /* 小屏幕桌面 */
  .cards-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (min-width: 1366px) {
  /* 标准桌面 */
  .cards-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

@media (min-width: 1600px) {
  /* 宽屏桌面 */
  .cards-grid {
    grid-template-columns: repeat(5, 1fr);
  }
}

@media (min-width: 1920px) {
  /* 超大屏桌面 */
  .cards-grid {
    grid-template-columns: repeat(6, 1fr);
  }
}

.document-card {
  background-color: #ffffff;
  border-radius: 14px; /* 增加圆角 */
  overflow: hidden;
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.06); /* 增强阴影 */
  transition: all 0.3s ease;
  text-decoration: none;
  display: flex;
  flex-direction: column;
  position: relative;
  height: 100%;
}

.document-card:hover {
  transform: translateY(-6px); /* 增加悬停上浮距离 */
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.1); /* 增强悬停阴影 */
}

.card-thumbnail {
  width: 100%;
  height: 180px; /* 增加缩略图高度 */
  object-fit: cover;
  background: linear-gradient(135deg, #f5f7fa 0%, #e4eaf1 100%);
  position: relative;
  overflow: hidden;
}

.card-thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
}

.document-card:hover .card-thumbnail img {
  transform: scale(1.06); /* 增加图片放大比例 */
}

.card-thumbnail::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.05);
  transition: all 0.3s ease;
}

.document-card:hover .card-thumbnail::after {
  background: rgba(0, 0, 0, 0.08);
}

.thumbnail-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #94a3b8;
  font-size: 56px; /* 增加图标大小 */
  background: linear-gradient(135deg, #f5f7fa 0%, #e4eaf1 100%);
}

.card-content {
  padding: 20px; /* 增加内边距 */
  flex: 1;
  display: flex;
  flex-direction: column;
}

.card-title-container {
  overflow: hidden;
  margin-bottom: 10px;
}

.card-title {
  font-size: 19px; /* 微调标题字体大小 */
  font-weight: 600;
  color: #1e293b;
  line-height: 1.42; /* 微调行高 */
  transition: color 0.3s ease;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

.document-card:hover .card-title {
  color: #16a34a;
}

.card-description {
  font-size: 15px; /* 微调描述字体大小 */
  color: #64748b;
  line-height: 1.55; /* 微调行高 */
  margin-bottom: 14px;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  flex: 1;
}

.card-meta {
  display: flex;
  align-items: center;
  color: #94a3b8;
  font-size: 14px; /* 微调日期字体大小 */
}

.card-date {
  display: flex;
  align-items: center;
}

.card-date i {
  margin-right: 6px;
  font-size: 13px; /* 微调图标大小 */
}

.card-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(
    to bottom,
    rgba(0, 0, 0, 0) 0%,
    rgba(0, 0, 0, 0.07) 100%
  );
  opacity: 0;
  transition: opacity 0.3s ease;
  pointer-events: none;
}

.document-card:hover .card-overlay {
  opacity: 1;
}

/* 移动端适配 */
@media (max-width: 767px) {
  .documents-container {
    padding: 0 16px;
  }

  .section-title {
    font-size: 24px;
    margin-bottom: 24px;
  }

  .card-title-container {
  }

  .card-title {
    font-size: 16px;
    -webkit-line-clamp: 3;
  }

  .card-description {
    -webkit-line-clamp: 4; /* 移动端描述显示4行 */
    font-size: 14px;
  }

  .card-thumbnail {
    height: 160px; /* 移动端缩略图高度降低 */
  }
}

.breadcrumb {
  display: flex;
  flex-wrap: wrap;
  padding: 0.5rem 1rem;
  margin-bottom: 1rem;
  list-style: none;
  background-color: #f8f9fa;
  border-radius: 0.25rem;
}

.breadcrumb-item {
  display: flex;
}

.breadcrumb-item + .breadcrumb-item::before {
  display: inline-block;
  padding-right: 0.5rem;
  padding-left: 0.5rem;
  color: #6c757d;
  content: "/";
}

.breadcrumb-item.active {
  color: #6c757d;
}

