@charset "UTF-8";
:root {
    --font-family: system-ui, -apple-system, "Segoe UI", "Roboto", "Ubuntu", "Cantarell", "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
    --line-height: 1.5;
    --font-weight: 400;
    --font-size: 16px;
    --border-radius: 0.25rem;
    --border-width: 1px;
    --outline-width: 3px;
    --spacing: 1rem;
    --typography-spacing-vertical: 1.5rem;
    --block-spacing-vertical: calc(var(--spacing) * 2);
    --block-spacing-horizontal: var(--spacing);
    --grid-spacing-vertical: 0;
    --grid-spacing-horizontal: var(--spacing);
    --form-element-spacing-vertical: 0.75rem;
    --form-element-spacing-horizontal: 1rem;
    --nav-element-spacing-vertical: 1rem;
    --nav-element-spacing-horizontal: 0.5rem;
    --nav-link-spacing-vertical: 0.5rem;
    --nav-link-spacing-horizontal: 0.5rem;
    --form-label-font-weight: var(--font-weight);
    --transition: 0.2s ease-in-out
}

@media (min-width: 576px) {
    :root {
        --font-size: 17px
    }
}

@media (min-width: 768px) {
    :root {
        --font-size: 18px
    }
}

@media (min-width: 992px) {
    :root {
        --font-size: 19px
    }
}

@media (min-width: 1200px) {
    :root {
        --font-size: 20px
    }
}

a {
    --text-decoration: none
}

a.contrast, a.secondary {
    --text-decoration: underline
}

small {
    --font-size: 0.875em
}

h1, h2, h3, h4, h5, h6 {
    --font-weight: 700
}

h1 {
    --font-size: 2rem;
    --typography-spacing-vertical: 3rem
}

h2 {
    --font-size: 1.75rem;
    --typography-spacing-vertical: 2.625rem
}

h3 {
    --font-size: 1.5rem;
    --typography-spacing-vertical: 2.25rem
}

h4 {
    --font-size: 1.25rem;
    --typography-spacing-vertical: 1.874rem
}

h5 {
    --font-size: 1.125rem;
    --typography-spacing-vertical: 1.6875rem
}

[type=checkbox], [type=radio] {
    --border-width: 2px
}

[type=checkbox][role=switch] {
    --border-width: 3px
}

tfoot td, tfoot th, thead td, thead th {
    --border-width: 3px
}

:not(thead):not(tfoot) > * > td {
    --font-size: 0.875em
}

code, kbd, pre, samp {
    --font-family: "Menlo", "Consolas", "Roboto Mono", "Ubuntu Monospace", "Noto Mono", "Oxygen Mono", "Liberation Mono", monospace, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji"
}

kbd {
    --font-weight: bolder
}

:root:not([data-theme=dark]), [data-theme=light] {
    color-scheme: light;
    --background-color: #fff;
    --color: rgba(0, 0, 0, 0.8);
    --h1-color: rgba(0, 0, 0, 0.95);
    --h2-color: rgba(0, 0, 0, 0.9);
    --h3-color: rgba(0, 0, 0, 0.85);
    --h4-color: rgba(0, 0, 0, 0.8);
    --h5-color: rgba(0, 0, 0, 0.75);
    --h6-color: rgba(0, 0, 0, 0.7);
    --muted-color: rgba(0, 0, 0, 0.5);
    --muted-border-color: rgba(0, 0, 0, 0.1);
    --primary: rgba(16, 149, 193, 1);
    --primary-hover: rgba(6, 125, 166, 1);
    --primary-focus: rgba(16, 149, 193, 0.125);
    --primary-inverse: #fff;
    --secondary: rgba(0, 0, 0, 0.4);
    --secondary-hover: rgba(0, 0, 0, 0.6);
    --secondary-focus: rgba(0, 0, 0, 0.125);
    --secondary-inverse: #fff;
    --contrast: rgba(0, 0, 0, 0.9);
    --contrast-hover: rgba(0, 0, 0, 1);
    --contrast-focus: rgba(0, 0, 0, 0.125);
    --contrast-inverse: #fff;
    --mark-background-color: #fff2ca;
    --mark-color: #543a26;
    --ins-color: #388e3c;
    --del-color: #c62828;
    --blockquote-border-color: var(--muted-border-color);
    --blockquote-footer-color: var(--muted-color);
    --button-box-shadow: 0 0 0 rgba(0, 0, 0, 0);
    --button-hover-box-shadow: 0 0 0 rgba(0, 0, 0, 0);
    --form-element-background-color: transparent;
    --form-element-border-color: hsl(205deg, 14%, 68%);
    --form-element-color: var(--color);
    --form-element-placeholder-color: var(--muted-color);
    --form-element-active-background-color: transparent;
    --form-element-active-border-color: var(--primary);
    --form-element-focus-color: var(--primary-focus);
    --form-element-disabled-background-color: hsl(205deg, 18%, 86%);
    --form-element-disabled-border-color: hsl(205deg, 14%, 68%);
    --form-element-disabled-opacity: 0.5;
    --form-element-invalid-border-color: #c62828;
    --form-element-invalid-active-border-color: #d32f2f;
    --form-element-invalid-focus-color: rgba(211, 47, 47, 0.125);
    --form-element-valid-border-color: #388e3c;
    --form-element-valid-active-border-color: #43a047;
    --form-element-valid-focus-color: rgba(67, 160, 71, 0.125);
    --switch-background-color: hsl(205deg, 16%, 77%);
    --switch-color: var(--primary-inverse);
    --switch-checked-background-color: var(--primary);
    --range-border-color: hsl(205deg, 18%, 86%);
    --range-active-border-color: hsl(205deg, 16%, 77%);
    --range-thumb-border-color: var(--background-color);
    --range-thumb-color: var(--secondary);
    --range-thumb-hover-color: var(--secondary-hover);
    --range-thumb-active-color: var(--primary);
    --table-border-color: var(--muted-border-color);
    --table-row-stripped-background-color: #f6f8f9;
    --code-background-color: hsl(205deg, 20%, 94%);
    --code-color: var(--muted-color);
    --code-kbd-background-color: var(--contrast);
    --code-kbd-color: var(--contrast-inverse);
    --code-tag-color: hsl(330deg, 40%, 50%);
    --code-property-color: hsl(185deg, 40%, 40%);
    --code-value-color: hsl(40deg, 20%, 50%);
    --code-comment-color: hsl(205deg, 14%, 68%);
    --accordion-border-color: var(--muted-border-color);
    --accordion-close-summary-color: var(--color);
    --accordion-open-summary-color: var(--muted-color);
    --card-background-color: var(--background-color);
    --card-border-color: var(--muted-border-color);
    --card-box-shadow: 0.0145rem 0.029rem 0.174rem rgba(27, 40, 50, 0.01698), 0.0335rem 0.067rem 0.402rem rgba(27, 40, 50, 0.024), 0.0625rem 0.125rem 0.75rem rgba(27, 40, 50, 0.03), 0.1125rem 0.225rem 1.35rem rgba(27, 40, 50, 0.036), 0.2085rem 0.417rem 2.502rem rgba(27, 40, 50, 0.04302), 0.5rem 1rem 6rem rgba(27, 40, 50, 0.06), 0 0 0 0.0625rem rgba(27, 40, 50, 0.015);
    --card-sectionning-background-color: #fbfbfc;
    --dropdown-background-color: #fbfbfc;
    --dropdown-border-color: #e1e6eb;
    --dropdown-box-shadow: var(--card-box-shadow);
    --dropdown-color: var(--color);
    --dropdown-hover-background-color: hsl(205deg, 20%, 94%);
    --modal-overlay-background-color: rgba(213, 220, 226, 0.8);
    --progress-background-color: hsl(205deg, 18%, 86%);
    --progress-color: var(--primary);
    --loading-spinner-opacity: 0.5;
    --tooltip-background-color: var(--contrast);
    --tooltip-color: var(--contrast-inverse);
    --icon-checkbox: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23FFF' stroke-width='4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'%3E%3C/polyline%3E%3C/svg%3E");
    --icon-chevron: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='rgba(65, 84, 98, 0.999)' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
    --icon-chevron-button: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='rgba(255, 255, 255, 0.999)' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
    --icon-chevron-button-inverse: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='rgba(255, 255, 255, 0.999)' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
    --icon-close: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='rgba(115, 130, 140, 0.999)' stroke-width='4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='18' y1='6' x2='6' y2='18'%3E%3C/line%3E%3Cline x1='6' y1='6' x2='18' y2='18'%3E%3C/line%3E%3C/svg%3E");
    --icon-date: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='rgba(65, 84, 98, 0.999)' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'%3E%3C/rect%3E%3Cline x1='16' y1='2' x2='16' y2='6'%3E%3C/line%3E%3Cline x1='8' y1='2' x2='8' y2='6'%3E%3C/line%3E%3Cline x1='3' y1='10' x2='21' y2='10'%3E%3C/line%3E%3C/svg%3E");
    --icon-invalid: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='rgba(198, 40, 40, 0.999)' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'%3E%3C/circle%3E%3Cline x1='12' y1='8' x2='12' y2='12'%3E%3C/line%3E%3Cline x1='12' y1='16' x2='12.01' y2='16'%3E%3C/line%3E%3C/svg%3E");
    --icon-minus: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23FFF' stroke-width='4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='5' y1='12' x2='19' y2='12'%3E%3C/line%3E%3C/svg%3E");
    --icon-search: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='rgba(65, 84, 98, 0.999)' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'%3E%3C/circle%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'%3E%3C/line%3E%3C/svg%3E");
    --icon-time: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='rgba(65, 84, 98, 0.999)' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'%3E%3C/circle%3E%3Cpolyline points='12 6 12 12 16 14'%3E%3C/polyline%3E%3C/svg%3E");
    --icon-valid: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='rgba(56, 142, 60, 0.999)' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'%3E%3C/polyline%3E%3C/svg%3E")
}

@media only screen and (prefers-color-scheme: dark) {
    :root:not([data-theme=light]) {
        color-scheme: dark;
        --background-color: rgba(0, 0, 0, 0.3);
        --color: rgba(255, 255, 255, 0.9);
        --h1-color: rgba(255, 255, 255, 0.98);
        --h2-color: rgba(255, 255, 255, 0.95);
        --h3-color: rgba(255, 255, 255, 0.92);
        --h4-color: rgba(255, 255, 255, 0.88);
        --h5-color: rgba(255, 255, 255, 0.85);
        --h6-color: rgba(255, 255, 255, 0.82);
        --muted-color: rgba(255, 255, 255, 0.6);
        --muted-border-color: rgba(255, 255, 255, 0.1);
        --primary: rgba(120, 200, 255, 0.9);
        --primary-hover: rgba(140, 210, 255, 0.95);
        --primary-focus: rgba(120, 200, 255, 0.2);
        --primary-inverse: rgba(0, 0, 0, 0.9);
        --secondary: rgba(255, 255, 255, 0.4);
        --secondary-hover: rgba(255, 255, 255, 0.6);
        --secondary-focus: rgba(255, 255, 255, 0.2);
        --secondary-inverse: rgba(0, 0, 0, 0.9);
        --contrast: rgba(255, 255, 255, 0.95);
        --contrast-hover: rgba(255, 255, 255, 1);
        --contrast-focus: rgba(255, 255, 255, 0.2);
        --contrast-inverse: rgba(0, 0, 0, 0.9);
        --mark-background-color: #d1c284;
        --mark-color: #11191f;
        --ins-color: #388e3c;
        --del-color: #c62828;
        --blockquote-border-color: var(--muted-border-color);
        --blockquote-footer-color: var(--muted-color);
        --button-box-shadow: 0 0 0 rgba(0, 0, 0, 0);
        --button-hover-box-shadow: 0 0 0 rgba(0, 0, 0, 0);
        --form-element-background-color: #11191f;
        --form-element-border-color: #374956;
        --form-element-color: var(--color);
        --form-element-placeholder-color: var(--muted-color);
        --form-element-active-background-color: var(--form-element-background-color);
        --form-element-active-border-color: var(--primary);
        --form-element-focus-color: var(--primary-focus);
        --form-element-disabled-background-color: hsl(205deg, 25%, 23%);
        --form-element-disabled-border-color: hsl(205deg, 20%, 32%);
        --form-element-disabled-opacity: 0.5;
        --form-element-invalid-border-color: #b71c1c;
        --form-element-invalid-active-border-color: #c62828;
        --form-element-invalid-focus-color: rgba(198, 40, 40, 0.25);
        --form-element-valid-border-color: #2e7d32;
        --form-element-valid-active-border-color: #388e3c;
        --form-element-valid-focus-color: rgba(56, 142, 60, 0.25);
        --switch-background-color: #374956;
        --switch-color: var(--primary-inverse);
        --switch-checked-background-color: var(--primary);
        --range-border-color: #24333e;
        --range-active-border-color: hsl(205deg, 25%, 23%);
        --range-thumb-border-color: var(--background-color);
        --range-thumb-color: var(--secondary);
        --range-thumb-hover-color: var(--secondary-hover);
        --range-thumb-active-color: var(--primary);
        --table-border-color: var(--muted-border-color);
        --table-row-stripped-background-color: rgba(115, 130, 140, 0.05);
        --code-background-color: #18232c;
        --code-color: var(--muted-color);
        --code-kbd-background-color: var(--contrast);
        --code-kbd-color: var(--contrast-inverse);
        --code-tag-color: hsl(330deg, 30%, 50%);
        --code-property-color: hsl(185deg, 30%, 50%);
        --code-value-color: hsl(40deg, 10%, 50%);
        --code-comment-color: #4d606d;
        --accordion-border-color: var(--muted-border-color);
        --accordion-active-summary-color: var(--primary);
        --accordion-close-summary-color: var(--color);
        --accordion-open-summary-color: var(--muted-color);
        --card-background-color: #141e26;
        --card-border-color: var(--card-background-color);
        --card-box-shadow: 0.0145rem 0.029rem 0.174rem rgba(0, 0, 0, 0.01698), 0.0335rem 0.067rem 0.402rem rgba(0, 0, 0, 0.024), 0.0625rem 0.125rem 0.75rem rgba(0, 0, 0, 0.03), 0.1125rem 0.225rem 1.35rem rgba(0, 0, 0, 0.036), 0.2085rem 0.417rem 2.502rem rgba(0, 0, 0, 0.04302), 0.5rem 1rem 6rem rgba(0, 0, 0, 0.06), 0 0 0 0.0625rem rgba(0, 0, 0, 0.015);
        --card-sectionning-background-color: #18232c;
        --dropdown-background-color: hsl(205deg, 30%, 15%);
        --dropdown-border-color: #24333e;
        --dropdown-box-shadow: var(--card-box-shadow);
        --dropdown-color: var(--color);
        --dropdown-hover-background-color: rgba(36, 51, 62, 0.75);
        --modal-overlay-background-color: rgba(36, 51, 62, 0.9);
        --progress-background-color: #24333e;
        --progress-color: var(--primary);
        --loading-spinner-opacity: 0.5;
        --tooltip-background-color: var(--contrast);
        --tooltip-color: var(--contrast-inverse);
        --icon-checkbox: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23FFF' stroke-width='4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'%3E%3C/polyline%3E%3C/svg%3E");
        --icon-chevron: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='rgba(162, 175, 185, 0.999)' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
        --icon-chevron-button: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='rgba(255, 255, 255, 0.999)' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
        --icon-chevron-button-inverse: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='rgba(0, 0, 0, 0.999)' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
        --icon-close: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='rgba(115, 130, 140, 0.999)' stroke-width='4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='18' y1='6' x2='6' y2='18'%3E%3C/line%3E%3Cline x1='6' y1='6' x2='18' y2='18'%3E%3C/line%3E%3C/svg%3E");
        --icon-date: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='rgba(162, 175, 185, 0.999)' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'%3E%3C/rect%3E%3Cline x1='16' y1='2' x2='16' y2='6'%3E%3C/line%3E%3Cline x1='8' y1='2' x2='8' y2='6'%3E%3C/line%3E%3Cline x1='3' y1='10' x2='21' y2='10'%3E%3C/line%3E%3C/svg%3E");
        --icon-invalid: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='rgba(183, 28, 28, 0.999)' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'%3E%3C/circle%3E%3Cline x1='12' y1='8' x2='12' y2='12'%3E%3C/line%3E%3Cline x1='12' y1='16' x2='12.01' y2='16'%3E%3C/line%3E%3C/svg%3E");
        --icon-minus: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23FFF' stroke-width='4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='5' y1='12' x2='19' y2='12'%3E%3C/line%3E%3C/svg%3E");
        --icon-search: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='rgba(162, 175, 185, 0.999)' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'%3E%3C/circle%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'%3E%3C/line%3E%3C/svg%3E");
        --icon-time: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='rgba(162, 175, 185, 0.999)' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'%3E%3C/circle%3E%3Cpolyline points='12 6 12 12 16 14'%3E%3C/polyline%3E%3C/svg%3E");
        --icon-valid: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='rgba(46, 125, 50, 0.999)' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'%3E%3C/polyline%3E%3C/svg%3E")
    }
}

[data-theme=dark] {
    color-scheme: dark;
    --background-color: rgba(0, 0, 0, 0.3);
    --color: rgba(255, 255, 255, 0.9);
    --h1-color: rgba(255, 255, 255, 0.98);
    --h2-color: rgba(255, 255, 255, 0.95);
    --h3-color: rgba(255, 255, 255, 0.92);
    --h4-color: rgba(255, 255, 255, 0.88);
    --h5-color: rgba(255, 255, 255, 0.85);
    --h6-color: rgba(255, 255, 255, 0.82);
    --muted-color: rgba(255, 255, 255, 0.6);
    --muted-border-color: rgba(255, 255, 255, 0.1);
    --primary: rgba(120, 200, 255, 0.9);
    --primary-hover: rgba(140, 210, 255, 0.95);
    --primary-focus: rgba(120, 200, 255, 0.2);
    --primary-inverse: rgba(0, 0, 0, 0.9);
    --secondary: rgba(255, 255, 255, 0.4);
    --secondary-hover: rgba(255, 255, 255, 0.6);
    --secondary-focus: rgba(255, 255, 255, 0.2);
    --secondary-inverse: rgba(0, 0, 0, 0.9);
    --contrast: rgba(255, 255, 255, 0.95);
    --contrast-hover: rgba(255, 255, 255, 1);
    --contrast-focus: rgba(255, 255, 255, 0.2);
    --contrast-inverse: rgba(0, 0, 0, 0.9);
    --mark-background-color: #d1c284;
    --mark-color: #11191f;
    --ins-color: #388e3c;
    --del-color: #c62828;
    --blockquote-border-color: var(--muted-border-color);
    --blockquote-footer-color: var(--muted-color);
    --button-box-shadow: 0 0 0 rgba(0, 0, 0, 0);
    --button-hover-box-shadow: 0 0 0 rgba(0, 0, 0, 0);
    --form-element-background-color: #11191f;
    --form-element-border-color: #374956;
    --form-element-color: var(--color);
    --form-element-placeholder-color: var(--muted-color);
    --form-element-active-background-color: var(--form-element-background-color);
    --form-element-active-border-color: var(--primary);
    --form-element-focus-color: var(--primary-focus);
    --form-element-disabled-background-color: hsl(205deg, 25%, 23%);
    --form-element-disabled-border-color: hsl(205deg, 20%, 32%);
    --form-element-disabled-opacity: 0.5;
    --form-element-invalid-border-color: #b71c1c;
    --form-element-invalid-active-border-color: #c62828;
    --form-element-invalid-focus-color: rgba(198, 40, 40, 0.25);
    --form-element-valid-border-color: #2e7d32;
    --form-element-valid-active-border-color: #388e3c;
    --form-element-valid-focus-color: rgba(56, 142, 60, 0.25);
    --switch-background-color: #374956;
    --switch-color: var(--primary-inverse);
    --switch-checked-background-color: var(--primary);
    --range-border-color: #24333e;
    --range-active-border-color: hsl(205deg, 25%, 23%);
    --range-thumb-border-color: var(--background-color);
    --range-thumb-color: var(--secondary);
    --range-thumb-hover-color: var(--secondary-hover);
    --range-thumb-active-color: var(--primary);
    --table-border-color: var(--muted-border-color);
    --table-row-stripped-background-color: rgba(115, 130, 140, 0.05);
    --code-background-color: #18232c;
    --code-color: var(--muted-color);
    --code-kbd-background-color: var(--contrast);
    --code-kbd-color: var(--contrast-inverse);
    --code-tag-color: hsl(330deg, 30%, 50%);
    --code-property-color: hsl(185deg, 30%, 50%);
    --code-value-color: hsl(40deg, 10%, 50%);
    --code-comment-color: #4d606d;
    --accordion-border-color: var(--muted-border-color);
    --accordion-active-summary-color: var(--primary);
    --accordion-close-summary-color: var(--color);
    --accordion-open-summary-color: var(--muted-color);
    --card-background-color: #141e26;
    --card-border-color: var(--card-background-color);
    --card-box-shadow: 0.0145rem 0.029rem 0.174rem rgba(0, 0, 0, 0.01698), 0.0335rem 0.067rem 0.402rem rgba(0, 0, 0, 0.024), 0.0625rem 0.125rem 0.75rem rgba(0, 0, 0, 0.03), 0.1125rem 0.225rem 1.35rem rgba(0, 0, 0, 0.036), 0.2085rem 0.417rem 2.502rem rgba(0, 0, 0, 0.04302), 0.5rem 1rem 6rem rgba(0, 0, 0, 0.06), 0 0 0 0.0625rem rgba(0, 0, 0, 0.015);
    --card-sectionning-background-color: #18232c;
    --dropdown-background-color: hsl(205deg, 30%, 15%);
    --dropdown-border-color: #24333e;
    --dropdown-box-shadow: var(--card-box-shadow);
    --dropdown-color: var(--color);
    --dropdown-hover-background-color: rgba(36, 51, 62, 0.75);
    --modal-overlay-background-color: rgba(36, 51, 62, 0.9);
    --progress-background-color: #24333e;
    --progress-color: var(--primary);
    --loading-spinner-opacity: 0.5;
    --tooltip-background-color: var(--contrast);
    --tooltip-color: var(--contrast-inverse);
    --icon-checkbox: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23FFF' stroke-width='4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'%3E%3C/polyline%3E%3C/svg%3E");
    --icon-chevron: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='rgba(162, 175, 185, 0.999)' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
    --icon-chevron-button: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='rgba(255, 255, 255, 0.999)' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
    --icon-chevron-button-inverse: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='rgba(0, 0, 0, 0.999)' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
    --icon-close: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='rgba(115, 130, 140, 0.999)' stroke-width='4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='18' y1='6' x2='6' y2='18'%3E%3C/line%3E%3Cline x1='6' y1='6' x2='18' y2='18'%3E%3C/line%3E%3C/svg%3E");
    --icon-date: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='rgba(162, 175, 185, 0.999)' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'%3E%3C/rect%3E%3Cline x1='16' y1='2' x2='16' y2='6'%3E%3C/line%3E%3Cline x1='8' y1='2' x2='8' y2='6'%3E%3C/line%3E%3Cline x1='3' y1='10' x2='21' y2='10'%3E%3C/line%3E%3C/svg%3E");
    --icon-invalid: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='rgba(183, 28, 28, 0.999)' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'%3E%3C/circle%3E%3Cline x1='12' y1='8' x2='12' y2='12'%3E%3C/line%3E%3Cline x1='12' y1='16' x2='12.01' y2='16'%3E%3C/line%3E%3C/svg%3E");
    --icon-minus: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23FFF' stroke-width='4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='5' y1='12' x2='19' y2='12'%3E%3C/line%3E%3C/svg%3E");
    --icon-search: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='rgba(162, 175, 185, 0.999)' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'%3E%3C/circle%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'%3E%3C/line%3E%3C/svg%3E");
    --icon-time: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='rgba(162, 175, 185, 0.999)' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'%3E%3C/circle%3E%3Cpolyline points='12 6 12 12 16 14'%3E%3C/polyline%3E%3C/svg%3E");
    --icon-valid: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='rgba(46, 125, 50, 0.999)' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'%3E%3C/polyline%3E%3C/svg%3E")
}

*, ::after, ::before {
    box-sizing: border-box;
    background-repeat: no-repeat
}

::after, ::before {
    text-decoration: inherit;
    vertical-align: inherit
}

:where(:root) {
    -webkit-tap-highlight-color: transparent;
    -webkit-text-size-adjust: 100%;
    -moz-text-size-adjust: 100%;
    text-size-adjust: 100%;
    text-rendering: optimizeLegibility;
    background-color: var(--background-color);
    color: var(--color);
    font-weight: var(--font-weight);
    font-size: var(--font-size);
    line-height: var(--line-height);
    font-family: var(--font-family);
    overflow-wrap: break-word;
    cursor: default;
    -moz-tab-size: 4;
    -o-tab-size: 4;
    tab-size: 4
}

.container, .container-fluid {
    width: 100%;
    margin-right: auto;
    margin-left: auto;
    padding-right: var(--spacing);
    padding-left: var(--spacing)
}

@media (min-width: 576px) {
    .container {
        max-width: 510px;
        padding-right: 0;
        padding-left: 0
    }
}

@media (min-width: 768px) {
    .container {
        max-width: 700px
    }
}

@media (min-width: 992px) {
    .container {
        max-width: 920px
    }
}

@media (min-width: 1200px) {
    .container {
        max-width: 1130px
    }
}

/** * Grid * Minimal grid system with auto-layout columns */ 

.grid {
	grid-column-gap: var(--pico-grid-column-gap);
	grid-row-gap: var(--pico-grid-row-gap);
	display: grid;
	grid-template-columns: 1fr;
}

@media (min-width: 768px) {
	.grid {
		grid-template-columns: repeat(auto-fit, minmax(0%, 1fr));
	}
}

.grid>* {
	min-width: 0;
}

b, strong {
    font-weight: bolder
}

sub, sup {
    position: relative;
    font-size: .75em;
    line-height: 0;
    vertical-align: baseline
}

sub {
    bottom: -.25em
}

sup {
    top: -.5em
}

address, blockquote, dl, figure, form, ol, p, pre, table, ul {
    margin-top: 0;
    margin-bottom: var(--typography-spacing-vertical);
    color: var(--color);
    font-style: normal;
    font-weight: var(--font-weight);
    font-size: var(--font-size)
}

[role=link], a {
    --color: var(--primary);
    --background-color: transparent;
    outline: 0;
    background-color: var(--background-color);
    color: var(--color);
    -webkit-text-decoration: var(--text-decoration);
    text-decoration: var(--text-decoration);
    transition: background-color var(--transition), color var(--transition), box-shadow var(--transition), -webkit-text-decoration var(--transition);
    transition: background-color var(--transition), color var(--transition), text-decoration var(--transition), box-shadow var(--transition);
    transition: background-color var(--transition), color var(--transition), text-decoration var(--transition), box-shadow var(--transition), -webkit-text-decoration var(--transition)
}

[role=link]:is([aria-current],:hover,:active,:focus), a:is([aria-current],:hover,:active,:focus) {
    --color: var(--primary-hover);
    --text-decoration: underline
}

[role=link]:focus, a:focus {
    --background-color: var(--primary-focus)
}

[role=link].secondary, a.secondary {
    --color: var(--secondary)
}

[role=link].secondary:is([aria-current],:hover,:active,:focus), a.secondary:is([aria-current],:hover,:active,:focus) {
    --color: var(--secondary-hover)
}

[role=link].secondary:focus, a.secondary:focus {
    --background-color: var(--secondary-focus)
}

[role=link].contrast, a.contrast {
    --color: var(--contrast)
}

[role=link].contrast:is([aria-current],:hover,:active,:focus), a.contrast:is([aria-current],:hover,:active,:focus) {
    --color: var(--contrast-hover)
}

[role=link].contrast:focus, a.contrast:focus {
    --background-color: var(--contrast-focus)
}

h1, h2, h3, h4, h5, h6 {
    margin-top: 0;
    margin-bottom: var(--typography-spacing-vertical);
    color: var(--color);
    font-weight: var(--font-weight);
    font-size: var(--font-size);
    font-family: var(--font-family)
}

h1 {
    --color: var(--h1-color)
}

h2 {
    --color: var(--h2-color)
}

h3 {
    --color: var(--h3-color)
}

h4 {
    --color: var(--h4-color)
}

h5 {
    --color: var(--h5-color)
}

h6 {
    --color: var(--h6-color)
}

:where(address,blockquote,dl,figure,form,ol,p,pre,table,ul) ~ :is(h1,h2,h3,h4,h5,h6) {
    margin-top: var(--typography-spacing-vertical)
}

.headings {
    margin-bottom: var(--typography-spacing-vertical)
}

.headings > *, hgroup > * {
    margin-bottom: 0
}

.headings > :last-child, hgroup > :last-child {
    --color: var(--muted-color);
    --font-weight: unset;
    font-size: 1rem;
    font-family: unset
}

p {
    margin-bottom: var(--typography-spacing-vertical)
}

small {
    font-size: var(--font-size)
}

:where(dl,ol,ul) {
    padding-right: 0;
    padding-left: var(--spacing);
    -webkit-padding-start: var(--spacing);
    padding-inline-start: var(--spacing);
    -webkit-padding-end: 0;
    padding-inline-end: 0
}

:where(dl,ol,ul) li {
    margin-bottom: calc(var(--typography-spacing-vertical) * .25)
}

:where(dl,ol,ul) :is(dl,ol,ul) {
    margin: 0;
    margin-top: calc(var(--typography-spacing-vertical) * .25)
}

ul li {
    list-style: square
}

mark {
    padding: .125rem .25rem;
    background-color: var(--mark-background-color);
    color: var(--mark-color);
    vertical-align: baseline
}

blockquote {
    display: block;
    margin: var(--typography-spacing-vertical) 0;
    padding: var(--spacing);
    border-right: none;
    border-left: .25rem solid var(--blockquote-border-color);
    -webkit-border-start: .25rem solid var(--blockquote-border-color);
    border-inline-start: .25rem solid var(--blockquote-border-color);
    -webkit-border-end: none;
    border-inline-end: none
}

blockquote footer {
    margin-top: calc(var(--typography-spacing-vertical) * .5);
    color: var(--blockquote-footer-color)
}

abbr[title] {
    border-bottom: 1px dotted;
    text-decoration: none;
    cursor: help
}

ins {
    color: var(--ins-color);
    text-decoration: none
}

del {
    color: var(--del-color)
}

::-moz-selection {
    background-color: var(--primary-focus)
}

::selection {
    background-color: var(--primary-focus)
}

button {
    margin: 0;
    overflow: visible;
    font-family: inherit;
    text-transform: none
}

[type=button], [type=reset], [type=submit], button {
    -webkit-appearance: button
}

button {
    display: block;
    width: 100%;
    margin-bottom: var(--spacing)
}

[role=button] {
    display: inline-block;
    text-decoration: none
}

[role=button], button, input[type=button], input[type=reset], input[type=submit] {
    --background-color: var(--primary);
    --border-color: var(--primary);
    --color: var(--primary-inverse);
    --box-shadow: 0 0 0 rgba(0, 0, 0, 0);
    padding: var(--form-element-spacing-vertical) var(--form-element-spacing-horizontal);
    border: var(--border-width) solid var(--border-color);
    border-radius: var(--border-radius);
    outline: 0;
    background-color: var(--background-color);
    box-shadow: var(--box-shadow);
    color: var(--color);
    font-weight: var(--font-weight);
    font-size: 1rem;
    line-height: var(--line-height);
    text-align: center;
    cursor: pointer;
    transition: background-color var(--transition), border-color var(--transition), color var(--transition), box-shadow var(--transition)
}

[role=button]:is([aria-current],:hover,:active,:focus), button:is([aria-current],:hover,:active,:focus), input[type=button]:is([aria-current],:hover,:active,:focus), input[type=reset]:is([aria-current],:hover,:active,:focus), input[type=submit]:is([aria-current],:hover,:active,:focus) {
    --background-color: var(--primary-hover);
    --border-color: var(--primary-hover);
    --box-shadow: 0 0 0 rgba(0, 0, 0, 0);
    --color: var(--primary-inverse)
}

[role=button]:focus, button:focus, input[type=button]:focus, input[type=reset]:focus, input[type=submit]:focus {
    --box-shadow: 0 0 0 rgba(0, 0, 0, 0), 0 0 0 var(--outline-width) var(--primary-focus)
}

:is(button,input[type=submit],input[type=button],[role=button]).secondary, input[type=reset] {
    --background-color: var(--secondary);
    --border-color: var(--secondary);
    --color: var(--secondary-inverse);
    cursor: pointer
}

:is(button,input[type=submit],input[type=button],[role=button]).secondary:is([aria-current],:hover,:active,:focus), input[type=reset]:is([aria-current],:hover,:active,:focus) {
    --background-color: var(--secondary-hover);
    --border-color: var(--secondary-hover);
    --color: var(--secondary-inverse)
}

:is(button,input[type=submit],input[type=button],[role=button]).secondary:focus, input[type=reset]:focus {
    --box-shadow: 0 0 0 rgba(0, 0, 0, 0), 0 0 0 var(--outline-width) var(--secondary-focus)
}

:is(button,input[type=submit],input[type=button],[role=button]).contrast {
    --background-color: var(--contrast);
    --border-color: var(--contrast);
    --color: var(--contrast-inverse)
}

:is(button,input[type=submit],input[type=button],[role=button]).contrast:is([aria-current],:hover,:active,:focus) {
    --background-color: var(--contrast-hover);
    --border-color: var(--contrast-hover);
    --color: var(--contrast-inverse)
}

:is(button,input[type=submit],input[type=button],[role=button]).contrast:focus {
    --box-shadow: 0 0 0 rgba(0, 0, 0, 0), 0 0 0 var(--outline-width) var(--contrast-focus)
}

:is(button,input[type=submit],input[type=button],[role=button]).outline, input[type=reset].outline {
    --background-color: transparent;
    --color: var(--primary)
}

:is(button,input[type=submit],input[type=button],[role=button]).outline:is([aria-current],:hover,:active,:focus), input[type=reset].outline:is([aria-current],:hover,:active,:focus) {
    --background-color: transparent;
    --color: var(--primary-hover)
}

:is(button,input[type=submit],input[type=button],[role=button]).outline.secondary, input[type=reset].outline {
    --color: var(--secondary)
}

:is(button,input[type=submit],input[type=button],[role=button]).outline.secondary:is([aria-current],:hover,:active,:focus), input[type=reset].outline:is([aria-current],:hover,:active,:focus) {
    --color: var(--secondary-hover)
}

:is(button,input[type=submit],input[type=button],[role=button]).outline.contrast {
    --color: var(--contrast)
}

:is(button,input[type=submit],input[type=button],[role=button]).outline.contrast:is([aria-current],:hover,:active,:focus) {
    --color: var(--contrast-hover)
}

:where(button,[type=submit],[type=button],[type=reset],[role=button])[disabled], :where(fieldset[disabled]) :is(button,[type=submit],[type=button],[type=reset],[role=button]), a[role=button]:not([href]) {
    opacity: .5;
    pointer-events: none
}

input, optgroup, select, textarea {
    margin: 0;
    font-size: 1rem;
    line-height: var(--line-height);
    font-family: inherit;
    letter-spacing: inherit
}

input {
    overflow: visible
}

select {
    text-transform: none
}

legend {
    max-width: 100%;
    padding: 0;
    color: inherit;
    white-space: normal
}

textarea {
    overflow: auto
}

[type=checkbox], [type=radio] {
    padding: 0
}

::-webkit-inner-spin-button, ::-webkit-outer-spin-button {
    height: auto
}

[type=search] {
    -webkit-appearance: textfield;
    outline-offset: -2px
}

[type=search]::-webkit-search-decoration {
    -webkit-appearance: none
}

::-webkit-file-upload-button {
    -webkit-appearance: button;
    font: inherit
}

::-moz-focus-inner {
    padding: 0;
    border-style: none
}

:-moz-focusring {
    outline: 0
}

:-moz-ui-invalid {
    box-shadow: none
}

::-ms-expand {
    display: none
}

[type=file], [type=range] {
    padding: 0;
    border-width: 0
}

input:not([type=checkbox]):not([type=radio]):not([type=range]) {
    height: calc(1rem * var(--line-height) + var(--form-element-spacing-vertical) * 2 + var(--border-width) * 2)
}

fieldset {
    margin: 0;
    margin-bottom: var(--spacing);
    padding: 0;
    border: 0
}

fieldset legend, label {
    display: block;
    margin-bottom: calc(var(--spacing) * .25);
    font-weight: var(--form-label-font-weight, var(--font-weight))
}

input:not([type=checkbox]):not([type=radio]), select, textarea {
    width: 100%
}

input:not([type=checkbox]):not([type=radio]):not([type=range]):not([type=file]), select, textarea {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    padding: var(--form-element-spacing-vertical) var(--form-element-spacing-horizontal)
}

input, select, textarea {
    --background-color: var(--form-element-background-color);
    --border-color: var(--form-element-border-color);
    --color: var(--form-element-color);
    --box-shadow: none;
    border: var(--border-width) solid var(--border-color);
    border-radius: var(--border-radius);
    outline: 0;
    background-color: var(--background-color);
    box-shadow: var(--box-shadow);
    color: var(--color);
    font-weight: var(--font-weight);
    transition: background-color var(--transition), border-color var(--transition), color var(--transition), box-shadow var(--transition)
}

:where(select,textarea):is(:active,:focus), input:not([type=submit]):not([type=button]):not([type=reset]):not([type=checkbox]):not([type=radio]):not([readonly]):is(:active,:focus) {
    --background-color: var(--form-element-active-background-color)
}

:where(select,textarea):is(:active,:focus), input:not([type=submit]):not([type=button]):not([type=reset]):not([role=switch]):not([readonly]):is(:active,:focus) {
    --border-color: var(--form-element-active-border-color)
}

input:not([type=submit]):not([type=button]):not([type=reset]):not([type=range]):not([type=file]):not([readonly]):focus, select:focus, textarea:focus {
    --box-shadow: 0 0 0 var(--outline-width) var(--form-element-focus-color)
}

:where(fieldset[disabled]) :is(input:not([type=submit]):not([type=button]):not([type=reset]),select,textarea), input:not([type=submit]):not([type=button]):not([type=reset])[disabled], select[disabled], textarea[disabled] {
    --background-color: var(--form-element-disabled-background-color);
    --border-color: var(--form-element-disabled-border-color);
    opacity: var(--form-element-disabled-opacity);
    pointer-events: none
}

:where(input,select,textarea):not([type=checkbox]):not([type=radio])[aria-invalid] {
    padding-right: calc(var(--form-element-spacing-horizontal) + 1.5rem) !important;
    padding-left: var(--form-element-spacing-horizontal);
    -webkit-padding-start: var(--form-element-spacing-horizontal) !important;
    padding-inline-start: var(--form-element-spacing-horizontal) !important;
    -webkit-padding-end: calc(var(--form-element-spacing-horizontal) + 1.5rem) !important;
    padding-inline-end: calc(var(--form-element-spacing-horizontal) + 1.5rem) !important;
    background-position: center right .75rem;
    background-size: 1rem auto;
    background-repeat: no-repeat
}

:where(input,select,textarea):not([type=checkbox]):not([type=radio])[aria-invalid=false] {
    background-image: var(--icon-valid)
}

:where(input,select,textarea):not([type=checkbox]):not([type=radio])[aria-invalid=true] {
    background-image: var(--icon-invalid)
}

:where(input,select,textarea)[aria-invalid=false] {
    --border-color: var(--form-element-valid-border-color)
}

:where(input,select,textarea)[aria-invalid=false]:is(:active,:focus) {
    --border-color: var(--form-element-valid-active-border-color) !important;
    --box-shadow: 0 0 0 var(--outline-width) var(--form-element-valid-focus-color) !important
}

:where(input,select,textarea)[aria-invalid=true] {
    --border-color: var(--form-element-invalid-border-color)
}

:where(input,select,textarea)[aria-invalid=true]:is(:active,:focus) {
    --border-color: var(--form-element-invalid-active-border-color) !important;
    --box-shadow: 0 0 0 var(--outline-width) var(--form-element-invalid-focus-color) !important
}

[dir=rtl] :where(input,select,textarea):not([type=checkbox]):not([type=radio])[aria-invalid=false], [dir=rtl] :where(input,select,textarea):not([type=checkbox]):not([type=radio])[aria-invalid=true], [dir=rtl] :where(input,select,textarea):not([type=checkbox]):not([type=radio])[aria-invalid] {
    background-position: center left .75rem
}

input::-webkit-input-placeholder, input::placeholder, select:invalid, textarea::-webkit-input-placeholder, textarea::placeholder {
    color: var(--form-element-placeholder-color);
    opacity: 1
}

input:not([type=checkbox]):not([type=radio]), select, textarea {
    margin-bottom: var(--spacing)
}

select::-ms-expand {
    border: 0;
    background-color: transparent
}

select:not([multiple]):not([size]) {
    padding-right: calc(var(--form-element-spacing-horizontal) + 1.5rem);
    padding-left: var(--form-element-spacing-horizontal);
    -webkit-padding-start: var(--form-element-spacing-horizontal);
    padding-inline-start: var(--form-element-spacing-horizontal);
    -webkit-padding-end: calc(var(--form-element-spacing-horizontal) + 1.5rem);
    padding-inline-end: calc(var(--form-element-spacing-horizontal) + 1.5rem);
    background-image: var(--icon-chevron);
    background-position: center right .75rem;
    background-size: 1rem auto;
    background-repeat: no-repeat
}

[dir=rtl] select:not([multiple]):not([size]) {
    background-position: center left .75rem
}

:where(input,select,textarea) + small {
    display: block;
    width: 100%;
    margin-top: calc(var(--spacing) * -.75);
    margin-bottom: var(--spacing);
    color: var(--muted-color)
}

label > :where(input,select,textarea) {
    margin-top: calc(var(--spacing) * .25)
}

[type=checkbox], [type=radio] {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    width: 1.25em;
    height: 1.25em;
    margin-top: -.125em;
    margin-right: .375em;
    margin-left: 0;
    -webkit-margin-start: 0;
    margin-inline-start: 0;
    -webkit-margin-end: .375em;
    margin-inline-end: .375em;
    border-width: var(--border-width);
    font-size: inherit;
    vertical-align: middle;
    cursor: pointer
}

[type=checkbox]::-ms-check, [type=radio]::-ms-check {
    display: none
}

[type=checkbox]:checked, [type=checkbox]:checked:active, [type=checkbox]:checked:focus, [type=radio]:checked, [type=radio]:checked:active, [type=radio]:checked:focus {
    --background-color: var(--primary);
    --border-color: var(--primary);
    background-image: var(--icon-checkbox);
    background-position: center;
    background-size: .75em auto;
    background-repeat: no-repeat
}

[type=checkbox] ~ label, [type=radio] ~ label {
    display: inline-block;
    margin-right: .375em;
    margin-bottom: 0;
    cursor: pointer
}

[type=checkbox]:indeterminate {
    --background-color: var(--primary);
    --border-color: var(--primary);
    background-image: var(--icon-minus);
    background-position: center;
    background-size: .75em auto;
    background-repeat: no-repeat
}

[type=radio] {
    border-radius: 50%
}

[type=radio]:checked, [type=radio]:checked:active, [type=radio]:checked:focus {
    --background-color: var(--primary-inverse);
    border-width: .35em;
    background-image: none
}

[type=checkbox][role=switch] {
    --background-color: var(--switch-background-color);
    --border-color: var(--switch-background-color);
    --color: var(--switch-color);
    width: 2.25em;
    height: 1.25em;
    border: var(--border-width) solid var(--border-color);
    border-radius: 1.25em;
    background-color: var(--background-color);
    line-height: 1.25em
}

[type=checkbox][role=switch]:focus {
    --background-color: var(--switch-background-color);
    --border-color: var(--switch-background-color)
}

[type=checkbox][role=switch]:checked {
    --background-color: var(--switch-checked-background-color);
    --border-color: var(--switch-checked-background-color)
}

[type=checkbox][role=switch]:before {
    display: block;
    width: calc(1.25em - (var(--border-width) * 2));
    height: 100%;
    border-radius: 50%;
    background-color: var(--color);
    content: "";
    transition: margin .1s ease-in-out
}

[type=checkbox][role=switch]:checked {
    background-image: none
}

[type=checkbox][role=switch]:checked::before {
    margin-left: calc(1.125em - var(--border-width));
    -webkit-margin-start: calc(1.125em - var(--border-width));
    margin-inline-start: calc(1.125em - var(--border-width))
}

[type=checkbox]:checked[aria-invalid=false], [type=checkbox][aria-invalid=false], [type=checkbox][role=switch]:checked[aria-invalid=false], [type=checkbox][role=switch][aria-invalid=false], [type=radio]:checked[aria-invalid=false], [type=radio][aria-invalid=false] {
    --border-color: var(--form-element-valid-border-color)
}

[type=checkbox]:checked[aria-invalid=true], [type=checkbox][aria-invalid=true], [type=checkbox][role=switch]:checked[aria-invalid=true], [type=checkbox][role=switch][aria-invalid=true], [type=radio]:checked[aria-invalid=true], [type=radio][aria-invalid=true] {
    --border-color: var(--form-element-invalid-border-color)
}

[type=color]::-webkit-color-swatch-wrapper {
    padding: 0
}

[type=color]::-moz-focus-inner {
    padding: 0
}

[type=color]::-webkit-color-swatch {
    border: 0;
    border-radius: calc(var(--border-radius) * .5)
}

[type=color]::-moz-color-swatch {
    border: 0;
    border-radius: calc(var(--border-radius) * .5)
}

input:not([type=checkbox]):not([type=radio]):not([type=range]):not([type=file])[type=date], input:not([type=checkbox]):not([type=radio]):not([type=range]):not([type=file])[type=datetime-local], input:not([type=checkbox]):not([type=radio]):not([type=range]):not([type=file])[type=month], input:not([type=checkbox]):not([type=radio]):not([type=range]):not([type=file])[type=time], input:not([type=checkbox]):not([type=radio]):not([type=range]):not([type=file])[type=week] {
    --icon-position: 0.75rem;
    --icon-width: 1rem;
    padding-right: calc(var(--icon-width) + var(--icon-position));
    background-image: var(--icon-date);
    background-position: center right var(--icon-position);
    background-size: var(--icon-width) auto;
    background-repeat: no-repeat
}

input:not([type=checkbox]):not([type=radio]):not([type=range]):not([type=file])[type=time] {
    background-image: var(--icon-time)
}

[type=date]::-webkit-calendar-picker-indicator, [type=datetime-local]::-webkit-calendar-picker-indicator, [type=month]::-webkit-calendar-picker-indicator, [type=time]::-webkit-calendar-picker-indicator, [type=week]::-webkit-calendar-picker-indicator {
    width: var(--icon-width);
    margin-right: calc(var(--icon-width) * -1);
    margin-left: var(--icon-position);
    opacity: 0
}

[dir=rtl] :is([type=date],[type=datetime-local],[type=month],[type=time],[type=week]) {
    text-align: right
}

[type=file] {
    --color: var(--muted-color);
    padding: calc(var(--form-element-spacing-vertical) * .5) 0;
    border: 0;
    border-radius: 0;
    background: 0 0
}

[type=file]::-webkit-file-upload-button {
    --background-color: var(--secondary);
    --border-color: var(--secondary);
    --color: var(--secondary-inverse);
    margin-right: calc(var(--spacing) / 2);
    margin-left: 0;
    -webkit-margin-start: 0;
    margin-inline-start: 0;
    -webkit-margin-end: calc(var(--spacing) / 2);
    margin-inline-end: calc(var(--spacing) / 2);
    padding: calc(var(--form-element-spacing-vertical) * .5) calc(var(--form-element-spacing-horizontal) * .5);
    border: var(--border-width) solid var(--border-color);
    border-radius: var(--border-radius);
    outline: 0;
    background-color: var(--background-color);
    box-shadow: var(--box-shadow);
    color: var(--color);
    font-weight: var(--font-weight);
    font-size: 1rem;
    line-height: var(--line-height);
    text-align: center;
    cursor: pointer;
    -webkit-transition: background-color var(--transition), border-color var(--transition), color var(--transition), box-shadow var(--transition);
    transition: background-color var(--transition), border-color var(--transition), color var(--transition), box-shadow var(--transition)
}

[type=file]::file-selector-button {
    --background-color: var(--secondary);
    --border-color: var(--secondary);
    --color: var(--secondary-inverse);
    margin-right: calc(var(--spacing) / 2);
    margin-left: 0;
    -webkit-margin-start: 0;
    margin-inline-start: 0;
    -webkit-margin-end: calc(var(--spacing) / 2);
    margin-inline-end: calc(var(--spacing) / 2);
    padding: calc(var(--form-element-spacing-vertical) * .5) calc(var(--form-element-spacing-horizontal) * .5);
    border: var(--border-width) solid var(--border-color);
    border-radius: var(--border-radius);
    outline: 0;
    background-color: var(--background-color);
    box-shadow: var(--box-shadow);
    color: var(--color);
    font-weight: var(--font-weight);
    font-size: 1rem;
    line-height: var(--line-height);
    text-align: center;
    cursor: pointer;
    transition: background-color var(--transition), border-color var(--transition), color var(--transition), box-shadow var(--transition)
}

[type=file]::-webkit-file-upload-button:is(:hover,:active,:focus) {
    --background-color: var(--secondary-hover);
    --border-color: var(--secondary-hover)
}

[type=file]::file-selector-button:is(:hover,:active,:focus) {
    --background-color: var(--secondary-hover);
    --border-color: var(--secondary-hover)
}

[type=file]::-webkit-file-upload-button {
    --background-color: var(--secondary);
    --border-color: var(--secondary);
    --color: var(--secondary-inverse);
    margin-right: calc(var(--spacing) / 2);
    margin-left: 0;
    -webkit-margin-start: 0;
    margin-inline-start: 0;
    -webkit-margin-end: calc(var(--spacing) / 2);
    margin-inline-end: calc(var(--spacing) / 2);
    padding: calc(var(--form-element-spacing-vertical) * .5) calc(var(--form-element-spacing-horizontal) * .5);
    border: var(--border-width) solid var(--border-color);
    border-radius: var(--border-radius);
    outline: 0;
    background-color: var(--background-color);
    box-shadow: var(--box-shadow);
    color: var(--color);
    font-weight: var(--font-weight);
    font-size: 1rem;
    line-height: var(--line-height);
    text-align: center;
    cursor: pointer;
    -webkit-transition: background-color var(--transition), border-color var(--transition), color var(--transition), box-shadow var(--transition);
    transition: background-color var(--transition), border-color var(--transition), color var(--transition), box-shadow var(--transition)
}

[type=file]::-webkit-file-upload-button:is(:hover,:active,:focus) {
    --background-color: var(--secondary-hover);
    --border-color: var(--secondary-hover)
}

[type=file]::-ms-browse {
    --background-color: var(--secondary);
    --border-color: var(--secondary);
    --color: var(--secondary-inverse);
    margin-right: calc(var(--spacing) / 2);
    margin-left: 0;
    margin-inline-start: 0;
    margin-inline-end: calc(var(--spacing) / 2);
    padding: calc(var(--form-element-spacing-vertical) * .5) calc(var(--form-element-spacing-horizontal) * .5);
    border: var(--border-width) solid var(--border-color);
    border-radius: var(--border-radius);
    outline: 0;
    background-color: var(--background-color);
    box-shadow: var(--box-shadow);
    color: var(--color);
    font-weight: var(--font-weight);
    font-size: 1rem;
    line-height: var(--line-height);
    text-align: center;
    cursor: pointer;
    -ms-transition: background-color var(--transition), border-color var(--transition), color var(--transition), box-shadow var(--transition);
    transition: background-color var(--transition), border-color var(--transition), color var(--transition), box-shadow var(--transition)
}

[type=file]::-ms-browse:is(:hover,:active,:focus) {
    --background-color: var(--secondary-hover);
    --border-color: var(--secondary-hover)
}

[type=range] {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    width: 100%;
    height: 1.25rem;
    background: 0 0
}

[type=range]::-webkit-slider-runnable-track {
    width: 100%;
    height: .25rem;
    border-radius: var(--border-radius);
    background-color: var(--range-border-color);
    -webkit-transition: background-color var(--transition), box-shadow var(--transition);
    transition: background-color var(--transition), box-shadow var(--transition)
}

[type=range]::-moz-range-track {
    width: 100%;
    height: .25rem;
    border-radius: var(--border-radius);
    background-color: var(--range-border-color);
    -moz-transition: background-color var(--transition), box-shadow var(--transition);
    transition: background-color var(--transition), box-shadow var(--transition)
}

[type=range]::-ms-track {
    width: 100%;
    height: .25rem;
    border-radius: var(--border-radius);
    background-color: var(--range-border-color);
    -ms-transition: background-color var(--transition), box-shadow var(--transition);
    transition: background-color var(--transition), box-shadow var(--transition)
}

[type=range]::-webkit-slider-thumb {
    -webkit-appearance: none;
    width: 1.25rem;
    height: 1.25rem;
    margin-top: -.5rem;
    border: 2px solid var(--range-thumb-border-color);
    border-radius: 50%;
    background-color: var(--range-thumb-color);
    cursor: pointer;
    -webkit-transition: background-color var(--transition), transform var(--transition);
    transition: background-color var(--transition), transform var(--transition)
}

[type=range]::-moz-range-thumb {
    -webkit-appearance: none;
    width: 1.25rem;
    height: 1.25rem;
    margin-top: -.5rem;
    border: 2px solid var(--range-thumb-border-color);
    border-radius: 50%;
    background-color: var(--range-thumb-color);
    cursor: pointer;
    -moz-transition: background-color var(--transition), transform var(--transition);
    transition: background-color var(--transition), transform var(--transition)
}

[type=range]::-ms-thumb {
    -webkit-appearance: none;
    width: 1.25rem;
    height: 1.25rem;
    margin-top: -.5rem;
    border: 2px solid var(--range-thumb-border-color);
    border-radius: 50%;
    background-color: var(--range-thumb-color);
    cursor: pointer;
    -ms-transition: background-color var(--transition), transform var(--transition);
    transition: background-color var(--transition), transform var(--transition)
}

[type=range]:focus, [type=range]:hover {
    --range-border-color: var(--range-active-border-color);
    --range-thumb-color: var(--range-thumb-hover-color)
}

[type=range]:active {
    --range-thumb-color: var(--range-thumb-active-color)
}

[type=range]:active::-webkit-slider-thumb {
    transform: scale(1.25)
}

[type=range]:active::-moz-range-thumb {
    transform: scale(1.25)
}

[type=range]:active::-ms-thumb {
    transform: scale(1.25)
}

input:not([type=checkbox]):not([type=radio]):not([type=range]):not([type=file])[type=search] {
    -webkit-padding-start: calc(var(--form-element-spacing-horizontal) + 1.75rem);
    padding-inline-start: calc(var(--form-element-spacing-horizontal) + 1.75rem);
    border-radius: 5rem;
    background-image: var(--icon-search);
    background-position: center left 1.125rem;
    background-size: 1rem auto;
    background-repeat: no-repeat
}

input:not([type=checkbox]):not([type=radio]):not([type=range]):not([type=file])[type=search][aria-invalid] {
    -webkit-padding-start: calc(var(--form-element-spacing-horizontal) + 1.75rem) !important;
    padding-inline-start: calc(var(--form-element-spacing-horizontal) + 1.75rem) !important;
    background-position: center left 1.125rem, center right .75rem
}

input:not([type=checkbox]):not([type=radio]):not([type=range]):not([type=file])[type=search][aria-invalid=false] {
    background-image: var(--icon-search), var(--icon-valid)
}

input:not([type=checkbox]):not([type=radio]):not([type=range]):not([type=file])[type=search][aria-invalid=true] {
    background-image: var(--icon-search), var(--icon-invalid)
}

[type=search]::-webkit-search-cancel-button {
    -webkit-appearance: none;
    display: none
}

[dir=rtl] :where(input):not([type=checkbox]):not([type=radio]):not([type=range]):not([type=file])[type=search] {
    background-position: center right 1.125rem
}

[dir=rtl] :where(input):not([type=checkbox]):not([type=radio]):not([type=range]):not([type=file])[type=search][aria-invalid] {
    background-position: center right 1.125rem, center left .75rem
}

code, kbd, pre, samp {
    font-size: .875em;
    font-family: var(--font-family)
}

pre {
    -ms-overflow-style: scrollbar;
    overflow: auto
}

code, kbd, pre {
    border-radius: var(--border-radius);
    color: var(--code-color);
    font-weight: var(--font-weight);
    line-height: initial
}

code, kbd {
    display: inline-block;
    padding: .375rem .5rem
}

pre {
    display: block;
    margin-bottom: var(--spacing);
    overflow-x: auto
}

pre > code {
    display: block;
    padding: var(--spacing);
		background-color: rgba(0, 0, 0, 0.55);
    font-size: 14px;
    line-height: var(--line-height)
}

code b {
    color: var(--code-tag-color);
    font-weight: var(--font-weight)
}

code i {
    color: var(--code-property-color);
    font-style: normal
}

code u {
    color: var(--code-value-color);
    text-decoration: none
}

code em {
    color: var(--code-comment-color);
    font-style: normal
}

kbd {
    background-color: var(--code-kbd-background-color);
    color: var(--code-kbd-color);
    vertical-align: baseline
}

hr {
    height: 0;
    border: 0;
    border-top: 1px solid var(--muted-border-color);
    color: inherit
}

[hidden], template {
    display: none !important
}

canvas {
    display: inline-block
}

:where(navli)::before {
    float: left;
    content: "​"
}

nav, nav ul {
    display: flex
}

nav {
    justify-content: space-between
}

nav ol, nav ul {
    align-items: center;
    margin-bottom: 0;
    padding: 0;
    list-style: none
}

nav ol:first-of-type, nav ul:first-of-type {
    margin-left: calc(var(--nav-element-spacing-horizontal) * -1)
}

nav ol:last-of-type, nav ul:last-of-type {
    margin-right: calc(var(--nav-element-spacing-horizontal) * -1)
}

nav li {
    display: inline-block;
    margin: 0;
    padding: var(--nav-element-spacing-vertical) var(--nav-element-spacing-horizontal)
}

nav li > * {
    --spacing: 0
}

nav :where(a,[role=link]) {
    display: inline-block;
    margin: calc(var(--nav-link-spacing-vertical) * -1) calc(var(--nav-link-spacing-horizontal) * -1);
    padding: var(--nav-link-spacing-vertical) var(--nav-link-spacing-horizontal);
    border-radius: var(--border-radius);
    text-decoration: none
}

nav :where(a,[role=link]):is([aria-current],:hover,:active,:focus) {
    text-decoration: none
}

nav [role=button] {
    margin-right: inherit;
    margin-left: inherit;
    padding: var(--nav-link-spacing-vertical) var(--nav-link-spacing-horizontal)
}

aside li, aside nav, aside ol, aside ul {
    display: block
}

aside li {
    padding: calc(var(--nav-element-spacing-vertical) * .5) var(--nav-element-spacing-horizontal)
}

aside li a {
    display: block
}

aside li [role=button] {
    margin: inherit
}

progress {
    display: inline-block;
    vertical-align: baseline
}

progress {
    -webkit-appearance: none;
    -moz-appearance: none;
    display: inline-block;
    appearance: none;
    width: 100%;
    height: .5rem;
    margin-bottom: calc(var(--spacing) * .5);
    overflow: hidden;
    border: 0;
    border-radius: var(--border-radius);
    background-color: var(--progress-background-color);
    color: var(--progress-color)
}

progress::-webkit-progress-bar {
    border-radius: var(--border-radius);
    background: 0 0
}

progress[value]::-webkit-progress-value {
    background-color: var(--progress-color)
}

progress::-moz-progress-bar {
    background-color: var(--progress-color)
}

@media (prefers-reduced-motion: no-preference) {
    progress:indeterminate {
        background: var(--progress-background-color) linear-gradient(to right, var(--progress-color) 30%, var(--progress-background-color) 30%) top left/150% 150% no-repeat;
        -webkit-animation: progressIndeterminate 1s linear infinite;
        animation: progressIndeterminate 1s linear infinite
    }

    progress:indeterminate[value]::-webkit-progress-value {
        background-color: transparent
    }

    progress:indeterminate::-moz-progress-bar {
        background-color: transparent
    }
}

@media (prefers-reduced-motion: no-preference) {
    [dir=rtl] progress:indeterminate {
        animation-direction: reverse
    }
}

@-webkit-keyframes progressIndeterminate {
    0% {
        background-position: 200% 0
    }
    100% {
        background-position: -200% 0
    }
}

@keyframes progressIndeterminate {
    0% {
        background-position: 200% 0
    }
    100% {
        background-position: -200% 0
    }
}

[aria-busy=true] {
    cursor: progress
}

[aria-busy=true]:not(input):not(select):not(textarea)::before {
    display: inline-block;
    width: 1em;
    height: 1em;
    border: .1875em solid currentColor;
    border-radius: 1em;
    border-right-color: transparent;
    content: "";
    vertical-align: text-bottom;
    vertical-align: -.125em;
    -webkit-animation: spinner .75s linear infinite;
    animation: spinner .75s linear infinite;
    opacity: var(--loading-spinner-opacity)
}

[aria-busy=true]:not(input):not(select):not(textarea):not(:empty)::before {
    margin-right: calc(var(--spacing) * .5);
    margin-left: 0;
    -webkit-margin-start: 0;
    margin-inline-start: 0;
    -webkit-margin-end: calc(var(--spacing) * .5);
    margin-inline-end: calc(var(--spacing) * .5)
}

[aria-busy=true]:not(input):not(select):not(textarea):empty {
    text-align: center
}

a[aria-busy=true], button[aria-busy=true], input[type=button][aria-busy=true], input[type=reset][aria-busy=true], input[type=submit][aria-busy=true] {
    pointer-events: none
}

@-webkit-keyframes spinner {
    to {
        transform: rotate(360deg)
    }
}

@keyframes spinner {
    to {
        transform: rotate(360deg)
    }
}

[data-tooltip] {
    position: relative
}

[data-tooltip]:not(a):not(button):not(input) {
    border-bottom: 1px dotted;
    text-decoration: none;
    cursor: help
}

[data-tooltip]::after, [data-tooltip]::before {
    display: block;
    z-index: 99;
    position: absolute;
    bottom: 100%;
    left: 50%;
    padding: .25rem .5rem;
    overflow: hidden;
    transform: translate(-50%, -.25rem);
    border-radius: var(--border-radius);
    background: var(--tooltip-background-color);
    content: attr(data-tooltip);
    color: var(--tooltip-color);
    font-style: normal;
    font-weight: var(--font-weight);
    font-size: .875rem;
    text-decoration: none;
    text-overflow: ellipsis;
    white-space: nowrap;
    opacity: 0;
    pointer-events: none
}

[data-tooltip]::after {
    padding: 0;
    transform: translate(-50%, 0);
    border-top: .3rem solid;
    border-right: .3rem solid transparent;
    border-left: .3rem solid transparent;
    border-radius: 0;
    background-color: transparent;
    content: "";
    color: var(--tooltip-background-color)
}

[data-tooltip]:focus::after, [data-tooltip]:focus::before, [data-tooltip]:hover::after, [data-tooltip]:hover::before {
    opacity: 1
}

@media (hover: hover) and (pointer: fine) {
    [data-tooltip]:focus::after, [data-tooltip]:focus::before, [data-tooltip]:hover::after, [data-tooltip]:hover::before {
        -webkit-animation-duration: .2s;
        animation-duration: .2s;
        -webkit-animation-name: slide;
        animation-name: slide
    }

    [data-tooltip]:focus::after, [data-tooltip]:hover::after {
        -webkit-animation-name: slideCaret;
        animation-name: slideCaret
    }
}

@-webkit-keyframes slide {
    from {
        transform: translate(-50%, .75rem);
        opacity: 0
    }
    to {
        transform: translate(-50%, -.25rem);
        opacity: 1
    }
}

@keyframes slide {
    from {
        transform: translate(-50%, .75rem);
        opacity: 0
    }
    to {
        transform: translate(-50%, -.25rem);
        opacity: 1
    }
}

@-webkit-keyframes slideCaret {
    from {
        opacity: 0
    }
    50% {
        transform: translate(-50%, -.25rem);
        opacity: 0
    }
    to {
        transform: translate(-50%, 0);
        opacity: 1
    }
}

@keyframes slideCaret {
    from {
        opacity: 0
    }
    50% {
        transform: translate(-50%, -.25rem);
        opacity: 0
    }
    to {
        transform: translate(-50%, 0);
        opacity: 1
    }
}

[aria-controls] {
    cursor: pointer
}

[aria-disabled=true], [disabled] {
    cursor: not-allowed
}

[aria-hidden=false][hidden] {
    display: initial
}

[aria-hidden=false][hidden]:not(:focus) {
    clip: rect(0, 0, 0, 0);
    position: absolute
}

[tabindex], a, area, button, input, label, select, summary, textarea {
    -ms-touch-action: manipulation
}

[dir=rtl] {
    direction: rtl
}

:root {
    --icon-external: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='rgba(115, 130, 140, 0.999)' opacity='0.66' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M18 13v6a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h6'%3E%3C/path%3E%3Cpolyline points='15 3 21 3 21 9'%3E%3C/polyline%3E%3Cline x1='10' y1='14' x2='21' y2='3'%3E%3C/line%3E%3C/svg%3E");
    --icon-check: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23FFF' stroke-width='5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'%3E%3C/polyline%3E%3C/svg%3E");
    --icon-check-dark: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='rgba(0, 0, 0, 0.75)' stroke-width='5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'%3E%3C/polyline%3E%3C/svg%3E")
}

:root:not([data-theme=dark]), [data-theme=light] {
    --invalid-color: #c62828;
    --valid-color: #388e3c;
    --nav-background-color: rgba(255, 255, 255, 0.7);
    --nav-border-color: rgba(115, 130, 140, 0.2);
    --nav-logo-color: #fff;
    --article-code-background-color: #f9fafb
}

@media only screen and (prefers-color-scheme: dark) {
    :root:not([data-theme=light]) {
        --invalid-color: rgba(183, 28, 28, 0.5);
        --valid-color: rgba(46, 125, 50, 0.5);
        --nav-background-color: rgba(16, 24, 30, 0.8);
        --nav-border-color: rgba(115, 130, 140, 0.2);
        --nav-logo-color: #0e1419;
        --article-code-background-color: var(--code-background-color)
    }
}

[data-theme=dark] {
    --invalid-color: rgba(183, 28, 28, 0.5);
    --valid-color: rgba(46, 125, 50, 0.5);
    --nav-background-color: rgba(16, 24, 30, 0.8);
    --nav-border-color: rgba(115, 130, 140, 0.2);
    --nav-logo-color: #0e1419;
    --article-code-background-color: var(--code-background-color)
}

html {
    scroll-behavior: smooth
}

.switcher {
    position: fixed;
    right: calc(var(--spacing) / 2 + 0px);
    bottom: var(--spacing);
    width: auto;
    margin-bottom: 0;
    padding: .75rem;
    border-radius: 2rem;
    box-shadow: var(--card-box-shadow);
    line-height: 1;
    text-align: right
}

.switcher::after {
    display: inline-block;
    width: 1rem;
    height: 1rem;
    border: .15rem solid currentColor;
    border-radius: 50%;
    background: linear-gradient(to right, currentColor 0, currentColor 50%, transparent 50%);
    content: "";
    vertical-align: bottom;
    transition: transform var(--transition)
}

.switcher i {
    display: inline-block;
    max-width: 0;
    padding: 0;
    overflow: hidden;
    font-style: normal;
    font-size: .875rem;
    white-space: nowrap
}

.switcher:focus, .switcher:hover {
    max-width: 100%;
    transition: background-color var(--transition), border-color var(--transition), color var(--transition), box-shadow var(--transition)
}

.switcher:hover::after {
    transform: rotate(180deg)
}

.switcher:hover i {
    max-width: 100%;
    padding: 0 calc(var(--spacing) / 2) 0 calc(var(--spacing) / 4);
    transition: max-width var(--transition), padding var(--transition)
}

.switcher:focus {
    box-shadow: var(--card-box-shadow), 0 0 0 .2rem var(--secondary-focus)
}

@media (min-width: 576px) {
    .switcher {
        right: calc(var(--spacing) + 0px)
    }
}

:root:not([data-theme=dark]), [data-theme=light] {
    --demo-background: linear-gradient(
            180deg,
            #fff 0%,
            rgba(188, 235, 251, 0.25) 33%,
            rgba(188, 235, 251, 0.25) 66%,
            #fff 100%
    )
}

@media only screen and (prefers-color-scheme: dark) {
    :root:not([data-theme=light]) {
        --demo-background: linear-gradient(180deg, #11191f 0%,
        rgba(10, 53, 67, 0.5) 33%,
        rgba(10, 53, 67, 0.5) 66%,
        #11191f 100%)
    }
}

[data-theme=dark] {
    --demo-background: linear-gradient(180deg, #11191f 0%,
    rgba(10, 53, 67, 0.5) 33%,
    rgba(10, 53, 67, 0.5) 66%,
    #11191f 100%)
}

header h1, header h2, main h1, main h2 {
    --font-weight: 800
}

h1 {
    line-height: 1.125
}

@media (min-width: 576px) {
    h1 {
        --font-size: 2.25rem
    }
}

@media (min-width: 768px) {
    h1 {
        --font-size: 2.5rem
    }
}

@media (min-width: 992px) {
    h1 {
        --font-size: 2.75rem
    }
}

@media (min-width: 1200px) {
    h1 {
        --font-size: 3rem
    }
}

h2 {
    line-height: 1.25
}

@media (min-width: 576px) {
    h2 {
        --font-size: 1.875rem
    }
}

@media (min-width: 768px) {
    h2 {
        --font-size: 2rem
    }
}

@media (min-width: 992px) {
    h2 {
        --font-size: 2.125rem
    }
}

@media (min-width: 1200px) {
    h2 {
        --font-size: 2.25rem
    }
}

ul.check {
    padding: 0
}

ul.check li {
    margin-left: 1.5rem;
    list-style: none
}

ul.check li::before {
    display: block;
    position: absolute;
    width: 1rem;
    height: 1rem;
    margin-top: .25rem;
    margin-left: -1.5rem;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='rgba(16, 149, 193, 0.999)' stroke-width='4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'%3E%3C/polyline%3E%3C/svg%3E");
    background-size: 100%;
    content: ""
}

body {
    width: 100%;
    margin: 0;
    transition: padding-top 0.3s ease-in-out;
}

body.nav-visible {
    padding-top: 60px; /* Adjust based on nav height */
}

footer, header, main > section {
    --block-spacing-vertical: 3rem;
    --demo-height: calc(4.5rem + 352px);
    width: 100%;
    margin: 0;
    padding: var(--block-spacing-vertical) 0
}

@media (min-width: 576px) {
    footer, header, main > section {
        --block-spacing-vertical: 4rem;
        --demo-height: calc(6rem + 392px)
    }
}

@media (min-width: 768px) {
    footer, header, main > section {
        --block-spacing-vertical: 5rem;
        --demo-height: calc(7.5rem + 440px)
    }
}

@media (min-width: 992px) {
    footer, header, main > section {
        --block-spacing-vertical: 6rem;
        --demo-height: calc(9rem + 488px)
    }
}

@media (min-width: 1200px) {
    footer, header, main > section {
        --block-spacing-vertical: 4rem;
        --demo-height: calc(10.5rem + 540px)
    }
}

header {
    padding-bottom: 0
}

#demo {
    display: flex;
    align-items: center
}

#examples, #star {
    background-color: var(--background-color)
}

#principles {
    padding-top: 0
}

#star {
    padding: calc(var(--block-spacing-vertical) / 2) 0;
    text-align: center
}

body > nav {
    --nav-link-spacing-vertical: 1rem;
    box-shadow: 0 1px 0 var(--nav-border-color)
}

body > nav a {
    border-radius: 0
}

body > nav a svg {
    vertical-align: text-bottom;
    height: 1rem;
		color: initial;
}

body > nav ul:first-of-type {
    margin-left: calc(var(--spacing) * -1)
}

body > nav ul:first-of-type li {
    padding: 0
}

header h1, header p {
    text-align: center
}

header h1 {
    margin-bottom: var(--spacing)
}

header h1 ~ p {
    color: var(--muted-color)
}

header a:not(:last-of-type) {
    margin-right: calc(var(--spacing) * .5)
}

header p:last-of-type {
    margin-bottom: 0
}

article {
    margin: var(--block-spacing-vertical) 0;
    padding: var(--block-spacing-vertical) var(--block-spacing-horizontal);
    overflow: hidden;
    border-radius: var(--border-radius);
    background: var(--card-background-color);
    box-shadow: var(--card-box-shadow)
}

article > footer, article > header, article > pre {
    margin-right: calc(var(--block-spacing-horizontal) * -1);
    margin-left: calc(var(--block-spacing-horizontal) * -1);
    padding: calc(var(--block-spacing-vertical) * .66) var(--block-spacing-horizontal);
    background-color: var(--card-sectionning-background-color)
}

article > header {
    margin-top: calc(var(--block-spacing-vertical) * -1);
    margin-bottom: var(--block-spacing-vertical);
    border-bottom: var(--border-width) solid var(--card-border-color)
}

article > footer, article > pre {
    margin-top: var(--block-spacing-vertical);
    margin-bottom: calc(var(--block-spacing-vertical) * -1);
    border-top: var(--border-width) solid var(--card-border-color)
}

#demo {
    height: var(--demo-height);
    background: var(--demo-background)
}

#demo article {
    --block-spacing-vertical: 2rem;
    max-width: 510px;
    height: auto;
    min-height: calc(var(--block-spacing-vertical) * 2);
    max-height: calc(var(--block-spacing-vertical) * 2);
    margin: 0;
    margin-right: auto;
    margin-left: auto;
    pointer-events: none;
    transition: min-height var(--transition), max-height var(--transition);
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none
}

@media (min-width: 576px) {
    #demo article {
        --block-spacing-vertical: 2.5rem
    }
}

@media (min-width: 768px) {
    #demo article {
        --block-spacing-vertical: 3rem
    }
}

@media (min-width: 992px) {
    #demo article {
        --block-spacing-vertical: 3.5rem
    }
}

@media (min-width: 1200px) {
    #demo article {
        --block-spacing-vertical: 4rem
    }
}

#demo article pre > code {
    padding: 0
}

#demo article label {
    color: var(--color)
}

#demo article .demo-last-child, #demo article form {
    margin-bottom: 0 !important
}

#demo article input[type=text] {
    height: inherit
}

#demo article .ti-cursor {
    margin: 0 -.5ch !important
}

#demo article .fadeIn, #demo article .fadeOut {
    -webkit-animation-name: fadeIn;
    animation-name: fadeIn;
    -webkit-animation-duration: .4s;
    animation-duration: .4s;
    -webkit-animation-fill-mode: both;
    animation-fill-mode: both
}

#demo article .fadeOut {
    -webkit-animation-name: fadeOut;
    animation-name: fadeOut
}

@-webkit-keyframes fadeIn {
    from {
        opacity: 0
    }
    to {
        opacity: 1
    }
}

@keyframes fadeIn {
    from {
        opacity: 0
    }
    to {
        opacity: 1
    }
}

@-webkit-keyframes fadeOut {
    from {
        opacity: 1
    }
    to {
        opacity: 0
    }
}

@keyframes fadeOut {
    from {
        opacity: 1
    }
    to {
        opacity: 0
    }
}

a[role=button].active, button.active, input[type=button].active, input[type=reset].active, input[type=submit].active {
    --background-color: var(--primary-hover);
    --border-color: var(--primary-hover);
    --box-shadow: 0 0 0 rgba(0, 0, 0, 0), 0 0 0 var(--outline-width) var(--primary-focus)
}

input:not([type=submit]):not([type=button]):not([type=reset]):not([type=checkbox]):not([type=radio]):not([readonly]).active, select.active, textarea.active {
    --background-color: var(--form-element-active-background-color)
}

input:not([type=submit]):not([type=button]):not([type=reset]):not([role=switch]):not([readonly]).active, select.active, textarea.active {
    --border-color: var(--form-element-active-border-color)
}

input:not([type=submit]):not([type=button]):not([type=reset]):not([type=range]):not([type=file]):not([readonly]).active, select.active, textarea.active {
    --box-shadow: 0 0 0 var(--outline-width) var(--form-element-focus-color)
}

[type=checkbox]:checked, [type=checkbox]:checked.active, [type=radio]:checked, [type=radio]:checked.active {
    --background-color: var(--primary);
    --border-color: var(--primary)
}

[type=checkbox][role=switch].active {
    --background-color: var(--switch-background-color);
    --border-color: var(--switch-background-color)
}

[type=checkbox][role=switch]:checked {
    --background-color: var(--switch-checked-background-color);
    --border-color: var(--switch-checked-background-color)
}

[type=range].active {
    --range-thumb-color: var(--range-thumb-active-color);
    --range-border-color: var(--range-active-border-color)
}

[type=range].active::-webkit-slider-thumb {
    transform: scale(1.25)
}

[type=range].active::-moz-range-thumb {
    transform: scale(1.25)
}

[type=range].active::-ms-thumb {
    transform: scale(1.25)
}





hgroup {
    text-align: center
}

hgroup h2 {
    margin-bottom: var(--spacing)
}

hgroup:after {
    display: none
}

h3 {
    --font-weight: 400
}

svg {
    color: var(--primary);
    width: auto;
    height: 1.25rem
}

 h4 {
    --font-size: 1rem;
    --font-weight: 400;
    margin-bottom: .5rem
}

p {
    --color: var(--muted-color)
}

#examples .grid {
    grid-gap: 2rem;
    display: grid;
    grid-template-columns:1fr;
    margin: 0
}

@media (min-width: 576px) {
    #examples .grid {
        grid-template-columns:1fr 1fr
    }
}

@media (min-width: 992px) {
    #examples .grid {
        grid-template-columns:1fr 1fr 1fr
    }
}

#examples .grid > div > a {
    text-transform: uppercase;
    font-weight: 500
}

.example {
    position: relative;
    width: 100%;
    margin-top: calc(var(--spacing) * .5);
    margin-bottom: var(--spacing);
    padding-top: 56.25%
}

.example .desktop, .example .mobile {
    position: absolute;
    transform: scale(1.001);
    background-color: var(--card-background-color);
    background-repeat: no-repeat;
    background-size: 200% auto;
    box-shadow: var(--card-box-shadow);
    transition: background-position .15s ease-in-out, transform .3s ease-in-out
}

.example .desktop::before, .example .mobile::before {
    position: absolute;
    top: -1px;
    right: -1px;
    bottom: -1px;
    left: -1px;
    border: 1px solid rgba(138, 153, 163, .25);
    content: "";
    transition: box-shadow .3s ease-in-out
}

.example .desktop {
    top: 0;
    left: 0;
    width: calc(100% - var(--spacing));
    padding-top: calc(56.25% - var(--spacing))
}

.example .mobile {
    right: 0;
    bottom: 0;
    width: 19.53125%;
    padding-top: calc(42.2916666667% - var(--spacing));
    border-radius: var(--border-radius);
    transition-delay: 75ms
}

.example .mobile::before {
    border-radius: var(--border-radius);
    transition-delay: 75ms
}

a:active .desktop, a:focus .desktop, a:hover .desktop {
    transform: scale(1.03125)
}

a:active .mobile, a:focus .mobile, a:hover .mobile {
    transform: scale(1.0625)
}

a:active .desktop::before, a:active .mobile::before, a:focus .desktop::before, a:focus .mobile::before, a:hover .desktop::before, a:hover .mobile::before {
    box-shadow: 0 0 1rem .1rem
}

:root:not([data-theme=dark]) .example .desktop, :root:not([data-theme=dark]) .example .mobile, [data-theme=light] .example .desktop, [data-theme=light] .example .mobile {
    background-position: 100% 0;
    background-position: calc(100% - 1px) 0
}

:root:not([data-theme=dark]) .example:hover .desktop, :root:not([data-theme=dark]) .example:hover .mobile, [data-theme=light] .example:hover .desktop, [data-theme=light] .example:hover .mobile {
    background-position: 0 0
}

@media only screen and (prefers-color-scheme: dark) {
    :root:not([data-theme=light]) .example .desktop, :root:not([data-theme=light]) .example .mobile {
        background-position: 0 0
    }

    :root:not([data-theme=light]) .example:hover .desktop, :root:not([data-theme=light]) .example:hover .mobile {
        background-position: 100% 0;
        background-position: calc(100% - 1px) 0
    }
}

[data-theme=dark] .example .desktop, [data-theme=dark] .example .mobile {
    background-position: 0 0
}

[data-theme=dark] .example:hover .desktop, [data-theme=dark] .example:hover .mobile {
    background-position: 100% 0;
    background-position: calc(100% - 1px) 0
}

#why [data-theme]:first-of-type pre, #why ul {
    margin-bottom: var(--block-spacing-vertical)
}

[data-theme=invalid], [data-theme=valid] {
    position: relative;
    margin-bottom: 0 !important
}

[data-theme=invalid]:before, [data-theme=valid]:before {
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    padding: .375rem .75rem;
    border-radius: 0;
    color: var(--primary-inverse);
    font-size: 14px;
    line-height: 1
}

@media (min-width: 992px) {
    [data-theme=invalid]:before, [data-theme=valid]:before {
        top: var(--spacing);
        right: var(--spacing)
    }
}

[data-theme=invalid] pre, [data-theme=valid] pre {
    padding: var(--spacing)
}

[data-theme=invalid] pre code, [data-theme=valid] pre code {
    padding: calc(var(--spacing) * 1.625) 0
}

[data-theme=invalid]:before {
    background: var(--invalid-color);
    content: "Bulky"
}

[data-theme=valid] pre {
    margin-bottom: 0
}

[data-theme=valid]:before {
    background: var(--valid-color);
    content: "Great"
}

#star p {
    margin-bottom: 0;
    line-height: 1
}

#star iframe {
    display: block;
    margin-top: calc(var(--spacing) * .5);
    margin-right: auto;
    margin-left: auto
}

@media (min-width: 576px) {
    #star iframe {
        display: inline-block;
        margin-top: 0;
        margin-right: 0;
        margin-bottom: .125rem;
        margin-left: calc(var(--spacing) * .25);
        vertical-align: middle
    }
}

body > footer ul, body > footer ul li {
    margin-bottom: 0;
    padding: 0;
    color: var(--muted-color);
    list-style: none
}

body > footer li {
    display: inline-block
}

body > footer li:not(:first-child)::before {
    margin: 0 .25rem;
    content: "·"
}

body > footer ul:first-of-type {
    margin-bottom: calc(var(--spacing) * .5)
}

body > footer ul:first-of-type a {
    text-decoration: none
}

@media (max-width: 767px) {
    body > footer ul:last-of-type li {
        display: list-item
    }

    body > footer ul:last-of-type li::before {
        display: none
    }
}

header {
    padding-bottom: var(--block-spacing-vertical)
}

section#demo {
    display: none
}

[data-typeit-id]:before {
    content: '.';
    display: inline-block;
    width: 0;
    visibility: hidden;
}

@keyframes blink-9870177 {
    0% {
        opacity: 0
    }
    49% {
        opacity: 0
    }
    50% {
        opacity: 1
    }
}

[data-typeit-id='9870177'] .ti-cursor {
    animation: blink-9870177 1s infinite;
}

[data-typeit-id='9870177'] .ti-cursor.with-delay {
    animation-delay: 500ms;
}

[data-typeit-id='9870177'] .ti-cursor.disabled {
    animation: none;
}

.panel-container {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

@media (min-width: 768px) {
    .panel-container {
        flex-direction: row;
        gap: 2.5rem;
    }
}

.snippet-panel {
    flex: 1;
    margin-right: 10px; /* adjust as needed */
}

.documentation-panel {
    background-color: rgba(255, 255, 255, 0.10);
    border-radius: 20px;
    flex: 1;
    padding: 30px;
    backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.15);
}

.snippet-documentation-panel {
    margin-top: 20px;
    margin-bottom: 20px;
}

.snippet-documentation-panel h2 {
    font-size: 2.0rem;
}

.halign-left {
    text-align: left;
}

.grid-all th, .grid-all td {
    border: 1px solid #dfe2e5;
    border-collapse: collapse;
}

.hljs-string {
    color: green;
}

.hljs-meta .hljs-string {
    color: green;
}

html{
    margin: 0;
    padding: 0;
    min-height: 100%;
    background:
        radial-gradient(circle at var(--x1, 25%) var(--y1, 75%), rgba(130, 0, 255, 0.4), transparent 40%),
        radial-gradient(circle at var(--x2, 75%) var(--y2, 25%), rgba(0, 98, 255, 0.5), transparent 45%),
        radial-gradient(circle at var(--x3, 50%) var(--y3, 50%), rgba(72, 0, 120, 0.6), transparent 60%),
        radial-gradient(circle at var(--x4, 60%) var(--y4, 80%), rgba(200, 0, 255, 0.3), transparent 50%),
        linear-gradient(135deg, #3a0ca3, #4361ee, #7209b7);
    background-blend-mode: screen;
    background-repeat: no-repeat;
    background-size: cover;
    background-attachment: fixed;
    transition: background-position 0.2s ease;
}

html {
    min-height: 100%;
    background:
        radial-gradient(circle at var(--x1, 25%) var(--y1, 75%), rgba(130, 0, 255, 0.4), transparent 40%),
        radial-gradient(circle at var(--x2, 75%) var(--y2, 25%), rgba(0, 98, 255, 0.5), transparent 45%),
        radial-gradient(circle at var(--x3, 50%) var(--y3, 50%), rgba(72, 0, 120, 0.6), transparent 60%),
        radial-gradient(circle at var(--x4, 60%) var(--y4, 80%), rgba(200, 0, 255, 0.3), transparent 50%),
        linear-gradient(135deg, #3a0ca3, #4361ee, #7209b7);
    background-attachment: fixed;
    background-blend-mode: screen;  
    background-size: cover;
}

@keyframes gradientGlow {
  0% {
    --x1: 30%;
    --y1: 70%;
    --x2: 70%;
    --y2: 30%;
    --x3: 50%;
    --y3: 50%;
  }

  50% {
    --x1: 40%;
    --y1: 60%;
    --x2: 60%;
    --y2: 40%;
    --x3: 48%;
    --y3: 52%;
  }

  100% {
    --x1: 35%;
    --y1: 65%;
    --x2: 65%;
    --y2: 35%;
    --x3: 52%;
    --y3: 48%;
  }
}

nav {
  background-color: rgba(0, 0, 0, 0.2);
  backdrop-filter: blur(10px);
}

.header-cta {
  display: flex;
  gap: 0.5rem;
  justify-content: center;
  margin: 1.5rem 0 0 0;
}

.banner-snippet {
  display: flex;
  justify-content: center;
  border-radius: 0.25rem;
  margin: 0.5em 0 0 0;
}

.banner-snippet code {
  margin-top: 0.5rem;
  background-color:rgba(255, 255, 255, 0.10);
}

.dotted {
  background-image: url("./assets/halftone.png");
  background-size: 158%;
  background-repeat: repeat-y;
  background-position: center center;
  width: 190px;
  height: 100vh;
  position: fixed;
  left: 0;
  opacity: .1;
  top: 0;
	z-index: -5;
  pointer-events: none;
}

.dotted-right {
  background-image: url("./assets/halftone.png");
  background-size: 158%;
  transform: rotate(180deg);
  background-repeat: repeat-y;
  background-position: center center;
  width: 190px;
  height: 100vh;
  position: fixed;
  right: 0;
  opacity: .1;
  top: 0;
	z-index: -5;
  pointer-events: none;
}

@media (max-width: 576px) {
	.dotted, .dotted-right {
		opacity: 0.05;
	}

  .dotted {
    left: -80px;
  }
  .dotted-right {
    right: -80px;
  }
}

/* ===========================
   Navigation Styles
=========================== */

.nav {
    background-color: rgba(0, 0, 0, 0.2);
    padding: 0.25rem 1rem;
    font-size: 1rem;
    font-weight: bold;
    font-size: 1rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    position: fixed;
    z-index: 1000;
    top: 0;
    left: 0;
    right: 0;
    transform: translateY(-100%);
    transition: transform 0.3s ease-in-out;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

.nav.nav-visible {
    transform: translateY(0);
}

.nav .logo {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
}

.nav ul {
    gap: 1rem;
}

.nav-section {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-direction: row;
    flex-wrap: nowrap;
}

.nav-section>div {
    margin-right: .5rem;
}

.nav-section:last-child {

    color: #ffffff99;
}

.nav-section:last-child div:hover {
    color: #ffffffff;
}

.nav-section:last-child div {
    margin-right: 1.5rem;
}

.nav ul li {
    list-style: none;
}

.nav .logo-link {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: #ffffff;
}

.nav .nav-section:last-child a[role="menuitem"] {
    font-size: 1rem;
}

/* ===========================
   Cutout Styles
=========================== */

.boxicon {
    width: 50px;
    height: 50px;
}

.boxicon .inner-box {
    position: relative;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: 126%;
}

/***** cutout box sizing *****/

.box1 {
    width: 300px;
    height: 300px;
    margin: 0rem 2rem;
}

.box2 {
    width: 150px;
    height: 150px;
    margin: 0rem 1rem;
}

.box3 {
    width: 450px;
    height: 450px;
    margin: 0rem 2rem;
}

/***** cutout box shapes *****/

.box-shape1 {
    background-image: url("./assets/image-box.svg");
    background-repeat: no-repeat;
    background-position: center center;
    background-size: stretch;
}

.box-shape2 {
    background-image: url("./assets/image-box2.svg");
    background-repeat: no-repeat;
    background-position: center center;
    background-size: stretch;
}

.box-shape3 {
    background-image: url("./assets/image-box3.svg");
    background-repeat: no-repeat;
    background-position: center center;
    background-size: stretch;
}

/***** cutout box rotations *****/
.box0 {
    position: relative;
    filter: drop-shadow(7px 10px 0px rgba(0, 0, 0, .7));
}

.box90 {
    transform: rotate(90deg);
    filter: drop-shadow(7px -10px 0px rgba(0, 0, 0, .7));
}

.box90 .inner-box {
    transform: rotate(270deg);
    background-size: contain;
}

.box180 {
    transform: rotate(180deg);
    filter: drop-shadow(-7px -10px 0px rgba(0, 0, 0, .7));
}

.box180 .inner-box {
    transform: rotate(-180deg);
    background-size: contain;
}

.box270 {
    transform: rotate(270deg);
    filter: drop-shadow(-7px 10px 0px rgba(0, 0, 0, .7));
}

.box270 .inner-box {
    transform: rotate(90deg);
    background-size: contain;
}

/***** cutout box inner content and images *****/
.inner-box {
    height: 58%;
    width: 58%;
    position: absolute;
    top: 21%;
    left: 21%;
    color: black;

    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
}

.cards {
    background-image: url("./assets/cards1.jpg");
}

.shouting {
    background-image: url("./assets/man1.webp");
}

.thinking {
    background-image: url("./assets/think1.png");
}

.mrdocs {
    background-image: url("./assets/mrdocs.svg");
}

/* ===========================
   Header Styles
=========================== */

header .container {
	display: flex;
	flex-direction: column;
}

header .header-image {
	align-self: center;
}

@media (min-width: 768px) {
	header .container {
		align-items: center;
		justify-content: center;
		flex-direction: row;
	}
}

.header-content {
	display: flex;
	flex-direction: column;
	align-items: center;
}

.header-cta a[aria-label="Documentation"] {
    color: #fff;
    background-color: rgba(255, 255, 255, 0.25);
}

/* ===========================
   Principles Styles
=========================== */

.principles-banner {
	align-items: center;
	justify-items: center;
}

.principles-content {
	text-align: center;
	order: 1
}

.principles-image {
	order: 2;
}

@media (min-width: 768px) {
  .principles-image {
    justify-self: end;
    align-self: center;
		order: 1;
  }
}

@media (min-width: 768px) {
	.principles .container {
		display: flex;
		flex-direction: column;
		gap: 2.5rem;
	}

  .principles-banner {
    grid-template-columns: 35% 65%;
		align-items: center;
		justify-items: center;
  }

	.principles-features {
		display: grid;
		grid-template-columns: 1fr 1fr;
		gap: 5rem;
		row-gap: 1rem;
	}
}
