diff --git a/.github/workflows/pytest.yaml b/.github/workflows/pytest.yaml
index 4baa43733..b5b8cb784 100644
--- a/.github/workflows/pytest.yaml
+++ b/.github/workflows/pytest.yaml
@@ -48,7 +48,7 @@ jobs:
run: |
make check
- e2e:
+ playwright-shiny:
runs-on: ${{ matrix.os }}
if: github.event_name != 'release'
strategy:
@@ -67,9 +67,9 @@ jobs:
- name: Run End-to-End tests
timeout-minutes: 20
run: |
- make e2e
+ make playwright-shiny
- e2e-examples:
+ playwright-examples:
runs-on: ${{ matrix.os }}
if: github.event_name != 'release'
strategy:
@@ -99,11 +99,11 @@ jobs:
- name: Run example app tests
timeout-minutes: 20
run: |
- make e2e-examples
+ make playwright-examples
- e2e-deploys:
- # Only allow one `e2e-deploys` job to run at a time. (Independent of branch / PR)
- concurrency: e2e-deploys
+ playwright-deploys:
+ # Only allow one `playwright-deploys` job to run at a time. (Independent of branch / PR)
+ concurrency: playwright-deploys
runs-on: ${{ matrix.os }}
if: ${{ github.event_name == 'push' || (github.event_name == 'pull_request' && startsWith(github.head_ref, 'deploy')) }}
strategy:
@@ -128,7 +128,7 @@ jobs:
DEPLOY_SHINYAPPS_SECRET: "${{ secrets.DEPLOY_SHINYAPPS_SECRET }}"
timeout-minutes: 30
run: |
- make e2e-deploys
+ make playwright-deploys
pypi:
name: "Deploy to PyPI"
@@ -202,7 +202,7 @@ jobs:
- name: Run End-to-End tests
timeout-minutes: 20
run: |
- make e2e-junit
+ make testrail-junit
- name: Report results to Testrail
env:
TESTRAIL_URL: "https://posit.testrail.io"
diff --git a/.gitignore b/.gitignore
index a1827a31b..5560ec767 100644
--- a/.gitignore
+++ b/.gitignore
@@ -1,5 +1,5 @@
# Byte-compiled / optimized / DLL files
-__pycache__/
+**/__pycache__/
*.py[cod]
*$py.class
@@ -110,3 +110,6 @@ docs/source/reference/
.Rproj.user
/.luarc.json
+
+# Developer scratch area
+_dev/
diff --git a/.vscode/settings.json b/.vscode/settings.json
index d2d06aa89..07dbac4c2 100644
--- a/.vscode/settings.json
+++ b/.vscode/settings.json
@@ -29,7 +29,7 @@
"editor.formatOnSave": true,
"editor.tabSize": 4,
"editor.codeActionsOnSave": {
- "source.organizeImports": true
+ "source.organizeImports": "explicit"
}
},
"isort.args": ["--profile", "black"],
diff --git a/CHANGELOG.md b/CHANGELOG.md
index a20207b4c..093a5fd7f 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -9,10 +9,11 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
## [UNRELEASED]
### New features
-- `shiny create` now allows you to select from a list of template apps.
-- `shiny create` provides templates which help you build your own custom JavaScript components.
+* `shiny create` now allows you to select from a list of template apps.
+* `shiny create` provides templates which help you build your own custom JavaScript components.
* Closed #814: The functions `reactive.Calc` and `reactive.Effect` have been changed to have lowercase names: `reactive.calc`, and `reactive.effect`. The old capitalized names are now aliases to the new lowercase names, so existing code will continue to work. Similarly, the class `reactive.Value` has a new alias, `reactive.value`, but in this case, since the original was a class, it keeps the original capitalized name as the primary name. The examples have not been changed yet, but will be changed in a future release. (#822)
+* Added `ui.layout_columns()` for creating responsive column-forward layouts based on Bootstrap's 12-column CSS Grid. (#856)
### Bug fixes
@@ -20,10 +21,12 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
### Other changes
+* Closed #492: `shiny.ui.nav()` is now deprecated in favor of the more aptly named `shiny.ui.nav_panel()` (#876).
* Update penguins example to credit Allison Horst and drop usage of `shiny.experimental` (#798).
+* `as_fillable_container()` and `as_fill_item()` no longer mutate the `Tag` object that was passed in. Instead, it returns a new `Tag` object. Also closed #856: these functions now put the `html-fill-container` and `html-fill-item` CSS classes last, instead of first. (#862)
-## [0.6.0] - 2023-08-08
+## [0.6.0] - 2023-10-30
### Breaking Changes
* `shiny.run` only allows positional arguments for `app`, `host`, and `port`, all other arguments must be specified with keywords.
diff --git a/MANIFEST.in b/MANIFEST.in
index b37964d55..cabdd7ce4 100644
--- a/MANIFEST.in
+++ b/MANIFEST.in
@@ -9,3 +9,4 @@ recursive-include docs *.rst conf.py Makefile make.bat *.jpg *.png *.gif
recursive-include shiny/www *
recursive-include shiny/experimental/www *
recursive-include shiny/api-examples *
+recursive-include shiny/templates *
diff --git a/Makefile b/Makefile
index ab53d9ad1..d4fc1bb2c 100644
--- a/Makefile
+++ b/Makefile
@@ -1,4 +1,4 @@
-.PHONY: help clean clean-test clean-pyc clean-build help lint test e2e e2e-examples
+.PHONY: help clean clean-test clean-pyc clean-build help lint test playwright-shiny playwright-examples playwright-deploys install-trcli install-playwright
.DEFAULT_GOAL := help
define BROWSER_PYSCRIPT
@@ -83,31 +83,34 @@ test: ## run tests quickly with the default Python
python3 tests/pytest/asyncio_prevent.py
pytest
-# Default `FILE` to `e2e` if not specified
-FILE:=tests/e2e
+# Default `SUB_FILE` to empty
+SUB_FILE:=
-DEPLOYS_FILE:=tests/deploys
+DEPLOYS_FILE:=tests/playwright/deploys
-playwright-install:
+install-playwright:
playwright install --with-deps
-trcli-install:
+install-trcli:
which trcli || pip install trcli
-e2e: playwright-install ## end-to-end tests with playwright
- pytest $(FILE) -m "not examples and not integrationtest"
+install-rsconnect: ## install the main version of rsconnect till pypi version supports shiny express
+ pip install git+https://github.com/rstudio/rsconnect-python.git#egg=rsconnect-python
-e2e-examples: playwright-install ## end-to-end tests on examples with playwright
- pytest $(FILE) -m "examples"
+playwright-shiny: install-playwright ## end-to-end tests with playwright
+ pytest tests/playwright/shiny/$(SUB_FILE)
-e2e-deploys: playwright-install ## end-to-end tests on deploys with playwright
- pytest $(DEPLOYS_FILE) -s -m "integrationtest"
+playwright-examples: install-playwright ## end-to-end tests on examples with playwright
+ pytest tests/playwright/examples
-e2e-junit: playwright-install trcli-install ## end-to-end tests with playwright and generate junit report
- pytest $(FILE) --junitxml=report.xml
+playwright-deploys: install-playwright install-rsconnect ## end-to-end tests on deploys with playwright
+ pytest tests/playwright/deploys/$(SUB_FILE) -s
+
+testrail-junit: install-playwright install-trcli ## end-to-end tests with playwright and generate junit report
+ pytest tests/playwright/shiny/$(SUB_FILE) --junitxml=report.xml
coverage: ## check combined code coverage (must run e2e last)
- pytest --cov-report term-missing --cov=shiny tests/pytest/ tests/e2e/ -m "not examples and not integrationtest"
+ pytest --cov-report term-missing --cov=shiny tests/pytest/ tests/playwright/shiny/$(SUB_FILE)
coverage html
$(BROWSER) htmlcov/index.html
diff --git a/docs/.gitignore b/docs/.gitignore
index 95eb9c701..a3135790a 100644
--- a/docs/.gitignore
+++ b/docs/.gitignore
@@ -4,3 +4,4 @@ _inv/
_sidebar.yml
/.quarto/
objects.json
+site_libs/
diff --git a/docs/Makefile b/docs/Makefile
index d14e9b8b1..91fabe65c 100644
--- a/docs/Makefile
+++ b/docs/Makefile
@@ -39,11 +39,14 @@ $(PYBIN): $(VENV)
help:
@python -c "$$PRINT_HELP_PYSCRIPT" < $(MAKEFILE_LIST)
+dev-htmltools: $(PYBIN) ## Install development version of htmltools
+ $(PYBIN)/pip install https://github.com/rstudio/py-htmltools/tarball/main
+
deps: $(PYBIN) ## Install build dependencies
$(PYBIN)/pip install pip --upgrade
$(PYBIN)/pip install -e ..[doc]
-quartodoc: ## Build qmd files for API docs
+quartodoc: $(PYBIN) ## Build qmd files for API docs
. $(PYBIN)/activate \
&& quartodoc interlinks \
&& quartodoc build --config _quartodoc.yml --verbose
diff --git a/docs/README.md b/docs/README.md
index 82f211be5..fa9453816 100644
--- a/docs/README.md
+++ b/docs/README.md
@@ -8,6 +8,9 @@ This directory contains files to generate Shiny for Python API documentation, us
To build the docs, first install the Python dependencies and Quarto extensions:
```bash
+# Install development version of htmltools (do this if you are using a development version of shiny)
+make dev-htmltools
+
# Install build dependencies
make deps
```
diff --git a/docs/_quarto.yml b/docs/_quarto.yml
index b4f5d299c..3e1093ae7 100644
--- a/docs/_quarto.yml
+++ b/docs/_quarto.yml
@@ -5,6 +5,7 @@ project:
format:
html:
toc: true
+ css: shiny-docs.css
website:
title: "Shiny for Python (dev version)"
diff --git a/docs/_quartodoc.yml b/docs/_quartodoc.yml
index 503e57d74..9be9d456d 100644
--- a/docs/_quartodoc.yml
+++ b/docs/_quartodoc.yml
@@ -18,15 +18,16 @@ quartodoc:
- express.layout.span
- express.layout.pre
- express.layout.sidebar
+ - express.layout.layout_columns
- express.layout.layout_column_wrap
- express.layout.column
- express.layout.row
- express.layout.card
- express.layout.accordion
- express.layout.accordion_panel
- - express.layout.navset_tab
- - express.layout.navset_card_tab
- - express.layout.nav
+ - express.layout.navset
+ - express.layout.navset_card
+ - express.layout.nav_panel
- express.layout.page_fluid
- express.layout.page_fixed
- express.layout.page_fillable
@@ -46,6 +47,7 @@ quartodoc:
contents:
- ui.sidebar
- ui.layout_sidebar
+ - ui.layout_columns
- ui.layout_column_wrap
- ui.card
- ui.card_header
@@ -87,10 +89,10 @@ quartodoc:
- title: Navigation (tab) panels
desc: Create segments of UI content.
contents:
- - ui.nav
- - ui.nav_control
+ - ui.nav_panel
- ui.nav_spacer
- ui.nav_menu
+ - ui.nav_control
- ui.navset_bar
- ui.navset_tab
- ui.navset_pill
@@ -306,6 +308,7 @@ quartodoc:
contents:
- ui.panel_main
- ui.panel_sidebar
+ - ui.nav
- title: Experimental
desc: "These methods are under consideration and are considered unstable. However, if there is a method you are excited about, please let us know!"
contents:
diff --git a/docs/_renderer.py b/docs/_renderer.py
index ee72ca8af..cab180bdb 100644
--- a/docs/_renderer.py
+++ b/docs/_renderer.py
@@ -13,8 +13,11 @@
from griffe.docstrings import dataclasses as ds
from plum import dispatch
from quartodoc import MdRenderer
+from quartodoc.pandoc.blocks import DefinitionList
from quartodoc.renderers.base import convert_rst_link_to_md, sanitize
+# from quartodoc.ast import preview
+
SHINY_PATH = Path(files("shiny").joinpath())
SHINYLIVE_CODE_TEMPLATE = """
@@ -129,7 +132,7 @@ def render_annotation(self, el: None):
@dispatch
def render_annotation(self, el: exp.Expr):
- # an expression is essentially a list[exp.Name | str]
+ # an expression is essentially a list[exp.ExprName | str]
# e.g. Optional[TagList]
# -> [Name(source="Optional", ...), "[", Name(...), "]"]
@@ -138,12 +141,40 @@ def render_annotation(self, el: exp.Expr):
@dispatch
def render_annotation(self, el: exp.ExprName):
# e.g. Name(source="Optional", full="typing.Optional")
- return f"[{el.path}](`{el.canonical_path}`)"
+ return f"[{el.name}](`{el.canonical_path}`)"
@dispatch
- def summarize(self, el: dc.Object | dc.Alias):
- result = super().summarize(el)
- return html.escape(result)
+ # Overload of `quartodoc.renderers.md_renderer` to fix bug where the descriptions
+ # are cut off and never display other places. Fixing by always displaying the
+ # documentation.
+ def summarize(self, obj: Union[dc.Object, dc.Alias]) -> str:
+ # get high-level description
+ doc = obj.docstring
+ if doc is None:
+ docstring_parts = []
+ else:
+ docstring_parts = doc.parsed
+
+ if len(docstring_parts) and isinstance(
+ docstring_parts[0], ds.DocstringSectionText
+ ):
+ description = docstring_parts[0].value
+
+ # ## Approach: Always return the full description!
+ return description
+
+ # ## Alternative: Add ellipsis if the lines are cut off
+
+ # # If the description is more than one line, only show the first line.
+ # # Add `...` to indicate the description was truncated
+ # parts = description.split("\n")
+ # short = parts[0]
+ # if len(parts) > 1:
+ # short += "…"
+
+ # return short
+
+ return ""
# Consolidate the parameter type info into a single column
@dispatch
@@ -158,15 +189,14 @@ def render(self, el: ds.DocstringParameter):
# Wrap everything in a code block to allow for links
param = "" + param + ""
- clean_desc = sanitize(el.description, allow_markdown=True)
- return (param, clean_desc)
+ return (param, el.description)
@dispatch
def render(self, el: ds.DocstringSectionParameters):
rows = list(map(self.render, el.value))
- header = ["Parameter", "Description"]
+ # rows is a list of tuples of (, )
- return self._render_table(rows, header)
+ return str(DefinitionList(rows))
@dispatch
def signature(self, el: dc.Function, source: Optional[dc.Alias] = None):
diff --git a/docs/shiny-docs.css b/docs/shiny-docs.css
new file mode 100644
index 000000000..f5b1c0ba3
--- /dev/null
+++ b/docs/shiny-docs.css
@@ -0,0 +1,4 @@
+#parameters dd {
+ margin-top: 0.5rem;
+ margin-left: 2rem;
+}
diff --git a/examples/event/app.py b/examples/event/app.py
index 20adf5d25..31ee8eb26 100644
--- a/examples/event/app.py
+++ b/examples/event/app.py
@@ -12,12 +12,12 @@
"""
),
ui.navset_card_tab(
- ui.nav(
+ ui.nav_panel(
"Sync",
ui.input_action_button("btn", "Click me"),
ui.output_ui("btn_value"),
),
- ui.nav(
+ ui.nav_panel(
"Async",
ui.input_action_button("btn_async", "Click me"),
ui.output_ui("btn_async_value"),
diff --git a/examples/express/nav_app.py b/examples/express/nav_app.py
index 07fb07b34..d4f421ce8 100644
--- a/examples/express/nav_app.py
+++ b/examples/express/nav_app.py
@@ -4,12 +4,12 @@
from shiny import render, ui
from shiny.express import input, layout
-with layout.column(width=6):
- with layout.navset_tab():
- with layout.nav(title="One"):
+with layout.layout_column_wrap(width=1 / 2):
+ with layout.navset():
+ with layout.nav_panel(title="One"):
ui.input_slider("n", "N", 1, 100, 50)
- with layout.nav(title="Two"):
+ with layout.nav_panel(title="Two"):
@render.plot
def histogram():
@@ -17,13 +17,11 @@ def histogram():
x = 100 + 15 * np.random.randn(437)
plt.hist(x, input.n(), density=True)
-
-with layout.column(width=6):
- with layout.navset_card_tab():
- with layout.nav(title="One"):
+ with layout.navset_card():
+ with layout.nav_panel(title="One"):
ui.input_slider("n2", "N", 1, 100, 50)
- with layout.nav(title="Two"):
+ with layout.nav_panel(title="Two"):
@render.plot
def histogram2():
diff --git a/examples/inputs-update/app.py b/examples/inputs-update/app.py
index 133bdbfa9..be210a807 100644
--- a/examples/inputs-update/app.py
+++ b/examples/inputs-update/app.py
@@ -78,8 +78,8 @@
),
),
ui.navset_tab(
- ui.nav("panel1", ui.h2("This is the first panel.")),
- ui.nav("panel2", ui.h2("This is the second panel.")),
+ ui.nav_panel("panel1", ui.h2("This is the first panel.")),
+ ui.nav_panel("panel2", ui.h2("This is the second panel.")),
id="inTabset",
),
),
diff --git a/examples/static_plots/app.py b/examples/static_plots/app.py
index 043126331..cc99f20c0 100644
--- a/examples/static_plots/app.py
+++ b/examples/static_plots/app.py
@@ -8,7 +8,7 @@
nav = ui.navset_pill_list(
ui.nav_control(ui.p("Choose a package", class_="lead text-center")),
- ui.nav(
+ ui.nav_panel(
"Plotnine",
ui.output_plot("plotnine"),
ui.div(
@@ -27,7 +27,7 @@
),
),
),
- ui.nav(
+ ui.nav_panel(
"Seaborn",
ui.output_plot("seaborn"),
ui.div(
@@ -36,11 +36,11 @@
ui.input_slider("cov", "Co-variance", min=0, max=1, value=0.4),
),
),
- ui.nav("Pandas", ui.output_plot("pandas")),
- ui.nav("Holoviews", ui.output_plot("holoviews", height="600px")),
- ui.nav("xarray", ui.output_plot("xarray")),
- ui.nav("geopandas", ui.output_plot("geopandas")),
- ui.nav("missingno", ui.output_plot("missingno")),
+ ui.nav_panel("Pandas", ui.output_plot("pandas")),
+ ui.nav_panel("Holoviews", ui.output_plot("holoviews", height="600px")),
+ ui.nav_panel("xarray", ui.output_plot("xarray")),
+ ui.nav_panel("geopandas", ui.output_plot("geopandas")),
+ ui.nav_panel("missingno", ui.output_plot("missingno")),
widths=(2, 10),
well=False,
)
diff --git a/pyrightconfig.json b/pyrightconfig.json
index e10033fb7..284b67df5 100644
--- a/pyrightconfig.json
+++ b/pyrightconfig.json
@@ -6,8 +6,9 @@
"dist",
"typings",
"sandbox",
+ "_dev",
"docs",
- "tests/deploys/apps",
+ "tests/playwright/deploys/apps",
"shiny/templates"
],
"typeCheckingMode": "strict",
diff --git a/scripts/htmlDependencies.R b/scripts/htmlDependencies.R
index 24f23fcbc..20cca4307 100755
--- a/scripts/htmlDependencies.R
+++ b/scripts/htmlDependencies.R
@@ -11,7 +11,7 @@ versions <- list()
message("Installing GitHub packages: bslib, shiny, htmltools")
withr::local_temp_libpaths()
ignore <- capture.output({
- pak::pkg_install(c("cran::bslib", "cran::shiny", "cran::htmltools"))
+ pak::pkg_install(c("rstudio/bslib", "cran::shiny", "cran::htmltools"))
#pak::pkg_install(c("rstudio/bslib@main", "rstudio/shiny@main", "rstudio/htmltools@main"))
})
diff --git a/setup.cfg b/setup.cfg
index 44b7b81e0..6322b6094 100644
--- a/setup.cfg
+++ b/setup.cfg
@@ -37,7 +37,7 @@ install_requires =
starlette>=0.17.1
websockets>=10.0
python-multipart
- htmltools>=0.4.1.9001
+ htmltools @ git+https://github.com/posit-dev/py-htmltools.git
click>=8.1.4
markdown-it-py>=1.1.0
# This is needed for markdown-it-py. Without it, when loading shiny/ui/_markdown.py,
@@ -103,8 +103,8 @@ doc =
tabulate
shinylive==0.1.1
pydantic==1.10
- quartodoc==0.7.1
- griffe
+ quartodoc==0.7.2
+ griffe==0.33.0
[options.packages.find]
include = shiny, shiny.*
@@ -124,7 +124,7 @@ console_scripts =
# W503: Line break occurred before a binary operator
# E203: whitespace before ':' (see https://black.readthedocs.io/en/stable/guides/using_black_with_other_tools.html#flake8)
ignore = E302, E501, F403, F405, W503, E203
-extend_exclude = docs, .venv, venv, typings, e2e, build
+extend_exclude = docs, .venv, venv, typings, build, _dev
[isort]
profile=black
diff --git a/shiny/_app.py b/shiny/_app.py
index f8b01d139..664a2238a 100644
--- a/shiny/_app.py
+++ b/shiny/_app.py
@@ -46,12 +46,12 @@ class App:
----------
ui
The UI definition for the app (e.g., a call to :func:`~shiny.ui.page_fluid` or
- :func:`~shiny.ui.page_fixed`, with layouts and controls nested inside). You can
+ similar, with layouts and controls nested inside). You can
also pass a function that takes a :class:`~starlette.requests.Request` and
returns a UI definition, if you need the UI definition to be created dynamically
for each pageview.
server
- A function which is called once for each session, ensuring that each app is
+ A function which is called once for each session, ensuring that each session is
independent.
static_assets
Static files to be served by the app. If this is a string or Path object, it
@@ -225,7 +225,7 @@ def run(self, **kwargs: object) -> None:
Parameters
----------
- kwargs
+ **kwargs
Keyword arguments passed to :func:`~shiny.run_app`.
"""
from ._main import run_app
diff --git a/shiny/_main.py b/shiny/_main.py
index 57fc2d2dc..9a9dc659d 100644
--- a/shiny/_main.py
+++ b/shiny/_main.py
@@ -197,7 +197,7 @@ def run_app(
**kwargs: object,
) -> None:
"""
- Starts a Shiny app. Press ``Ctrl+C`` (or ``Ctrl+Break`` on Windows) to stop.
+ Starts a Shiny app. Press ``Ctrl+C`` (or ``Ctrl+Break`` on Windows) to stop the app.
Parameters
----------
@@ -207,8 +207,8 @@ def run_app(
directory. In other cases, the app location can be specified as a
``:`` string where the ``:`` is only necessary if
the application is named something other than ``app``. Note that ````
- can be relative path to a ``.py`` file or a directory (with an ``app.py`` file
- inside it); and in this case, the relative path is resolved relative to the
+ can be a relative path to a ``.py`` file or a directory (with an ``app.py`` file
+ inside of it); and in this case, the relative path is resolved relative to the
``app_dir`` directory.
host
The address that the app should listen on.
@@ -220,8 +220,8 @@ def run_app(
reload
Enable auto-reload.
reload_dirs
- List of directories (in addition to the app directory) to watch for changes that
- will trigger app reloading.
+ A list of directories (in addition to the app directory) to watch for changes that
+ will trigger an app reload.
reload_includes
List or tuple of file globs to indicate which files should be monitored for
changes. Can be combined with `reload_excludes`.
@@ -233,7 +233,7 @@ def run_app(
log_level
Log level.
app_dir
- Look for ``app`` under this directory (by adding this to the ``PYTHONPATH``).
+ The directory to look for ``app`` under (by adding this to the ``PYTHONPATH``).
factory
Treat ``app`` as an application factory, i.e. a () -> callable.
launch_browser
@@ -245,7 +245,7 @@ def run_app(
Tip
---
The ``shiny run`` command-line interface (which comes installed with Shiny) provides
- the same functionality as this function.
+ the same functionality as :func:`~shiny.run_app`.
Examples
--------
@@ -499,10 +499,32 @@ def try_import_module(module: str) -> Optional[types.ModuleType]:
),
help="Choose a template for your new application.",
)
-def create(template: Optional[str] = None) -> None:
- from ._template_utils import template_query
+@click.option(
+ "--mode",
+ "-m",
+ type=click.Choice(
+ ["core", "express"],
+ case_sensitive=False,
+ ),
+ help="Do you want to use a Shiny Express template or a Shiny Core template?",
+)
+@click.option(
+ "--github",
+ "-g",
+ help="The GitHub URL of the template sub-directory. For example https://github.com/posit-dev/py-shiny-templates/tree/main/dashboard",
+)
+def create(
+ template: Optional[str] = None,
+ mode: Optional[str] = None,
+ github: Optional[str] = None,
+) -> None:
+ from ._template_utils import template_query, use_git_template
+
+ if github is not None:
+ use_git_template(github, mode)
+ return
- template_query(template)
+ template_query(template, mode)
@main.command(
diff --git a/shiny/_template_utils.py b/shiny/_template_utils.py
index 8f908afb5..dd9d54072 100644
--- a/shiny/_template_utils.py
+++ b/shiny/_template_utils.py
@@ -1,10 +1,14 @@
import os
import shutil
import sys
+import tempfile
+import zipfile
from pathlib import Path
from typing import Dict, List, Optional
+from urllib.parse import urlparse
import questionary
+import requests
from questionary import Choice
from ._custom_component_template_questions import (
@@ -33,7 +37,7 @@ def choice_from_dict(choice_dict: Dict[str, str]) -> List[Choice]:
return [Choice(title=key, value=value) for key, value in choice_dict.items()]
-def template_query(question_state: Optional[str] = None):
+def template_query(question_state: Optional[str] = None, mode: Optional[str] = None):
"""
This will initiate a CLI query which will ask the user which template they would like.
If called without arguments this function will start from the top level and ask which
@@ -67,20 +71,99 @@ def template_query(question_state: Optional[str] = None):
elif template in package_template_choices.values():
js_component_questions(template)
else:
- app_template_questions(template)
+ app_template_questions(template, mode)
-def app_template_questions(template: str):
+def download_and_extract_zip(url: str, temp_dir: Path):
+ response = requests.get(url)
+ response.raise_for_status()
+ zip_file_path = temp_dir / "repo.zip"
+ zip_file_path.write_bytes(response.content)
+ with zipfile.ZipFile(zip_file_path, "r") as zip_file:
+ zip_file.extractall(temp_dir)
+
+
+def use_git_template(url: str, mode: Optional[str] = None):
+ # Github requires that we download the whole repository, so we need to
+ # download and unzip the repo, then navigate to the subdirectory.
+
+ parsed_url = urlparse(url)
+ path_parts = parsed_url.path.strip("/").split("/")
+ repo_owner, repo_name, _, branch_name = path_parts[:4]
+ subdirectory = "/".join(path_parts[4:])
+
+ zip_url = f"https://github.com/{repo_owner}/{repo_name}/archive/refs/heads/{branch_name}.zip"
+
+ with tempfile.TemporaryDirectory() as temp_dir:
+ temp_dir = Path(temp_dir)
+ download_and_extract_zip(zip_url, temp_dir)
+
+ template_dir = os.path.join(
+ temp_dir, f"{repo_name}-{branch_name}", subdirectory
+ )
+
+ if not os.path.exists(template_dir):
+ raise Exception(f"Template directory '{template_dir}' does not exist")
+
+ directory = repo_name + "-" + branch_name
+ path = temp_dir / directory / subdirectory
+ return app_template_questions(mode=mode, template_dir=path)
+
+
+def app_template_questions(
+ template: Optional[str] = None,
+ mode: Optional[str] = None,
+ template_dir: Optional[Path] = None,
+):
+ if template_dir is None:
+ if template is None:
+ raise ValueError("You must provide either template or template_dir")
+ template_dir = Path(__file__).parent / "templates/app-templates" / template
+
+ # Not all apps will be implemented in both express and core so we can
+ # avoid the questions if it's a core only app.
+ template_files = [file.name for file in template_dir.iterdir() if file.is_file()]
+ express_available = "app-express.py" in template_files
+
+ if mode == "express" and not express_available:
+ raise Exception("Express mode not available for that template.")
+
+ if mode is None and express_available:
+ mode = questionary.select(
+ "Would you like to use Shiny Express?",
+ [
+ Choice("Yes", "express"),
+ Choice("No", "core"),
+ back_choice,
+ cancel_choice,
+ ],
+ ).ask()
+
+ if mode is None or mode == "cancel":
+ sys.exit(1)
+ if mode == "back":
+ template_query()
+ return
+
appdir = questionary.path(
"Enter destination directory:",
- default=build_path_string(),
+ default=build_path_string(""),
only_directories=True,
).ask()
if appdir is None:
sys.exit(1)
- app_dir = copy_template_files(appdir, template, template_subdir="app-templates")
+ if appdir == ".":
+ appdir = build_path_string(template_dir.name)
+
+ app_dir = copy_template_files(
+ Path(appdir),
+ template_dir=template_dir,
+ express_available=express_available,
+ mode=mode,
+ )
+
print(f"Created Shiny app at {app_dir}")
print(f"Next steps open and edit the app file: {app_dir}/app.py")
@@ -129,8 +212,16 @@ def js_component_questions(component_type: Optional[str] = None):
if appdir is None:
sys.exit(1)
+ if appdir == ".":
+ appdir = build_path_string(component_type)
+
app_dir = copy_template_files(
- appdir, component_type, template_subdir="package-templates"
+ Path(appdir),
+ template_dir=Path(__file__).parent
+ / "templates/package-templates"
+ / component_type,
+ express_available=False,
+ mode=None,
)
# Print messsage saying we're building the component
@@ -152,12 +243,12 @@ def build_path_string(*path: str):
return os.path.join(".", *path)
-def copy_template_files(dest: str, template: str, template_subdir: str):
- if dest == ".":
- dest = build_path_string(template)
-
- app_dir = Path(dest)
- template_dir = Path(__file__).parent / "templates" / template_subdir / template
+def copy_template_files(
+ app_dir: Path,
+ template_dir: Path,
+ express_available: bool,
+ mode: Optional[str] = None,
+):
duplicate_files = [
file.name for file in template_dir.iterdir() if (app_dir / file.name).exists()
]
@@ -178,4 +269,16 @@ def copy_template_files(dest: str, template: str, template_subdir: str):
else:
shutil.copytree(item, app_dir / item.name)
+ def rename_unlink(file_to_rename: str, file_to_delete: str, dir: Path = app_dir):
+ (dir / file_to_rename).rename(dir / "app.py")
+ (dir / file_to_delete).unlink()
+
+ if express_available:
+ if mode == "express":
+ rename_unlink("app-express.py", "app-core.py")
+ if mode == "core":
+ rename_unlink("app-core.py", "app-express.py")
+ if (app_dir / "app-core.py").exists():
+ (app_dir / "app-core.py").rename(app_dir / "app.py")
+
return app_dir
diff --git a/shiny/_validation.py b/shiny/_validation.py
index 91d23f754..4f451831b 100644
--- a/shiny/_validation.py
+++ b/shiny/_validation.py
@@ -26,9 +26,16 @@ def req(*args: T, cancel_output: bool = False) -> T | None:
This is a convenient shorthand for throwing :func:`~shiny.types.SilentException` /
:func:`~shiny.types.SilentCancelOutputException` if any of the arguments are falsy.
+ The term "falsy" generally indicates that a value is considered `False` when
+ encountered in a logical context. We use the term a little loosely here; our usage
+ tries to match the intuitive notions of "Is this value missing or available?", or
+ "Has the user provided an answer?", or in the case of action buttons, "Has the
+ button been clicked?". So `False`, `None`, `0`, and `""` would be examples of Falsy
+ values.
+
Parameters
----------
- args
+ *args
Any number of arguments to check.
cancel_output
If ``True``, throw :func:`~shiny.types.SilentCancelOutputException` instead of
diff --git a/shiny/_versions.py b/shiny/_versions.py
index 5e1b69999..7a4a1832a 100644
--- a/shiny/_versions.py
+++ b/shiny/_versions.py
@@ -1,5 +1,5 @@
shiny_html_deps = "1.8.0"
-bslib = "0.6.1"
+bslib = "0.6.1.9000"
htmltools = "0.5.7"
bootstrap = "5.3.1"
requirejs = "2.3.6"
diff --git a/shiny/api-examples/as_fill_item/app.py b/shiny/api-examples/as_fill_item/app.py
index 70dfb98d1..20d0e748c 100644
--- a/shiny/api-examples/as_fill_item/app.py
+++ b/shiny/api-examples/as_fill_item/app.py
@@ -6,7 +6,7 @@
from shiny.ui import fill
-def outer_inner() -> tuple[htmltools.Tag, htmltools.Tag]:
+def outer_inner() -> htmltools.Tag:
inner = ui.div(
id="inner",
style=htmltools.css(
@@ -22,17 +22,17 @@ def outer_inner() -> tuple[htmltools.Tag, htmltools.Tag]:
border="3px red solid",
),
)
- return outer, inner
+ return outer
-outer0, inner0 = outer_inner()
+outer0 = outer_inner()
-outer1, inner1 = outer_inner()
-fill.as_fill_item(inner1)
+outer1 = outer_inner()
+outer1.children[0] = fill.as_fill_item(outer1.children[0])
-outer2, inner2 = outer_inner()
-fill.as_fillable_container(outer2)
-fill.as_fill_item(inner2)
+outer2 = outer_inner()
+outer2 = fill.as_fillable_container(outer2)
+outer2.children[0] = fill.as_fill_item(outer2.children[0])
app_ui = ui.page_fluid(
diff --git a/shiny/api-examples/as_fillable_container/app.py b/shiny/api-examples/as_fillable_container/app.py
index 47fd96208..a327f4d18 100644
--- a/shiny/api-examples/as_fillable_container/app.py
+++ b/shiny/api-examples/as_fillable_container/app.py
@@ -6,7 +6,7 @@
from shiny.ui import fill
-def outer_inner() -> tuple[htmltools.Tag, htmltools.Tag]:
+def outer_inner() -> htmltools.Tag:
inner = ui.div(
id="inner",
style=htmltools.css(
@@ -22,23 +22,22 @@ def outer_inner() -> tuple[htmltools.Tag, htmltools.Tag]:
border="3px red solid",
),
)
- return outer, inner
+ return outer
-outer0, inner0 = outer_inner()
-outer1, inner1 = outer_inner()
-outer2, inner2 = outer_inner()
+outer0 = outer_inner()
-fill.as_fillable_container(outer2)
-
-fill.as_fillable_container(outer2)
-fill.as_fill_item(inner2)
+outer1 = outer_inner()
+outer1 = fill.as_fillable_container(outer1)
+outer2 = outer_inner()
+outer2 = fill.as_fillable_container(outer2)
+outer2.children[0] = fill.as_fill_item(outer2.children[0])
app_ui = ui.page_fluid(
ui.markdown(
"""\
- # `as_fill_container()`
+ # `as_fillable_container()`
For an item to fill its parent element,
* the item must have `as_fill_item()` be called on it
@@ -49,7 +48,7 @@ def outer_inner() -> tuple[htmltools.Tag, htmltools.Tag]:
),
ui.row(
ui.column(4, ui.h5("Default behavior")),
- ui.column(4, ui.h5(ui.markdown("`as_fill_container(red)`"))),
+ ui.column(4, ui.h5(ui.markdown("`as_fillable_container(red)`"))),
ui.column(
4,
ui.h5(ui.markdown("`as_fill_item(blue)` + `as_fillable_container(red)`")),
diff --git a/shiny/api-examples/layout_column_wrap/app.py b/shiny/api-examples/layout_column_wrap/app.py
index 7dbeb11a9..9e12df756 100644
--- a/shiny/api-examples/layout_column_wrap/app.py
+++ b/shiny/api-examples/layout_column_wrap/app.py
@@ -7,7 +7,7 @@
ui.layout_column_wrap(y, y, y, width=1 / 2),
ui.hr(),
# Has three columns when viewport is wider than 750px
- ui.layout_column_wrap(y, y, y, width="250%"),
+ ui.layout_column_wrap(y, y, y, width="250px"),
)
diff --git a/shiny/api-examples/layout_columns/app.py b/shiny/api-examples/layout_columns/app.py
new file mode 100644
index 000000000..4691f902c
--- /dev/null
+++ b/shiny/api-examples/layout_columns/app.py
@@ -0,0 +1,33 @@
+from model_plots import * # model plots and cards
+
+from shiny import App, Inputs, Outputs, Session, render, ui
+
+app_ui = ui.page_fluid(
+ ui.panel_title(ui.h2("Model Dashboard")),
+ ui.markdown("Using `ui.layout_columns()` for the layout."),
+ ui.layout_columns(
+ card_loss,
+ card_acc,
+ card_feat,
+ col_widths={"sm": (5, 7, 12)},
+ # row_heights=(2, 3),
+ # height="700px",
+ ),
+)
+
+
+def server(input: Inputs, output: Outputs, session: Session):
+ @render.plot
+ def loss_over_time():
+ return plot_loss_over_time()
+
+ @render.plot
+ def accuracy_over_time():
+ return plot_accuracy_over_time()
+
+ @render.plot
+ def feature_importance():
+ return plot_feature_importance()
+
+
+app = App(app_ui, server)
diff --git a/shiny/api-examples/layout_columns/model_plots.py b/shiny/api-examples/layout_columns/model_plots.py
new file mode 100644
index 000000000..951204df9
--- /dev/null
+++ b/shiny/api-examples/layout_columns/model_plots.py
@@ -0,0 +1,56 @@
+import matplotlib.pyplot as plt
+import numpy as np
+
+from shiny import ui
+
+
+def plot_loss_over_time():
+ epochs = np.arange(1, 101)
+ loss = 1000 / np.sqrt(epochs) + np.random.rand(100) * 25
+
+ fig = plt.figure(figsize=(10, 6))
+ plt.plot(epochs, loss)
+ plt.xlabel("Epochs")
+ plt.ylabel("Loss")
+ return fig
+
+
+def plot_accuracy_over_time():
+ epochs = np.arange(1, 101)
+ accuracy = np.sqrt(epochs) / 12 + np.random.rand(100) * 0.15
+ accuracy = [np.min([np.max(accuracy[:i]), 1]) for i in range(1, 101)]
+
+ fig = plt.figure(figsize=(10, 6))
+ plt.plot(epochs, accuracy)
+ plt.xlabel("Epochs")
+ plt.ylabel("Accuracy")
+ return fig
+
+
+def plot_feature_importance():
+ features = ["Product Category", "Price", "Brand", "Rating", "Number of Reviews"]
+ importance = np.random.rand(5)
+
+ fig = plt.figure(figsize=(10, 6))
+ plt.barh(features, importance)
+ plt.xlabel("Importance")
+ return fig
+
+
+card_loss = ui.card(
+ ui.card_header("Loss Over Time"),
+ ui.output_plot("loss_over_time"),
+ full_screen=True,
+)
+
+card_acc = ui.card(
+ ui.card_header("Accuracy Over Time"),
+ ui.output_plot("accuracy_over_time"),
+ full_screen=True,
+)
+
+card_feat = ui.card(
+ ui.card_header("Feature Importance"),
+ ui.output_plot("feature_importance"),
+ full_screen=True,
+)
diff --git a/shiny/api-examples/nav/app.py b/shiny/api-examples/nav/app.py
index 48ed374fd..269c6a18e 100644
--- a/shiny/api-examples/nav/app.py
+++ b/shiny/api-examples/nav/app.py
@@ -6,9 +6,9 @@
def nav_controls(prefix: str) -> List[NavSetArg]:
return [
- ui.nav("a", prefix + ": tab a content"),
- ui.nav("b", prefix + ": tab b content"),
- ui.nav("c", prefix + ": tab c content"),
+ ui.nav_panel("a", prefix + ": tab a content"),
+ ui.nav_panel("b", prefix + ": tab b content"),
+ ui.nav_panel("c", prefix + ": tab c content"),
ui.nav_spacer(),
ui.nav_menu(
"Links",
diff --git a/shiny/api-examples/navset_hidden/app.py b/shiny/api-examples/navset_hidden/app.py
index 09ff8d859..014869a97 100644
--- a/shiny/api-examples/navset_hidden/app.py
+++ b/shiny/api-examples/navset_hidden/app.py
@@ -9,9 +9,9 @@
),
ui.panel_main(
ui.navset_hidden(
- ui.nav(None, "Panel 1 content", value="panel1"),
- ui.nav(None, "Panel 2 content", value="panel2"),
- ui.nav(None, "Panel 3 content", value="panel3"),
+ ui.nav_panel(None, "Panel 1 content", value="panel1"),
+ ui.nav_panel(None, "Panel 2 content", value="panel2"),
+ ui.nav_panel(None, "Panel 3 content", value="panel3"),
id="hidden_tabs",
),
),
diff --git a/shiny/api-examples/update_navs/app.py b/shiny/api-examples/update_navs/app.py
index e319eba51..6a8e392a9 100644
--- a/shiny/api-examples/update_navs/app.py
+++ b/shiny/api-examples/update_navs/app.py
@@ -7,9 +7,9 @@
),
ui.panel_main(
ui.navset_card_tab(
- ui.nav("Panel 1", "Panel 1 content", value="panel1"),
- ui.nav("Panel 2", "Panel 2 content", value="panel2"),
- ui.nav("Panel 3", "Panel 3 content", value="panel3"),
+ ui.nav_panel("Panel 1", "Panel 1 content", value="panel1"),
+ ui.nav_panel("Panel 2", "Panel 2 content", value="panel2"),
+ ui.nav_panel("Panel 3", "Panel 3 content", value="panel3"),
id="inTabset",
),
),
diff --git a/shiny/experimental/ui/_card.py b/shiny/experimental/ui/_card.py
index 6acd6b641..34d518a72 100644
--- a/shiny/experimental/ui/_card.py
+++ b/shiny/experimental/ui/_card.py
@@ -48,30 +48,30 @@ def card(
"""
A Bootstrap card component
- A general purpose container for grouping related UI elements together with a border
- and optional padding. To learn more about `card()`s, see [this
+ A card is a general purpose container that groups related UI elements together with a border
+ and optional padding. To learn more about `card()`s, see [the bslib card
article](https://rstudio.github.io/bslib/articles/cards.html).
Parameters
----------
*args
- Unnamed arguments can be any valid child of an :class:`~htmltools.Tag` (which
- includes card items such as :func:`~shiny.experimental.ui.card_body`.
+ Unnamed arguments can be any valid child of an :class:`~htmltools.Tag` (This
+ includes card items such as :func:`~shiny.experimental.ui.card_body`).
full_screen
- If `True`, an icon will appear when hovering over the card body. Clicking the
+ If `True`, an icon will appear when the user's pointer hovers over the card body. Clicking the
icon expands the card to fit viewport size.
- height,max_height,min_height
- Any valid CSS unit (e.g., `height="200px"`). Doesn't apply when a card is made
- `full_screen` (in this case, consider setting a `height` in
- :func:`~shiny.experimental.ui.card_body`).
+ height, max_height, min_height
+ Any valid CSS unit (e.g., `height="200px"`). These will not apply when a card is made
+ `full_screen`. In this case, consider setting a `height` in
+ :func:`~shiny.experimental.ui.card_body`.
fill
Whether or not to allow the card to grow/shrink to fit a fillable container with
an opinionated height (e.g., :func:`~shiny.ui.page_fillable`).
class_
Additional CSS classes for the returned Tag.
wrapper
- A function (which returns a UI element) to call on unnamed arguments in `*args`
- which are not already card item(s) (like
+ A function that returns a UI element to call on any unnamed arguments in `*args`
+ that are not already card item(s) (like
:func:`~shiny.ui.card_header`,
:func:`~shiny.experimental.ui.card_body`, etc.). Note that non-card items are
grouped together into one `wrapper` call (e.g. given `card("a", "b",
@@ -83,17 +83,17 @@ def card(
Returns
-------
:
- An :func:`~shiny.ui.tags.div` tag.
+ A :func:`~shiny.ui.tags.div` tag.
See Also
--------
* :func:`~shiny.ui.layout_column_wrap` for laying out multiple cards
- (or multiple columns inside a card).
- * :func:`~shiny.ui.card_header` for creating a header within the card.
- * :func:`~shiny.experimental.ui.card_title` for creating a title within the card body.
- * :func:`~shiny.experimental.ui.card_body` for putting content inside the card.
- * :func:`~shiny.ui.card_footer` for creating a footer within the card.
- * :func:`~shiny.experimental.ui.card_image` for adding an image to the card.
+ or multiple columns inside a card.
+ * :func:`~shiny.ui.card_header` for creating a header within a card.
+ * :func:`~shiny.experimental.ui.card_title` for creating a title within a card body.
+ * :func:`~shiny.experimental.ui.card_body` for putting content inside a card.
+ * :func:`~shiny.ui.card_footer` for creating a footer within a card.
+ * :func:`~shiny.experimental.ui.card_image` for adding an image to a card.
"""
return _card_impl(
*args,
@@ -118,33 +118,35 @@ def card_title(
**kwargs: TagAttrValue,
) -> Tagifiable:
"""
- Card title container
+ A card title container
- A general container for the "title" of a :func:`~shiny.ui.card`. This component is designed
+ :func:`~shiny.experimental.ui.card_title` creates a general container for the "title" of
+ a :func:`~shiny.ui.card`. This component is designed
to be provided as a direct child to :func:`~shiny.ui.card`.
Parameters
----------
*args
- Contents to the card's title. Or tag attributes that are supplied to the
+ Contents to appear in the card's title, or tag attributes to pass to the
resolved :class:`~htmltools.Tag` object.
container
- Method for the returned Tag object. Defaults to :func:`shiny.ui.tags.h5`.
+ Method for the returned :class:`~htmltools.Tag` object. Defaults to
+ :func:`~shiny.ui.tags`.h5.
**kwargs
- Additional HTML attributes for the returned Tag.
+ Additional HTML attributes for the returned :class:`~htmltools.Tag` object.
Returns
-------
:
- A Tag object.
+ An :class:`~htmltools.Tag` object.
See Also
--------
* :func:`~shiny.ui.card` for creating a card component.
- * :func:`~shiny.ui.card_header` for creating a header within the card.
- * :func:`~shiny.experimental.ui.card_body` for putting content inside the card.
- * :func:`~shiny.ui.card_footer` for creating a footer within the card.
- * :func:`~shiny.experimental.ui.card_image` for adding an image to the card.
+ * :func:`~shiny.ui.card_header` for creating a header within a card.
+ * :func:`~shiny.experimental.ui.card_body` for putting content inside a card.
+ * :func:`~shiny.ui.card_footer` for creating a footer within a card.
+ * :func:`~shiny.experimental.ui.card_image` for adding an image to a card.
"""
return container(*args, **kwargs)
@@ -188,21 +190,22 @@ def card_image(
**kwargs: TagAttrValue,
) -> Tagifiable:
"""
- Card image container
+ A card image container
- A general container for an image within a :func:`~shiny.ui.card`. This component is designed to be
+ :func:`~shiny.experimental.ui.card_image` creates a general container for an image within a
+ :func:`~shiny.ui.card`. This component is designed to be
provided as a direct child to :func:`~shiny.ui.card`.
Parameters
----------
file
- A file path pointing an image. The image will be base64 encoded and provided to
- the `src` attribute of the ``. Alternatively, you may set this value to
+ A file path pointing to an image. The image will be base64 encoded and provided to
+ the `src` attribute of the `` tag. Alternatively, you may set this value to
`None` and provide the `src` yourself via `*args:TagAttrs` or
- `**kwargs:TagAttrValue` (e.g. `{"src": "HOSTED_PATH_TO_IMAGE"}` or
+ `**kwargs:TagAttrValue` (e.g., `{"src": "HOSTED_PATH_TO_IMAGE"}` or
`src="HOSTED_PATH_TO_IMAGE"`).
*args
- Dictionary of tag attributes that are supplied to the resolved
+ A dictionary of tag attributes that are supplied to the resolved
:class:`~htmltools.Tag` object.
href
An optional URL to link to.
@@ -211,23 +214,24 @@ def card_image(
mime_type
The mime type of the `file`.
class_
- Additional CSS classes for the resolved Tag.
+ Additional CSS classes for the resolved :class:`~htmltools.Tag` object.
height
- Any valid CSS unit (e.g., `height="200px"`). Doesn't apply when a card is made
- `full_screen` (in this case, consider setting a `height` in
- :func:`~shiny.experimental.ui.card_body`).
+ Any valid CSS unit (e.g., `height="200px"`). `height` will not apply when a card is made
+ `full_screen`. In this case, consider setting a `height` in
+ :func:`~shiny.experimental.ui.card_body`.
fill
Whether to allow this element to grow/shrink to fit its `card` container.
width
Any valid CSS unit (e.g., `width="100%"`).
container
- Method to wrap the returned Tag object. Defaults to :func:`~shiny.experimental.ui.card_body`.
+ Method to wrap the returned :class:`~htmltools.Tag` object. Defaults to
+ :func:`~shiny.experimental.ui.card_body`.
If :func:`~shiny.experimental.ui.card_body` is used, each image will be in separate cards. If
the `container` method does not return a :class:`~shiny.ui.CardItem`, it
allows for consecutive non-`CardItem` objects to be bundled into a single
:func:`~shiny.experimental.ui.card_body` within :func:`~shiny.ui.card`.
**kwargs
- Additional HTML attributes for the resolved Tag.
+ Additional HTML attributes for the resolved :class:`~htmltools.Tag`.
"""
src = None
if file is not None:
diff --git a/shiny/experimental/ui/_deprecated.py b/shiny/experimental/ui/_deprecated.py
index 9fb3f1601..6d324bb0e 100644
--- a/shiny/experimental/ui/_deprecated.py
+++ b/shiny/experimental/ui/_deprecated.py
@@ -212,7 +212,7 @@ def input_text_area(
autocomplete: Optional[str] = None,
spellcheck: Optional[Literal["true", "false"]] = None,
) -> Tag:
- """Deprecated. Please use `shiny.ui.input_text_area()` instead."""
+ """Deprecated. Please use :func:`~shiny.ui.input_text_area()` instead."""
warn_deprecated(
"`shiny.experimental.ui.input_text_area()` is deprecated. "
"This method will be removed in a future version, "
@@ -249,7 +249,7 @@ def navset_pill_card(
footer: TagChild = None,
placement: Literal["above", "below"] = "above",
) -> MainNavSetCard:
- """Deprecated. Please use `navset_card_pill()` instead of `navset_pill_card()`."""
+ """Deprecated. Please use :func:`~navset_card_pill()` instead of `navset_pill_card()`."""
warn_deprecated(
"`shiny.experimental.ui.navset_pill_card()` is deprecated. "
"This method will be removed in a future version, "
@@ -275,7 +275,7 @@ def navset_tab_card(
header: TagChild = None,
footer: TagChild = None,
) -> MainNavSetCard:
- """Deprecated. Please use `navset_card_tab()` instead of `navset_tab_card()`."""
+ """Deprecated. Please use :func:`~navset_card_tab()` instead of `navset_tab_card()`."""
warn_deprecated(
"`shiny.experimental.ui.navset_tab_card()` is deprecated. "
"This method will be removed in a future version, "
@@ -304,7 +304,7 @@ def tooltip(
options: Optional[dict[str, object]] = None,
**kwargs: TagAttrValue,
) -> Tag:
- """Deprecated. Please use `shiny.ui.tooltip()` instead."""
+ """Deprecated. Please use :func:`~shiny.ui.tooltip()` instead."""
warn_deprecated(
"`shiny.experimental.ui.tooltip()` is deprecated. "
"This method will be removed in a future version, "
@@ -322,7 +322,7 @@ def tooltip(
# Deprecated 2023-08-23
def tooltip_update(id: str, *args: TagChild, session: Optional[Session] = None) -> None:
- """Deprecated. Please use `shiny.ui.update_tooltip()` instead."""
+ """Deprecated. Please use :func:`~shiny.ui.update_tooltip()` instead."""
warn_deprecated(
"`shiny.experimental.ui.tooltip_update()` is deprecated. "
"This method will be removed in a future version, "
@@ -337,7 +337,7 @@ def tooltip_update(id: str, *args: TagChild, session: Optional[Session] = None)
# Deprecated 2023-09-12
def update_tooltip(id: str, *args: TagChild, session: Optional[Session] = None) -> None:
- """Deprecated. Please use `shiny.ui.update_tooltip()` instead."""
+ """Deprecated. Please use :func:`~shiny.ui.update_tooltip()` instead."""
warn_deprecated(
"`shiny.experimental.ui.update_tooltip()` is deprecated. "
"This method will be removed in a future version, "
@@ -356,7 +356,7 @@ def tooltip_toggle(
show: Optional[bool] = None,
session: Optional[Session] = None,
) -> None:
- """Deprecated. Please use `shiny.ui.update_tooltip()`."""
+ """Deprecated. Please use :func:`~shiny.ui.update_tooltip()`."""
warn_deprecated(
"`shiny.experimental.ui.tooltip_toggle()` is deprecated. "
"This method will be removed in a future version, "
@@ -375,7 +375,7 @@ def toggle_tooltip(
show: Optional[bool] = None,
session: Optional[Session] = None,
) -> None:
- """Deprecated. Please use `shiny.ui.update_tooltip()` instead."""
+ """Deprecated. Please use :func:`~shiny.ui.update_tooltip()` instead."""
warn_deprecated(
"`shiny.experimental.ui.tooltip_toggle()` is deprecated. "
"This method will be removed in a future version, "
@@ -438,7 +438,7 @@ def sidebar(
gap: Optional[CssUnit] = None,
padding: Optional[CssUnit | list[CssUnit]] = None,
) -> MainSidebar:
- """Deprecated. Please use `shiny.ui.sidebar()` instead."""
+ """Deprecated. Please use :func:`~shiny.ui.sidebar()` instead."""
warn_deprecated(
"`shiny.experimental.ui.sidebar()` is deprecated. "
"This method will be removed in a future version, "
@@ -475,7 +475,7 @@ def layout_sidebar(
height: Optional[CssUnit] = None,
**kwargs: TagAttrValue,
) -> MainCardItem:
- """Deprecated. Please use `shiny.ui.layout_sidebar()` instead."""
+ """Deprecated. Please use :func:`~shiny.ui.layout_sidebar()` instead."""
warn_deprecated(
"`shiny.experimental.ui.layout_sidebar()` is deprecated. "
"This method will be removed in a future version, "
@@ -505,7 +505,7 @@ def toggle_sidebar(
open: Literal["toggle", "open", "closed", "always"] | bool | None = None,
session: Session | None = None,
) -> None:
- """Deprecated. Please use `shiny.ui.update_sidebar()` instead."""
+ """Deprecated. Please use :func:`~shiny.ui.update_sidebar()` instead."""
warn_deprecated(
"`shiny.experimental.ui.toggle_sidebar()` is deprecated. "
"This method will be removed in a future version, "
@@ -531,7 +531,7 @@ def sidebar_toggle(
open: Literal["toggle", "open", "closed", "always"] | bool | None = None,
session: Session | None = None,
) -> None:
- """Deprecated. Please use `shiny.ui.update_sidebar()` instead of
+ """Deprecated. Please use :func:`~shiny.ui.update_sidebar()` instead of
`shiny.experimental.ui.sidebar_toggle()`."""
warn_deprecated(
"`shiny.experimental.ui.sidebar_toggle()` is deprecated. "
@@ -553,7 +553,7 @@ def panel_sidebar(
width: int = 4,
**kwargs: TagAttrValue,
) -> DeprecatedPanelSidebar:
- """Deprecated. Please use `shiny.ui.sidebar()` instead of
+ """Deprecated. Please use :func:`~shiny.ui.sidebar()` instead of
`shiny.experimental.ui.panel_sidebar()`."""
warn_deprecated(
"`shiny.experimental.ui.panel_sidebar()` is deprecated. "
@@ -574,7 +574,7 @@ def panel_main(
width: int = 8,
**kwargs: TagAttrValue,
) -> DeprecatedPanelMain:
- """Deprecated. Please use `shiny.ui.layout_sidebar()` instead of
+ """Deprecated. Please use :func:`~shiny.ui.layout_sidebar()` instead of
`shiny.experimental.ui.panel_main()`."""
warn_deprecated(
"`shiny.experimental.ui.panel_main()` is deprecated. "
@@ -612,7 +612,7 @@ def as_css_unit(value: CssUnit) -> str:
# Deprecated 2023-09-12
def as_css_unit(value: None | CssUnit) -> None | str:
"""
- Deprecated. Please use `shiny.ui.css_unit.as_css_unit()` instead.
+ Deprecated. Please use :func:`~shiny.ui.css_unit.as_css_unit()` instead.
"""
warn_deprecated(
"`shiny.experimental.ui.as_css_unit()` is deprecated. "
@@ -635,7 +635,7 @@ def as_css_padding(padding: None) -> None:
# Deprecated 2023-09-12
def as_css_padding(padding: CssUnit | list[CssUnit] | None) -> str | None:
"""
- Deprecated. Please use `shiny.ui.css_unit.as_css_padding()` instead.
+ Deprecated. Please use :func:`~shiny.ui.css_unit.as_css_padding()` instead.
"""
warn_deprecated(
"`shiny.experimental.ui.as_css_padding()` is deprecated. "
@@ -660,7 +660,7 @@ def popover(
options: Optional[dict[str, Any]] = None,
**kwargs: TagAttrValue,
) -> Tag:
- """Deprecated. Please use `shiny.ui.popover()` instead."""
+ """Deprecated. Please use :func:`~shiny.ui.popover()` instead."""
warn_deprecated(
"`shiny.experimental.ui.popover()` is deprecated. "
"This method will be removed in a future version, "
@@ -683,7 +683,7 @@ def toggle_popover(
show: Optional[bool] = None,
session: Optional[Session] = None,
) -> None:
- """Deprecated. Please use `shiny.ui.update_popover()` instead."""
+ """Deprecated. Please use :func:`~shiny.ui.update_popover()` instead."""
warn_deprecated(
"`shiny.experimental.ui.update_popover()` is deprecated. "
"This method will be removed in a future version, "
@@ -699,7 +699,7 @@ def update_popover(
title: Optional[TagChild] = None,
session: Optional[Session] = None,
) -> None:
- """Deprecated. Please use `shiny.ui.update_popover()` instead."""
+ """Deprecated. Please use :func:`~shiny.ui.update_popover()` instead."""
warn_deprecated(
"`shiny.experimental.ui.update_popover()` is deprecated. "
"This method will be removed in a future version, "
@@ -733,7 +733,7 @@ def accordion(
height: Optional[CssUnit] = None,
**kwargs: TagAttrValue,
) -> Tag:
- """Deprecated. Please use `shiny.ui.accordion()` instead."""
+ """Deprecated. Please use :func:`~shiny.ui.accordion()` instead."""
warn_deprecated(
"`shiny.experimental.ui.accordion()` is deprecated. "
"This method will be removed in a future version, "
@@ -759,7 +759,7 @@ def accordion_panel(
icon: Optional[TagChild] = None,
**kwargs: TagAttrValue,
) -> MainAccordionPanel:
- """Deprecated. Please use `shiny.ui.accordion_panel()` instead."""
+ """Deprecated. Please use :func:`~shiny.ui.accordion_panel()` instead."""
warn_deprecated(
"`shiny.experimental.ui.accordion_panel()` is deprecated. "
"This method will be removed in a future version, "
@@ -780,7 +780,7 @@ def accordion_panel_set(
values: bool | str | list[str],
session: Optional[Session] = None,
) -> None:
- """Deprecated. Please use `shiny.ui.update_accordion()` instead."""
+ """Deprecated. Please use :func:`~shiny.ui.update_accordion()` instead."""
warn_deprecated(
"`shiny.experimental.ui.accordion_panel_set()` is deprecated. "
"This method will be removed in a future version, "
@@ -795,7 +795,7 @@ def accordion_panel_open(
values: bool | str | list[str],
session: Optional[Session] = None,
) -> None:
- """Deprecated. Please use `shiny.ui.update_accordion_panel(id, value, show=True)` or `shiny.ui.update_accordion(id, show = True)` instead."""
+ """Deprecated. Please use :func:`~shiny.ui.update_accordion_panel(id, value, show=True)` or :func:`~shiny.ui.update_accordion(id, show = True)` instead."""
warn_deprecated(
"`shiny.experimental.ui.accordion_panel_open()` is deprecated. "
"This method will be removed in a future version, "
@@ -819,7 +819,7 @@ def accordion_panel_close(
values: bool | str | list[str],
session: Optional[Session] = None,
) -> None:
- """Deprecated. Please use `shiny.ui.update_accordion_panel(id, value, show=False)` or `shiny.ui.update_accordion(id, show = False)` instead."""
+ """Deprecated. Please use :func:`~shiny.ui.update_accordion_panel(id, value, show=False)` or :func:`~shiny.ui.update_accordion(id, show = False)` instead."""
warn_deprecated(
"`shiny.experimental.ui.accordion_panel_close()` is deprecated. "
"This method will be removed in a future version, "
@@ -844,7 +844,7 @@ def accordion_panel_insert(
position: Literal["after", "before"] = "after",
session: Optional[Session] = None,
) -> None:
- """Deprecated. Please use `shiny.ui.insert_accordion_panel()` instead."""
+ """Deprecated. Please use :func:`~shiny.ui.insert_accordion_panel()` instead."""
warn_deprecated(
"`shiny.experimental.ui.accordion_panel_insert()` is deprecated. "
"This method will be removed in a future version, "
@@ -865,7 +865,7 @@ def accordion_panel_remove(
target: str | list[str],
session: Optional[Session] = None,
) -> None:
- """Deprecated. Please use `shiny.ui.remove_accordion_panel()` instead."""
+ """Deprecated. Please use :func:`~shiny.ui.remove_accordion_panel()` instead."""
warn_deprecated(
"`shiny.experimental.ui.accordion_panel_remove()` is deprecated. "
"This method will be removed in a future version, "
@@ -888,7 +888,7 @@ def update_accordion_panel(
icon: TagChild | None | MISSING_TYPE = MISSING,
session: Optional[Session] = None,
) -> None:
- """Deprecated. Please use `shiny.ui.update_accordion_panel()` instead."""
+ """Deprecated. Please use :func:`~shiny.ui.update_accordion_panel()` instead."""
warn_deprecated(
"`shiny.experimental.ui.update_accordion_panel()` is deprecated. "
"This method will be removed in a future version, "
@@ -922,7 +922,7 @@ def as_fill_carrier(
warn_deprecated(
"`shiny.experimental.ui.as_fill_carrier()` is deprecated. "
"This method will be removed in a future version, "
- "please use `shiny.ui.fill.as_fill_container()` and `shiny.ui.fill.as_fillable_item()` instead."
+ "please use `shiny.ui.fill.as_fillable_container()` and `shiny.ui.fill.as_fillable_item()` instead."
)
if min_height is not None:
@@ -947,7 +947,7 @@ def as_fillable_container(
max_height: None = None,
gap: None = None,
) -> TagT:
- """Deprecated. Please use `shiny.ui.fill.as_fillable_container()` instead."""
+ """Deprecated. Please use :func:`~shiny.ui.fill.as_fillable_container()` instead."""
warn_deprecated(
"`shiny.experimental.ui.as_fillable_container()` is deprecated. "
"This method will be removed in a future version, "
@@ -975,7 +975,7 @@ def as_fill_item(
min_height: None = None,
max_height: None = None,
) -> TagT:
- """Deprecated. Please use `shiny.ui.fill.as_fill_item()` instead."""
+ """Deprecated. Please use :func:`~shiny.ui.fill.as_fill_item()` instead."""
warn_deprecated(
"`shiny.experimental.ui.as_fill_item()` is deprecated. "
"This method will be removed in a future version, "
@@ -994,7 +994,7 @@ def as_fill_item(
def remove_all_fill(tag: TagT) -> TagT:
- """Deprecated. Please use `shiny.ui.fill.remove_all_fill()` instead."""
+ """Deprecated. Please use :func:`~shiny.ui.fill.remove_all_fill()` instead."""
warn_deprecated(
"`shiny.experimental.ui.remove_all_fill()` is deprecated. "
"This method will be removed in a future version, "
@@ -1038,7 +1038,7 @@ def is_fill_item(tag: TagChild) -> bool:
# ######################
TagCallable = TagFunction
-"""Deprecated. Please use `htmltools.TagFunction"""
+"""Deprecated. Please use `htmltools.TagFunction` instead."""
class CardItem(MainCardItem):
@@ -1061,7 +1061,7 @@ def card_header(
container: TagFunction = tags.div,
**kwargs: TagAttrValue,
) -> MainCardItem:
- """Deprecated. Please use `shiny.ui.card_header()` instead."""
+ """Deprecated. Please use :func:`~shiny.ui.card_header()` instead."""
warn_deprecated(
"`shiny.experimental.ui.card_header()` is deprecated. "
"This method will be removed in a future version, "
@@ -1074,7 +1074,7 @@ def card_footer(
*args: TagChild | TagAttrs,
**kwargs: TagAttrValue,
) -> MainCardItem:
- """Deprecated. Please use `shiny.ui.card_footer()` instead."""
+ """Deprecated. Please use :func:`~shiny.ui.card_footer()` instead."""
warn_deprecated(
"`shiny.experimental.ui.card_footer()` is deprecated. "
"This method will be removed in a future version, "
@@ -1103,7 +1103,7 @@ def value_box(
class_: Optional[str] = None,
**kwargs: TagAttrValue,
) -> Tag:
- """Deprecated. Please use `shiny.ui.value_box()` instead."""
+ """Deprecated. Please use :func:`~shiny.ui.value_box()` instead."""
warn_deprecated(
"`shiny.experimental.ui.value_box()` is deprecated. "
"This method will be removed in a future version, "
@@ -1135,7 +1135,7 @@ def showcase_left_center(
max_height: CssUnit = "100px",
max_height_full_screen: CssUnit = "67%",
) -> MainShowcaseLayout:
- """Deprecated. Please use `shiny.ui.showcase_left_center()` instead."""
+ """Deprecated. Please use :func:`~shiny.ui.showcase_left_center()` instead."""
warn_deprecated(
"`shiny.experimental.ui.showcase_left_center()` is deprecated. "
"This method will be removed in a future version, "
@@ -1153,7 +1153,7 @@ def showcase_top_right(
max_height: CssUnit = "75px",
max_height_full_screen: CssUnit = "67%",
) -> MainShowcaseLayout:
- """Deprecated. Please use `shiny.ui.showcase_top_right()` instead."""
+ """Deprecated. Please use :func:`~shiny.ui.showcase_top_right()` instead."""
warn_deprecated(
"`shiny.experimental.ui.showcase_top_right()` is deprecated. "
"This method will be removed in a future version, "
@@ -1182,7 +1182,7 @@ def layout_column_wrap(
class_: Optional[str] = None,
**kwargs: TagAttrValue,
) -> Tag:
- """Deprecated. Please use `shiny.ui.layout_column_wrap()` instead."""
+ """Deprecated. Please use :func:`~shiny.ui.layout_column_wrap()` instead."""
warn_deprecated(
"`shiny.experimental.ui.layout_column_wrap()` is deprecated. "
"This method will be removed in a future version, "
@@ -1228,7 +1228,7 @@ def navset_bar(
collapsible: bool = True,
fluid: bool = True,
) -> MainNavSetBar:
- """Deprecated. Please use `shiny.ui.navset_bar()` instead."""
+ """Deprecated. Please use :func:`~shiny.ui.navset_bar()` instead."""
warn_deprecated(
"`shiny.experimental.ui.navset_bar()` is deprecated. "
"This method will be removed in a future version, "
@@ -1261,7 +1261,7 @@ def navset_card_tab(
header: TagChild = None,
footer: TagChild = None,
) -> MainNavSetCard:
- """Deprecated. Please use `shiny.ui.navset_card_tab()` instead."""
+ """Deprecated. Please use :func:`~shiny.ui.navset_card_tab()` instead."""
warn_deprecated(
"`shiny.experimental.ui.navset_card_tab()` is deprecated. "
"This method will be removed in a future version, "
@@ -1286,7 +1286,7 @@ def navset_card_pill(
footer: TagChild = None,
placement: Literal["above", "below"] = "above",
) -> MainNavSetCard:
- """Deprecated. Please use `shiny.ui.navset_card_pill()` instead."""
+ """Deprecated. Please use :func:`~shiny.ui.navset_card_pill()` instead."""
warn_deprecated(
"`shiny.experimental.ui.navset_card_pill()` is deprecated. "
"This method will be removed in a future version, "
@@ -1318,7 +1318,7 @@ def output_plot(
brush: bool | MainBrushOpts = False,
fill: bool | MISSING_TYPE = MISSING,
) -> Tag:
- """Deprecated. Please use `shiny.ui.output_plot()` instead."""
+ """Deprecated. Please use :func:`~shiny.ui.output_plot()` instead."""
warn_deprecated(
"`shiny.experimental.ui.output_plot()` is deprecated. "
"This method will be removed in a future version, "
@@ -1352,7 +1352,7 @@ def output_image(
fill: bool = False,
# /NEW
) -> Tag:
- """Deprecated. Please use `shiny.ui.output_image()` instead."""
+ """Deprecated. Please use :func:`~shiny.ui.output_image()` instead."""
warn_deprecated(
"`shiny.experimental.ui.output_image()` is deprecated. "
"This method will be removed in a future version, "
@@ -1380,7 +1380,7 @@ def output_ui(
fillable: bool = False,
**kwargs: TagAttrValue,
) -> Tag:
- """Deprecated. Please use `shiny.ui.output_ui()` instead."""
+ """Deprecated. Please use :func:`~shiny.ui.output_ui()` instead."""
warn_deprecated(
"`shiny.experimental.ui.output_ui()` is deprecated. "
"This method will be removed in a future version, "
@@ -1409,7 +1409,7 @@ def page_sidebar(
lang: Optional[str] = None,
**kwargs: TagAttrValue,
) -> Tag:
- """Deprecated. Please use `shiny.ui.page_sidebar()` instead."""
+ """Deprecated. Please use :func:`~shiny.ui.page_sidebar()` instead."""
warn_deprecated(
"`shiny.experimental.ui.page_sidebar()` is deprecated. "
"This method will be removed in a future version, "
@@ -1451,7 +1451,7 @@ def page_navbar(
window_title: str | MISSING_TYPE = MISSING,
lang: Optional[str] = None,
) -> Tag:
- """Deprecated. Please use `shiny.ui.page_navbar()` instead."""
+ """Deprecated. Please use :func:`~shiny.ui.page_navbar()` instead."""
warn_deprecated(
"`shiny.experimental.ui.page_navbar()` is deprecated. "
"This method will be removed in a future version, "
@@ -1488,7 +1488,7 @@ def page_fillable(
lang: Optional[str] = None,
**kwargs: TagAttrValue,
) -> Tag:
- """Deprecated. Please use `shiny.ui.page_fillable()` instead."""
+ """Deprecated. Please use :func:`~shiny.ui.page_fillable()` instead."""
warn_deprecated(
"`shiny.experimental.ui.page_fillable()` is deprecated. "
"This method will be removed in a future version, "
diff --git a/shiny/express/_recall_context.py b/shiny/express/_recall_context.py
index 3317ff2a1..0dc55d52a 100644
--- a/shiny/express/_recall_context.py
+++ b/shiny/express/_recall_context.py
@@ -5,7 +5,7 @@
from types import TracebackType
from typing import Callable, Generic, Mapping, Optional, Type, TypeVar
-from htmltools import HTML, Tag, Tagifiable, TagList, tags
+from htmltools import Tag, wrap_displayhook_handler
from .._typing_extensions import ParamSpec
@@ -32,19 +32,6 @@ def __init__(
self.args: list[object] = list(args)
self.kwargs: dict[str, object] = dict(kwargs)
- def append_arg(self, value: object):
- if isinstance(value, (Tag, TagList, Tagifiable)):
- self.args.append(value)
- elif hasattr(value, "_repr_html_"):
- self.args.append(HTML(value._repr_html_())) # pyright: ignore
- else:
- # We should NOT end up here for objects that were `def`ed, because they
- # would already have been filtered out by _display_decorator_function_def().
- # This is only for other kinds of expressions, the kind which would normally
- # be printed at the console.
- if value is not None:
- self.args.append(tags.pre(repr(value)))
-
def __enter__(self) -> None:
if self.default_page is not None:
from . import _run
@@ -53,7 +40,7 @@ def __enter__(self) -> None:
self._prev_displayhook = sys.displayhook
# Collect each of the "printed" values in the args list.
- sys.displayhook = self.append_arg
+ sys.displayhook = wrap_displayhook_handler(self.args.append)
def __exit__(
self,
diff --git a/shiny/express/_run.py b/shiny/express/_run.py
index cf3db87ad..001c3139a 100644
--- a/shiny/express/_run.py
+++ b/shiny/express/_run.py
@@ -1,6 +1,7 @@
from __future__ import annotations
import ast
+import logging
import sys
from pathlib import Path
from typing import cast
@@ -19,7 +20,7 @@
__all__ = ("wrap_express_app",)
-_DEFAULT_PAGE_FUNCTION = ui.page_fluid
+_DEFAULT_PAGE_FUNCTION = ui.page_fixed
def wrap_express_app(file: Path) -> App:
@@ -35,6 +36,10 @@ def wrap_express_app(file: Path) -> App:
:
A `shiny.App` object.
"""
+ logging.getLogger("uvicorn.error").warning(
+ "Detected Shiny Express app. please note that Shiny Express is still in "
+ "development and the API is subject to change!"
+ )
app_ui = run_express(file)
@@ -67,46 +72,64 @@ def set_result(x: object):
nonlocal ui_result
ui_result = cast(Tag, x)
+ prev_displayhook = sys.displayhook
sys.displayhook = set_result
- reset_top_level_recall_context_manager()
- get_top_level_recall_context_manager().__enter__()
-
- file_path = str(file.resolve())
-
- var_context: dict[str, object] = {
- "__file__": file_path,
- display_decorator_func_name: _display_decorator_function_def,
- }
-
- # Execute each top-level node in the AST
- for node in tree.body:
- if isinstance(node, (ast.FunctionDef, ast.AsyncFunctionDef)):
- exec(
- compile(ast.Module([node], type_ignores=[]), file_path, "exec"),
- var_context,
- var_context,
- )
- else:
- exec(
- compile(ast.Interactive([node], type_ignores=[]), file_path, "single"),
- var_context,
- var_context,
+ try:
+ reset_top_level_recall_context_manager()
+ get_top_level_recall_context_manager().__enter__()
+
+ file_path = str(file.resolve())
+
+ var_context: dict[str, object] = {
+ "__file__": file_path,
+ display_decorator_func_name: _display_decorator_function_def,
+ }
+
+ # Execute each top-level node in the AST
+ for node in tree.body:
+ if isinstance(node, (ast.FunctionDef, ast.AsyncFunctionDef)):
+ exec(
+ compile(ast.Module([node], type_ignores=[]), file_path, "exec"),
+ var_context,
+ var_context,
+ )
+ else:
+ exec(
+ compile(
+ ast.Interactive([node], type_ignores=[]), file_path, "single"
+ ),
+ var_context,
+ var_context,
+ )
+
+ # When we called the function to get the top level recall context manager, we didn't
+ # store the result in a variable and re-use that variable here. That is intentional,
+ # because during the evaluation of the app code,
+ # replace_top_level_recall_context_manager() may have been called, which swaps
+ # out the context manager, and it's the new one that we need to exit here.
+ get_top_level_recall_context_manager().__exit__(None, None, None)
+
+ # If we're running as an Express app but there's also a top-level item named app
+ # which is a shiny.App object, the user probably made a mistake.
+ if "app" in var_context and isinstance(var_context["app"], App):
+ raise RuntimeError(
+ "This looks like a Shiny Express app because it imports shiny.express, "
+ "but it also looks like a Shiny Core app because it has a variable named "
+ "`app` which is a shiny.App object. Remove either the shiny.express import, "
+ "or the app=App()."
)
- get_top_level_recall_context_manager().__exit__(None, None, None)
+ return ui_result
- # If we're running as an Express app but there's also a top-level item named app
- # which is a shiny.App object, the user probably made a mistake.
- if "app" in var_context and isinstance(var_context["app"], App):
- raise RuntimeError(
- "This looks like a Shiny Express app because it imports shiny.express, "
- "but it also looks like a Shiny Classic app because it has a variable named "
- "`app` which is a shiny.App object. Remove either the shiny.express import, "
- "or the app=App()."
- )
+ except AttributeError as e:
+ # Need to catch AttributeError and convert to a different type of error, because
+ # uvicorn specifically catches AttributeErrors and prints an error message that
+ # is helpful for normal ASGI apps, but misleading in the case of Shiny Express.
+ raise RuntimeError(e) from e
- return ui_result
+ finally:
+ sys.displayhook = prev_displayhook
_top_level_recall_context_manager: RecallContextManager[Tag]
diff --git a/shiny/express/layout.py b/shiny/express/layout.py
index f3fb7ade7..3ea390868 100644
--- a/shiny/express/layout.py
+++ b/shiny/express/layout.py
@@ -7,6 +7,7 @@
from .. import ui
from ..types import MISSING, MISSING_TYPE
+from ..ui._layout_columns import BreakpointsUser
from ..ui.css import CssUnit
from . import _run
from ._recall_context import RecallContextManager, wrap_recall_context_manager
@@ -19,14 +20,15 @@
"pre",
"sidebar",
"layout_column_wrap",
+ "layout_columns",
"column",
"row",
"card",
"accordion",
"accordion_panel",
- "navset_tab",
- "navset_card_tab",
- "nav",
+ "navset",
+ "navset_card",
+ "nav_panel",
"page_fluid",
"page_fixed",
"page_fillable",
@@ -80,10 +82,12 @@ def sidebar(
position
Where the sidebar should appear relative to the main content.
open
- The initial state of the sidebar. It can be `"desktop"` (the sidebar starts open
- on desktop screen, closed on mobile), `"open"` or `True` (the sidebar starts
- open), `"closed"` or `False` (the sidebar starts closed), or `"always"` or
- `None` (the sidebar is always open and cannot be closed).
+ The initial state of the sidebar.
+
+ * `"desktop"`: the sidebar starts open on desktop screen, closed on mobile
+ * `"open"` or `True`: the sidebar starts open
+ * `"closed"` or `False`: the sidebar starts closed
+ * `"always"` or `None`: the sidebar is always open and cannot be closed
In :func:`~shiny.ui.update_sidebar`, `open` indicates the desired state of the
sidebar. Note that :func:`~shiny.ui.update_sidebar` can only open or close the
@@ -112,12 +116,15 @@ def sidebar(
padding
Padding within the sidebar itself. This can be a numeric vector (which will be
interpreted as pixels) or a character vector with valid CSS lengths. `padding`
- may be one to four values. If one, then that value will be used for all four
- sides. If two, then the first value will be used for the top and bottom, while
- the second value will be used for left and right. If three, then the first will
- be used for top, the second will be left and right, and the third will be
- bottom. If four, then the values will be interpreted as top, right, bottom, and
- left respectively.
+ may be one to four values.
+
+ * If a single value, then that value will be used for all four sides.
+ * If two, then the first value will be used for the top and bottom, while
+ the second value will be used for left and right.
+ * If three values, then the first will be used for top, the second will be left
+ and right, and the third will be bottom.
+ * If four, then the values will be interpreted as top, right, bottom, and left
+ respectively.
Returns
-------
@@ -166,21 +173,26 @@ def layout_column_wrap(
Parameters
----------
width
- The desired width of each card. It can be a (unit-less) number between 0 and 1
- and should be specified as `1/num`, where `num` represents the number of desired
- columns. It can be a CSS length unit representing either the minimum (when
- `fixed_width=False`) or fixed width (`fixed_width=True`). It can also be `None`,
- which allows power users to set the `grid-template-columns` CSS property
- manually, either via a `style` attribute or a CSS stylesheet. If missing, a
- value of `200px` will be used.
+ The desired width of each card. It can be one of the following:
+
+ * A (unit-less) number between 0 and 1, specified as `1/num`, where `num`
+ represents the number of desired columns.
+ * A CSS length unit representing either the minimum (when `fixed_width=False`)
+ or fixed width (`fixed_width=True`).
+ * `None`, which allows power users to set the `grid-template-columns` CSS
+ property manually, either via a `style` attribute or a CSS stylesheet.
+ * If missing, a value of `200px` will be used.
fixed_width
When `width` is greater than 1 or is a CSS length unit, e.g. `"200px"`,
`fixed_width` indicates whether that `width` value represents the absolute size
of each column (`fixed_width=TRUE`) or the minimum size of a column
- (`fixed_width=FALSE`). When `fixed_width=FALSE`, new columns are added to a row
- when `width` space is available and columns will never exceed the container or
- viewport size. When `fixed_width=TRUE`, all columns will be exactly `width`
- wide, which may result in columns overflowing the parent container.
+ (`fixed_width=FALSE`).
+
+ When `fixed_width=FALSE`, new columns are added to a row when `width` space is
+ available and columns will never exceed the container or viewport size.
+
+ When `fixed_width=TRUE`, all columns will be exactly `width` wide, which may
+ result in columns overflowing the parent container.
heights_equal
If `"all"` (the default), every card in every row of the grid will have the same
height. If `"row"`, then every card in _each_ row of the grid will have the same
@@ -206,6 +218,11 @@ def layout_column_wrap(
-------
:
A :class:`~htmltools.Tag` element.
+
+ See Also
+ --------
+ * :func:`~shiny.express.layout.layout_columns` for laying out elements into a
+ responsive 12-column grid.
"""
return RecallContextManager(
ui.layout_column_wrap,
@@ -225,6 +242,110 @@ def layout_column_wrap(
)
+def layout_columns(
+ *,
+ col_widths: BreakpointsUser[int] = None,
+ row_heights: BreakpointsUser[CssUnit] = None,
+ fill: bool = True,
+ fillable: bool = True,
+ gap: Optional[CssUnit] = None,
+ class_: Optional[str] = None,
+ height: Optional[CssUnit] = None,
+ **kwargs: TagAttrValue,
+):
+ """
+ Create responsive, column-based grid layouts, based on a 12-column grid.
+
+ Parameters
+ ----------
+ col_widths
+ The widths of the columns, possibly at different breakpoints. Can be one of the
+ following:
+
+ * `None` (the default): Automatically determines a sensible number of columns
+ based on the number of children given to the layout.
+ * A list or tuple of integers between 1 and 12, where each element represents
+ the number of columns for the relevant UI element. Column widths are recycled
+ to extend the values in `col_widths` to match the actual number of items in
+ the layout, and children are wrapped onto the next row when a row exceeds 12
+ column units. For example, `col_widths=(4, 8, 12)` allocates 4 columns to the
+ first element, 8 columns to the second element, and 12 columns to the third
+ element (which wraps to the next row). Negative values are also allowed, and
+ are treated as empty columns. For example, `col_widths=(-2, 8, -2)` would
+ allocate 8 columns to an element (with 2 empty columns on either side).
+ * A dictionary of column widths at different breakpoints. The keys should be
+ one of `"xs"`, `"sm"`, `"md"`, `"lg"`, `"xl"`, or `"xxl"`, and the values are
+ either of the above. For example, `col_widths={"sm": (3, 3, 6), "lg": (4)}`.
+
+ row_heights
+ The heights of the rows, possibly at different breakpoints. Can be one of the
+ following:
+
+ * A numeric vector, where each value represents the
+ [fractional unit](https://css-tricks.com/introduction-fr-css-unit/)
+ (`fr`) height of the relevant row. If there are more rows than values
+ provided, the pattern will be repeated. For example, `row_heights=(1, 2)`
+ allows even rows to take up twice as much space as odd rows.
+ * A list of numeric or CSS length units, where each value represents the height
+ of the relevant row. If more rows are needed than values provided, the pattern
+ will repeat. For example, `row_heights=["auto", 1]` allows the height of odd
+ rows to be driven my it's contents and even rows to be
+ [`1fr`](https://css-tricks.com/introduction-fr-css-unit/).
+ * A single string containing CSS length units. In this case, the value is
+ supplied directly to `grid-auto-rows`.
+ * A dictionary of row heights at different breakpoints, where each key is a
+ breakpoint name (one of `"xs"`, `"sm"`, `"md"`, `"lg"`, `"xl"`, or `"xxl"`)
+ and where the values may be any of the above options.
+
+ fill
+ Whether or not to allow the layout to grow/shrink to fit a fillable container
+ with an opinionated height (e.g., :func:`~shiny.ui.page_fillable`).
+
+ fillable
+ Whether or not each element is wrapped in a fillable container.
+
+ gap
+ Any valid CSS unit to use for the gap between columns.
+
+ class_
+ CSS class(es) to apply to the containing element.
+
+ height
+ Any valid CSS unit to use for the height.
+
+ **kwargs
+ Additional attributes to apply to the containing element.
+
+ Returns
+ -------
+ :
+ An :class:`~htmltools.Tag` element.
+
+ See Also
+ --------
+ * :func:`~shiny.express.layout.layout_column_wrap` for laying out elements into a
+ uniform grid.
+
+ Reference
+ --------
+ * [Bootstrap CSS Grid](https://getbootstrap.com/docs/5.3/layout/grid/)
+ * [Bootstrap Breakpoints](https://getbootstrap.com/docs/5.3/layout/breakpoints/)
+ """
+ return RecallContextManager(
+ ui.layout_columns,
+ kwargs=dict(
+ col_widths=col_widths,
+ row_heights=row_heights,
+ fill=fill,
+ fillable=fillable,
+ gap=gap,
+ class_=class_,
+ height=height,
+ **kwargs,
+ ),
+ )
+
+
def column(width: int, *, offset: int = 0, **kwargs: TagAttrValue):
"""
Responsive row-column based layout
@@ -238,7 +359,7 @@ def column(width: int, *, offset: int = 0, **kwargs: TagAttrValue):
The width of the column (an integer between 1 and 12).
offset
The number of columns to offset this column from the end of the previous column.
- kwargs
+ **kwargs
Attributes to place on the column tag.
Returns
@@ -274,7 +395,7 @@ def row(**kwargs: TagAttrValue):
Parameters
----------
- kwargs
+ **kwargs
Attributes to place on the row tag.
Returns
@@ -320,13 +441,6 @@ def card(
an opinionated height (e.g., :func:`~shiny.ui.page_fillable`).
class_
Additional CSS classes for the returned Tag.
- wrapper
- A function (which returns a UI element) to call on unnamed arguments in `*args`
- which are not already card item(s) (like :func:`~shiny.ui.card_header`,
- :func:`~shiny.experimental.ui.card_body`, etc.). Note that non-card items are
- grouped together into one `wrapper` call (e.g. given `card("a", "b",
- card_body("c"), "d")`, `wrapper` would be called twice, once with `"a"` and
- `"b"` and once with `"d"`).
**kwargs
HTML attributes on the returned Tag.
@@ -335,6 +449,15 @@ def card(
:
An :func:`~shiny.ui.tags.div` tag.
"""
+
+ # wrapper
+ # A function (which returns a UI element) to call on unnamed arguments in `*args`
+ # which are not already card item(s) (like :func:`~shiny.ui.card_header`,
+ # :func:`~shiny.experimental.ui.card_body`, etc.). Note that non-card items are
+ # grouped together into one `wrapper` call (e.g. given `card("a", "b",
+ # card_body("c"), "d")`, `wrapper` would be called twice, once with `"a"` and
+ # `"b"` and once with `"d"`).
+
return RecallContextManager(
ui.card,
kwargs=dict(
@@ -453,20 +576,21 @@ def accordion_panel(
# ======================================================================================
-def navset_tab(
+def navset(
*,
+ type: Literal["underline", "pill", "tab"] = "underline",
id: Optional[str] = None,
selected: Optional[str] = None,
header: TagChild = None,
footer: TagChild = None,
):
"""
- Render nav items as a tabset.
-
- This function wraps :func:`~shiny.ui.navset_tab`.
+ Render a set of nav items
Parameters
----------
+ type
+ The type of navset to render. Can be one of `"underline"`, `"pill"`, or `"tab"`.
id
If provided, will create an input value that holds the currently selected nav
item.
@@ -478,8 +602,21 @@ def navset_tab(
footer
UI to display below the selected content.
"""
+ # *args
+ # A collection of nav items (e.g., :func:`shiny.ui.nav`).
+
+ funcs = {
+ "underline": ui.navset_underline,
+ "pill": ui.navset_pill,
+ "tab": ui.navset_tab,
+ }
+
+ func = funcs.get(type, None)
+ if func is None:
+ raise ValueError(f"Invalid navset type: {type!r}")
+
return RecallContextManager(
- ui.navset_tab,
+ func,
kwargs=dict(
id=id,
selected=selected,
@@ -489,8 +626,9 @@ def navset_tab(
)
-def navset_card_tab(
+def navset_card(
*,
+ type: Literal["underline", "pill", "tab"] = "underline",
id: Optional[str] = None,
selected: Optional[str] = None,
title: Optional[TagChild] = None,
@@ -499,12 +637,12 @@ def navset_card_tab(
footer: TagChild = None,
):
"""
- Render nav items as a tabset inside a card container.
-
- This function wraps :func:`~shiny.ui.navset_card_tab`.
+ Render a set of nav items inside a card container.
Parameters
----------
+ type
+ The type of navset to render. Can be one of `"underline"`, `"pill"`, or `"tab"`.
id
If provided, will create an input value that holds the currently selected nav
item.
@@ -512,31 +650,27 @@ def navset_card_tab(
Choose a particular nav item to select by default value (should match it's
``value``).
sidebar
- A `Sidebar` component to display on every `nav()` page.
- fillable
- Whether or not to allow fill items to grow/shrink to fit the browser window. If
- `True`, all `nav()` pages are fillable. A character vector, matching the value
- of `nav()`s to be filled, may also be provided. Note that, if a `sidebar` is
- provided, `fillable` makes the main content portion fillable.
- gap
- A CSS length unit defining the gap (i.e., spacing) between elements provided to
- `*args`.
- padding
- Padding to use for the body. This can be a numeric vector (which will be
- interpreted as pixels) or a character vector with valid CSS lengths. The length
- can be between one and four. If one, then that value will be used for all four
- sides. If two, then the first value will be used for the top and bottom, while
- the second value will be used for left and right. If three, then the first will
- be used for top, the second will be left and right, and the third will be
- bottom. If four, then the values will be interpreted as top, right, bottom, and
- left respectively.
+ A :class:`shiny.ui.Sidebar` component to display on every :func:`~shiny.ui.nav` page.
header
UI to display above the selected content.
footer
UI to display below the selected content.
"""
+ # *args
+ # A collection of nav items (e.g., :func:`shiny.ui.nav`).
+
+ funcs = {
+ "underline": ui.navset_card_underline,
+ "pill": ui.navset_card_pill,
+ "tab": ui.navset_card_tab,
+ }
+
+ func = funcs.get(type, None)
+ if func is None:
+ raise ValueError(f"Invalid navset type: {type!r}")
+
return RecallContextManager(
- ui.navset_card_tab,
+ func,
kwargs=dict(
id=id,
selected=selected,
@@ -548,7 +682,7 @@ def navset_card_tab(
)
-def nav(
+def nav_panel(
title: TagChild,
*,
value: Optional[str] = None,
@@ -573,7 +707,7 @@ def nav(
An icon to appear inline with the button/link.
"""
return RecallContextManager(
- ui.nav,
+ ui.nav_panel,
args=(title,),
kwargs=dict(
value=value,
@@ -605,7 +739,7 @@ def page_fluid(
ISO 639-1 language code for the HTML page, such as ``"en"`` or ``"ko"``. This
will be used as the lang in the ```` tag, as in ````. The
default, `None`, results in an empty string.
- kwargs
+ **kwargs
Attributes on the page level container.
Returns
@@ -643,7 +777,7 @@ def page_fixed(
ISO 639-1 language code for the HTML page, such as ``"en"`` or ``"ko"``. This
will be used as the lang in the ```` tag, as in ````. The
default, `None`, results in an empty string.
- kwargs
+ **kwargs
Attributes on the page level container.
Returns
@@ -673,7 +807,7 @@ def page_fillable(
"""
Creates a fillable page.
- This function wraps :func:`~shiny.ui.page_fixed`.
+ This function wraps :func:`~shiny.ui.page_fillable`.
Parameters
----------
@@ -728,8 +862,6 @@ def page_sidebar(
Parameters
----------
- sidebar
- Content to display in the sidebar.
title
A title to display at the top of the page.
fillable
@@ -744,7 +876,7 @@ def page_sidebar(
ISO 639-1 language code for the HTML page, such as ``"en"`` or ``"ko"``. This
will be used as the lang in the ```` tag, as in ````. The
default, `None`, results in an empty string.
- kwargs
+ **kwargs
Additional attributes passed to :func:`~shiny.ui.layout_sidebar`.
Returns
@@ -752,6 +884,9 @@ def page_sidebar(
:
A UI element.
"""
+ # sidebar
+ # Content to display in the sidebar.
+
return RecallContextManager(
ui.page_sidebar,
kwargs=dict(
diff --git a/shiny/input_handler.py b/shiny/input_handler.py
index 49885319a..abd48cdb2 100644
--- a/shiny/input_handler.py
+++ b/shiny/input_handler.py
@@ -68,7 +68,7 @@ def _process_value(self, type: str, value: Any, name: str, session: Session) ->
``add()`` ing an input handler will make it persist for the duration of the Python
process (unless Shiny is explicitly reloaded). For that reason, verbose naming is
encouraged to minimize the risk of colliding with other Shiny input binding(s) which
-happen to use the same ``type`` (if this the binding is bundled with a package, we
+happen to use the same ``type`` (if the binding is bundled with a package, we
recommend the format of "packageName.widgetName").
Example
diff --git a/shiny/reactive/_core.py b/shiny/reactive/_core.py
index b3ffc94f2..40576c527 100644
--- a/shiny/reactive/_core.py
+++ b/shiny/reactive/_core.py
@@ -208,12 +208,12 @@ def isolate():
Ordinarily, the simple act of reading a reactive value causes a relationship to be
established between the caller and the reactive value, where a change to the
reactive value will cause the caller to re-execute. (The same applies for the act of
- getting a reactive expression's value.) `with isolate()` lets you read a reactive
- value or expression without establishing this relationship.
+ getting a reactive calculation's value.) `with isolate()` lets you read a reactive
+ value or calculation without establishing this relationship.
- ``with isolate()`` can also be useful for calling reactive expression at the
+ ``with isolate()`` can also be useful for calling reactive calculations at the
console, which can be useful for debugging. To do so, wrap the calls to the reactive
- expression with ``with isolate()``.
+ calculation with ``with isolate()``.
Returns
-------
@@ -253,7 +253,7 @@ async def flush() -> None:
Warning
-------
- This function shouldn't ever need to be called inside a Shiny app. It's only
+ You shouldn't ever need to call this function inside of a Shiny app. It's only
useful for testing and running reactive code interactively in the console.
"""
await _reactive_environment.flush()
@@ -263,14 +263,15 @@ def on_flushed(
func: Callable[[], Awaitable[None]], once: bool = False
) -> Callable[[], None]:
"""
- Register a function to be called when the reactive environment is flushed
+ Register a function to be called when the reactive environment is flushed.
Parameters
----------
func
The function to be called when the reactive environment is flushed
once
- If True, the function will only be called once, and then removed from the
+ Should the function be run once, and then cleared, or should it
+ re-run each time the event occurs.
Returns
-------
@@ -289,8 +290,8 @@ def lock() -> asyncio.Lock:
"""
A lock that should be held whenever manipulating the reactive graph.
- For example, this makes it safe to set a :class:`~reactive.Value` and call
- :func:`~reactive.flush()` from a different :class:`~asyncio.Task` than the one that
+ For example, :func:`~shiny.reactive.lock` makes it safe to set a :class:`~reactive.Value` and call
+ :func:`~shiny.reactive.flush` from a different :class:`~asyncio.Task` than the one that
is running the Shiny :class:`~shiny.Session`.
"""
return _reactive_environment.lock
@@ -303,8 +304,8 @@ def invalidate_later(
"""
Scheduled Invalidation
- Schedules the current reactive context to be invalidated in the given number of
- seconds.
+ When called from within a reactive context, :func:`~shiny.reactive.invalidate_later`
+ schedules the reactive context to be invalidated in the given number of seconds.
Parameters
----------
@@ -313,7 +314,7 @@ def invalidate_later(
Note
----
- When called within a reactive function (i.e., :func:`Effect`, :func:`Calc`,
+ When called within a reactive function (i.e., :func:`~reactive.effect`, :func:`~reactive.calc`,
:func:`render.ui`, etc.), that reactive context is invalidated (and re-executes)
after the interval has passed. The re-execution will reset the invalidation flag, so
in a typical use case, the object will keep re-executing and waiting for the
diff --git a/shiny/reactive/_poll.py b/shiny/reactive/_poll.py
index 479757ae5..413125a8b 100644
--- a/shiny/reactive/_poll.py
+++ b/shiny/reactive/_poll.py
@@ -29,9 +29,11 @@ def poll(
"""
Create a reactive polling object.
- Polling is a technique that approximates "real-time" or streaming updates, using a
- data source that does not actually have push notifications but does have a quick way
- to repeatedly check for changes on demand.
+ Polling is a technique that approximates "real-time" or streaming updates, as if a
+ data source were pushing notifications each time it is updated. The data source does
+ not actually push notifications; a polling object repeatedly checks for changes in an
+ efficient way at specified intervals. If a change is detected, the polling object runs
+ a function to re-read the data source.
A reactive polling object is constructed using two functions: a polling function,
which is a fast-running, inexpensive function that is used to determine whether some
@@ -48,7 +50,7 @@ def poll(
object at the top level of app.py (outside of the server function).
Both `poll_func` and the decorated (data reading) function can read reactive values
- and ~shiny.reactive.Calc objects. Any invalidations triggered by reactive
+ and :class:`~shiny.reactive.calc` objects. Any invalidations triggered by reactive
dependencies will apply to the reactive polling object immediately (not waiting for
the `interval_secs` delay to expire).
@@ -57,7 +59,7 @@ def poll(
poll_func
A function to be called frequently to determine whether a data source has
changed. The return value should be something that can be compared inexpensively
- using `==`. Both regular functions and coroutine functions are allowed.
+ using `==`. Both regular functions and co-routine functions are allowed.
Note that the `poll_func` should NOT return a bool that indicates whether the
data source has changed. Rather, each `poll_func` return value will be checked
@@ -71,12 +73,12 @@ def poll(
The function that will be used to compare each `poll_func` return value with its
immediate predecessor.
priority
- Reactive polling is implemented using an ~shiny.reactive.Effect to call
+ Reactive polling is implemented using an :class:`~shiny.reactive.effect` to call
`poll_func` on a timer; use the `priority` argument to control the order of this
- Effect's execution versus other Effects in your app. See ~shiny.reactive.Effect
- for more details.
+ Effect's execution versus other Effects in your app. See
+ :func:`~shiny.reactive.effect` for more details.
session
- A :class:`~shiny.Session` instance. If not provided, it is inferred via
+ A :class:`~shiny.Session` instance. If not provided, a session is inferred via
:func:`~shiny.session.get_current_session`. If there is no current session (i.e.
`poll` is being created outside of the server function), the lifetime of this
reactive poll object will not be tied to any specific session.
@@ -86,9 +88,9 @@ def poll(
:
A decorator that should be applied to a no-argument function that (expensively)
reads whatever data is desired. (This function may be a regular function or a
- coroutine function.) The result of the decorator is a reactive ~shiny.reactive.Calc
- that always returns up-to-date data, and invalidates callers when changes are
- detected via polling.
+ co-routine function.) The result of the decorator is a reactive
+ :class:`~shiny.reactive.calc` that always returns up-to-date data, and invalidates
+ callers when changes are detected via polling.
See Also
--------
@@ -224,9 +226,9 @@ def file_reader(
Note that `file_reader` works only on single files, not directories of files.
Both the `filepath` function and the decorated (file reading) function can read
- reactive values and ~shiny.reactive.Calc objects. Any invalidations triggered by
- reactive dependencies will apply to the reactive file reader object immediately (not
- waiting for the `interval_secs` delay to expire).
+ reactive values and :class:`~shiny.reactive.calc` objects. Any invalidations
+ triggered by reactive dependencies will apply to the reactive file reader object
+ immediately (not waiting for the `interval_secs` delay to expire).
Parameters
----------
@@ -239,18 +241,18 @@ def file_reader(
error and close the session.
If a function is used, make sure it is high performance (or is cached, i.e. use
- a ~shiny.reactive.Calc), as it will be called very frequently.
+ a :class:`~shiny.reactive.calc)`, as it will be called very frequently.
interval_secs
The number of seconds to wait after each time the file metadata is checked.
Note: depending on what other tasks are executing, the actual wait time may far
exceed this value.
priority
- Reactive polling is implemented using an ~shiny.reactive.Effect to call
+ Reactive polling is implemented using an :class:`~shiny.reactive.effect` to call
`poll_func` on a timer; use the `priority` argument to control the order of this
- Effect's execution versus other Effects in your app. See ~shiny.reactive.Effect
- for more details.
+ Effect's execution versus other Effects in your app. See
+ :func:`~shiny.reactive.effect` for more details.
session
- A :class:`~shiny.Session` instance. If not provided, it is inferred via
+ A :class:`~shiny.Session` instance. If not provided, a session is inferred via
:func:`~shiny.session.get_current_session`. If there is no current session (i.e.
`poll` is being created outside of the server function), the lifetime of this
reactive poll object will not be tied to any specific session.
@@ -260,9 +262,9 @@ def file_reader(
:
A decorator that should be applied to a no-argument function that (expensively)
reads whatever data is desired. (This function may be a regular function or a
- coroutine function.) The result of the decorator is a reactive ~shiny.reactive.Calc
- that always returns up-to-date data, and invalidates callers when changes are
- detected via polling.
+ co-routine function.) The result of the decorator is a reactive
+ :class:`~shiny.reactive.calc` that always returns up-to-date data, and invalidates
+ callers when changes are detected via polling.
See Also
--------
diff --git a/shiny/reactive/_reactives.py b/shiny/reactive/_reactives.py
index fd724b130..249654b4b 100644
--- a/shiny/reactive/_reactives.py
+++ b/shiny/reactive/_reactives.py
@@ -51,8 +51,8 @@ class Value(Generic[T]):
Create a reactive value.
Reactive values are the source of reactivity in Shiny. Changes to reactive values
- invalidate downstream reactive functions (:func:`~shiny.reactive.Calc`,
- :func:`~shiny.reactive.Effect`, and `render` functions decorated with `@output`).
+ invalidate downstream reactive functions (:func:`~shiny.reactive.calc`,
+ :func:`~shiny.reactive.effect`, and `render` functions decorated with `@output`).
When these functions are invalidated, they get scheduled to re-execute.
Shiny input values are read-only reactive values. For example, `input.x` is a
@@ -80,14 +80,14 @@ class Value(Generic[T]):
Note
----
A reactive value may only be read from within a reactive function (e.g.,
- :func:`~shiny.reactive.Calc`, :func:`~shiny.reactive.Effect`,
+ :func:`~shiny.reactive.calc`, :func:`~shiny.reactive.effect`,
:func:`shiny.render.text`, etc.) and, when doing so, the function takes a reactive
dependency on the value (i.e., when the value changes, the calling reactive function
will re-execute).
See Also
--------
- ~shiny.Inputs ~shiny.reactive.Calc ~shiny.reactive.Effect
+ ~shiny.Inputs ~shiny.reactive.calc ~shiny.reactive.effect
"""
# These overloads are necessary so that the following hold:
@@ -232,7 +232,7 @@ class Calc_(Generic[T]):
Warning
-------
Most users shouldn't use this class directly to initialize a reactive calculation
- (instead, use the :func:`~shiny.reactive.Calc` decorator).
+ (instead, use the :func:`~shiny.reactive.calc` decorator).
"""
def __init__(
@@ -337,7 +337,7 @@ class CalcAsync_(Calc_[T]):
Warning
-------
Most users shouldn't use this class directly to initialize a reactive calculation
- (instead, use the :func:`~shiny.reactive.Calc` decorator).
+ (instead, use the :func:`~shiny.reactive.calc` decorator).
"""
def __init__(
@@ -401,18 +401,17 @@ def calc(
"""
Mark a function as a reactive calculation.
- A reactive calculation is a function whose return value depends solely on other
- reactive value(s) (i.e., :class:`~shiny.Inputs`, :class:`~shiny.reactive.Value`,
+ A reactive calculation is a function whose return value depends on other
+ reactive value(s) (i.e., :class:`~shiny.Inputs`, :class:`~shiny.reactive.Value`s,
and other reactive calculations). Whenever a reactive value changes, any reactive
- calculations that depend on it are "invalidated" and automatically re-execute when
- necessary. If a reactive calculation is marked as invalidated, any other reactive
+ calculations that depend on it are "invalidated" and automatically re-execute if called while invalid. If a reactive calculation is marked as invalidated, any other reactive
calculations that recently called it are also marked as invalidated. In this way,
invalidations ripple through reactive calculations that depend on each other.
Parameters
----------
session
- A :class:`~shiny.Session` instance. If not provided, it is inferred via
+ A :class:`~shiny.Session` instance. If not provided, the session is inferred via
:func:`~shiny.session.get_current_session`.
Returns
@@ -423,13 +422,15 @@ def calc(
Tip
---
Reactive calculations should not produce any side effects; to reactively produce
- side effects, use :func:`~shiny.reactive.Effect` instead.
+ side effects, use :func:`~shiny.reactive.effect` instead.
+
+ Reactive calculations are analagous to reactive expressions in Shiny for R.
See Also
--------
~shiny.Inputs
~shiny.reactive.Value
- ~shiny.reactive.Effect
+ ~shiny.reactive.effect
~shiny.reactive.invalidate_later
~shiny.reactive.event
"""
@@ -671,17 +672,17 @@ def effect(
"""
Mark a function as a reactive side effect.
- A reactive effect is like a reactive calculation (:func:`~shiny.reactive.Calc`) in
+ A reactive effect is like a reactive calculation (:func:`~shiny.reactive.calc`) in
that it can read reactive values and call reactive calculations, and will
automatically re-execute when those dependencies change. But unlike reactive
calculations, it doesn't return a result and can't be used as an input to other
- reactive expressions. Thus, observers are only useful for their side effects (for
+ reactive expressions. Thus, reactive effects are only useful for their side effects (for
example, performing I/O).
Another contrast between reactive calculations and effects is their execution
strategy. Reactive calculations use lazy evaluation; that is, when their
dependencies change, they don't re-execute right away but rather wait until they are
- called by someone else. Indeed, if they are not called then they will never
+ called by someone else. Indeed, if they are not called, then they will never
re-execute. In contrast, effects use eager evaluation; as soon as their dependencies
change, they schedule themselves to re-execute.
@@ -695,7 +696,7 @@ def effect(
priority value will execute before all effects with lower priority values.
Positive, negative, and zero values are allowed.
session
- A :class:`~shiny.Session` instance. If not provided, it is inferred via
+ A :class:`~shiny.Session` instance. If not provided, the session is inferred via
:func:`~shiny.session.get_current_session`.
Returns
@@ -703,11 +704,15 @@ def effect(
:
A decorator that marks a function as a reactive effect (:class:`Effect_`).
+ Tip
+ ---
+ Reactive effects are analagous to observers in Shiny for R.
+
See Also
--------
~shiny.Inputs
~shiny.reactive.Value
- ~shiny.reactive.Effect
+ ~shiny.reactive.effect
~shiny.reactive.invalidate_later
~shiny.reactive.event
"""
@@ -738,22 +743,26 @@ def event(
Mark a function to react only when an "event" occurs.
Shiny's reactive programming framework is primarily designed for calculated values
- (:func:`~shiny.reactive.Calc`) and side-effect-causing actions
- (:func:`~shiny.reactive.Effect`) that respond to **any** of their inputs changing.
+ (:func:`~shiny.reactive.calc`) and side-effect-causing actions
+ (:func:`~shiny.reactive.effect`) that respond to **any** of their inputs changing.
That's often what is desired in Shiny apps, but not always: sometimes you want to
wait for a specific action to be taken from the user, like clicking an
- :func:`~shiny.ui.input_action_button`, before calculating or taking an action. A
- reactive value (or function) which triggers other calculation or action in this way
- is called an event.
+ :func:`~shiny.ui.input_action_button`, before calculating or taking an action. You
+ do not want the calculation or action to be prematurely triggered if other reactive
+ values that it calls are invalidated. The reactive value (or function) which triggers
+ other calculations or actions in this way is called an event.
These situations demand a more imperative, "event handling" style of programming,
which ``@reactive.event()`` provides. It does this by using the
:func:`~shiny.reactive.isolate` primitive under-the-hood to essentially "limit" the
- set of reactive dependencies to those in ``args``.
+ set of reactive dependencies to those in ``args``. In other words, the event can call
+ as many reactive values as it likes in its code body without taking a reactive
+ dependency on them; it will be invalidated only when a dependency listed in args is
+ invalidated.
Parameters
----------
- args
+ *args
One or more callables that represent the event; most likely this will be a
reactive input value linked to a :func:`~shiny.ui.input_action_button` or
similar (e.g., ``input.click``), but it can also be a (reactive or non-reactive)
@@ -761,7 +770,7 @@ def event(
ignore_none
Whether to ignore the event if the value is ``None`` or ``0``.
ignore_init
- If ``False``, the event trigger on the first run.
+ If ``False``, the event triggers on the first run.
Returns
-------
@@ -771,7 +780,7 @@ def event(
Tip
----
This decorator must be applied before the relevant reactivity decorator (i.e.,
- ``@reactive.event`` must be applied before ``@reactive.Effect``, ``@reactive.Calc``,
+ ``@reactive.event`` must be applied before ``@reactive.effect``, ``@reactive.calc``,
``@render.ui``, etc).
"""
@@ -796,8 +805,8 @@ def decorator(user_fn: Callable[[], T]) -> Callable[[], T]:
if isinstance(user_fn, Calc_):
raise TypeError(
- "`@reactive.event()` must be applied before `@reactive.Calc`.\n"
- + "In other words, `@reactive.Calc` must be above `@reactive.event()`."
+ "`@reactive.event()` must be applied before `@reactive.calc`.\n"
+ + "In other words, `@reactive.calc` must be above `@reactive.event()`."
)
# This is here instead of at the top of the .py file in order to avoid a
diff --git a/shiny/render/_dataframe.py b/shiny/render/_dataframe.py
index f788c0896..2e3af17ce 100644
--- a/shiny/render/_dataframe.py
+++ b/shiny/render/_dataframe.py
@@ -260,7 +260,7 @@ def data_frame(
_fn: DataFrameTransformer.ValueFn | None = None,
) -> DataFrameTransformer.OutputRenderer | DataFrameTransformer.OutputRendererDecorator:
"""
- Reactively render a Pandas data frame object (or similar) as an interactive table or
+ Reactively render a pandas `DataFrame` object (or similar) as an interactive table or
grid. Features fast virtualized scrolling, sorting, filtering, and row selection
(single or multiple).
diff --git a/shiny/render/_display.py b/shiny/render/_display.py
index f40d599de..b9eb002ee 100644
--- a/shiny/render/_display.py
+++ b/shiny/render/_display.py
@@ -4,7 +4,7 @@
import sys
from typing import Any, Callable, Optional, Union, overload
-from htmltools import TagAttrValue, TagFunction, TagList
+from htmltools import TagAttrValue, TagFunction, TagList, wrap_displayhook_handler
from .. import ui as _ui
from ..session._utils import RenderedDeps
@@ -29,7 +29,7 @@ async def DisplayTransformer(
) -> RenderedDeps | None:
results: list[object] = []
orig_displayhook = sys.displayhook
- sys.displayhook = results.append
+ sys.displayhook = wrap_displayhook_handler(results.append)
try:
x = _fn()
if inspect.iscoroutine(x):
@@ -95,7 +95,7 @@ def display(
fillable
Whether or not the UI output area should be considered a fillable (i.e.,
flexbox) container.
- kwargs
+ **kwargs
Attributes to be applied to the output container.
diff --git a/shiny/render/_render.py b/shiny/render/_render.py
index 80ce58a72..9c0d986e0 100644
--- a/shiny/render/_render.py
+++ b/shiny/render/_render.py
@@ -354,7 +354,7 @@ def image(
Returns
-------
:
- A decorator for a function that returns an `~shiny.types.ImgData` object.
+ A decorator for a function that returns an :func:`~shiny.types.ImgData` object.
Tip
----
@@ -457,12 +457,14 @@ def table(
**kwargs: object,
) -> TableTransformer.OutputRenderer | TableTransformer.OutputRendererDecorator:
"""
- Reactively render a Pandas data frame object (or similar) as a basic HTML table.
+ Reactively render a pandas ``DataFrame`` object (or similar) as a basic HTML
+ table.
- Consider using ~shiny.render.data_frame instead of this renderer, as it provides
- high performance virtual scrolling, built-in filtering and sorting, and a better
- default appearance. This renderer may still be helpful if you use pandas styling
- features that are not currently supported by ~shiny.render.data_frame.
+ Consider using :func:`~shiny.render.data_frame` instead of this renderer, as
+ it provides high performance virtual scrolling, built-in filtering and sorting,
+ and a better default appearance. This renderer may still be helpful if you
+ use pandas styling features that are not currently supported by
+ :func:`~shiny.render.data_frame`.
Parameters
----------
@@ -544,7 +546,8 @@ def ui(
Returns
-------
:
- A decorator for a function that returns an object of type `~shiny.ui.TagChild`.
+ A decorator for a function that returns an object of type
+ :class:`~shiny.ui.TagChild`.
Tip
----
diff --git a/shiny/render/transformer/_transformer.py b/shiny/render/transformer/_transformer.py
index 5efbf2e53..0392f4d97 100644
--- a/shiny/render/transformer/_transformer.py
+++ b/shiny/render/transformer/_transformer.py
@@ -652,7 +652,7 @@ def output_transformer(
* The first parameter to the handler function has the class
:class:`~shiny.render.transformer.TransformerMetadata` and is typically called
- `_meta`. This information gives context the to the handler while trying to
+ `_meta`. This information gives context to the handler while trying to
resolve the app-supplied value function (typically called `_fn`).
* The second parameter is the app-defined output value function (e.g. `_fn`). It's
return type (`IT`) determines what types can be returned by the app-supplied
@@ -666,7 +666,7 @@ def output_transformer(
default value. No default value is needed for keyword arguments that are passed
through (e.g. `**kwargs: Any`).
- The tranform function's return type (`OT`) determines the output type of the
+ The transform function's return type (`OT`) determines the output type of the
:class:`~shiny.render.transformer.OutputRenderer`. Note that in many cases (but not
all!) `IT` and `OT` will be the same. The `None` type should typically be defined in
both `IT` and `OT`. If `IT` allows for `None` values, it (typically) signals that
diff --git a/shiny/session/_utils.py b/shiny/session/_utils.py
index fce434fb1..dd1c255cd 100644
--- a/shiny/session/_utils.py
+++ b/shiny/session/_utils.py
@@ -44,8 +44,8 @@ def get_current_session() -> Optional[Session]:
Note
----
- Shiny apps should not need to call this function directly. Instead, it's intended to
- be used by Shiny developing who wish to create new functions that should only be
+ Shiny apps should not need to call this function directly. Instead, it is intended to
+ be used by Shiny developers who wish to create new functions that should only be
called from within an active Shiny session.
See Also
@@ -58,12 +58,12 @@ def get_current_session() -> Optional[Session]:
@contextmanager
def session_context(session: Optional[Session]):
"""
- Context manager for current session.
+ A context manager for current session.
Parameters
----------
session
- A :class:`~shiny.Session` instance. If not provided, it is inferred via
+ A :class:`~shiny.Session` instance. If not provided, the instance is inferred via
:func:`~shiny.session.get_current_session`.
"""
token: Token[Session | None] = _current_session.set(session)
@@ -81,7 +81,7 @@ def require_active_session(session: Optional[Session]) -> Session:
Parameters
----------
session
- A :class:`~shiny.Session` instance. If not provided, it is inferred via
+ A :class:`~shiny.Session` instance. If not provided, the session is inferred via
:func:`~shiny.session.get_current_session`.
Returns
@@ -91,8 +91,8 @@ def require_active_session(session: Optional[Session]) -> Session:
Note
----
- Shiny apps should not need to call this function directly. Instead, it's intended to
- be used by Shiny developing who wish to create new functions that should only be
+ Shiny apps should not need to call this function directly. Instead, it is intended to
+ be used by Shiny developers who wish to create new functions that should only be
called from within an active Shiny session.
Raises
diff --git a/shiny/templates/app-templates/basic-app/app.py b/shiny/templates/app-templates/basic-app/app-core.py
similarity index 100%
rename from shiny/templates/app-templates/basic-app/app.py
rename to shiny/templates/app-templates/basic-app/app-core.py
diff --git a/shiny/templates/app-templates/basic-app/app-express.py b/shiny/templates/app-templates/basic-app/app-express.py
new file mode 100644
index 000000000..0ba68b071
--- /dev/null
+++ b/shiny/templates/app-templates/basic-app/app-express.py
@@ -0,0 +1,10 @@
+from shiny import render, ui
+from shiny.express import input
+
+ui.panel_title("Hello Shiny!")
+ui.input_slider("n", "N", 0, 100, 20)
+
+
+@render.text
+def txt():
+ return f"n*2 is {input.n() * 2}"
diff --git a/shiny/templates/app-templates/dashboard/app.py b/shiny/templates/app-templates/dashboard/app-core.py
similarity index 95%
rename from shiny/templates/app-templates/dashboard/app.py
rename to shiny/templates/app-templates/dashboard/app-core.py
index 41983bbba..3e83227e0 100644
--- a/shiny/templates/app-templates/dashboard/app.py
+++ b/shiny/templates/app-templates/dashboard/app-core.py
@@ -30,13 +30,12 @@ def make_value_box(penguin):
),
),
ui.row(
- ui.layout_column_wrap(
+ ui.layout_columns(
*[make_value_box(penguin) for penguin in species],
- width=1 / 3,
)
),
ui.row(
- ui.layout_column_wrap(
+ ui.layout_columns(
ui.card(
ui.card_header("Summary statistics"),
ui.output_data_frame("summary_statistics"),
@@ -45,7 +44,6 @@ def make_value_box(penguin):
ui.card_header("Penguin bills"),
ui.output_plot("length_depth"),
),
- width=1 / 2,
),
),
)
diff --git a/shiny/templates/app-templates/multi-page/app.py b/shiny/templates/app-templates/multi-page/app-core.py
similarity index 100%
rename from shiny/templates/app-templates/multi-page/app.py
rename to shiny/templates/app-templates/multi-page/app-core.py
diff --git a/shiny/templates/app-templates/multi-page/modules.py b/shiny/templates/app-templates/multi-page/modules.py
index c8df0bfd2..3b9081bc3 100644
--- a/shiny/templates/app-templates/multi-page/modules.py
+++ b/shiny/templates/app-templates/multi-page/modules.py
@@ -8,24 +8,21 @@
@module.ui
def training_ui():
- return ui.nav(
+ return ui.nav_panel(
"Training Dashboard",
- ui.row(
- ui.layout_column_wrap(
- ui.card(
- ui.card_header("Model Metrics"),
- ui.output_plot("metric"),
- ui.input_select(
- "metric",
- "Metric",
- choices=["ROC Curve", "Precision-Recall"],
- ),
+ ui.layout_columns(
+ ui.card(
+ ui.card_header("Model Metrics"),
+ ui.output_plot("metric"),
+ ui.input_select(
+ "metric",
+ "Metric",
+ choices=["ROC Curve", "Precision-Recall"],
),
- ui.card(
- ui.card_header("Training Scores"),
- ui.output_plot("score_dist"),
- ),
- width=1 / 2,
+ ),
+ ui.card(
+ ui.card_header("Training Scores"),
+ ui.output_plot("score_dist"),
),
),
)
@@ -52,24 +49,25 @@ def metric():
@module.ui
def data_view_ui():
- return ui.nav(
+ return ui.nav_panel(
"View Data",
- ui.row(
- ui.layout_column_wrap(
- ui.value_box(
- title="Row count",
- value=ui.output_text("row_count"),
- theme="primary",
- ),
- ui.value_box(
- title="Mean score",
- value=ui.output_text("mean_score"),
- theme="bg-green",
- ),
- width=1 / 2,
+ ui.layout_columns(
+ ui.value_box(
+ title="Row count",
+ value=ui.output_text("row_count"),
+ theme="primary",
+ ),
+ ui.value_box(
+ title="Mean score",
+ value=ui.output_text("mean_score"),
+ theme="bg-green",
),
+ gap="20px",
+ ),
+ ui.layout_columns(
+ ui.card(ui.output_data_frame("data")),
+ style="margin-top: 20px;",
),
- ui.card(ui.output_data_frame("data")),
)
diff --git a/shiny/templates/package-templates/js-input/custom_component/distjs/index.js b/shiny/templates/package-templates/js-input/custom_component/distjs/index.js
index adf9f6c5e..620c5999a 100644
--- a/shiny/templates/package-templates/js-input/custom_component/distjs/index.js
+++ b/shiny/templates/package-templates/js-input/custom_component/distjs/index.js
@@ -177,15 +177,15 @@
super(), this._$Ep = void 0, this.isUpdatePending = false, this.hasUpdated = false, this._$Em = null, this._$Ev();
}
_$Ev() {
- this._$Eg = new Promise((t4) => this.enableUpdating = t4), this._$AL = /* @__PURE__ */ new Map(), this._$E_(), this.requestUpdate(), this.constructor.l?.forEach((t4) => t4(this));
+ this._$Eg = new Promise((t4) => this.enableUpdating = t4), this._$AL = /* @__PURE__ */ new Map(), this._$ES(), this.requestUpdate(), this.constructor.l?.forEach((t4) => t4(this));
}
addController(t4) {
- (this._$ES ??= []).push(t4), void 0 !== this.renderRoot && this.isConnected && t4.hostConnected?.();
+ (this._$E_ ??= /* @__PURE__ */ new Set()).add(t4), void 0 !== this.renderRoot && this.isConnected && t4.hostConnected?.();
}
removeController(t4) {
- this._$ES?.splice(this._$ES.indexOf(t4) >>> 0, 1);
+ this._$E_?.delete(t4);
}
- _$E_() {
+ _$ES() {
const t4 = /* @__PURE__ */ new Map(), s4 = this.constructor.elementProperties;
for (const i4 of s4.keys())
this.hasOwnProperty(i4) && (t4.set(i4, this[i4]), delete this[i4]);
@@ -196,12 +196,12 @@
return S(t4, this.constructor.elementStyles), t4;
}
connectedCallback() {
- this.renderRoot ??= this.createRenderRoot(), this.enableUpdating(true), this._$ES?.forEach((t4) => t4.hostConnected?.());
+ this.renderRoot ??= this.createRenderRoot(), this.enableUpdating(true), this._$E_?.forEach((t4) => t4.hostConnected?.());
}
enableUpdating(t4) {
}
disconnectedCallback() {
- this._$ES?.forEach((t4) => t4.hostDisconnected?.());
+ this._$E_?.forEach((t4) => t4.hostDisconnected?.());
}
attributeChangedCallback(t4, s4, i4) {
this._$AK(t4, i4);
@@ -248,7 +248,7 @@
if (!this.isUpdatePending)
return;
if (!this.hasUpdated) {
- if (this._$Ep) {
+ if (this.renderRoot ??= this.createRenderRoot(), this._$Ep) {
for (const [t6, s5] of this._$Ep)
this[t6] = s5;
this._$Ep = void 0;
@@ -261,7 +261,7 @@
let t4 = false;
const s4 = this._$AL;
try {
- t4 = this.shouldUpdate(s4), t4 ? (this.willUpdate(s4), this._$ES?.forEach((t5) => t5.hostUpdate?.()), this.update(s4)) : this._$ET();
+ t4 = this.shouldUpdate(s4), t4 ? (this.willUpdate(s4), this._$E_?.forEach((t5) => t5.hostUpdate?.()), this.update(s4)) : this._$ET();
} catch (s5) {
throw t4 = false, this._$ET(), s5;
}
@@ -270,7 +270,7 @@
willUpdate(t4) {
}
_$AE(t4) {
- this._$ES?.forEach((t5) => t5.hostUpdated?.()), this.hasUpdated || (this.hasUpdated = true, this.firstUpdated(t4)), this.updated(t4);
+ this._$E_?.forEach((t5) => t5.hostUpdated?.()), this.hasUpdated || (this.hasUpdated = true, this.firstUpdated(t4)), this.updated(t4);
}
_$ET() {
this._$AL = /* @__PURE__ */ new Map(), this.isUpdatePending = false;
@@ -292,7 +292,7 @@
firstUpdated(t4) {
}
};
- b.elementStyles = [], b.shadowRootOptions = { mode: "open" }, b[d("elementProperties")] = /* @__PURE__ */ new Map(), b[d("finalized")] = /* @__PURE__ */ new Map(), p?.({ ReactiveElement: b }), (a.reactiveElementVersions ??= []).push("2.0.1");
+ b.elementStyles = [], b.shadowRootOptions = { mode: "open" }, b[d("elementProperties")] = /* @__PURE__ */ new Map(), b[d("finalized")] = /* @__PURE__ */ new Map(), p?.({ ReactiveElement: b }), (a.reactiveElementVersions ??= []).push("2.0.2");
// node_modules/lit-html/lit-html.js
var t2 = globalThis;
@@ -551,7 +551,7 @@
}
};
var Z = t2.litHtmlPolyfillSupport;
- Z?.(V, M), (t2.litHtmlVersions ??= []).push("3.0.2");
+ Z?.(V, M), (t2.litHtmlVersions ??= []).push("3.1.0");
var j = (t4, i4, s4) => {
const e5 = s4?.renderBefore ?? i4;
let h3 = e5._$litPart$;
@@ -588,7 +588,7 @@
s3._$litElement$ = true, s3["finalized", "finalized"] = true, globalThis.litElementHydrateSupport?.({ LitElement: s3 });
var r4 = globalThis.litElementPolyfillSupport;
r4?.({ LitElement: s3 });
- (globalThis.litElementVersions ??= []).push("4.0.1");
+ (globalThis.litElementVersions ??= []).push("4.0.2");
// node_modules/@lit/reactive-element/decorators/custom-element.js
var t3 = (t4) => (e5, o5) => {
@@ -627,9 +627,41 @@
})(t4, e5, o5);
}
+ // node_modules/@posit-dev/shiny-bindings-core/dist/OptionalShiny.js
+ var Shiny = window.Shiny;
+
+ // node_modules/@posit-dev/shiny-bindings-core/dist/makeInputBinding.js
+ function makeInputBinding(tagName, { type = null } = {}) {
+ if (!Shiny) {
+ return;
+ }
+ class NewCustomBinding extends Shiny["InputBinding"] {
+ constructor() {
+ super();
+ }
+ find(scope) {
+ return $(scope).find(tagName);
+ }
+ getValue(el) {
+ return el.value;
+ }
+ getType(_2) {
+ return type;
+ }
+ subscribe(el, callback) {
+ el.notifyBindingOfChange = (ad) => callback(ad ?? false);
+ }
+ unsubscribe(el) {
+ el.notifyBindingOfChange = (_2) => {
+ };
+ }
+ }
+ Shiny.inputBindings.register(new NewCustomBinding(), `${tagName}-Binding`);
+ }
+
// srcts/index.ts
- var customInputTag = "shiny-custom-input";
- var ShinyCustomInput = class extends s3 {
+ var customInputTag = "custom-component";
+ var CustomComponentEl = class extends s3 {
constructor() {
super(...arguments);
this.value = 0;
@@ -638,14 +670,15 @@
* This alerts Shiny that the value has changed and it should check for the
* latest value. This is set by the input binding.
*/
- this.onChangeCallback = null;
+ this.notifyBindingOfChange = () => {
+ };
}
/**
* Function to run when the increment button is clicked.
*/
onIncrement() {
this.value++;
- this.onChangeCallback?.(true);
+ this.notifyBindingOfChange(true);
}
render() {
return x`
@@ -655,7 +688,7 @@
`;
}
};
- ShinyCustomInput.styles = i`
+ CustomComponentEl.styles = i`
:host {
display: block;
border: solid 1px gray;
@@ -666,25 +699,11 @@
`;
__decorateClass([
n4({ type: Number })
- ], ShinyCustomInput.prototype, "value", 2);
- ShinyCustomInput = __decorateClass([
+ ], CustomComponentEl.prototype, "value", 2);
+ CustomComponentEl = __decorateClass([
t3(customInputTag)
- ], ShinyCustomInput);
- var CustomInputBinding = class extends Shiny.InputBinding {
- constructor() {
- super();
- }
- find(scope) {
- return $(scope).find(customInputTag);
- }
- getValue(el) {
- return el.value;
- }
- subscribe(el, callback) {
- el.onChangeCallback = callback;
- }
- };
- Shiny.inputBindings.register(new CustomInputBinding(), customInputTag);
+ ], CustomComponentEl);
+ makeInputBinding(customInputTag);
})();
/*! Bundled license information:
diff --git a/shiny/templates/package-templates/js-input/package-lock.json b/shiny/templates/package-templates/js-input/package-lock.json
index cd7fbe350..b14fe37f3 100644
--- a/shiny/templates/package-templates/js-input/package-lock.json
+++ b/shiny/templates/package-templates/js-input/package-lock.json
@@ -9,7 +9,7 @@
"version": "1.0.0",
"license": "MIT",
"dependencies": {
- "@shiny-helpers/main": "0.0.13",
+ "@posit-dev/shiny-bindings-core": "^0.0.3",
"lit": "^3.0.2"
},
"devDependencies": {
@@ -382,10 +382,10 @@
"@lit-labs/ssr-dom-shim": "^1.1.2"
}
},
- "node_modules/@shiny-helpers/main": {
- "version": "0.0.13",
- "resolved": "https://registry.npmjs.org/@shiny-helpers/main/-/main-0.0.13.tgz",
- "integrity": "sha512-N53oFskuOxKlE2o0/5vI+7I87p4MRNB8Q5LA/vCWQP35nBCIA2ymePCPWVG5P58CFqeKpvBdmUhdN1FlGdf1fA=="
+ "node_modules/@posit-dev/shiny-bindings-core": {
+ "version": "0.0.3",
+ "resolved": "https://registry.npmjs.org/@posit-dev/shiny-bindings-core/-/shiny-bindings-core-0.0.3.tgz",
+ "integrity": "sha512-G4Zd916Y9YkvuQHRJtRceQBwJD51pBsEyYZFpkIwHiyR56nGGbX0POqHSE39ZQMxa+ewhiBhd4FvK5RgGOoVCA=="
},
"node_modules/@types/trusted-types": {
"version": "2.0.7",
@@ -458,9 +458,9 @@
}
},
"node_modules/typescript": {
- "version": "5.3.2",
- "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.3.2.tgz",
- "integrity": "sha512-6l+RyNy7oAHDfxC4FzSJcz9vnjTKxrLpDG5M2Vu4SHRVNg6xzqZp6LYSR9zjqQTu8DU/f5xwxUdADOkbrIX2gQ==",
+ "version": "5.3.3",
+ "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.3.3.tgz",
+ "integrity": "sha512-pXWcraxM0uxAS+tN0AG/BF2TyqmHO014Z070UsJ+pFvYuRSq8KH8DmWpnbXe0pEPDHXZV3FcAbJkijJ5oNEnWw==",
"dev": true,
"bin": {
"tsc": "bin/tsc",
diff --git a/shiny/templates/package-templates/js-input/package.json b/shiny/templates/package-templates/js-input/package.json
index 6ca6d3887..a3cf5f842 100644
--- a/shiny/templates/package-templates/js-input/package.json
+++ b/shiny/templates/package-templates/js-input/package.json
@@ -14,7 +14,7 @@
"typescript": "^5.2.2"
},
"dependencies": {
- "lit": "^3.0.2",
- "@shiny-helpers/main": "0.0.18"
+ "@posit-dev/shiny-bindings-core": "^0.0.3",
+ "lit": "^3.0.2"
}
}
diff --git a/shiny/templates/package-templates/js-input/srcts/index.ts b/shiny/templates/package-templates/js-input/srcts/index.ts
index 70b716a69..5edc92d89 100644
--- a/shiny/templates/package-templates/js-input/srcts/index.ts
+++ b/shiny/templates/package-templates/js-input/srcts/index.ts
@@ -1,16 +1,14 @@
import { LitElement, html, css } from "lit";
-import { customElement, property } from "lit/decorators.js";
-import type { CustomElementInput } from "@shiny-helpers/main";
-import { makeInputBinding } from "@shiny-helpers/main";
+import { property } from "lit/decorators.js";
+import type { CustomElementInput } from "@posit-dev/shiny-bindings-core";
+import { makeInputBinding } from "@posit-dev/shiny-bindings-core";
-const customInputTag = "custom-component";
/**
* An example element.
*
* @csspart button - The button that increments the value
* @csspart display - The span containing the value
*/
-@customElement(customInputTag)
export class CustomComponentEl
extends LitElement
implements CustomElementInput
@@ -53,4 +51,6 @@ export class CustomComponentEl
}
// Setup the input binding
-makeInputBinding(customInputTag);
+makeInputBinding("custom-component", CustomComponentEl, {
+ registerElement: true,
+});
diff --git a/shiny/templates/package-templates/js-input/tsconfig.json b/shiny/templates/package-templates/js-input/tsconfig.json
index 3ed0398b3..fcac5bbd6 100644
--- a/shiny/templates/package-templates/js-input/tsconfig.json
+++ b/shiny/templates/package-templates/js-input/tsconfig.json
@@ -11,8 +11,8 @@
"checkJs": false,
"skipLibCheck": true,
"isolatedModules": true,
- "outDir": "dist",
- "rootDir": "./src",
+ "outDir": "custom_component/distjs",
+ "rootDir": "srcts",
"noUnusedLocals": true,
"noUnusedParameters": true,
"noImplicitReturns": true,
diff --git a/shiny/templates/package-templates/js-output/custom_component/custom_component.py b/shiny/templates/package-templates/js-output/custom_component/custom_component.py
index 39cdea547..789e73371 100644
--- a/shiny/templates/package-templates/js-output/custom_component/custom_component.py
+++ b/shiny/templates/package-templates/js-output/custom_component/custom_component.py
@@ -35,7 +35,7 @@ async def render_custom_component(
return None
if not isinstance(res, int):
- # Throw an error if the value is not a dataframe
+ # Throw an error if the value is not an integer.
raise TypeError(f"Expected a integer, got {type(res)}. ")
# Send the results to the client. Make sure that this is a serializable
diff --git a/shiny/templates/package-templates/js-output/package-lock.json b/shiny/templates/package-templates/js-output/package-lock.json
index e3f727ac9..b14fe37f3 100644
--- a/shiny/templates/package-templates/js-output/package-lock.json
+++ b/shiny/templates/package-templates/js-output/package-lock.json
@@ -9,7 +9,7 @@
"version": "1.0.0",
"license": "MIT",
"dependencies": {
- "@shiny-helpers/main": "^0.0.18",
+ "@posit-dev/shiny-bindings-core": "^0.0.3",
"lit": "^3.0.2"
},
"devDependencies": {
@@ -382,10 +382,10 @@
"@lit-labs/ssr-dom-shim": "^1.1.2"
}
},
- "node_modules/@shiny-helpers/main": {
- "version": "0.0.18",
- "resolved": "https://registry.npmjs.org/@shiny-helpers/main/-/main-0.0.18.tgz",
- "integrity": "sha512-+qyE2+wD8JCTNltNGmYe5DZy/lE++RUfl100IjMgz1VJqf5mTD4cghYb0NsCCHc8AF+YpyDOAmmZVx3aIyffuA=="
+ "node_modules/@posit-dev/shiny-bindings-core": {
+ "version": "0.0.3",
+ "resolved": "https://registry.npmjs.org/@posit-dev/shiny-bindings-core/-/shiny-bindings-core-0.0.3.tgz",
+ "integrity": "sha512-G4Zd916Y9YkvuQHRJtRceQBwJD51pBsEyYZFpkIwHiyR56nGGbX0POqHSE39ZQMxa+ewhiBhd4FvK5RgGOoVCA=="
},
"node_modules/@types/trusted-types": {
"version": "2.0.7",
@@ -458,9 +458,9 @@
}
},
"node_modules/typescript": {
- "version": "5.3.2",
- "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.3.2.tgz",
- "integrity": "sha512-6l+RyNy7oAHDfxC4FzSJcz9vnjTKxrLpDG5M2Vu4SHRVNg6xzqZp6LYSR9zjqQTu8DU/f5xwxUdADOkbrIX2gQ==",
+ "version": "5.3.3",
+ "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.3.3.tgz",
+ "integrity": "sha512-pXWcraxM0uxAS+tN0AG/BF2TyqmHO014Z070UsJ+pFvYuRSq8KH8DmWpnbXe0pEPDHXZV3FcAbJkijJ5oNEnWw==",
"dev": true,
"bin": {
"tsc": "bin/tsc",
diff --git a/shiny/templates/package-templates/js-output/package.json b/shiny/templates/package-templates/js-output/package.json
index 1e35952f6..a3cf5f842 100644
--- a/shiny/templates/package-templates/js-output/package.json
+++ b/shiny/templates/package-templates/js-output/package.json
@@ -14,7 +14,7 @@
"typescript": "^5.2.2"
},
"dependencies": {
- "lit": "^3.0.2",
- "@shiny-helpers/main": "^0.0.18"
+ "@posit-dev/shiny-bindings-core": "^0.0.3",
+ "lit": "^3.0.2"
}
}
diff --git a/shiny/templates/package-templates/js-output/srcts/index.ts b/shiny/templates/package-templates/js-output/srcts/index.ts
index 722dd8ce8..6e0c00b97 100644
--- a/shiny/templates/package-templates/js-output/srcts/index.ts
+++ b/shiny/templates/package-templates/js-output/srcts/index.ts
@@ -1,7 +1,7 @@
import { LitElement, html, css } from "lit";
import { property } from "lit/decorators.js";
-import { makeOutputBinding } from "@shiny-helpers/main";
+import { makeOutputBinding } from "@posit-dev/shiny-bindings-core";
// What the server-side output binding will send to the client. It's important
// to make sure this matches what the python code is sending.
diff --git a/shiny/templates/package-templates/js-output/tsconfig.json b/shiny/templates/package-templates/js-output/tsconfig.json
index 3ed0398b3..fcac5bbd6 100644
--- a/shiny/templates/package-templates/js-output/tsconfig.json
+++ b/shiny/templates/package-templates/js-output/tsconfig.json
@@ -11,8 +11,8 @@
"checkJs": false,
"skipLibCheck": true,
"isolatedModules": true,
- "outDir": "dist",
- "rootDir": "./src",
+ "outDir": "custom_component/distjs",
+ "rootDir": "srcts",
"noUnusedLocals": true,
"noUnusedParameters": true,
"noImplicitReturns": true,
diff --git a/shiny/templates/package-templates/js-react/custom_component/__init__.py b/shiny/templates/package-templates/js-react/custom_component/__init__.py
index ec4c3a3fe..ff6916ded 100644
--- a/shiny/templates/package-templates/js-react/custom_component/__init__.py
+++ b/shiny/templates/package-templates/js-react/custom_component/__init__.py
@@ -1,5 +1,11 @@
-from .custom_component import custom_component
+from .custom_component import (
+ input_custom_component,
+ output_custom_component,
+ render_custom_component,
+)
__all__ = [
- "custom_component",
+ "input_custom_component",
+ "output_custom_component",
+ "render_custom_component",
]
diff --git a/shiny/templates/package-templates/js-react/custom_component/custom_component.py b/shiny/templates/package-templates/js-react/custom_component/custom_component.py
index 114f037f4..91529e1f6 100644
--- a/shiny/templates/package-templates/js-react/custom_component/custom_component.py
+++ b/shiny/templates/package-templates/js-react/custom_component/custom_component.py
@@ -3,6 +3,12 @@
from htmltools import HTMLDependency, Tag
from shiny.module import resolve_id
+from shiny.render.transformer import (
+ TransformerMetadata,
+ ValueFn,
+ output_transformer,
+ resolve_value_fn,
+)
# This object is used to let Shiny know where the dependencies needed to run
# our component all live. In this case, we're just using a single javascript
@@ -18,14 +24,46 @@
)
-def custom_component(id: str):
+def input_custom_component(id: str):
"""
A shiny input.
"""
return Tag(
# This is the name of the custom tag we created with our webcomponent
- "custom-component",
+ "custom-component-input",
custom_component_deps,
# Use resolve_id so that our component will work in a module
id=resolve_id(id),
)
+
+
+# Output component
+
+
+@output_transformer()
+async def render_custom_component(
+ _meta: TransformerMetadata,
+ _fn: ValueFn[str | None],
+):
+ res = await resolve_value_fn(_fn)
+ if res is None:
+ return None
+
+ if not isinstance(res, str):
+ # Throw an error if the value is not a string
+ raise TypeError(f"Expected a string, got {type(res)}. ")
+
+ # Send the results to the client. Make sure that this is a serializable
+ # object and matches what is expected in the javascript code.
+ return {"value": res}
+
+
+def output_custom_component(id: str):
+ """
+ Show a color
+ """
+ return Tag(
+ "custom-component-output",
+ custom_component_deps,
+ id=resolve_id(id),
+ )
diff --git a/shiny/templates/package-templates/js-react/example-app/app.py b/shiny/templates/package-templates/js-react/example-app/app.py
index 795cca6a1..a87660408 100644
--- a/shiny/templates/package-templates/js-react/example-app/app.py
+++ b/shiny/templates/package-templates/js-react/example-app/app.py
@@ -1,19 +1,23 @@
# pyright: basic
-from custom_component import custom_component
+from custom_component import (
+ input_custom_component,
+ output_custom_component,
+ render_custom_component,
+)
-from shiny import App, render, ui
+from shiny import App, ui
app_ui = ui.page_fluid(
- custom_component("myComponent"),
- ui.output_text("valueOut"),
+ input_custom_component("color"),
+ output_custom_component("valueOut"),
)
def server(input, output, session):
- @render.text
+ @render_custom_component
def valueOut():
- return f"Value from input is {input.myComponent()}"
+ return input.color()
app = App(app_ui, server)
diff --git a/shiny/templates/package-templates/js-react/package-lock.json b/shiny/templates/package-templates/js-react/package-lock.json
index e07e883b8..dc7eb9191 100644
--- a/shiny/templates/package-templates/js-react/package-lock.json
+++ b/shiny/templates/package-templates/js-react/package-lock.json
@@ -9,7 +9,7 @@
"version": "1.0.0",
"license": "MIT",
"dependencies": {
- "@shiny-helpers/react": "^0.0.13",
+ "@posit-dev/shiny-bindings-react": "^0.0.3",
"react": "^18.2.0",
"react-color": "^2.19.3",
"react-dom": "^18.2.0"
@@ -381,16 +381,21 @@
"react": "*"
}
},
- "node_modules/@shiny-helpers/react": {
- "version": "0.0.13",
- "resolved": "https://registry.npmjs.org/@shiny-helpers/react/-/react-0.0.13.tgz",
- "integrity": "sha512-4vzXoCglKl1OoVYRqcrxc4JI684kGY1oyEjrE6K4L1ITEeNiV3CtXTn4Qsks7HBm/5oCyv9TigQnFheubirSuw==",
+ "node_modules/@posit-dev/shiny-bindings-core": {
+ "version": "0.0.2",
+ "resolved": "https://registry.npmjs.org/@posit-dev/shiny-bindings-core/-/shiny-bindings-core-0.0.2.tgz",
+ "integrity": "sha512-uJ1cUAjtIZVFqU7bXqjZm8HX72FrM3BVfCtReppTUrtqE2SJnOQNlUZpc+xkV+3WkPeqnpn0NS7SH880mkcrPQ=="
+ },
+ "node_modules/@posit-dev/shiny-bindings-react": {
+ "version": "0.0.3",
+ "resolved": "https://registry.npmjs.org/@posit-dev/shiny-bindings-react/-/shiny-bindings-react-0.0.3.tgz",
+ "integrity": "sha512-zarfRZ3/dUFBf11Vc2fUM4grpp6xaJQAkqZRj9W/Xbtax3LJ4PElzPzjZicN9PdDBL72cux8XJ+U+0G3b6G8Nw==",
"dependencies": {
+ "@posit-dev/shiny-bindings-core": "*",
"@types/react": "^18.2.38",
"@types/react-dom": "^18.2.16",
"react": "^18.2.0",
"react-dom": "^18.2.0",
- "shiny-helpers": "*",
"typescript": "^5.2.2"
},
"peerDependencies": {
@@ -404,9 +409,9 @@
"integrity": "sha512-ga8y9v9uyeiLdpKddhxYQkxNDrfvuPrlFb0N1qnZZByvcElJaXthF1UhvCh9TLWJBEHeNtdnbysW7Y6Uq8CVng=="
},
"node_modules/@types/react": {
- "version": "18.2.39",
- "resolved": "https://registry.npmjs.org/@types/react/-/react-18.2.39.tgz",
- "integrity": "sha512-Oiw+ppED6IremMInLV4HXGbfbG6GyziY3kqAwJYOR0PNbkYDmLWQA3a95EhdSmamsvbkJN96ZNN+YD+fGjzSBA==",
+ "version": "18.2.42",
+ "resolved": "https://registry.npmjs.org/@types/react/-/react-18.2.42.tgz",
+ "integrity": "sha512-c1zEr96MjakLYus/wPnuWDo1/zErfdU9rNsIGmE+NV71nx88FG9Ttgo5dqorXTu/LImX2f63WBP986gJkMPNbA==",
"dependencies": {
"@types/prop-types": "*",
"@types/scheduler": "*",
@@ -446,9 +451,9 @@
"integrity": "sha512-WZLiwShhwLRmeV6zH+GkbOFT6Z6VklCItrDioxUnv+u4Ll+8vKeFySoFyK/0ctcRpOmwAicELfmys1sDc/Rw+A=="
},
"node_modules/csstype": {
- "version": "3.1.2",
- "resolved": "https://registry.npmjs.org/csstype/-/csstype-3.1.2.tgz",
- "integrity": "sha512-I7K1Uu0MBPzaFKg4nI5Q7Vs2t+3gWWW648spaF+Rg7pI9ds18Ugn+lvg4SHczUdKlHI5LWBXyqfS8+DufyBsgQ=="
+ "version": "3.1.3",
+ "resolved": "https://registry.npmjs.org/csstype/-/csstype-3.1.3.tgz",
+ "integrity": "sha512-M1uQkMl8rQK/szD0LNhtqxIPLpimGm8sOBwU7lLnCpSbTyY3yeU1Vc7l4KT5zT4s/yOxHH5O7tIuuLOCnLADRw=="
},
"node_modules/esbuild": {
"version": "0.19.5",
@@ -597,24 +602,15 @@
"loose-envify": "^1.1.0"
}
},
- "node_modules/shiny-helpers": {
- "version": "0.0.12",
- "resolved": "https://registry.npmjs.org/shiny-helpers/-/shiny-helpers-0.0.12.tgz",
- "integrity": "sha512-8S99ig6OP/fsi/dzhstjw/4eHegY6tksUJE4821gqIGCu6DP9FlJGYZIt4hJqSEWdWpC2HlnFNLdd2PFkIThTw==",
- "peerDependencies": {
- "react": "^18.2.0",
- "react-dom": "^18.2.0"
- }
- },
"node_modules/tinycolor2": {
"version": "1.6.0",
"resolved": "https://registry.npmjs.org/tinycolor2/-/tinycolor2-1.6.0.tgz",
"integrity": "sha512-XPaBkWQJdsf3pLKJV9p4qN/S+fm2Oj8AIPo1BTUhg5oxkvm9+SVEGFdhyOz7tTdUTfvxMiAs4sp6/eZO2Ew+pw=="
},
"node_modules/typescript": {
- "version": "5.3.2",
- "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.3.2.tgz",
- "integrity": "sha512-6l+RyNy7oAHDfxC4FzSJcz9vnjTKxrLpDG5M2Vu4SHRVNg6xzqZp6LYSR9zjqQTu8DU/f5xwxUdADOkbrIX2gQ==",
+ "version": "5.3.3",
+ "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.3.3.tgz",
+ "integrity": "sha512-pXWcraxM0uxAS+tN0AG/BF2TyqmHO014Z070UsJ+pFvYuRSq8KH8DmWpnbXe0pEPDHXZV3FcAbJkijJ5oNEnWw==",
"bin": {
"tsc": "bin/tsc",
"tsserver": "bin/tsserver"
diff --git a/shiny/templates/package-templates/js-react/package.json b/shiny/templates/package-templates/js-react/package.json
index 5a799590f..6ac2fbb2c 100644
--- a/shiny/templates/package-templates/js-react/package.json
+++ b/shiny/templates/package-templates/js-react/package.json
@@ -16,9 +16,9 @@
"typescript": "^5.2.2"
},
"dependencies": {
+ "@posit-dev/shiny-bindings-react": "^0.0.3",
"react": "^18.2.0",
"react-color": "^2.19.3",
- "react-dom": "^18.2.0",
- "@shiny-helpers/react": "^0.0.13"
+ "react-dom": "^18.2.0"
}
}
diff --git a/shiny/templates/package-templates/js-react/srcts/index.tsx b/shiny/templates/package-templates/js-react/srcts/index.tsx
index 606038896..4698b8219 100644
--- a/shiny/templates/package-templates/js-react/srcts/index.tsx
+++ b/shiny/templates/package-templates/js-react/srcts/index.tsx
@@ -1,17 +1,16 @@
import { SketchPicker } from "react-color";
-import type { ColorResult } from "react-color";
import React from "react";
-import { makeReactInput } from "@shiny-helpers/react";
+import { makeReactInput, makeReactOutput } from "@shiny-helpers/react";
// Generates a new input binding that renders the supplied react component
// into the root of the webcomponent.
makeReactInput({
- tagName: "custom-component",
+ tagName: "custom-component-input",
initialValue: "#fff",
- renderComp: ({ onNewValue }) => (
+ renderComp: ({ initialValue, onNewValue }) => (
onNewValue(color)}
/>
),
@@ -25,15 +24,29 @@ function ColorPickerReact({
initialValue: string;
onNewValue: (x: string) => void;
}) {
- const [currentColor, setCurrentColor] = React.useState(initialValue);
+ const [currentColor, setCurrentColor] = React.useState(initialValue);
return (
{
+ onChange={(color) => {
setCurrentColor(color.hex);
onNewValue(color.hex);
}}
/>
);
}
+
+makeReactOutput<{ value: string }>({
+ tagName: "custom-component-output",
+ renderComp: ({ value }) => (
+
+ ),
+});
diff --git a/shiny/templates/package-templates/js-react/tsconfig.json b/shiny/templates/package-templates/js-react/tsconfig.json
index 3f5645b52..b0c09e394 100644
--- a/shiny/templates/package-templates/js-react/tsconfig.json
+++ b/shiny/templates/package-templates/js-react/tsconfig.json
@@ -11,8 +11,8 @@
"checkJs": false,
"skipLibCheck": true,
"isolatedModules": true,
- "outDir": "dist",
- "rootDir": "./src",
+ "outDir": "custom_component/distjs",
+ "rootDir": "srcts",
"noUnusedLocals": true,
"noUnusedParameters": true,
"noImplicitReturns": true,
@@ -25,13 +25,7 @@
"noImplicitOverride": true,
"esModuleInterop": true,
"strict": true,
- "jsx": "react-jsx",
- "plugins": [
- {
- "name": "ts-lit-plugin",
- "strict": true
- }
- ]
+ "jsx": "react-jsx"
},
"include": ["srcts/**/*.ts", "srcts/index.tsx"],
"exclude": []
diff --git a/shiny/types.py b/shiny/types.py
index 5d62c47b1..fbdedbf89 100644
--- a/shiny/types.py
+++ b/shiny/types.py
@@ -37,7 +37,7 @@ class MISSING_TYPE:
# FileUploadOperation class.
class FileInfo(TypedDict):
"""
- Information about a file upload.
+ Class for information about a file upload.
See Also
--------
@@ -49,7 +49,7 @@ class FileInfo(TypedDict):
"""
name: str
- """The name of the file."""
+ """The name of the file being uploaded."""
size: int
"""The size of the file in bytes."""
type: str
@@ -144,7 +144,7 @@ class ActionButtonValue(int):
class NavSetArg(Protocol):
"""
- An value suitable for passing to a navigation container (e.g.,
+ A value suitable for passing to a navigation container (e.g.,
:func:`~shiny.ui.navset_tab`).
"""
diff --git a/shiny/ui/__init__.py b/shiny/ui/__init__.py
index 69fed6996..39a9f4832 100644
--- a/shiny/ui/__init__.py
+++ b/shiny/ui/__init__.py
@@ -23,6 +23,7 @@
)
from ._layout import layout_column_wrap
+from ._layout_columns import layout_columns
# Expose the following modules for extended usage: ex: ui.fill.as_fill_item(x)
@@ -86,7 +87,7 @@
from ._markdown import markdown
from ._modal import modal_button, modal, modal_show, modal_remove
from ._navs import (
- nav,
+ nav_panel,
nav_menu,
nav_control,
nav_spacer,
@@ -102,6 +103,7 @@
# Deprecated
navset_pill_card,
navset_tab_card,
+ nav,
)
from ._notification import notification_show, notification_remove
from ._output import (
@@ -185,6 +187,7 @@
"panel_sidebar",
"panel_main",
# _layout
+ "layout_columns",
"layout_column_wrap",
# _card
"CardItem",
@@ -267,7 +270,7 @@
"modal_show",
"modal_remove",
# _navs
- "nav",
+ "nav_panel",
"nav_menu",
"nav_control",
"nav_spacer",
@@ -283,6 +286,7 @@
# # Deprecated
"navset_pill_card",
"navset_tab_card",
+ "nav",
# _notification
"notification_show",
"notification_remove",
diff --git a/shiny/ui/_accordion.py b/shiny/ui/_accordion.py
index 1631d05fc..fdfefef93 100644
--- a/shiny/ui/_accordion.py
+++ b/shiny/ui/_accordion.py
@@ -26,7 +26,7 @@
class AccordionPanel:
"""
- Internal class used to represent an accordion panel.
+ The internal class used to represent an accordion panel.
This class is used to represent an accordion panel. It is not intended to be
instantiated directly. Instead, use :func:`~shiny.ui.accordion_panel`.
@@ -34,7 +34,7 @@ class AccordionPanel:
Parameters
----------
*args
- Contents to the accordion panel body. Or tag attributes that are supplied to the
+ Contents to appear in the accordion panel body, or tag attributes that are supplied to the
returned :class:`~htmltools.Tag` object.
data_value
A character string that uniquely identifies this panel.
@@ -397,7 +397,7 @@ def update_accordion(
session: Optional[Session] = None,
) -> None:
"""
- Dynamically set accordions panel state
+ Dynamically set accordions' states.
Dynamically (i.e., programmatically) update/modify :func:`~shiny.ui.accordion`s in a Shiny app.
These functions require an `id` to be provided to the :func:`~shiny.ui.accordion` and must also be
@@ -408,11 +408,11 @@ def update_accordion(
id
A string that matches an existing :func:`~shiny.ui.accordion`'s `id`.
show
- either a string or list of strings (used to identify particular
+ Either a string or list of strings (used to identify particular
:func:`~shiny.ui.accordion_panel`(s) by their `value`) or a `bool` to set the state of all
panels.
session
- A shiny session object (the default should almost always be used).
+ A Shiny session object (the default should almost always be used).
References
----------
@@ -442,7 +442,7 @@ def insert_accordion_panel(
session: Optional[Session] = None,
) -> None:
"""
- Insert an :func:`~shiny.ui.accordion_panel`
+ Insert an :func:`~shiny.ui.accordion_panel`.
Parameters
----------
@@ -457,7 +457,7 @@ def insert_accordion_panel(
`"after"` will append after the last panel and `"before"` will prepend before
the first panel.
session
- A shiny session object (the default should almost always be used).
+ A Shiny session object (the default should almost always be used).
References
----------
@@ -495,7 +495,7 @@ def remove_accordion_panel(
session: Optional[Session] = None,
) -> None:
"""
- Remove an :func:`~shiny.ui.accordion_panel`
+ Remove an :func:`~shiny.ui.accordion_panel`.
Parameters
----------
@@ -504,7 +504,7 @@ def remove_accordion_panel(
target
The `value` of an existing panel to remove.
session
- A shiny session object (the default should almost always be used).
+ A Shiny session object (the default should almost always be used).
References
----------
@@ -552,7 +552,7 @@ def update_accordion_panel(
session: Optional[Session] = None,
) -> None:
"""
- Dynamically update accordions panel contents
+ Dynamically update accordion panel contents.
Dynamically (i.e., programmatically) update/modify :func:`~shiny.ui.accordion` panels in a Shiny app.
These functions require an `id` to be provided to the :func:`~shiny.ui.accordion` and must also be
@@ -573,7 +573,7 @@ def update_accordion_panel(
icon
If not missing, the new icon of the panel.
session
- A shiny session object (the default should almost always be used).
+ A Shiny session object (the default should almost always be used).
References
----------
diff --git a/shiny/ui/_bootstrap.py b/shiny/ui/_bootstrap.py
index be0d23084..b66c79755 100644
--- a/shiny/ui/_bootstrap.py
+++ b/shiny/ui/_bootstrap.py
@@ -50,9 +50,9 @@ def row(*args: TagChild | TagAttrs, **kwargs: TagAttrValue) -> Tag:
Parameters
----------
- args
+ *args
Any number of child elements.
- kwargs
+ **kwargs
Attributes to place on the row tag.
Returns
@@ -79,11 +79,11 @@ def column(
----------
width
The width of the column (an integer between 1 and 12).
- args
+ *args
UI elements to place within the column.
offset
The number of columns to offset this column from the end of the previous column.
- kwargs
+ **kwargs
Attributes to place on the column tag.
Returns
@@ -110,16 +110,16 @@ def column(
def panel_well(*args: TagChild | TagAttrs, **kwargs: TagAttrValue) -> Tag:
"""
- Create a well panel
+ Create a well panel.
- Creates a panel with a slightly inset border and grey background. Equivalent to
+ Creates a panel with a slightly inset border and gray background. Equivalent to
Bootstrap's ``well`` CSS class.
Parameters
----------
- args
+ *args
UI elements to include inside the panel.
- kwargs
+ **kwargs
Attributes to place on the panel tag.
Returns
@@ -147,7 +147,7 @@ def panel_conditional(
**kwargs: TagAttrValue,
) -> Tag:
"""
- Create a conditional panel
+ Create a conditional panel.
Show UI elements only if a ``JavaScript`` condition is ``true``.
@@ -156,9 +156,9 @@ def panel_conditional(
condition
A JavaScript expression that will be evaluated repeatedly to determine whether
the panel should be displayed.
- args
+ *args
UI elements to include inside the panel.
- kwargs
+ **kwargs
Attributes to place on the panel tag.
Returns
@@ -170,12 +170,13 @@ def panel_conditional(
----
In the JS expression, you can refer to input and output JavaScript objects that
contain the current values of input and output. For example, if you have an input
- with an id of foo, then you can use input.foo to read its value. (Be sure not to
- modify the input/output objects, as this may cause unpredictable behavior.)
+ with an ``id`` of ``foo``, then you can use ``input.foo`` to read its value.
+ (Be sure not to modify the input/output objects, as this may cause unpredictable
+ behavior.)
You are not recommended to use special JavaScript characters such as a period . in
- the input id's, but if you do use them anyway, for example, ``id = "foo.bar"``, you
- will have to use ``input["foo.bar"]`` instead of ``input.foo.bar`` to read the input
+ the input id's, but if you do use them anyway, for example, `id = "foo.bar"`, you
+ will have to use `input["foo.bar"]` instead of ``input.foo.bar`` to read the input
value.
Tip
@@ -251,9 +252,9 @@ def panel_fixed(
Parameters
----------
- args
+ *args
UI elements to include inside the panel.
- kwargs
+ **kwargs
Arguments passed along to :func:`~shiny.ui.panel_absolute`.
Returns
@@ -297,28 +298,28 @@ def panel_absolute(
"""
Create a panel of absolutely positioned content.
- Creates a ``
`` tag whose CSS position is set to absolute (or fixed if ``fixed =
- True``). The way absolute positioning works in HTML is that absolute coordinates are
- specified relative to its nearest parent element whose position is not set to static
- (which is the default), and if no such parent is found, then relative to the page
- borders. If you're not sure what that means, just keep in mind that you may get
+ Creates a `
` tag whose CSS position is set to absolute (or fixed if ``fixed =
+ True``). In HTML, absolute coordinates are specified relative to an element's
+ nearest parent element whose position is not set to static (the default).
+ If no such parent is found, the coordinates are relative to the page borders.
+ If you're not sure what that means, just keep in mind that you may get
strange results if you use this function from inside of certain types of panels.
Parameters
----------
- args
+ *args
UI elements to include inside the panel.
top
- Distance between the top of the panel, and the top of the page or parent
+ Distance between the top of the panel and the top of the page or parent
container.
left
- Distance between the left side of the panel, and the left of the page or parent
+ Distance between the left side of the panel and the left of the page or parent
container.
right
- Distance between the right side of the panel, and the right of the page or
+ Distance between the right side of the panel and the right of the page or
parent container.
bottom
- Distance between the bottom of the panel, and the bottom of the page or parent
+ Distance between the bottom of the panel and the bottom of the page or parent
container.
width
Width of the panel.
@@ -335,7 +336,7 @@ def panel_absolute(
arrow, or ``"inherit"`` for the usual cursor behavior (including changing to an
I-beam when the cursor is over text). The default is ``"auto"``, which is
equivalent to ``"move" if draggable else "inherit"``.
- kwargs
+ **kwargs
Attributes added to the content's container tag.
Returns
@@ -351,12 +352,12 @@ def panel_absolute(
results.
Like most other distance parameters in Shiny, the position and size parameters take
- a number (interpreted as pixels) or a valid CSS size string, such as ``"100px"``
- (100 pixels) or ``"25%"``.
+ a number (interpreted as pixels) or a valid CSS size string, such as `"100px"`
+ (100 pixels) or `"25%"`.
- For arcane HTML reasons, to have the panel fill the page or parent you should
+ For arcane HTML reasons, to have the panel fill the page or parent,
specify 0 for ``top``, ``left``, ``right``, and ``bottom`` rather than the more
- obvious ``width = "100%"`` and ``height = "100%"``.
+ obvious `width = "100%"` and `height = "100%"`.
"""
style = css(
@@ -385,11 +386,14 @@ def help_text(*args: TagChild | TagAttrs, **kwargs: TagAttrValue) -> Tag:
"""
Create a help text element
+ Help text is stylized text which can be added to the user interface to provide additional explanation
+ or context. Text passed to :func:`~shiny.ui.help_text` receives the Bootstrap `help-block` class.
+
Parameters
----------
- args
+ *args
UI elements to include inside the help text.
- kwargs
+ **kwargs
Attributes to add to the text container.
Returns
diff --git a/shiny/ui/_card.py b/shiny/ui/_card.py
index aeaba298a..daa3785cd 100644
--- a/shiny/ui/_card.py
+++ b/shiny/ui/_card.py
@@ -367,7 +367,7 @@ def card_body(
class CardItem:
"""
- A wrapper around a :class:`~htmltools.Tag` object that represent the content of a
+ A wrapper around a :class:`~htmltools.Tag` object that represents the content of a
card item (e.g., :func:`~shiny.ui.card_header` or
:func:`~shiny.card_footer`).
@@ -377,15 +377,15 @@ class CardItem:
Parameters
----------
item
- A :class:`~htmltools.Tag` object that represent the content of a card item
+ A :class:`~htmltools.Tag` object that represents the content of a card item
(e.g., :func:`~shiny.ui.card_header` or
:func:`~shiny.card_footer`).
See Also
--------
* :func:`~shiny.ui.card` for creating a card component.
- * :func:`~shiny.ui.card_header` for creating a header within the card.
- * :func:`~shiny.ui.card_footer` for creating a footer within the card.
+ * :func:`~shiny.ui.card_header` for creating a header within a card.
+ * :func:`~shiny.ui.card_footer` for creating a footer within a card.
"""
def __init__(
@@ -396,7 +396,7 @@ def __init__(
def resolve(self) -> TagChild:
"""
- Resolves the `CardItem` class by returning the `item` provided at initialization.
+ Resolves an object with the `CardItem` class by returning the `item` provided at initialization.
Returns
-------
diff --git a/shiny/ui/_download_button.py b/shiny/ui/_download_button.py
index 42c5d61de..be0e92fd4 100644
--- a/shiny/ui/_download_button.py
+++ b/shiny/ui/_download_button.py
@@ -31,7 +31,7 @@ def download_button(
An icon to display on the button.
width
The width of the button.
- kwargs
+ **kwargs
Additional attributes for the button.
Returns
@@ -74,7 +74,7 @@ def download_link(
**kwargs: TagAttrValue,
) -> Tag:
"""
- Create a download button
+ Create a download button.
Parameters
----------
@@ -86,7 +86,7 @@ def download_link(
An icon to display on the button.
width
The width of the button.
- kwargs
+ **kwargs
Additional attributes for the button.
Returns
diff --git a/shiny/ui/_include_helpers.py b/shiny/ui/_include_helpers.py
index 1739bfc40..8ceebb12f 100644
--- a/shiny/ui/_include_helpers.py
+++ b/shiny/ui/_include_helpers.py
@@ -27,28 +27,31 @@ def include_js(
**kwargs: TagAttrValue,
) -> Tag:
"""
- Include a JavaScript file
+ Include a JavaScript file.
Parameters
----------
path
A path to a JS file.
method
- One of the following: ``"link"``, ``"link_files"``, or ``"inline"``. ``"link"``
- is the link to the CSS file via a :func:`~ui.tags.link` tag. This method is
- generally preferrable to ``"inline"`` since it allows the browser to cache the
- file. ``"link_files"`` is the same as ``"link"``, but also allow for the CSS
- file to request other files within ``path``'s immediate parent directory (e.g.,
- ``@import()`` another file). Note that this isn't the default behavior because
- you should **be careful not to include files in the same directory as ``path``
- that contain sensitive information**. A good general rule of thumb to follow is
- to have ``path`` be located in a subdirectory of the app directory. For example,
- if the app's source is located at ``/app/app.py``, then ``path`` should be
- somewhere like ``/app/css/custom.css`` (and all the other relevant accompanying
- 'safe' files should be located under ``/app/css/``). And finally, ``"inline"``
- is the inline the CSS file contents within a :func:`~ui.tags.style` tag.
+ One of the following:
+
+ * ``"link"`` is the link to the CSS file via a :func:`~ui.tags.link` tag. This
+ method is generally preferable to ``"inline"`` since it allows the browser to
+ cache the file.
+ * ``"link_files"`` is the same as ``"link"``, but also allow for the CSS file to
+ request other files within ``path``'s immediate parent directory (e.g.,
+ ``@import()`` another file). Note that this isn't the default behavior because
+ you should **be careful not to include files in the same directory as ``path``
+ that contain sensitive information**. A good general rule of thumb to follow
+ is to have ``path`` be located in a subdirectory of the app directory. For
+ example, if the app's source is located at ``/app/app.py``, then ``path``
+ should be somewhere like ``/app/css/custom.css`` (and all the other relevant
+ accompanying 'safe' files should be located under ``/app/css/``).
+ * ``"inline"`` is the inline the CSS file contents within a
+ :func:`~ui.tags.style` tag.
**kwargs
- Attributes which are passed on to `~ui.tags.script`
+ Attributes which are passed on to `~ui.tags.script`.
Returns
@@ -59,9 +62,10 @@ def include_js(
Note
----
This places a :func:`~ui.tags.script` tag in the :func:`~ui.tags.body` of the
- document. If instead, you want to place the tag in the :func:`~ui.tags.head` of the
- document, you can wrap it in ``head_content`` (in this case, just make sure you're
- aware that the DOM probably won't be ready when the script is executed).
+ document. If you want to place the tag in the :func:`~ui.tags.head` of the
+ document instead, you can wrap it in ``head_content`` (in this case, just
+ make sure you're aware that the DOM probably won't be ready when the script
+ is executed).
```{python}
#| eval: false
@@ -98,26 +102,29 @@ def include_css(
path: Path | str, *, method: Literal["link", "link_files", "inline"] = "link"
) -> Tag:
"""
- Include a CSS file
+ Include a CSS file.
Parameters
----------
path
A path to a CSS file.
method
- One of the following: ``"link"``, ``"link_files"``, or ``"inline"``. ``"link"``
- is the link to the CSS file via a :func:`~ui.tags.link` tag. This method is
- generally preferrable to ``"inline"`` since it allows the browser to cache the
- file. ``"link_files"`` is the same as ``"link"``, but also allow for the CSS
- file to request other files within ``path``'s immediate parent directory (e.g.,
- ``@import()`` another file). Note that this isn't the default behavior because
- you should **be careful not to include files in the same directory as ``path``
- that contain sensitive information**. A good general rule of thumb to follow is
- to have ``path`` be located in a subdirectory of the app directory. For example,
- if the app's source is located at ``/app/app.py``, then ``path`` should be
- somewhere like ``/app/css/custom.css`` (and all the other relevant accompanying
- 'safe' files should be located under ``/app/css/``). And finally, ``"inline"``
- is the inline the CSS file contents within a :func:`~ui.tags.style` tag.
+ One of the following:
+
+ * ``"link"`` is the link to the CSS file via a :func:`~ui.tags.link` tag. This
+ method is generally preferable to ``"inline"`` since it allows the browser to
+ cache the file.
+ * ``"link_files"`` is the same as ``"link"``, but also allow for the CSS file to
+ request other files within ``path``'s immediate parent directory (e.g.,
+ ``@import()`` another file). Note that this isn't the default behavior because
+ you should **be careful not to include files in the same directory as ``path``
+ that contain sensitive information**. A good general rule of thumb to follow
+ is to have ``path`` be located in a subdirectory of the app directory. For
+ example, if the app's source is located at ``/app/app.py``, then ``path``
+ should be somewhere like ``/app/css/custom.css`` (and all the other relevant
+ accompanying 'safe' files should be located under ``/app/css/``).
+ * ``"inline"`` is the inline the CSS file contents within a
+ :func:`~ui.tags.style` tag.
Returns
diff --git a/shiny/ui/_input_action_button.py b/shiny/ui/_input_action_button.py
index a2af0bc0f..b29ca7d7b 100644
--- a/shiny/ui/_input_action_button.py
+++ b/shiny/ui/_input_action_button.py
@@ -31,7 +31,7 @@ def input_action_button(
An icon to appear inline with the button/link.
width
The CSS width, e.g. '400px', or '100%'
- kwargs
+ **kwargs
Attributes to be applied to the button.
Returns
@@ -85,7 +85,7 @@ def input_action_link(
An input label.
icon
An icon to appear inline with the button/link.
- kwargs
+ **kwargs
Attributes to be applied to the link.
Returns
diff --git a/shiny/ui/_input_check_radio.py b/shiny/ui/_input_check_radio.py
index d00566364..6c330f62e 100644
--- a/shiny/ui/_input_check_radio.py
+++ b/shiny/ui/_input_check_radio.py
@@ -91,7 +91,7 @@ def input_switch(
) -> Tag:
"""
Create a switch that can be used to specify logical values. Similar to
- ~shiny.ui.input_checkbox, but implies to the user that the change will take effect
+ :func:`~shiny.ui.input_checkbox`, but implies to the user that the change will take effect
immediately.
Parameters
@@ -193,9 +193,9 @@ def input_checkbox_group(
selected
The values that should be initially selected, if any.
inline
- If `True`, the result is displayed inline
+ If `True`, the result is displayed inline.
width
- The CSS width, e.g. '400px', or '100%'
+ The CSS width, e.g. '400px', or '100%'.
Returns
-------
@@ -263,9 +263,9 @@ def input_radio_buttons(
selected
The values that should be initially selected, if any.
inline
- If ``True``, the result is displayed inline
+ If ``True``, the result is displayed inline.
width
- The CSS width, e.g. '400px', or '100%'
+ The CSS width, e.g. '400px', or '100%'.
Returns
-------
diff --git a/shiny/ui/_input_file.py b/shiny/ui/_input_file.py
index 25b93f23f..b1e8caa86 100644
--- a/shiny/ui/_input_file.py
+++ b/shiny/ui/_input_file.py
@@ -65,12 +65,12 @@ def input_file(
::: {.callout-note title="Server value"}
A list of dictionaries (one for each file upload) with the following keys:
- * name: The filename provided by the web browser. This is *not* the path to read
+ * ``name``: The filename provided by the web browser. This is *not* the path to read
to get at the actual data that was uploaded (see 'datapath').
- * size: The size of the uploaded data, in bytes.
- * type: The MIME type reported by the browser (for example, 'text/plain'), or
+ * ``size``: The size of the uploaded data, in bytes.
+ * ``type``: The MIME type reported by the browser (for example, 'text/plain'), or
empty string if the browser didn't know.
- * datapath: The path to a temp file that contains the data that was uploaded.
+ * ``datapath``: The path to a temp file that contains the data that was uploaded.
This file may be deleted if the user performs another upload operation.
:::
diff --git a/shiny/ui/_input_password.py b/shiny/ui/_input_password.py
index 7e3214ca6..fbdd49eaf 100644
--- a/shiny/ui/_input_password.py
+++ b/shiny/ui/_input_password.py
@@ -30,7 +30,7 @@ def input_password(
value
Initial value.
width
- The CSS width, e.g. '400px', or '100%'
+ The CSS width, e.g., '400px', or '100%'.
placeholder
The placeholder of the input.
diff --git a/shiny/ui/_input_select.py b/shiny/ui/_input_select.py
index 98f22d2d8..945640096 100644
--- a/shiny/ui/_input_select.py
+++ b/shiny/ui/_input_select.py
@@ -37,8 +37,10 @@
_topics = {
"Server value": """
-A list of strings, usually of length 1, with the value of the selected items. When
-``multiple=True`` and nothing is selected, this value will be ``None``.
+If `multiple=False`, the server value is a string with the value of the selected item.
+If `multiple=True`, the server value is a tuple containing the values of the
+selected items. When ``multiple=True`` and nothing is selected, this value
+will be ``None``.
"""
}
@@ -84,8 +86,10 @@ def input_selectize(
Notes
------
::: {.callout-note title="Server value"}
- A list of strings, usually of length 1, with the value of the selected items. When
- ``multiple=True`` and nothing is selected, this value will be ``None``.
+ If `multiple=False`, the server value is a string with the value of the selected item.
+ If `multiple=True`, the server value is a tuple containing the values of the
+ selected items. When ``multiple=True`` and nothing is selected, this value
+ will be ``None``.
:::
See Also
@@ -153,8 +157,10 @@ def input_select(
Notes
------
::: {.callout-note title="Server value"}
- A list of strings, usually of length 1, with the value of the selected items. When
- ``multiple=True`` and nothing is selected, this value will be ``None``.
+ If `multiple=False`, the server value is a string with the value of the selected item.
+ If `multiple=True`, the server value is a tuple containing the values of the
+ selected items. When ``multiple=True`` and nothing is selected, this value
+ will be ``None``.
:::
See Also
diff --git a/shiny/ui/_input_slider.py b/shiny/ui/_input_slider.py
index 32902817f..eeb37b389 100644
--- a/shiny/ui/_input_slider.py
+++ b/shiny/ui/_input_slider.py
@@ -98,7 +98,7 @@ def input_slider(
animate
``True`` to show simple animation controls with default settings; ``False`` not
to; or a custom settings list, such as those created using
- :class:`AnimationOptions()`.
+ :class:`~AnimationOptions`.
width
The CSS width, e.g. '400px', or '100%'
sep
@@ -132,7 +132,7 @@ def input_slider(
------
::: {.callout-note title="Server value"}
A number, date, or date-time (depending on the class of value), or in the case of
- slider range, a list of two numbers/dates/date-times.
+ slider range, a tuple of two numbers/dates/date-times.
:::
See Also
diff --git a/shiny/ui/_input_text.py b/shiny/ui/_input_text.py
index 61a328271..78da52bcd 100644
--- a/shiny/ui/_input_text.py
+++ b/shiny/ui/_input_text.py
@@ -22,7 +22,7 @@ def input_text(
spellcheck: Optional[Literal["true", "false"]] = None,
) -> Tag:
"""
- Create an input control for entry of text values
+ Create an input control for entry of text values.
Parameters
----------
@@ -33,17 +33,17 @@ def input_text(
value
Initial value.
width
- The CSS width, e.g. '400px', or '100%'
+ The CSS width, e.g., '400px', or '100%'.
placeholder
A hint as to what can be entered into the control.
autocomplete
- Whether to enable browser autocompletion of the text input (default is None).
- If None, then it will use the browser's default behavior. Other possible values
+ Whether to enable browser autocompletion of the text input (default is ``None``).
+ If `None`, then it will use the browser's default behavior. Other possible values
include "on", "off", "name", "username", and "email". See
https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/autocomplete for
more.
spellcheck
- Whether to enable browser spell checking of the text input (default is None). If
+ Whether to enable browser spell checking of the text input (default is ``None``). If
None, then it will use the browser's default behavior.
Returns
@@ -108,16 +108,16 @@ def input_text_area(
value
Initial value.
width
- The CSS width, e.g. '400px', or '100%'
+ The CSS width, e.g., '400px', or '100%'.
height
- The CSS height, e.g. '400px', or '100%'
+ The CSS height, e.g., '400px', or '100%'.
cols
- Value of the visible character columns of the input, e.g. 80. This argument will
+ Value of the visible character columns of the input, e.g., 80. This argument will
only take effect if there is not a CSS width rule defined for this element; such
a rule could come from the width argument of this function or from a containing
page layout such as :func:`~shiny.ui.page_fluid`.
rows
- The value of the visible character rows of the input, e.g. 6. If the height
+ The value of the visible character rows of the input, e.g., 6. If the height
argument is specified, height will take precedence in the browser's rendering.
placeholder
A hint as to what can be entered into the control.
@@ -131,11 +131,11 @@ def input_text_area(
autocomplete
Whether to enable browser autocompletion of the text input (default is "off").
If `None`, then it will use the browser's default behavior. Other possible
- values include "on", "name", "username", and "email". See [Mozila's autocomplete
+ values include "on", "name", "username", and "email". See [Mozilla's autocomplete
documentation](https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/autocomplete)
for more.
spellcheck
- Whether to enable browser spell checking of the text input (default is None). If
+ Whether to enable browser spell checking of the text input (default is ``None``). If
None, then it will use the browser's default behavior.
Returns
diff --git a/shiny/ui/_input_update.py b/shiny/ui/_input_update.py
index 22a185d9c..85571e40c 100644
--- a/shiny/ui/_input_update.py
+++ b/shiny/ui/_input_update.py
@@ -45,7 +45,7 @@
The syntax of these functions is similar to the functions that created the inputs in
the first place. For example, :func:`~shiny.ui.input_numeric` and
- :func:`~update_numeric` take a similar set of arguments.
+ :func:`~shiny.ui.update_numeric` take a similar set of arguments.
Any arguments with ``None`` values will be ignored; they will not result in any
changes to the input object on the client.
@@ -82,7 +82,7 @@ def update_action_button(
An icon to appear inline with the button/link.
session
A :class:`~shiny.Session` instance. If not provided, it is inferred via
- :func:`~shiny.session.get_current_session`.
+ :func:`~shiny.session.get_current_session`.
Note
----
@@ -909,7 +909,7 @@ def update_tooltip(
session: Optional[Session] = None,
) -> None:
"""
- Update tooltip contents
+ Update tooltip contents.
Parameters
----------
@@ -966,12 +966,12 @@ def update_popover(
----------
id
The id of the popover DOM element to update.
- args
+ *args
The new contents of the popover.
title
The new title of the popover.
show
- Opens (`True`) or closes (`False) the popover.
+ Opens (`True`) or closes (`False`) the popover.
session
A Shiny session object (the default should almost always be used).
diff --git a/shiny/ui/_insert.py b/shiny/ui/_insert.py
index c802cd741..13c4fbdd4 100644
--- a/shiny/ui/_insert.py
+++ b/shiny/ui/_insert.py
@@ -18,35 +18,31 @@ def insert_ui(
session: Optional[Session] = None,
) -> None:
"""
- Insert UI objects
+ Insert UI objects.
Parameters
----------
ui
The UI object you want to insert. This can be anything that you usually put
- inside your apps's ui function. If you're inserting multiple elements in one
+ inside your app's UI function. If you're inserting multiple elements in one
call, make sure to wrap them in either a :func:`~shiny.ui.TagList` or a
:func:`~shiny.ui.tags.div` (the latter option has the advantage that you can
give it an id to make it easier to reference or remove it later on). If you want
- to insert raw html, use :func:`~shiny.ui.HTML`.
+ to insert raw HTML, use :func:`~shiny.ui.HTML`.
selector
A string that is accepted by jQuery's selector (i.e. the string ``s`` to be
placed in a ``$(s)`` jQuery call) which determines the element(s) relative to
which you want to insert your UI object.
where
- Where your UI object should go relative to the selector:
-
- - beforeBegin: Before the selector element itself
- - afterBegin: Just inside the selector element, before its first child
- - beforeEnd: Just inside the selector element, after its last child (default)
- - afterEnd: After the selector element itself
-
- Adapted from
+ Where your UI object should go relative to the selector: "beforeBegin":
+ before the selector element itself; "beforeEnd": just inside the selector
+ element, after its last child (default); "afterEnd": after the selector
+ element itself. Adapted from
https://developer.mozilla.org/en-US/docs/Web/API/Element/insertAdjacentHTML.
multiple
- In case your selector matches more than one element, multiple determines whether
- Shiny should insert the UI object relative to all matched elements or just
- relative to the first matched element (default).
+ In case your selector matches more than one element, ``multiple``
+ determines whether Shiny should insert the UI object relative to all
+ matched elements or just relative to the first matched element (default).
immediate
Whether the UI object should be immediately inserted or removed, or whether
Shiny should wait until all outputs have been updated and all effects have been
@@ -95,21 +91,21 @@ def remove_ui(
session: Optional[Session] = None,
) -> None:
"""
- Remove UI objects
+ Remove UI objects.
Parameters
----------
selector
A string that is accepted by jQuery's selector (i.e. the string ``x`` to be
- placed in a ``$(x)`` jQuery call) which determines the element(s) to remove. If
+ placed in a ``$(x)`` jQuery call), which determines the element(s) to remove. If
you want to remove a Shiny input or output, note that many of these are wrapped
in ``
``s, so you may need to use a somewhat complex selector — see the
Examples below. (Alternatively, you could also wrap the inputs/outputs that you
want to be able to remove easily in a ``
`` with an id.)
multiple
- In case your selector matches more than one element, multiple determines whether
- Shiny should insert the UI object relative to all matched elements or just
- relative to the first matched element (default).
+ In case your selector matches more than one element, ``multiple`` determines
+ whether Shiny should insert the UI object relative to all matched elements
+ or just relative to the first matched element (default).
immediate
Whether the UI object should be immediately inserted or removed, or whether
Shiny should wait until all outputs have been updated and all effects have been
diff --git a/shiny/ui/_layout.py b/shiny/ui/_layout.py
index 57f422ec4..c4bce6481 100644
--- a/shiny/ui/_layout.py
+++ b/shiny/ui/_layout.py
@@ -1,6 +1,6 @@
from __future__ import annotations
-from typing import Literal, Optional, cast
+from typing import Iterable, Literal, Optional, cast
from htmltools import Tag, TagAttrs, TagAttrValue, TagChild, css, div
@@ -33,8 +33,8 @@ def layout_column_wrap(
"""
A grid-like, column-first layout
- Wraps a 1d sequence of UI elements into a 2d grid. The number of columns (and rows)
- in the grid dependent on the column `width` as well as the size of the display.
+ Wraps a 1d sequence of UI elements into a 2d grid. The number of columns
+ (and rows) in the grid depends on the column width and the size of the display.
Parameters
----------
@@ -43,21 +43,26 @@ def layout_column_wrap(
:func:`~shiny.ui.card`). Named arguments become attributes on the
containing :class:`~htmltools.Tag` element.
width
- The desired width of each card. It can be a (unit-less) number between 0 and 1
- and should be specified as `1/num`, where `num` represents the number of desired
- columns. It can be a CSS length unit representing either the minimum (when
- `fixed_width=False`) or fixed width (`fixed_width=True`). It can also be `None`,
- which allows power users to set the `grid-template-columns` CSS property
- manually, either via a `style` attribute or a CSS stylesheet. If missing, a
- value of `200px` will be used.
+ The desired width of each card. It can be one of the following:
+
+ * A (unit-less) number between 0 and 1, specified as `1/num`, where `num`
+ represents the number of desired columns.
+ * A CSS length unit representing either the minimum (when `fixed_width=False`)
+ or fixed width (`fixed_width=True`).
+ * `None`, which allows power users to set the `grid-template-columns` CSS
+ property manually, either via a `style` attribute or a CSS stylesheet.
+ * If missing, a value of `200px` will be used.
fixed_width
- When `width` is greater than 1 or is a CSS length unit, e.g. `"200px"`,
+ When `width` is greater than 1 or is a CSS length unit, e.g., `"200px"`,
`fixed_width` indicates whether that `width` value represents the absolute size
of each column (`fixed_width=TRUE`) or the minimum size of a column
- (`fixed_width=FALSE`). When `fixed_width=FALSE`, new columns are added to a row
- when `width` space is available and columns will never exceed the container or
- viewport size. When `fixed_width=TRUE`, all columns will be exactly `width`
- wide, which may result in columns overflowing the parent container.
+ (`fixed_width=FALSE`).
+
+ When `fixed_width=FALSE`, new columns are added to a row when `width` space is
+ available and columns will never exceed the container or viewport size.
+
+ When `fixed_width=TRUE`, all columns will be exactly `width` wide, which may
+ result in columns overflowing the parent container.
heights_equal
If `"all"` (the default), every card in every row of the grid will have the same
height. If `"row"`, then every card in _each_ row of the grid will have the same
@@ -83,6 +88,11 @@ def layout_column_wrap(
-------
:
A :class:`~htmltools.Tag` element.
+
+ See Also
+ --------
+ * :func:`~shiny.ui.layout_columns` for laying out elements into a responsive
+ 12-column grid.
"""
attrs, children = consolidate_attrs(*args, class_=class_, **kwargs)
@@ -123,14 +133,6 @@ def layout_column_wrap(
else:
colspec = f"repeat(auto-fit, minmax(min({width_css_unit}, 100%), 1fr))"
- # Use a new dict so that we don't mutate the original `children` dict
- upgraded_children: list[TagChild] = []
- for child_value in children:
- child = div({"class": "bslib-gap-spacing"}, child_value)
- if fillable:
- child = as_fillable_container(child)
- upgraded_children.append(child)
-
tag_style_css = {
"grid-template-columns": colspec,
"grid-auto-rows": "1fr" if (heights_equal == "all") else None,
@@ -150,7 +152,7 @@ def layout_column_wrap(
"style": css(**tag_style_css),
},
attrs,
- *upgraded_children,
+ *wrap_all_in_gap_spaced_container(children, fillable),
components_dependency(),
)
if fill:
@@ -165,3 +167,23 @@ def is_probably_a_css_unit(x: TagChild) -> bool:
if isinstance_cssunit(x):
return True
return False
+
+
+def wrap_all_in_gap_spaced_container(
+ children: Iterable[TagChild],
+ fillable: bool = True,
+ class_: Optional[str] = None,
+) -> list[TagChild]:
+ item_class = "bslib-gap-spacing"
+ if class_ is not None:
+ item_class = f"{item_class} {class_}"
+
+ # Use a new list so that we don't mutate the original `children`
+ wrapped_children: list[TagChild] = []
+ for child_value in children:
+ child = div({"class": item_class}, child_value)
+ if fillable:
+ child = as_fillable_container(child)
+ wrapped_children.append(child)
+
+ return wrapped_children
diff --git a/shiny/ui/_layout_columns.py b/shiny/ui/_layout_columns.py
new file mode 100644
index 000000000..7bd2394db
--- /dev/null
+++ b/shiny/ui/_layout_columns.py
@@ -0,0 +1,281 @@
+from __future__ import annotations
+
+from enum import Enum
+from typing import Dict, Iterable, Literal, Optional, Tuple, TypeVar, Union, cast
+from warnings import warn
+
+from htmltools import Tag, TagAttrs, TagAttrValue, TagChild, css
+
+from ._html_deps_shinyverse import web_component_dependency
+from ._layout import wrap_all_in_gap_spaced_container
+from ._tag import consolidate_attrs
+from .css import CssUnit, as_css_unit
+from .fill import as_fill_item
+
+T = TypeVar("T")
+
+
+Breakpoint = Literal["xs", "sm", "md", "lg", "xl", "xxl"]
+"""
+References
+----------
+* [Available Bootstrap breakpoints](https://getbootstrap.com/docs/5.3/layout/breakpoints/#available-breakpoints)
+"""
+
+
+breakpoints: Tuple[Breakpoint, ...] = ("xs", "sm", "md", "lg", "xl", "xxl")
+
+
+BreakpointsSoft = Dict[Breakpoint, Union[Iterable[T], T, None]]
+BreakpointsOptional = Dict[Breakpoint, Union[Iterable[T], None]]
+BreakpointsComplete = Dict[Breakpoint, Iterable[T]]
+BreakpointsUser = Union[BreakpointsSoft[T], Iterable[T], T, None]
+
+
+def layout_columns(
+ *args: TagChild | TagAttrs,
+ col_widths: BreakpointsUser[int] = None,
+ row_heights: BreakpointsUser[CssUnit] = None,
+ fill: bool = True,
+ fillable: bool = True,
+ gap: Optional[CssUnit] = None,
+ class_: Optional[str] = None,
+ height: Optional[CssUnit] = None,
+ **kwargs: TagAttrValue,
+) -> Tag:
+ """
+ Create responsive, column-based grid layouts, based on a 12-column grid.
+
+ Parameters
+ ----------
+ *args
+ Child elements or attributes to be added to the layout.
+ col_widths
+ The widths of the columns, possibly at different breakpoints. Can be one of the
+ following:
+
+ * `None` (the default): Automatically determines a sensible number of columns
+ based on the number of children given to the layout.
+ * A list or tuple of integers between 1 and 12, where each element represents
+ the number of columns for the relevant UI element. Column widths are recycled
+ to extend the values in `col_widths` to match the actual number of items in
+ the layout, and children are wrapped onto the next row when a row exceeds 12
+ column units. For example, `col_widths=(4, 8, 12)` allocates 4 columns to the
+ first element, 8 columns to the second element, and 12 columns to the third
+ element (which wraps to the next row). Negative values are also allowed, and
+ are treated as empty columns. For example, `col_widths=(-2, 8, -2)` would
+ allocate 8 columns to an element (with 2 empty columns on either side).
+ * A dictionary of column widths at different breakpoints. The keys should be
+ one of `"xs"`, `"sm"`, `"md"`, `"lg"`, `"xl"`, or `"xxl"`, and the values are
+ either of the above. For example, `col_widths={"sm": (3, 3, 6), "lg": (4)}`.
+ row_heights
+ The heights of the rows, possibly at different breakpoints. Can be one of the
+ following:
+
+ * A numeric vector, where each value represents the
+ [fractional unit](https://css-tricks.com/introduction-fr-css-unit/)
+ (`fr`) height of the relevant row. If there are more rows than values
+ provided, the pattern will be repeated. For example, `row_heights=(1, 2)`
+ allows even rows to take up twice as much space as odd rows.
+ * A list of numeric or CSS length units, where each value represents the height
+ of the relevant row. If more rows are needed than values provided, the pattern
+ will repeat. For example, `row_heights=["auto", 1]` allows the height of odd
+ rows to be driven my it's contents and even rows to be
+ [`1fr`](https://css-tricks.com/introduction-fr-css-unit/).
+ * A single string containing CSS length units. In this case, the value is
+ supplied directly to `grid-auto-rows`.
+ * A dictionary of row heights at different breakpoints, where each key is a
+ breakpoint name (one of `"xs"`, `"sm"`, `"md"`, `"lg"`, `"xl"`, or `"xxl"`)
+ and where the values may be any of the above options.
+ fill
+ Whether or not to allow the layout to grow/shrink to fit a fillable container
+ with an opinionated height (e.g., :func:`~shiny.ui.page_fillable`).
+ fillable
+ Whether or not each element is wrapped in a fillable container.
+ gap
+ Any valid CSS unit to use for the gap between columns.
+ class_
+ CSS class(es) to apply to the containing element.
+ height
+ Any valid CSS unit to use for the height.
+ **kwargs
+ Additional attributes to apply to the containing element.
+
+ Returns
+ -------
+ :
+ An :class:`~htmltools.Tag` element.
+
+ See Also
+ --------
+ * :func:`~shiny.ui.layout_column_wrap` for laying out elements into a uniform grid.
+
+ Reference
+ --------
+ * [Bootstrap CSS Grid](https://getbootstrap.com/docs/5.3/layout/grid/)
+ * [Bootstrap Breakpoints](https://getbootstrap.com/docs/5.3/layout/breakpoints/)
+ """
+ attrs, children = consolidate_attrs(*args, class_=class_, **kwargs)
+
+ col_widths_spec = as_col_spec(col_widths, len(children))
+
+ # Create the bslib-layout-columns element
+ tag = Tag(
+ "bslib-layout-columns",
+ {
+ "class": "bslib-grid grid bslib-mb-spacing",
+ "style": css(
+ gap=as_css_unit(gap),
+ height=as_css_unit(height),
+ ),
+ },
+ col_widths_attrs(col_widths_spec),
+ attrs,
+ row_heights_attrs(row_heights),
+ *wrap_all_in_gap_spaced_container(children, fillable, "bslib-grid-item"),
+ web_component_dependency(),
+ )
+
+ # Apply fill to the outer layout (fillable is applied to the children)
+ if fill:
+ tag = as_fill_item(tag)
+
+ return tag
+
+
+def as_col_spec(
+ col_widths: BreakpointsUser[int],
+ n_kids: int,
+) -> BreakpointsOptional[int] | None:
+ if col_widths is None:
+ return None
+
+ if not isinstance(col_widths, Dict):
+ return {"md": validate_col_width(col_widths, n_kids, "md")}
+
+ ret: BreakpointsOptional[int] = {}
+ col_widths_items = cast(BreakpointsSoft[int], col_widths).items()
+
+ for brk, value in col_widths_items:
+ if brk not in breakpoints:
+ raise ValueError(
+ f"Breakpoint '{brk}' is not valid. Valid breakpoints are: {', '.join(breakpoints)}'."
+ )
+
+ if value is None:
+ ret[brk] = None
+ elif isinstance(value, (int, Iterable)):
+ ret[brk] = validate_col_width(value, n_kids, brk)
+ else:
+ raise TypeError(
+ f"Invalid type for value at breakpoint '{brk}'. Expected int or Iterable[int]."
+ )
+
+ return ret
+
+
+def validate_col_width(
+ x: Iterable[int] | int, n_kids: int, break_name: Breakpoint
+) -> Iterable[int]:
+ if isinstance(x, int):
+ y = [x]
+ else:
+ y = x
+
+ if not all(isinstance(i, int) for i in y):
+ raise ValueError(
+ f"Column values at breakpoint '{break_name}' must be integers. Values greater than 0 indicate width, and negative values indicate a column offset."
+ )
+
+ if any(i == 0 for i in y):
+ raise ValueError(
+ f"Column values at breakpoint '{break_name}' must be greater than 0 to indicate width, or negative to indicate a column offset."
+ )
+
+ if not any(b > 0 for b in y):
+ raise ValueError(
+ f"Column values at breakpoint '{break_name}' must include at least one positive integer width."
+ )
+
+ if len(list(y)) > n_kids:
+ warn(
+ f"More column widths than children at breakpoint '{break_name}', extra widths will be ignored."
+ )
+
+ return y
+
+
+def col_widths_attrs(col_widths: BreakpointsOptional[int] | None) -> TagAttrs:
+ ret: Dict[str, TagAttrValue] = {}
+ if col_widths is None:
+ return ret
+
+ for break_name, value in col_widths.items():
+ if isinstance(break_name, Enum):
+ break_name = break_name.value
+ break_name = f"col-widths-{break_name}"
+ if value is None:
+ ret[break_name] = ""
+ else:
+ ret[break_name] = ",".join([str(v) for v in value])
+
+ return ret
+
+
+def maybe_fr_unit(x: CssUnit) -> str:
+ if isinstance(x, float):
+ x = round(x)
+
+ if isinstance(x, int):
+ return f"{x}fr"
+
+ return x
+
+
+def row_heights_attrs(
+ x: BreakpointsUser[CssUnit],
+) -> TagAttrs:
+ if x is None:
+ return {"style": "", "class": ""}
+
+ if isinstance(x, (int, float, str)): # CssUnit
+ x = [x]
+
+ if hasattr(x, "__iter__") and not isinstance(x, Dict):
+ # For a single row_heights, we use the same value across all breakpoints,
+ # including mobile
+ height = " ".join([maybe_fr_unit(h) for h in x])
+ return {
+ "style": css(
+ **{"--bslib-grid--row-heights": height},
+ ),
+ "class": "",
+ }
+
+ x = cast(BreakpointsSoft[CssUnit], x)
+
+ # Remove any None values from x
+ x_complete = {k: v for k, v in x.items() if v is not None}
+
+ # We use classes to activate CSS variables at the right breakpoints. Note: Mobile
+ # row height is derived from xs or defaults to auto in the CSS, so we don't need the
+ # class to activate it
+ classes = [
+ f"bslib-grid--row-heights--{brk}" for brk in x_complete.keys() if brk != "xs"
+ ]
+
+ # Create CSS variables, treating numeric values as fractional units, passing strings
+ css_vars: Dict[str, str] = {}
+ for brk, heights in x_complete.items():
+ var = f"--bslib-grid--row-heights--{brk}"
+
+ if isinstance(heights, CssUnit):
+ heights = [heights]
+
+ value = " ".join([maybe_fr_unit(h) for h in heights])
+ css_vars[var] = value
+
+ return {
+ "style": css(**css_vars),
+ "class": " ".join(classes),
+ }
diff --git a/shiny/ui/_modal.py b/shiny/ui/_modal.py
index a1203255c..8f6532f33 100644
--- a/shiny/ui/_modal.py
+++ b/shiny/ui/_modal.py
@@ -18,8 +18,9 @@
def modal_button(label: TagChild, icon: TagChild = None, **kwargs: TagAttrValue) -> Tag:
"""
- Creates a button that will dismiss a :func:`modal` (useful when customising the
- ``footer`` of :func:`modal`).
+ Creates a button that will dismiss a :func:`modal`. :func:`~shiny.ui.modal_button` is usually
+ passed to the `footer` of a :func:`~shiny.ui.modal` to add a button to the footer that will close
+ the :func:`~shiny.ui.modal`.
Parameters
----------
@@ -27,7 +28,7 @@ def modal_button(label: TagChild, icon: TagChild = None, **kwargs: TagAttrValue)
An input label.
icon
An icon to appear inline with the button/link.
- kwargs
+ **kwargs
Attributes to be applied to the button.
Returns
@@ -67,29 +68,32 @@ def modal(
**kwargs: TagAttrValue,
) -> Tag:
"""
- Creates the UI for a modal dialog, using Bootstrap's modal class. Modals are
+ Creates the UI for a modal dialog, using Bootstrap's modal class.
+
+ A modal is a dialog box that appears in front of the app. Modals are
typically used for showing important messages, or for presenting UI that requires
input from the user, such as a user name and/or password input.
Parameters
----------
- args
+ *args
UI elements for the body of the modal.
title
An optional title for the modal dialog.
footer
UI for footer. Use ``None`` for no footer.
size
- One of "s" for small, "m" (the default) for medium, or "l" for large.
+ The size of the modal dialogue box. Use one of "s" for small, "m" (the default)
+ for medium, or "l" for large.
easy_close
If ``True``, the modal dialog can be dismissed by clicking outside the dialog
- box, or be pressing the Escape key. If ``False`` (the default), the modal dialog
+ box, or by pressing the Escape key. If ``False`` (the default), the modal dialog
can't be dismissed in those ways; instead it must be dismissed by clicking on a
``modal_button()``, or from a call to ``modal_remove()`` on the server.
fade
If ``False``, the modal dialog will have no fade-in animation (it will simply
appear rather than fade in to view).
- kwargs
+ **kwargs
Attributes to be applied to the modal's body tag.
Returns
@@ -156,13 +160,16 @@ def modal_show(modal: Tag, session: Optional[Session] = None) -> None:
"""
Show a modal dialog.
+ :func:`~shiny.ui.modal_show` is used to display a modal that has been
+ created with :func:`~shiny.ui.modal`.
+
Parameters
----------
modal
Typically a :func:`modal` instance.
session
- A :class:`~shiny.Session` instance. If not provided, it is inferred via
- :func:`~shiny.session.get_current_session`.
+ The :class:`~shiny.Session` instance to display the modal in. If not provided,
+ the session is inferred via :func:`~shiny.session.get_current_session`.
See Also
-------
@@ -180,13 +187,17 @@ def modal_show(modal: Tag, session: Optional[Session] = None) -> None:
def modal_remove(session: Optional[Session] = None) -> None:
"""
- Remove a modal dialog.
+ Remove a modal dialog box.
+
+ :func:`~shiny.ui.modal_remove` provides a way to remove a modal programatically.
+ Modals can also be removed manually by the user if a :func:`~shiny.ui.modal_button`
+ is provided, or if the modal is created with `easy_close=True`.
Parameters
----------
session
- A :class:`~shiny.Session` instance. If not provided, it is inferred via
- :func:`~shiny.session.get_current_session`.
+ The :class:`~shiny.Session` instance that contains the modal to remove. If not
+ provided, the session is inferred via :func:`~shiny.session.get_current_session`.
See Also
-------
diff --git a/shiny/ui/_navs.py b/shiny/ui/_navs.py
index f57338d76..8a883d164 100644
--- a/shiny/ui/_navs.py
+++ b/shiny/ui/_navs.py
@@ -1,7 +1,7 @@
from __future__ import annotations
__all__ = (
- "nav",
+ "nav_panel",
"nav_menu",
"nav_control",
"nav_spacer",
@@ -17,6 +17,7 @@
# Deprecated - 2023-08-15
"navset_pill_card",
"navset_tab_card",
+ "nav",
)
import copy
@@ -34,7 +35,6 @@
from ._card import CardItem, WrapperCallable, card, card_body, card_footer, card_header
from ._html_deps_shinyverse import components_dependency
from ._sidebar import Sidebar, layout_sidebar
-from ._tag import tag_add_style
from .css import CssUnit, as_css_padding, as_css_unit
from .fill import as_fill_item, as_fillable_container
@@ -42,7 +42,7 @@
# -----------------------------------------------------------------------------
# Navigation items
# -----------------------------------------------------------------------------
-class Nav:
+class NavPanel:
nav: Tag
content: Optional[Tag]
@@ -98,12 +98,12 @@ def tagify(self) -> None:
@add_example()
-def nav(
+def nav_panel(
title: TagChild,
*args: TagChild,
value: Optional[str] = None,
icon: TagChild = None,
-) -> Nav:
+) -> NavPanel:
"""
Create a nav item pointing to some internal content.
@@ -114,11 +114,11 @@ def nav(
*args
UI elements to display when the item is active.
value
- The value of the item. This is used to determine whether the item is active
- (when an ``id`` is provided to the nav container), programmatically select the
- item (e.g., :func:`~shiny.ui.update_navs`), and/or be provided to the
- ``selected`` argument of the navigation container (e.g.,
- :func:`~shiny.ui.navset_tab`).
+ The value of the item. Use this value to determine whether the item is active
+ (when an ``id`` is provided to the nav container) or to programmatically
+ select the item (e.g., :func:`~shiny.ui.update_navs`). You can also
+ provide the value to the ``selected`` argument of the navigation container
+ (e.g., :func:`~shiny.ui.navset_tab`).
icon
An icon to appear inline with the button/link.
@@ -151,13 +151,13 @@ def nav(
role="tab",
)
- return Nav(
+ return NavPanel(
tags.li(link),
div(*args, class_="tab-pane", role="tabpanel", data_value=value),
)
-def nav_control(*args: TagChild) -> Nav:
+def nav_control(*args: TagChild) -> NavPanel:
"""
Place a control in the navigation container.
@@ -168,7 +168,7 @@ def nav_control(*args: TagChild) -> Nav:
See Also
--------
- * ~shiny.ui.nav
+ * ~shiny.ui.nav_panel
* ~shiny.ui.nav_menu
* ~shiny.ui.nav_spacer
* ~shiny.ui.navset_bar
@@ -183,18 +183,18 @@ def nav_control(*args: TagChild) -> Nav:
Example
-------
- See :func:`~shiny.ui.nav`
+ See :func:`~shiny.ui.nav_panel`
"""
- return Nav(tags.li(*args))
+ return NavPanel(tags.li(*args))
-def nav_spacer() -> Nav:
+def nav_spacer() -> NavPanel:
"""
Create space between nav items.
See Also
--------
- * ~shiny.ui.nav
+ * ~shiny.ui.nav_panel
* ~shiny.ui.nav_menu
* ~shiny.ui.nav_control
* ~shiny.ui.navset_bar
@@ -209,10 +209,10 @@ def nav_spacer() -> Nav:
Example
-------
- See :func:`~shiny.ui.nav`
+ See :func:`~shiny.ui.nav_panel`
"""
- return Nav(tags.li(components_dependency(), class_="bslib-nav-spacer"))
+ return NavPanel(tags.li(components_dependency(), class_="bslib-nav-spacer"))
class NavMenu:
@@ -291,12 +291,12 @@ def menu_string_as_nav(x: str | NavSetArg) -> NavSetArg:
else:
nav = tags.li(x, class_="dropdown-header")
- return Nav(nav)
+ return NavPanel(nav)
def nav_menu(
title: TagChild,
- *args: Nav | str,
+ *args: NavPanel | str,
value: Optional[str] = None,
icon: TagChild = None,
align: Literal["left", "right"] = "left",
@@ -309,16 +309,16 @@ def nav_menu(
title
A title to display. Can be a character string or UI elements (i.e., tags).
*args
- A collection of nav items (e.g., :func:`~shiny.ui.nav`) and/or strings.
+ A collection of nav items (e.g., :func:`~shiny.ui.nav_panel`) and/or strings.
Strings will be rendered as a section header unless the string is a set
of two or more hyphens (e.g., ``---``), in which case it will be rendered
as a divider.
value
- The value of the item. This is used to determine whether the item is active
- (when an ``id`` is provided to the nav container), programmatically select the
- item (e.g., :func:`~shiny.ui.update_navs`), and/or be provided to the
- ``selected`` argument of the navigation container (e.g.,
- :func:`~shiny.ui.navset_tab`).
+ The value of the item. Use this value to determine whether the item is active
+ (when an ``id`` is provided to the nav container) or to programmatically
+ select the item (e.g., :func:`~shiny.ui.update_navs`). You can also
+ provide the value to the ``selected`` argument of the navigation container
+ (e.g., :func:`~shiny.ui.navset_tab`).
icon
An icon to appear inline with the button/link.
align
@@ -331,7 +331,7 @@ def nav_menu(
See Also
-------
- * ~shiny.ui.nav
+ * ~shiny.ui.nav_panel
* ~shiny.ui.nav_control
* ~shiny.ui.nav_spacer
* ~shiny.ui.navset_bar
@@ -346,7 +346,7 @@ def nav_menu(
Example
-------
- See :func:`~shiny.ui.nav`
+ See :func:`~shiny.ui.nav_panel`
"""
if value is None:
value = str(title)
@@ -414,7 +414,7 @@ def navset_tab(
Parameters
----------
*args
- A collection of nav items (e.g., :func:`shiny.ui.nav`).
+ A collection of nav items (e.g., :func:`shiny.ui.nav_panel`).
id
If provided, will create an input value that holds the currently selected nav
item.
@@ -429,7 +429,7 @@ def navset_tab(
See Also
--------
- * ~shiny.ui.nav
+ * ~shiny.ui.nav_panel
* ~shiny.ui.nav_menu
* ~shiny.ui.nav_control
* ~shiny.ui.nav_spacer
@@ -444,7 +444,7 @@ def navset_tab(
Example
-------
- See :func:`~shiny.ui.nav`
+ See :func:`~shiny.ui.nav_panel`
"""
return NavSet(
@@ -470,7 +470,7 @@ def navset_pill(
Parameters
----------
*args
- A collection of nav items (e.g., :func:`shiny.ui.nav`).
+ A collection of nav items (e.g., :func:`shiny.ui.nav_panel`).
id
If provided, will create an input value that holds the currently selected nav
item.
@@ -484,7 +484,7 @@ def navset_pill(
See Also
--------
- * ~shiny.ui.nav
+ * ~shiny.ui.nav_panel
* ~shiny.ui.nav_menu
* ~shiny.ui.nav_control
* ~shiny.ui.nav_spacer
@@ -499,7 +499,7 @@ def navset_pill(
Example
-------
- See :func:`~shiny.ui.nav`
+ See :func:`~shiny.ui.nav_panel`
"""
return NavSet(
@@ -525,7 +525,7 @@ def navset_underline(
Parameters
----------
*args
- A collection of nav items (e.g., :func:`shiny.ui.nav`).
+ A collection of nav items (e.g., :func:`shiny.ui.nav_panel`).
id
If provided, will create an input value that holds the currently selected nav
item.
@@ -539,7 +539,7 @@ def navset_underline(
See Also
--------
- * ~shiny.ui.nav
+ * ~shiny.ui.nav_panel
* ~shiny.ui.nav_menu
* ~shiny.ui.nav_control
* ~shiny.ui.nav_spacer
@@ -554,7 +554,7 @@ def navset_underline(
Example
-------
- See :func:`~shiny.ui.nav`
+ See :func:`~shiny.ui.nav_panel`
"""
return NavSet(
*args,
@@ -580,7 +580,7 @@ def navset_hidden(
Parameters
----------
*args
- A collection of nav items (e.g., :func:`shiny.ui.nav`).
+ A collection of nav items (e.g., :func:`shiny.ui.nav_panel`).
id
If provided, will create an input value that holds the currently selected nav
item.
@@ -594,7 +594,7 @@ def navset_hidden(
See Also
--------
- * ~shiny.ui.nav
+ * ~shiny.ui.nav_panel
* ~shiny.ui.nav_menu
* ~shiny.ui.nav_control
* ~shiny.ui.nav_spacer
@@ -693,7 +693,7 @@ def navset_card_tab(
Parameters
----------
*args
- A collection of nav items (e.g., :func:`shiny.ui.nav`).
+ A collection of nav items (e.g., :func:`shiny.ui.nav_panel`).
id
If provided, will create an input value that holds the currently selected nav
item.
@@ -702,23 +702,6 @@ def navset_card_tab(
``value``).
sidebar
A `Sidebar` component to display on every `nav()` page.
- fillable
- Whether or not to allow fill items to grow/shrink to fit the browser window. If
- `True`, all `nav()` pages are fillable. A character vector, matching the value
- of `nav()`s to be filled, may also be provided. Note that, if a `sidebar` is
- provided, `fillable` makes the main content portion fillable.
- gap
- A CSS length unit defining the gap (i.e., spacing) between elements provided to
- `*args`.
- padding
- Padding to use for the body. This can be a numeric vector (which will be
- interpreted as pixels) or a character vector with valid CSS lengths. The length
- can be between one and four. If one, then that value will be used for all four
- sides. If two, then the first value will be used for the top and bottom, while
- the second value will be used for left and right. If three, then the first will
- be used for top, the second will be left and right, and the third will be
- bottom. If four, then the values will be interpreted as top, right, bottom, and
- left respectively.
header
UI to display above the selected content.
footer
@@ -726,7 +709,7 @@ def navset_card_tab(
See Also
--------
- * ~shiny.ui.nav
+ * ~shiny.ui.nav_panel
* ~shiny.ui.nav_menu
* ~shiny.ui.nav_control
* ~shiny.ui.nav_spacer
@@ -741,7 +724,7 @@ def navset_card_tab(
Example
-------
- See :func:`~shiny.ui.nav`
+ See :func:`~shiny.ui.nav_panel`
"""
return NavSetCard(
@@ -773,7 +756,7 @@ def navset_card_pill(
Parameters
----------
*args
- A collection of nav items (e.g., :func:`shiny.ui.nav`).
+ A collection of nav items (e.g., :func:`shiny.ui.nav_panel`).
id
If provided, will create an input value that holds the currently selected nav
item.
@@ -781,7 +764,7 @@ def navset_card_pill(
Choose a particular nav item to select by default value (should match it's
``value``).
sidebar
- A :class:`shiny.ui.Sidebar` component to display on every :func:`~shiny.ui.nav` page.
+ A :class:`shiny.ui.Sidebar` component to display on every :func:`~shiny.ui.nav_panel` page.
header
UI to display above the selected content.
footer
@@ -791,7 +774,7 @@ def navset_card_pill(
See Also
--------
- * ~shiny.ui.nav
+ * ~shiny.ui.nav_panel
* ~shiny.ui.nav_menu
* ~shiny.ui.nav_control
* ~shiny.ui.nav_spacer
@@ -806,7 +789,7 @@ def navset_card_pill(
Example
-------
- See :func:`~shiny.ui.nav`
+ See :func:`~shiny.ui.nav_panel`
"""
return NavSetCard(
@@ -833,12 +816,12 @@ def navset_card_underline(
placement: Literal["above", "below"] = "above",
) -> NavSetCard:
"""
- Render nav items active/focused navigation links are styled with an underline inside a card container.
+ Render nav items inside a card container. Active/focused navigation links are styled with an underline.
Parameters
----------
*args
- A collection of nav items (e.g., :func:`shiny.ui.nav`).
+ A collection of nav items (e.g., :func:`shiny.ui.nav_panel`).
id
If provided, will create an input value that holds the currently selected nav
item.
@@ -846,7 +829,7 @@ def navset_card_underline(
Choose a particular nav item to select by default value (should match it's
``value``).
sidebar
- A :class:`shiny.ui.Sidebar` component to display on every :func:`~shiny.ui.nav` page.
+ A :class:`shiny.ui.Sidebar` component to display on every :func:`~shiny.ui.nav_panel` page.
header
UI to display above the selected content.
footer
@@ -856,7 +839,7 @@ def navset_card_underline(
See Also
--------
- * ~shiny.ui.nav
+ * ~shiny.ui.nav_panel
* ~shiny.ui.nav_menu
* ~shiny.ui.nav_control
* ~shiny.ui.nav_spacer
@@ -871,7 +854,7 @@ def navset_card_underline(
Example
-------
- See :func:`~shiny.ui.nav`
+ See :func:`~shiny.ui.nav_panel`
"""
return NavSetCard(
*args,
@@ -935,7 +918,7 @@ def navset_pill_list(
Parameters
----------
*args
- A collection of nav items (e.g., :func:`shiny.ui.nav`).
+ A collection of nav items (e.g., :func:`shiny.ui.nav_panel`).
id
If provided, will create an input value that holds the currently selected nav
item.
@@ -953,7 +936,7 @@ def navset_pill_list(
See Also
--------
- * ~shiny.ui.nav
+ * ~shiny.ui.nav_panel
* ~shiny.ui.nav_menu
* ~shiny.ui.nav_control
* ~shiny.ui.nav_spacer
@@ -968,7 +951,7 @@ def navset_pill_list(
Example
-------
- See :func:`~shiny.ui.nav`
+ See :func:`~shiny.ui.nav_panel`
"""
return NavSetPillList(
@@ -1129,7 +1112,7 @@ def _make_tabs_fillable(
# must to be a fillable container.
content = as_fillable_container(as_fill_item(content))
- for child in content.children:
+ for i, child in enumerate(content.children):
# Only work on Tags
if not isinstance(child, Tag):
continue
@@ -1146,9 +1129,11 @@ def _make_tabs_fillable(
padding=as_css_padding(padding),
__bslib_navbar_margin="0;" if navbar else None,
)
- child = tag_add_style(child, styles)
+ child.add_style(cast(str, styles))
child = as_fillable_container(as_fill_item(child))
+ content.children[i] = child
+
return content
@@ -1180,7 +1165,7 @@ def navset_bar(
Parameters
----------
*args
- A collection of nav items (e.g., :func:`shiny.ui.nav`).
+ A collection of nav items (e.g., :func:`shiny.ui.nav_panel`).
title
Title to display in the navbar.
id
@@ -1190,7 +1175,7 @@ def navset_bar(
Choose a particular nav item to select by default value (should match it's
``value``).
sidebar
- A :class:`~shiny.ui.Sidebar` component to display on every :func:`~shiny.ui.nav` page.
+ A :class:`~shiny.ui.Sidebar` component to display on every :func:`~shiny.ui.nav_panel` page.
fillable
Whether or not to allow fill items to grow/shrink to fit the browser window. If
`True`, all `nav()` pages are fillable. A character vector, matching the value
@@ -1230,7 +1215,7 @@ def navset_bar(
See Also
--------
* ~shiny.ui.page_navbar
- * ~shiny.ui.nav
+ * ~shiny.ui.nav_panel
* ~shiny.ui.nav_menu
* ~shiny.ui.nav_control
* ~shiny.ui.nav_spacer
@@ -1245,7 +1230,7 @@ def navset_bar(
Example
-------
- See :func:`~shiny.ui.nav`.
+ See :func:`~shiny.ui.nav_panel`.
"""
# If args contains any lists, flatten them into args.
@@ -1394,3 +1379,24 @@ def navset_tab_card(
header=header,
footer=footer,
)
+
+
+# Deprecated 2023-12-07
+def nav(
+ title: TagChild,
+ *args: TagChild,
+ value: Optional[str] = None,
+ icon: TagChild = None,
+) -> NavPanel:
+ """Deprecated. Please use `nav_panel()` instead of `nav()`."""
+ warn_deprecated(
+ "`nav()` is deprecated. "
+ "This method will be removed in a future version, "
+ "please use :func:`~shiny.ui.nav_panel` instead."
+ )
+ return nav_panel(
+ title,
+ *args,
+ value=value,
+ icon=icon,
+ )
diff --git a/shiny/ui/_notification.py b/shiny/ui/_notification.py
index 40d4c83f7..15f9d6f50 100644
--- a/shiny/ui/_notification.py
+++ b/shiny/ui/_notification.py
@@ -25,17 +25,22 @@ def notification_show(
"""
Show a notification to the user.
+ A notification is a message that appears near the bottom corner of the app.
+ Notifications normally disappear after a short period of time, and should multiple
+ notifications appear together, they will stack on top of one another.
+
Parameters
----------
ui
- Content of message.
+ Contents of the notification message.
action
Message content that represents an action. For example, this could be a link
that the user can click on. This is separate from ui so customized layouts can
- handle the main notification content separately from action content.
+ handle the main notification content separately from the action content.
duration
Number of seconds to display the message before it disappears. Use ``None`` to
- make the message not automatically disappear.
+ prevent the message from disappearing automatically. The user will need to click
+ the corner of the notification to close it.
close_button
If ``True``, display a button which will make the notification disappear when
clicked. If ``False`` do not display.
@@ -44,11 +49,11 @@ def notification_show(
notification with the same ``id`` will be replaced with this one (otherwise, a
new notification is created).
type
- A string which controls the color of the notification. One of "default" (gray),
- "message" (blue), "warning" (yellow), or "error" (red).
+ A string which controls the color of the notification. This should be one of
+ "default" (gray), "message" (blue), "warning" (yellow), or "error" (red).
session
- A :class:`~shiny.Session` instance. If not provided, it is inferred via
- :func:`~shiny.session.get_current_session`.
+ The :class:`~shiny.Session` in which the notification should appear. If not
+ provided, the session is inferred via :func:`~shiny.session.get_current_session`.
Returns
-------
@@ -89,12 +94,16 @@ def notification_remove(id: str, *, session: Optional[Session] = None) -> str:
"""
Remove a notification.
+ :func:`~shiny.ui.notification_remove` provides a way to remove a notification programatically.
+ Notifications can also be removed manually by the user, or automatically after a
+ specififed amont of time passes.
+
Parameters
----------
id
- A notification ``id``.
+ The ``id`` of the notification to remove.
session
- A :class:`~shiny.Session` instance. If not provided, it is inferred via
+ The :class:`~shiny.Session` in which the notification appears. If not provided, the session is inferred via
:func:`~shiny.session.get_current_session`.
Returns
diff --git a/shiny/ui/_output.py b/shiny/ui/_output.py
index db780ca1b..7accac6a1 100644
--- a/shiny/ui/_output.py
+++ b/shiny/ui/_output.py
@@ -246,7 +246,7 @@ def output_text(
id
An output id.
inline
- If ``True``, the result is displayed inline
+ If ``True``, the result is displayed inline.
container
A Callable that returns the output container.
@@ -284,7 +284,8 @@ def output_text_verbatim(id: str, placeholder: bool = False) -> Tag:
An output id.
placeholder
If the output is empty or ``None``, should an empty rectangle be displayed to
- serve as a placeholder? (does not affect behavior when the output is nonempty)
+ serve as a placeholder? (This does not affect behavior when the output
+ is nonempty.)
Returns
-------
@@ -345,7 +346,7 @@ def output_ui(
id
An output id.
inline
- If ``True``, the result is displayed inline
+ If ``True``, the result is displayed inline.
container
A Callable that returns the output container.
fill
@@ -354,7 +355,7 @@ def output_ui(
fillable
Whether or not the UI output area should be considered a fillable (i.e.,
flexbox) container.
- kwargs
+ **kwargs
Attributes to be applied to the output container.
Returns
diff --git a/shiny/ui/_page.py b/shiny/ui/_page.py
index 98eee94cd..207bd1ab0 100644
--- a/shiny/ui/_page.py
+++ b/shiny/ui/_page.py
@@ -36,7 +36,7 @@
from ._tag import consolidate_attrs
from ._utils import get_window_title
from .css import CssUnit, as_css_padding, as_css_unit
-from .fill._fill import FILLABLE_CONTAINTER_ATTRS
+from .fill._fill import as_fillable_container
def page_sidebar(
@@ -56,7 +56,7 @@ def page_sidebar(
----------
sidebar
Content to display in the sidebar.
- args
+ *args
UI elements.
title
A title to display at the top of the page.
@@ -72,7 +72,7 @@ def page_sidebar(
ISO 639-1 language code for the HTML page, such as ``"en"`` or ``"ko"``. This
will be used as the lang in the ```` tag, as in ````. The
default, `None`, results in an empty string.
- kwargs
+ **kwargs
Additional attributes passed to :func:`~shiny.ui.layout_sidebar`.
Returns
@@ -135,7 +135,7 @@ def page_navbar(
Parameters
----------
- args
+ *args
UI elements.
title
The browser window title (defaults to the host URL of the page). Can also be set
@@ -144,7 +144,7 @@ def page_navbar(
If provided, will create an input value that holds the currently selected nav
item.
selected
- Choose a particular nav item to select by default value (should match it's
+ Choose a particular nav item to select by default value (should match its
``value``).
sidebar
A :func:`~shiny.ui.sidebar` component to display on every page.
@@ -261,7 +261,7 @@ def page_fillable(
**kwargs: TagAttrValue,
) -> Tag:
"""
- Creates a fillable page
+ Create a fillable page.
Parameters
----------
@@ -298,15 +298,10 @@ def page_fillable(
style = css(padding=as_css_padding(padding), gap=as_css_unit(gap))
- return page_bootstrap(
+ page = page_bootstrap(
head_content(tags.style("html { height: 100%; }")),
- # Even though page_bootstrap accepts *args/**kwargs, we need to prepend the
- # class value to the tags.body. To avoid having a within a for a
- # core code path, we can manually use `FILLABLE_CONTAINER_ATTRS` here as the
- # first set of attributes.
- FILLABLE_CONTAINTER_ATTRS,
{"class": "bslib-page-fill bslib-gap-spacing", "style": style},
- {"class": "bslib-flow-mobile"} if fillable_mobile else None,
+ {"class": "bslib-flow-mobile"} if not fillable_mobile else None,
attrs,
*children,
components_dependency(),
@@ -314,6 +309,15 @@ def page_fillable(
lang=lang,
)
+ # page returns a tag, but we need to make the fillable
+ body = page.children[1]
+ if not isinstance(body, Tag) or body.name != "body":
+ raise ValueError("Expected a tag")
+
+ page.children[1] = as_fillable_container(body)
+
+ return page
+
@add_example()
def page_fluid(
@@ -327,7 +331,7 @@ def page_fluid(
Parameters
----------
- args
+ *args
UI elements.
title
The browser window title (defaults to the host URL of the page). Can also be set
@@ -336,7 +340,7 @@ def page_fluid(
ISO 639-1 language code for the HTML page, such as ``"en"`` or ``"ko"``. This
will be used as the lang in the ```` tag, as in ````. The
default, `None`, results in an empty string.
- kwargs
+ **kwargs
Attributes on the page level container.
Returns
@@ -368,7 +372,7 @@ def page_fixed(
Parameters
----------
- args
+ *args
UI elements.
title
The browser window title (defaults to the host URL of the page). Can also be set
@@ -377,7 +381,7 @@ def page_fixed(
ISO 639-1 language code for the HTML page, such as ``"en"`` or ``"ko"``. This
will be used as the lang in the ```` tag, as in ````. The
default, `None`, results in an empty string.
- kwargs
+ **kwargs
Attributes on the page level container.
Returns
@@ -409,7 +413,7 @@ def page_bootstrap(
Parameters
----------
- args
+ *args
UI elements.
title
The browser window title (defaults to the host URL of the page). Can also be set
@@ -418,7 +422,7 @@ def page_bootstrap(
ISO 639-1 language code for the HTML page, such as ``"en"`` or ``"ko"``. This
will be used as the lang in the ```` tag, as in ````. The
default, `None`, results in an empty string.
- kwargs
+ **kwargs
Attributes on the the `` tag.
Returns
diff --git a/shiny/ui/_popover.py b/shiny/ui/_popover.py
index da11aca5e..93c476759 100644
--- a/shiny/ui/_popover.py
+++ b/shiny/ui/_popover.py
@@ -112,7 +112,6 @@ def fa_gear_icon(title: str):
See Also
--------
*
- * :func:`~shiny.ui.toggle_popover`
* :func:`~shiny.ui.update_popover`
* :func:`~shiny.ui.tooltip`
"""
diff --git a/shiny/ui/_progress.py b/shiny/ui/_progress.py
index 253916675..735ae032c 100644
--- a/shiny/ui/_progress.py
+++ b/shiny/ui/_progress.py
@@ -16,6 +16,11 @@ class Progress:
"""
Initialize a progress bar.
+ :func:`~shiny.ui.Progress` creates a computation manager that can be used with `with` to
+ run a block of code. Shiny will display a progress bar while the code runs, which
+ you can update by calling the `set()` and `message()` methods of the computation
+ manager at strategic points in the code block.
+
Parameters
----------
min
@@ -25,8 +30,8 @@ class Progress:
The value that represents the end of the progress bar. Must be greater than
``min``.
session
- A :class:`~shiny.Session` instance. If not provided, it is inferred via
- :func:`~shiny.session.get_current_session`.
+ The :class:`~shiny.Session` instance that the progress bar should appear in. If not
+ provided, the session is inferred via :func:`~shiny.session.get_current_session`.
"""
_style = "notification"
@@ -66,8 +71,9 @@ def set(
detail: Optional[str] = None,
) -> None:
"""
- Updates the progress panel. When called the first time, the progress panel is
- displayed.
+ Opens and updates the progress panel.
+
+ When called the first time, the progress panel is displayed.
Parameters
----------
diff --git a/shiny/ui/_sidebar.py b/shiny/ui/_sidebar.py
index f5a7bd1b2..ea5c4ee00 100644
--- a/shiny/ui/_sidebar.py
+++ b/shiny/ui/_sidebar.py
@@ -40,7 +40,7 @@
class Sidebar:
"""
- Sidebar object
+ A sidebar object
Class returned from :func:`~shiny.ui.sidebar`. Please do not use this
class directly. Instead, supply the :func:`~shiny.ui.sidebar` object to
@@ -55,7 +55,7 @@ class directly. Instead, supply the :func:`~shiny.ui.sidebar` object to
position
Where the sidebar should appear relative to the main content.
open
- The initial state of the sidebar.
+ The initial state of the sidebar (open or collapsed).
width
A valid CSS unit used for the width of the sidebar.
max_height_mobile
@@ -77,7 +77,7 @@ class directly. Instead, supply the :func:`~shiny.ui.sidebar` object to
position
Where the sidebar should appear relative to the main content.
open
- The initial state of the sidebar.
+ The initial state of the sidebar (open or collapsed).
width
A valid CSS unit used for the width of the sidebar.
max_height_mobile
@@ -168,10 +168,12 @@ def sidebar(
position
Where the sidebar should appear relative to the main content.
open
- The initial state of the sidebar. It can be `"desktop"` (the sidebar starts open
- on desktop screen, closed on mobile), `"open"` or `True` (the sidebar starts
- open), `"closed"` or `False` (the sidebar starts closed), or `"always"` or
- `None` (the sidebar is always open and cannot be closed).
+ The initial state of the sidebar.
+
+ * `"desktop"`: the sidebar starts open on desktop screen, closed on mobile
+ * `"open"` or `True`: the sidebar starts open
+ * `"closed"` or `False`: the sidebar starts closed
+ * `"always"` or `None`: the sidebar is always open and cannot be closed
In :func:`~shiny.ui.update_sidebar`, `open` indicates the desired state of the
sidebar. Note that :func:`~shiny.ui.update_sidebar` can only open or close the
@@ -200,12 +202,15 @@ def sidebar(
padding
Padding within the sidebar itself. This can be a numeric vector (which will be
interpreted as pixels) or a character vector with valid CSS lengths. `padding`
- may be one to four values. If one, then that value will be used for all four
- sides. If two, then the first value will be used for the top and bottom, while
- the second value will be used for left and right. If three, then the first will
- be used for top, the second will be left and right, and the third will be
- bottom. If four, then the values will be interpreted as top, right, bottom, and
- left respectively.
+ may be one to four values.
+
+ * If a single value, then that value will be used for all four sides.
+ * If two, then the first value will be used for the top and bottom, while
+ the second value will be used for left and right.
+ * If three values, then the first will be used for top, the second will be left
+ and right, and the third will be bottom.
+ * If four, then the values will be interpreted as top, right, bottom, and left
+ respectively.
Returns
-------
@@ -337,12 +342,15 @@ def layout_sidebar(
padding
Padding within the sidebar itself. This can be a numeric vector (which will be
interpreted as pixels) or a character vector with valid CSS lengths. `padding`
- may be one to four values. If one, then that value will be used for all four
- sides. If two, then the first value will be used for the top and bottom, while
- the second value will be used for left and right. If three, then the first will
- be used for top, the second will be left and right, and the third will be
- bottom. If four, then the values will be interpreted as top, right, bottom, and
- left respectively.
+ may be one to four values.
+
+ * If a single value, then that value will be used for all four sides.
+ * If two, then the first value will be used for the top and bottom, while
+ the second value will be used for left and right.
+ * If three values, then the first will be used for top, the second will be left
+ and right, and the third will be bottom.
+ * If four, then the values will be interpreted as top, right, bottom, and left
+ respectively.
height
Any valid CSS unit to use for the height.
@@ -504,7 +512,7 @@ def update_sidebar(
session: Optional[Session] = None,
) -> None:
"""
- Update a sidebar's visibility
+ Update a sidebar's visibility.
Set a :func:`~shiny.ui.sidebar` state during an active Shiny user session.
@@ -574,8 +582,7 @@ def panel_sidebar(
width: int = 4,
**kwargs: TagAttrValue,
) -> DeprecatedPanelSidebar:
- """Deprecated. Please use :func:`shiny.ui.sidebar` instead of
- `ui.panel_sidebar()`."""
+ """Deprecated. Please use :func:`~shiny.ui.sidebar` instead."""
# TODO-future: >= 2024-01-01; Add deprecation message below
# Plan of action:
# * No deprecation messages today (2023-10-11), and existing code _just works_.
@@ -597,7 +604,7 @@ def panel_main(
width: int = 8,
**kwargs: TagAttrValue,
) -> DeprecatedPanelMain:
- """Deprecated. Please supply `panel_main(*args)` directly to `layout_sidebar()`."""
+ """Deprecated. Please supply the `*args` of :func:`~shiny.ui.panel_main` directly to :func:`~shiny.ui.layout_sidebar`."""
# TODO-future: >= 2023-11-01; Add deprecation message below
# warn_deprecated("Please use `layout_sidebar(*args)` instead of `panel_main()`. `panel_main()` will go away in a future version of Shiny.")
diff --git a/shiny/ui/_tag.py b/shiny/ui/_tag.py
index f508c70d2..8ed5d2dca 100644
--- a/shiny/ui/_tag.py
+++ b/shiny/ui/_tag.py
@@ -2,7 +2,7 @@
from typing import TypeVar, cast, overload
-from htmltools import Tag, TagAttrs, TagAttrValue, TagChild, div
+from htmltools import TagAttrs, TagAttrValue, TagChild, div
TagChildT = TypeVar("TagChildT", bound=TagChild)
@@ -60,104 +60,3 @@ def trinary(x: bool | str | None) -> None | str:
return "true"
else:
return "false"
-
-
-TagT = TypeVar("TagT", bound="Tag")
-
-# Tag.add_class(x: str) -> Self[Tag]:
-# cls = self.attrs.get("class")
-# if cls:
-# x = cls + " " + x
-# self.attrs["class"] = x
-# return self
-
-
-# Do not export
-# "Prepend" version of `tag.add_class(class_)`
-def tag_prepend_class(tag: TagT, *class_: str | None) -> TagT:
- classes = (
- *class_,
- tag.attrs.get("class"),
- )
- classes = [c for c in classes if c is not None]
- if len(classes) == 0:
- return tag
- tag.attrs["class"] = " ".join(classes)
- return tag
-
-
-def tag_remove_class(tag: TagT, *class_: str | None) -> TagT:
- """
- Remove a class value from the HTML class attribute.
-
- Parameters
- ----------
- *class_
- The class name to remove.
-
- Returns
- -------
- :
- The modified tag.
- """
- cls = tag.attrs.get("class")
- # If no class values to remove from, quit
- if not cls:
- return tag
-
- # Remove any `None` values
- set_to_remove = {c for c in class_ if c is not None}
-
- # If no classes to remove, quit
- if len(set_to_remove) == 0:
- return tag
-
- # Get new set of classes
- # Order matters, otherwise we could use `set()` subtraction: `set(cls.split(" ")) - set(class_)`
- new_cls: list[str] = []
- for cls_val in cls.split(" "):
- if cls_val not in set_to_remove:
- new_cls.append(cls_val)
-
- # If no classes left, remove the attribute
- if len(new_cls) == 0:
- # If here, `attrs.class` must exist
- tag.attrs.pop("class")
- return tag
-
- # Otherwise, set the new class
- tag.attrs["class"] = " ".join(new_cls)
- return tag
-
-
-def tag_add_style(
- tag: TagT,
- *style: str | None,
-) -> TagT:
- """
- Add a style value(s) to the HTML style attribute.
-
- Parameters
- ----------
- *style
- CSS properties and values already properly formatted. Each should already contain trailing semicolons.
-
- See Also
- --------
- ~htmltools.css
-
- Returns
- -------
- :
- The modified tag.
- """
- styles = (
- tag.attrs.get("style"),
- *style,
- )
- non_none_style_tuple = (s for s in styles if s is not None)
- style_str = "".join(non_none_style_tuple)
-
- if style_str:
- tag.attrs["style"] = style_str
- return tag
diff --git a/shiny/ui/_tooltip.py b/shiny/ui/_tooltip.py
index 0fb54d5ed..85c3b7a76 100644
--- a/shiny/ui/_tooltip.py
+++ b/shiny/ui/_tooltip.py
@@ -19,7 +19,7 @@ def tooltip(
**kwargs: TagAttrValue,
) -> Tag:
"""
- Add a tooltip to a UI element
+ Add a tooltip to a UI element.
Display additional information when focusing (or hovering over) a UI element.
@@ -35,7 +35,7 @@ def tooltip(
Contents to the tooltip's body. Or tag attributes that are supplied to the
resolved :class:`~htmltools.Tag` object.
id
- A character string. Required to re-actively respond to the visibility of the
+ A character string. Required to reactively respond to the visibility of the
tooltip (via the `input[id]` value) and/or update the visibility/contents of the
tooltip.
placement
diff --git a/shiny/ui/_valuebox.py b/shiny/ui/_valuebox.py
index 1f7f77c69..219c77cbd 100644
--- a/shiny/ui/_valuebox.py
+++ b/shiny/ui/_valuebox.py
@@ -247,11 +247,11 @@ def value_box_theme(
Parameters
---------
name
- The name of the theme, e.g. `"primary"`, `"danger"`, `"purple"`). `name` can
- also be a bootstrap supported color: `"blue"`, `"purple"`, `"pink"`, `"red"`,
+ The name of the theme, e.g. `"primary"`, `"danger"`, `"purple"`. `name` can
+ also be a Bootstrap-supported color: `"blue"`, `"purple"`, `"pink"`, `"red"`,
`"orange"`, `"yellow"`, `"green"`, `"teal"`, and `"cyan"`. These colors can be
used with `bg-NAME`, `text-NAME`, and `bg-gradient-NAME1-NAME2`. If a `name`
- does not start with `text-` or `bg-`, it will be auto prefixed with `bg-`.
+ does not start with `text-` or `bg-`, it will be auto-prefixed with `bg-`.
fg,bg
The background and foreground colors for the theme.
@@ -312,7 +312,7 @@ def value_box(
Value box
An opinionated (:func:`~shiny.ui.card`-powered) box, designed for
- displaying a `value` and `title`. Optionally, a `showcase` can provide for context
+ displaying a `value` and `title`. Optionally, a `showcase` can provide context
for what the `value` represents (for example, it could hold an icon, or even a
:func:`~shiny.ui.output_plot`).
@@ -331,22 +331,26 @@ def value_box(
showcase_layout
One of `"left center"` (default), `"top right"` or `"bottom"`. Alternatively,
you can customize the showcase layout options with the
- :func:`~shiny.ui.showcase_left_center`, :func:`~shiny.ui.showcase_top_right()`,
- or :func:`~shiny.ui.showcase_bottom()` functions. Use the options functions when
+ :func:`~shiny.ui.showcase_left_center`, :func:`~shiny.ui.showcase_top_right`,
+ or :func:`~shiny.ui.showcase_bottom` functions. Use the options functions when
you want to control the height or width of the showcase area.
- theme
+ theme
The name of a theme (e.g. `"primary"`, `"danger"`, `"purple"`, `"bg-green"`,
`"text-red"`) for the value box, or a theme constructed with
- :func:`~shiny.ui.value_box_theme`. The theme names provide a convenient way to
- use your app's Bootstrap theme colors as the foreground or background colors of
- the value box. For more control, you can create your own theme with
- :func:`~shiny.ui.value_box_theme` where you can pass foreground and background
- colors directly. Bootstrap supported color themes: `"blue"`, `"purple"`,
- `"pink"`, `"red"`, `"orange"`, `"yellow"`, `"green"`, `"teal"`, and `"cyan"`.
- These colors can be used with `bg-NAME`, `text-NAME`, and
- `bg-gradient-NAME1-NAME2` to change the background, foreground, or use a
- background gradient respectively. If a `theme` string does not start with
- `text-` or `bg-`, it will be auto prefixed with `bg-`.
+ :func:`~shiny.ui.value_box_theme`.
+
+ The theme names provide a convenient way to use your app's Bootstrap theme
+ colors as the foreground or background colors of the value box. For more
+ control, you can create your own theme with :func:`~shiny.ui.value_box_theme`
+ where you can pass foreground and background colors directly.
+
+ Bootstrap supported color themes: `"blue"`, `"purple"`, `"pink"`, `"red"`,
+ `"orange"`, `"yellow"`, `"green"`, `"teal"`, and `"cyan"`. These colors can be
+ used with `bg-NAME`, `text-NAME`, and `bg-gradient-NAME1-NAME2` to change the
+ background, foreground, or use a background gradient respectively.
+
+ If a `theme` string does not start with `text-` or `bg-`, it will be auto
+ prefixed with `bg-`.
full_screen
If `True`, an icon will appear when hovering over the card body. Clicking the
icon expands the card to fit viewport size.
diff --git a/shiny/ui/fill/_fill.py b/shiny/ui/fill/_fill.py
index 87f58bd37..6dd6d1c88 100644
--- a/shiny/ui/fill/_fill.py
+++ b/shiny/ui/fill/_fill.py
@@ -1,12 +1,12 @@
from __future__ import annotations
+from copy import copy
from typing import TypeVar
from htmltools import Tag, TagAttrs
from ..._docstring import add_example
from .._html_deps_shinyverse import fill_dependency
-from .._tag import tag_prepend_class, tag_remove_class
__all__ = (
"as_fillable_container",
@@ -31,22 +31,21 @@
@add_example()
-# TODO-future-API; These methods mutate their input values. Should they return a new object instead? Or not return at all (like `LIST.sort()`)?
def as_fillable_container(
tag: TagT,
) -> TagT:
- tag_prepend_class(tag, FILL_CONTAINER_CLASS)
- tag.append(fill_dependency())
- return tag
+ res = copy(tag)
+ res.add_class(FILL_CONTAINER_CLASS)
+ res.append(fill_dependency())
+ return res
@add_example()
-# TODO-future-API; These methods mutate their input values. Should they return a new object instead? Or not return at all (like `LIST.sort()`)?
def as_fill_item(
tag: TagT,
) -> TagT:
"""
- Coerce a tag to a fill item
+ Coerce a tag to a fill item.
Filling layouts are built on the foundation of _fillable containers_ and _fill
items_ (_fill carriers_ are both _fillable containers_ and _fill items_). This is
@@ -64,24 +63,25 @@ def as_fill_item(
Returns
-------
:
- The original :class:`~htmltools.Tag` object (`tag`) with additional attributes
- (and an :class:`~htmltools.HTMLDependency`).
+ A copy of the original :class:`~htmltools.Tag` object (`tag`) with additional
+ attributes (and an :class:`~htmltools.HTMLDependency`).
See Also
--------
* :func:`~shiny.ui.fill.as_fillable_container`
* :func:`~shiny.ui.fill.remove_all_fill`
"""
- tag_prepend_class(tag, FILL_ITEM_CLASS)
- tag.append(fill_dependency())
- return tag
+ res = copy(tag)
+ res.add_class(FILL_ITEM_CLASS)
+ res.append(fill_dependency())
+ return res
def remove_all_fill(
tag: TagT,
) -> TagT:
"""
- Remove any filling layouts from a tag
+ Remove any filling layouts from a tag.
Filling layouts are built on the foundation of _fillable containers_ and _fill
items_ (_fill carriers_ are both _fillable containers_ and _fill items_). This is
@@ -109,8 +109,8 @@ def remove_all_fill(
* :func:`~shiny.ui.fill.as_fillable_container`
"""
- tag_remove_class(tag, FILL_CONTAINER_CLASS)
- tag_remove_class(tag, FILL_ITEM_CLASS)
+ tag.remove_class(FILL_CONTAINER_CLASS)
+ tag.remove_class(FILL_ITEM_CLASS)
return tag
diff --git a/shiny/www/shared/bootstrap/_version.json b/shiny/www/shared/bootstrap/_version.json
index 25f3fbe75..bcff3dd6d 100644
--- a/shiny/www/shared/bootstrap/_version.json
+++ b/shiny/www/shared/bootstrap/_version.json
@@ -1,7 +1,7 @@
{
"note!": "This file is auto-generated by scripts/htmlDependencies.R",
"shiny_version": "CRAN (R 4.3.1)",
- "bslib_version": "CRAN (R 4.3.1)",
+ "bslib_version": "Github (rstudio/bslib@f05bd23d7df5a7465e418a5794925dacdd27bb6b)",
"htmltools_version": "CRAN (R 4.3.1)",
"bootstrap_version": "5.3.1"
}
diff --git a/shiny/www/shared/bootstrap/bootstrap.min.css b/shiny/www/shared/bootstrap/bootstrap.min.css
index ec247f46f..a9d99d005 100644
--- a/shiny/www/shared/bootstrap/bootstrap.min.css
+++ b/shiny/www/shared/bootstrap/bootstrap.min.css
@@ -3,5 +3,3 @@
* Copyright 2011-2023 The Bootstrap Authors
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
*/:root,[data-bs-theme="light"]{--bs-blue: #007bc2;--bs-indigo: #4b00c1;--bs-purple: #74149c;--bs-pink: #bf007f;--bs-red: #c10000;--bs-orange: #f45100;--bs-yellow: #f9b928;--bs-green: #00891a;--bs-teal: #00bf7f;--bs-cyan: #03c7e8;--bs-black: #000;--bs-white: #fff;--bs-gray: #707782;--bs-gray-dark: #343A46;--bs-gray-100: #f8f8f8;--bs-gray-200: #e9ecef;--bs-gray-300: #dee2e6;--bs-gray-400: #cdd4da;--bs-gray-500: #8D959E;--bs-gray-600: #707782;--bs-gray-700: #48505F;--bs-gray-800: #343A46;--bs-gray-900: #1D1F21;--bs-default: #dee2e6;--bs-primary: #007bc2;--bs-secondary: #404040;--bs-success: #00891a;--bs-info: #03c7e8;--bs-warning: #f9b928;--bs-danger: #c10000;--bs-light: #f8f8f8;--bs-dark: #202020;--bs-default-rgb: 222,226,230;--bs-primary-rgb: 0,123,194;--bs-secondary-rgb: 64,64,64;--bs-success-rgb: 0,137,26;--bs-info-rgb: 3,199,232;--bs-warning-rgb: 249,185,40;--bs-danger-rgb: 193,0,0;--bs-light-rgb: 248,248,248;--bs-dark-rgb: 32,32,32;--bs-primary-text-emphasis: #00314e;--bs-secondary-text-emphasis: #1a1a1a;--bs-success-text-emphasis: #00370a;--bs-info-text-emphasis: #01505d;--bs-warning-text-emphasis: #644a10;--bs-danger-text-emphasis: #4d0000;--bs-light-text-emphasis: #48505F;--bs-dark-text-emphasis: #48505F;--bs-primary-bg-subtle: #cce5f3;--bs-secondary-bg-subtle: #d9d9d9;--bs-success-bg-subtle: #cce7d1;--bs-info-bg-subtle: #cdf4fa;--bs-warning-bg-subtle: #fef1d4;--bs-danger-bg-subtle: #f3cccc;--bs-light-bg-subtle: #fcfcfc;--bs-dark-bg-subtle: #cdd4da;--bs-primary-border-subtle: #99cae7;--bs-secondary-border-subtle: #b3b3b3;--bs-success-border-subtle: #99d0a3;--bs-info-border-subtle: #9ae9f6;--bs-warning-border-subtle: #fde3a9;--bs-danger-border-subtle: #e69999;--bs-light-border-subtle: #e9ecef;--bs-dark-border-subtle: #8D959E;--bs-white-rgb: 255,255,255;--bs-black-rgb: 0,0,0;--bs-font-sans-serif: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", "Noto Sans", "Liberation Sans", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--bs-font-monospace: "Source Code Pro", SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--bs-gradient: linear-gradient(180deg, rgba(255,255,255,0.15), rgba(255,255,255,0));--bs-body-font-family: "Open Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--bs-body-font-size:1rem;--bs-body-font-weight: 400;--bs-body-line-height: 1.5;--bs-body-color: #1D1F21;--bs-body-color-rgb: 29,31,33;--bs-body-bg: #fff;--bs-body-bg-rgb: 255,255,255;--bs-emphasis-color: #000;--bs-emphasis-color-rgb: 0,0,0;--bs-secondary-color: rgba(29,31,33,0.75);--bs-secondary-color-rgb: 29,31,33;--bs-secondary-bg: #e9ecef;--bs-secondary-bg-rgb: 233,236,239;--bs-tertiary-color: rgba(29,31,33,0.5);--bs-tertiary-color-rgb: 29,31,33;--bs-tertiary-bg: #f8f8f8;--bs-tertiary-bg-rgb: 248,248,248;--bs-heading-color: inherit;--bs-link-color: #007bc2;--bs-link-color-rgb: 0,123,194;--bs-link-decoration: underline;--bs-link-hover-color: #00629b;--bs-link-hover-color-rgb: 0,98,155;--bs-code-color: RGB(var(--bs-emphasis-color-rgb, 0, 0, 0));--bs-highlight-bg: #fef1d4;--bs-border-width: 1px;--bs-border-style: solid;--bs-border-color: #dee2e6;--bs-border-color-translucent: rgba(40,70,94,0.1);--bs-border-radius: 3px;--bs-border-radius-sm: .25rem;--bs-border-radius-lg: .5rem;--bs-border-radius-xl: 1rem;--bs-border-radius-xxl: 2rem;--bs-border-radius-2xl: var(--bs-border-radius-xxl);--bs-border-radius-pill: 50rem;--bs-box-shadow: 0px 1px 2px RGBA(var(--bslib-box-shadow-color-rgb), 0.1),0px 3px 7px RGBA(var(--bslib-box-shadow-color-rgb), 0.1),0px 12px 30px RGBA(var(--bslib-box-shadow-color-rgb), 0.08);--bs-box-shadow-sm: 0px 1px 2px RGBA(var(--bslib-box-shadow-color-rgb), 0.1),0px 2px 3px RGBA(var(--bslib-box-shadow-color-rgb), 0.1),0px 3px 8px RGBA(var(--bslib-box-shadow-color-rgb), 0.1);--bs-box-shadow-lg: 0px 16px 48px RGBA(var(--bslib-box-shadow-color-rgb), 0.1),0px 2px 3px RGBA(var(--bslib-box-shadow-color-rgb), 0.1),0px 16px 46px RGBA(var(--bslib-box-shadow-color-rgb), 0.1);--bs-box-shadow-inset: inset 0 1px 2px rgba(0,0,0,0.075);--bs-focus-ring-width: .25rem;--bs-focus-ring-opacity: .25;--bs-focus-ring-color: rgba(0,123,194,0.25);--bs-form-valid-color: #00891a;--bs-form-valid-border-color: #00891a;--bs-form-invalid-color: #c10000;--bs-form-invalid-border-color: #c10000}[data-bs-theme="dark"]{color-scheme:dark;--bs-body-color: #dee2e6;--bs-body-color-rgb: 222,226,230;--bs-body-bg: #1D1F21;--bs-body-bg-rgb: 29,31,33;--bs-emphasis-color: #fff;--bs-emphasis-color-rgb: 255,255,255;--bs-secondary-color: rgba(222,226,230,0.75);--bs-secondary-color-rgb: 222,226,230;--bs-secondary-bg: #343A46;--bs-secondary-bg-rgb: 52,58,70;--bs-tertiary-color: rgba(222,226,230,0.5);--bs-tertiary-color-rgb: 222,226,230;--bs-tertiary-bg: #292d34;--bs-tertiary-bg-rgb: 41,45,52;--bs-primary-text-emphasis: #66b0da;--bs-secondary-text-emphasis: #8c8c8c;--bs-success-text-emphasis: #66b876;--bs-info-text-emphasis: #68ddf1;--bs-warning-text-emphasis: #fbd57e;--bs-danger-text-emphasis: #da6666;--bs-light-text-emphasis: #f8f8f8;--bs-dark-text-emphasis: #dee2e6;--bs-primary-bg-subtle: #001927;--bs-secondary-bg-subtle: #0d0d0d;--bs-success-bg-subtle: #001b05;--bs-info-bg-subtle: #01282e;--bs-warning-bg-subtle: #322508;--bs-danger-bg-subtle: #270000;--bs-light-bg-subtle: #343A46;--bs-dark-bg-subtle: #1a1d23;--bs-primary-border-subtle: #004a74;--bs-secondary-border-subtle: #262626;--bs-success-border-subtle: #005210;--bs-info-border-subtle: #02778b;--bs-warning-border-subtle: #956f18;--bs-danger-border-subtle: #740000;--bs-light-border-subtle: #48505F;--bs-dark-border-subtle: #343A46;--bs-heading-color: inherit;--bs-link-color: #66b0da;--bs-link-hover-color: #85c0e1;--bs-link-color-rgb: 102,176,218;--bs-link-hover-color-rgb: 133,192,225;--bs-code-color: RGB(var(--bs-emphasis-color-rgb, 0, 0, 0));--bs-border-color: #495057;--bs-border-color-translucent: rgba(255,255,255,0.1);--bs-form-valid-color: #66b876;--bs-form-valid-border-color: #66b876;--bs-form-invalid-color: #da6666;--bs-form-invalid-border-color: #da6666}*,*::before,*::after{box-sizing:border-box}@media (prefers-reduced-motion: no-preference){:root{scroll-behavior:smooth}}body{margin:0;font-family:var(--bs-body-font-family);font-size:var(--bs-body-font-size);font-weight:var(--bs-body-font-weight);line-height:var(--bs-body-line-height);color:var(--bs-body-color);text-align:var(--bs-body-text-align);background-color:var(--bs-body-bg);-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:rgba(0,0,0,0)}hr{margin:2rem 0;color:inherit;border:0;border-top:var(--bs-border-width) solid;opacity:.25}h6,.h6,h5,.h5,h4,.h4,h3,.h3,h2,.h2,h1,.h1{margin-top:0;margin-bottom:.5rem;font-weight:400;line-height:1.2;color:var(--bs-heading-color)}h1,.h1{font-size:calc(1.335rem + 1.02vw)}@media (min-width: 1200px){h1,.h1{font-size:2.1rem}}h2,.h2{font-size:calc(1.325rem + .9vw)}@media (min-width: 1200px){h2,.h2{font-size:2rem}}h3,.h3{font-size:calc(1.3rem + .6vw)}@media (min-width: 1200px){h3,.h3{font-size:1.75rem}}h4,.h4{font-size:calc(1.275rem + .3vw)}@media (min-width: 1200px){h4,.h4{font-size:1.5rem}}h5,.h5{font-size:1.25rem}h6,.h6{font-size:1rem}p{margin-top:0;margin-bottom:1rem}abbr[title]{text-decoration:underline dotted;-webkit-text-decoration:underline dotted;-moz-text-decoration:underline dotted;-ms-text-decoration:underline dotted;-o-text-decoration:underline dotted;cursor:help;text-decoration-skip-ink:none}address{margin-bottom:1rem;font-style:normal;line-height:inherit}ol,ul{padding-left:2rem}ol,ul,dl{margin-top:0;margin-bottom:1rem}ol ol,ul ul,ol ul,ul ol{margin-bottom:0}dt{font-weight:700}dd{margin-bottom:.5rem;margin-left:0}blockquote{margin:0 0 1rem;padding:.625rem 1.25rem;border-left:.25rem solid #e9ecef}blockquote p:last-child,blockquote ul:last-child,blockquote ol:last-child{margin-bottom:0}b,strong{font-weight:bolder}small,.small{font-size:.875em}mark,.mark{padding:.1875em;background-color:var(--bs-highlight-bg)}sub,sup{position:relative;font-size:.75em;line-height:0;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}a{color:rgba(var(--bs-link-color-rgb), var(--bs-link-opacity, 1));text-decoration:underline;-webkit-text-decoration:underline;-moz-text-decoration:underline;-ms-text-decoration:underline;-o-text-decoration:underline}a:hover{--bs-link-color-rgb: var(--bs-link-hover-color-rgb)}a:not([href]):not([class]),a:not([href]):not([class]):hover{color:inherit;text-decoration:none}pre,code,kbd,samp{font-family:var(--bs-font-monospace);font-size:1em}pre{display:block;margin-top:0;margin-bottom:1rem;overflow:auto;font-size:.875em;color:RGB(var(--bs-emphasis-color-rgb, 0, 0, 0));background-color:RGBA(var(--bs-emphasis-color-rgb, 0, 0, 0), 0.04);padding:.5rem;border:1px solid var(--bs-border-color, #dee2e6);border-radius:3px}pre code{background-color:transparent;font-size:inherit;color:inherit;word-break:normal}code{font-size:.875em;color:var(--bs-code-color);background-color:RGBA(var(--bs-emphasis-color-rgb, 0, 0, 0), 0.04);border-radius:3px;padding:.125rem .25rem;word-wrap:break-word}a>code{color:inherit}kbd{padding:.1875rem .375rem;font-size:.875em;color:var(--bs-body-bg);background-color:var(--bs-body-color);border-radius:.25rem}kbd kbd{padding:0;font-size:1em}figure{margin:0 0 1rem}img,svg{vertical-align:middle}table{caption-side:bottom;border-collapse:collapse}caption{padding-top:.5rem;padding-bottom:.5rem;color:var(--bs-secondary-color);text-align:left}th{text-align:inherit;text-align:-webkit-match-parent}thead,tbody,tfoot,tr,td,th{border-color:inherit;border-style:solid;border-width:0}label{display:inline-block}button{border-radius:0}button:focus:not(:focus-visible){outline:0}input,button,select,optgroup,textarea{margin:0;font-family:inherit;font-size:inherit;line-height:inherit}button,select{text-transform:none}[role="button"]{cursor:pointer}select{word-wrap:normal}select:disabled{opacity:1}[list]:not([type="date"]):not([type="datetime-local"]):not([type="month"]):not([type="week"]):not([type="time"])::-webkit-calendar-picker-indicator{display:none !important}button,[type="button"],[type="reset"],[type="submit"]{-webkit-appearance:button}button:not(:disabled),[type="button"]:not(:disabled),[type="reset"]:not(:disabled),[type="submit"]:not(:disabled){cursor:pointer}::-moz-focus-inner{padding:0;border-style:none}textarea{resize:vertical}fieldset{min-width:0;padding:0;margin:0;border:0}legend{float:left;width:100%;padding:0;margin-bottom:.5rem;font-size:calc(1.275rem + .3vw);line-height:inherit}@media (min-width: 1200px){legend{font-size:1.5rem}}legend+*{clear:left}::-webkit-datetime-edit-fields-wrapper,::-webkit-datetime-edit-text,::-webkit-datetime-edit-minute,::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-month-field,::-webkit-datetime-edit-year-field{padding:0}::-webkit-inner-spin-button{height:auto}[type="search"]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-color-swatch-wrapper{padding:0}::file-selector-button{font:inherit;-webkit-appearance:button}output{display:inline-block}iframe{border:0}summary{display:list-item;cursor:pointer}progress{vertical-align:baseline}[hidden]{display:none !important}.lead{font-size:1.25rem;font-weight:300}.display-1{font-size:calc(1.625rem + 4.5vw);font-weight:300;line-height:1.2}@media (min-width: 1200px){.display-1{font-size:5rem}}.display-2{font-size:calc(1.575rem + 3.9vw);font-weight:300;line-height:1.2}@media (min-width: 1200px){.display-2{font-size:4.5rem}}.display-3{font-size:calc(1.525rem + 3.3vw);font-weight:300;line-height:1.2}@media (min-width: 1200px){.display-3{font-size:4rem}}.display-4{font-size:calc(1.475rem + 2.7vw);font-weight:300;line-height:1.2}@media (min-width: 1200px){.display-4{font-size:3.5rem}}.display-5{font-size:calc(1.425rem + 2.1vw);font-weight:300;line-height:1.2}@media (min-width: 1200px){.display-5{font-size:3rem}}.display-6{font-size:calc(1.375rem + 1.5vw);font-weight:300;line-height:1.2}@media (min-width: 1200px){.display-6{font-size:2.5rem}}.list-unstyled{padding-left:0;list-style:none}.list-inline{padding-left:0;list-style:none}.list-inline-item{display:inline-block}.list-inline-item:not(:last-child){margin-right:.5rem}.initialism{font-size:.875em;text-transform:uppercase}.blockquote{margin-bottom:1rem;font-size:1.25rem}.blockquote>:last-child{margin-bottom:0}.blockquote-footer{margin-top:-1rem;margin-bottom:1rem;font-size:.875em;color:#707782}.blockquote-footer::before{content:"\2014\00A0"}.img-fluid{max-width:100%;height:auto}.img-thumbnail{padding:.25rem;background-color:var(--bs-body-bg);border:var(--bs-border-width) solid var(--bs-border-color);border-radius:var(--bs-border-radius);max-width:100%;height:auto}.figure{display:inline-block}.figure-img{margin-bottom:.5rem;line-height:1}.figure-caption{font-size:.875em;color:var(--bs-secondary-color)}.container,.container-fluid,.container-xxl,.container-xl,.container-lg,.container-md,.container-sm{--bs-gutter-x: 1.5rem;--bs-gutter-y: 0;width:100%;padding-right:calc(var(--bs-gutter-x) * .5);padding-left:calc(var(--bs-gutter-x) * .5);margin-right:auto;margin-left:auto}@media (min-width: 576px){.container-sm,.container{max-width:540px}}@media (min-width: 768px){.container-md,.container-sm,.container{max-width:720px}}@media (min-width: 992px){.container-lg,.container-md,.container-sm,.container{max-width:960px}}@media (min-width: 1200px){.container-xl,.container-lg,.container-md,.container-sm,.container{max-width:1140px}}@media (min-width: 1400px){.container-xxl,.container-xl,.container-lg,.container-md,.container-sm,.container{max-width:1320px}}:root{--bs-breakpoint-xs: 0;--bs-breakpoint-sm: 576px;--bs-breakpoint-md: 768px;--bs-breakpoint-lg: 992px;--bs-breakpoint-xl: 1200px;--bs-breakpoint-xxl: 1400px}.row{--bs-gutter-x: 1.5rem;--bs-gutter-y: 0;display:flex;display:-webkit-flex;flex-wrap:wrap;-webkit-flex-wrap:wrap;margin-top:calc(-1 * var(--bs-gutter-y));margin-right:calc(-.5 * var(--bs-gutter-x));margin-left:calc(-.5 * var(--bs-gutter-x))}.row>*{flex-shrink:0;-webkit-flex-shrink:0;width:100%;max-width:100%;padding-right:calc(var(--bs-gutter-x) * .5);padding-left:calc(var(--bs-gutter-x) * .5);margin-top:var(--bs-gutter-y)}.grid{display:grid;grid-template-rows:repeat(var(--bs-rows, 1), 1fr);grid-template-columns:repeat(var(--bs-columns, 12), 1fr);gap:var(--bs-gap, 1.5rem)}.grid .g-col-1{grid-column:auto/span 1}.grid .g-col-2{grid-column:auto/span 2}.grid .g-col-3{grid-column:auto/span 3}.grid .g-col-4{grid-column:auto/span 4}.grid .g-col-5{grid-column:auto/span 5}.grid .g-col-6{grid-column:auto/span 6}.grid .g-col-7{grid-column:auto/span 7}.grid .g-col-8{grid-column:auto/span 8}.grid .g-col-9{grid-column:auto/span 9}.grid .g-col-10{grid-column:auto/span 10}.grid .g-col-11{grid-column:auto/span 11}.grid .g-col-12{grid-column:auto/span 12}.grid .g-start-1{grid-column-start:1}.grid .g-start-2{grid-column-start:2}.grid .g-start-3{grid-column-start:3}.grid .g-start-4{grid-column-start:4}.grid .g-start-5{grid-column-start:5}.grid .g-start-6{grid-column-start:6}.grid .g-start-7{grid-column-start:7}.grid .g-start-8{grid-column-start:8}.grid .g-start-9{grid-column-start:9}.grid .g-start-10{grid-column-start:10}.grid .g-start-11{grid-column-start:11}@media (min-width: 576px){.grid .g-col-sm-1{grid-column:auto/span 1}.grid .g-col-sm-2{grid-column:auto/span 2}.grid .g-col-sm-3{grid-column:auto/span 3}.grid .g-col-sm-4{grid-column:auto/span 4}.grid .g-col-sm-5{grid-column:auto/span 5}.grid .g-col-sm-6{grid-column:auto/span 6}.grid .g-col-sm-7{grid-column:auto/span 7}.grid .g-col-sm-8{grid-column:auto/span 8}.grid .g-col-sm-9{grid-column:auto/span 9}.grid .g-col-sm-10{grid-column:auto/span 10}.grid .g-col-sm-11{grid-column:auto/span 11}.grid .g-col-sm-12{grid-column:auto/span 12}.grid .g-start-sm-1{grid-column-start:1}.grid .g-start-sm-2{grid-column-start:2}.grid .g-start-sm-3{grid-column-start:3}.grid .g-start-sm-4{grid-column-start:4}.grid .g-start-sm-5{grid-column-start:5}.grid .g-start-sm-6{grid-column-start:6}.grid .g-start-sm-7{grid-column-start:7}.grid .g-start-sm-8{grid-column-start:8}.grid .g-start-sm-9{grid-column-start:9}.grid .g-start-sm-10{grid-column-start:10}.grid .g-start-sm-11{grid-column-start:11}}@media (min-width: 768px){.grid .g-col-md-1{grid-column:auto/span 1}.grid .g-col-md-2{grid-column:auto/span 2}.grid .g-col-md-3{grid-column:auto/span 3}.grid .g-col-md-4{grid-column:auto/span 4}.grid .g-col-md-5{grid-column:auto/span 5}.grid .g-col-md-6{grid-column:auto/span 6}.grid .g-col-md-7{grid-column:auto/span 7}.grid .g-col-md-8{grid-column:auto/span 8}.grid .g-col-md-9{grid-column:auto/span 9}.grid .g-col-md-10{grid-column:auto/span 10}.grid .g-col-md-11{grid-column:auto/span 11}.grid .g-col-md-12{grid-column:auto/span 12}.grid .g-start-md-1{grid-column-start:1}.grid .g-start-md-2{grid-column-start:2}.grid .g-start-md-3{grid-column-start:3}.grid .g-start-md-4{grid-column-start:4}.grid .g-start-md-5{grid-column-start:5}.grid .g-start-md-6{grid-column-start:6}.grid .g-start-md-7{grid-column-start:7}.grid .g-start-md-8{grid-column-start:8}.grid .g-start-md-9{grid-column-start:9}.grid .g-start-md-10{grid-column-start:10}.grid .g-start-md-11{grid-column-start:11}}@media (min-width: 992px){.grid .g-col-lg-1{grid-column:auto/span 1}.grid .g-col-lg-2{grid-column:auto/span 2}.grid .g-col-lg-3{grid-column:auto/span 3}.grid .g-col-lg-4{grid-column:auto/span 4}.grid .g-col-lg-5{grid-column:auto/span 5}.grid .g-col-lg-6{grid-column:auto/span 6}.grid .g-col-lg-7{grid-column:auto/span 7}.grid .g-col-lg-8{grid-column:auto/span 8}.grid .g-col-lg-9{grid-column:auto/span 9}.grid .g-col-lg-10{grid-column:auto/span 10}.grid .g-col-lg-11{grid-column:auto/span 11}.grid .g-col-lg-12{grid-column:auto/span 12}.grid .g-start-lg-1{grid-column-start:1}.grid .g-start-lg-2{grid-column-start:2}.grid .g-start-lg-3{grid-column-start:3}.grid .g-start-lg-4{grid-column-start:4}.grid .g-start-lg-5{grid-column-start:5}.grid .g-start-lg-6{grid-column-start:6}.grid .g-start-lg-7{grid-column-start:7}.grid .g-start-lg-8{grid-column-start:8}.grid .g-start-lg-9{grid-column-start:9}.grid .g-start-lg-10{grid-column-start:10}.grid .g-start-lg-11{grid-column-start:11}}@media (min-width: 1200px){.grid .g-col-xl-1{grid-column:auto/span 1}.grid .g-col-xl-2{grid-column:auto/span 2}.grid .g-col-xl-3{grid-column:auto/span 3}.grid .g-col-xl-4{grid-column:auto/span 4}.grid .g-col-xl-5{grid-column:auto/span 5}.grid .g-col-xl-6{grid-column:auto/span 6}.grid .g-col-xl-7{grid-column:auto/span 7}.grid .g-col-xl-8{grid-column:auto/span 8}.grid .g-col-xl-9{grid-column:auto/span 9}.grid .g-col-xl-10{grid-column:auto/span 10}.grid .g-col-xl-11{grid-column:auto/span 11}.grid .g-col-xl-12{grid-column:auto/span 12}.grid .g-start-xl-1{grid-column-start:1}.grid .g-start-xl-2{grid-column-start:2}.grid .g-start-xl-3{grid-column-start:3}.grid .g-start-xl-4{grid-column-start:4}.grid .g-start-xl-5{grid-column-start:5}.grid .g-start-xl-6{grid-column-start:6}.grid .g-start-xl-7{grid-column-start:7}.grid .g-start-xl-8{grid-column-start:8}.grid .g-start-xl-9{grid-column-start:9}.grid .g-start-xl-10{grid-column-start:10}.grid .g-start-xl-11{grid-column-start:11}}@media (min-width: 1400px){.grid .g-col-xxl-1{grid-column:auto/span 1}.grid .g-col-xxl-2{grid-column:auto/span 2}.grid .g-col-xxl-3{grid-column:auto/span 3}.grid .g-col-xxl-4{grid-column:auto/span 4}.grid .g-col-xxl-5{grid-column:auto/span 5}.grid .g-col-xxl-6{grid-column:auto/span 6}.grid .g-col-xxl-7{grid-column:auto/span 7}.grid .g-col-xxl-8{grid-column:auto/span 8}.grid .g-col-xxl-9{grid-column:auto/span 9}.grid .g-col-xxl-10{grid-column:auto/span 10}.grid .g-col-xxl-11{grid-column:auto/span 11}.grid .g-col-xxl-12{grid-column:auto/span 12}.grid .g-start-xxl-1{grid-column-start:1}.grid .g-start-xxl-2{grid-column-start:2}.grid .g-start-xxl-3{grid-column-start:3}.grid .g-start-xxl-4{grid-column-start:4}.grid .g-start-xxl-5{grid-column-start:5}.grid .g-start-xxl-6{grid-column-start:6}.grid .g-start-xxl-7{grid-column-start:7}.grid .g-start-xxl-8{grid-column-start:8}.grid .g-start-xxl-9{grid-column-start:9}.grid .g-start-xxl-10{grid-column-start:10}.grid .g-start-xxl-11{grid-column-start:11}}.col{flex:1 0 0%;-webkit-flex:1 0 0%}.row-cols-auto>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:auto}.row-cols-1>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:100%}.row-cols-2>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:50%}.row-cols-3>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:33.33333%}.row-cols-4>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:25%}.row-cols-5>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:20%}.row-cols-6>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:16.66667%}.col-auto{flex:0 0 auto;-webkit-flex:0 0 auto;width:auto}.col-1{flex:0 0 auto;-webkit-flex:0 0 auto;width:8.33333%}.col-2{flex:0 0 auto;-webkit-flex:0 0 auto;width:16.66667%}.col-3{flex:0 0 auto;-webkit-flex:0 0 auto;width:25%}.col-4{flex:0 0 auto;-webkit-flex:0 0 auto;width:33.33333%}.col-5{flex:0 0 auto;-webkit-flex:0 0 auto;width:41.66667%}.col-6{flex:0 0 auto;-webkit-flex:0 0 auto;width:50%}.col-7{flex:0 0 auto;-webkit-flex:0 0 auto;width:58.33333%}.col-8{flex:0 0 auto;-webkit-flex:0 0 auto;width:66.66667%}.col-9{flex:0 0 auto;-webkit-flex:0 0 auto;width:75%}.col-10{flex:0 0 auto;-webkit-flex:0 0 auto;width:83.33333%}.col-11{flex:0 0 auto;-webkit-flex:0 0 auto;width:91.66667%}.col-12{flex:0 0 auto;-webkit-flex:0 0 auto;width:100%}.offset-1{margin-left:8.33333%}.offset-2{margin-left:16.66667%}.offset-3{margin-left:25%}.offset-4{margin-left:33.33333%}.offset-5{margin-left:41.66667%}.offset-6{margin-left:50%}.offset-7{margin-left:58.33333%}.offset-8{margin-left:66.66667%}.offset-9{margin-left:75%}.offset-10{margin-left:83.33333%}.offset-11{margin-left:91.66667%}.g-0,.gx-0{--bs-gutter-x: 0}.g-0,.gy-0{--bs-gutter-y: 0}.g-1,.gx-1{--bs-gutter-x: .25rem}.g-1,.gy-1{--bs-gutter-y: .25rem}.g-2,.gx-2{--bs-gutter-x: .5rem}.g-2,.gy-2{--bs-gutter-y: .5rem}.g-3,.gx-3{--bs-gutter-x: 1rem}.g-3,.gy-3{--bs-gutter-y: 1rem}.g-4,.gx-4{--bs-gutter-x: 1.5rem}.g-4,.gy-4{--bs-gutter-y: 1.5rem}.g-5,.gx-5{--bs-gutter-x: 3rem}.g-5,.gy-5{--bs-gutter-y: 3rem}@media (min-width: 576px){.col-sm{flex:1 0 0%;-webkit-flex:1 0 0%}.row-cols-sm-auto>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:auto}.row-cols-sm-1>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:100%}.row-cols-sm-2>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:50%}.row-cols-sm-3>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:33.33333%}.row-cols-sm-4>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:25%}.row-cols-sm-5>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:20%}.row-cols-sm-6>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:16.66667%}.col-sm-auto{flex:0 0 auto;-webkit-flex:0 0 auto;width:auto}.col-sm-1{flex:0 0 auto;-webkit-flex:0 0 auto;width:8.33333%}.col-sm-2{flex:0 0 auto;-webkit-flex:0 0 auto;width:16.66667%}.col-sm-3{flex:0 0 auto;-webkit-flex:0 0 auto;width:25%}.col-sm-4{flex:0 0 auto;-webkit-flex:0 0 auto;width:33.33333%}.col-sm-5{flex:0 0 auto;-webkit-flex:0 0 auto;width:41.66667%}.col-sm-6{flex:0 0 auto;-webkit-flex:0 0 auto;width:50%}.col-sm-7{flex:0 0 auto;-webkit-flex:0 0 auto;width:58.33333%}.col-sm-8{flex:0 0 auto;-webkit-flex:0 0 auto;width:66.66667%}.col-sm-9{flex:0 0 auto;-webkit-flex:0 0 auto;width:75%}.col-sm-10{flex:0 0 auto;-webkit-flex:0 0 auto;width:83.33333%}.col-sm-11{flex:0 0 auto;-webkit-flex:0 0 auto;width:91.66667%}.col-sm-12{flex:0 0 auto;-webkit-flex:0 0 auto;width:100%}.offset-sm-0{margin-left:0}.offset-sm-1{margin-left:8.33333%}.offset-sm-2{margin-left:16.66667%}.offset-sm-3{margin-left:25%}.offset-sm-4{margin-left:33.33333%}.offset-sm-5{margin-left:41.66667%}.offset-sm-6{margin-left:50%}.offset-sm-7{margin-left:58.33333%}.offset-sm-8{margin-left:66.66667%}.offset-sm-9{margin-left:75%}.offset-sm-10{margin-left:83.33333%}.offset-sm-11{margin-left:91.66667%}.g-sm-0,.gx-sm-0{--bs-gutter-x: 0}.g-sm-0,.gy-sm-0{--bs-gutter-y: 0}.g-sm-1,.gx-sm-1{--bs-gutter-x: .25rem}.g-sm-1,.gy-sm-1{--bs-gutter-y: .25rem}.g-sm-2,.gx-sm-2{--bs-gutter-x: .5rem}.g-sm-2,.gy-sm-2{--bs-gutter-y: .5rem}.g-sm-3,.gx-sm-3{--bs-gutter-x: 1rem}.g-sm-3,.gy-sm-3{--bs-gutter-y: 1rem}.g-sm-4,.gx-sm-4{--bs-gutter-x: 1.5rem}.g-sm-4,.gy-sm-4{--bs-gutter-y: 1.5rem}.g-sm-5,.gx-sm-5{--bs-gutter-x: 3rem}.g-sm-5,.gy-sm-5{--bs-gutter-y: 3rem}}@media (min-width: 768px){.col-md{flex:1 0 0%;-webkit-flex:1 0 0%}.row-cols-md-auto>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:auto}.row-cols-md-1>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:100%}.row-cols-md-2>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:50%}.row-cols-md-3>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:33.33333%}.row-cols-md-4>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:25%}.row-cols-md-5>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:20%}.row-cols-md-6>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:16.66667%}.col-md-auto{flex:0 0 auto;-webkit-flex:0 0 auto;width:auto}.col-md-1{flex:0 0 auto;-webkit-flex:0 0 auto;width:8.33333%}.col-md-2{flex:0 0 auto;-webkit-flex:0 0 auto;width:16.66667%}.col-md-3{flex:0 0 auto;-webkit-flex:0 0 auto;width:25%}.col-md-4{flex:0 0 auto;-webkit-flex:0 0 auto;width:33.33333%}.col-md-5{flex:0 0 auto;-webkit-flex:0 0 auto;width:41.66667%}.col-md-6{flex:0 0 auto;-webkit-flex:0 0 auto;width:50%}.col-md-7{flex:0 0 auto;-webkit-flex:0 0 auto;width:58.33333%}.col-md-8{flex:0 0 auto;-webkit-flex:0 0 auto;width:66.66667%}.col-md-9{flex:0 0 auto;-webkit-flex:0 0 auto;width:75%}.col-md-10{flex:0 0 auto;-webkit-flex:0 0 auto;width:83.33333%}.col-md-11{flex:0 0 auto;-webkit-flex:0 0 auto;width:91.66667%}.col-md-12{flex:0 0 auto;-webkit-flex:0 0 auto;width:100%}.offset-md-0{margin-left:0}.offset-md-1{margin-left:8.33333%}.offset-md-2{margin-left:16.66667%}.offset-md-3{margin-left:25%}.offset-md-4{margin-left:33.33333%}.offset-md-5{margin-left:41.66667%}.offset-md-6{margin-left:50%}.offset-md-7{margin-left:58.33333%}.offset-md-8{margin-left:66.66667%}.offset-md-9{margin-left:75%}.offset-md-10{margin-left:83.33333%}.offset-md-11{margin-left:91.66667%}.g-md-0,.gx-md-0{--bs-gutter-x: 0}.g-md-0,.gy-md-0{--bs-gutter-y: 0}.g-md-1,.gx-md-1{--bs-gutter-x: .25rem}.g-md-1,.gy-md-1{--bs-gutter-y: .25rem}.g-md-2,.gx-md-2{--bs-gutter-x: .5rem}.g-md-2,.gy-md-2{--bs-gutter-y: .5rem}.g-md-3,.gx-md-3{--bs-gutter-x: 1rem}.g-md-3,.gy-md-3{--bs-gutter-y: 1rem}.g-md-4,.gx-md-4{--bs-gutter-x: 1.5rem}.g-md-4,.gy-md-4{--bs-gutter-y: 1.5rem}.g-md-5,.gx-md-5{--bs-gutter-x: 3rem}.g-md-5,.gy-md-5{--bs-gutter-y: 3rem}}@media (min-width: 992px){.col-lg{flex:1 0 0%;-webkit-flex:1 0 0%}.row-cols-lg-auto>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:auto}.row-cols-lg-1>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:100%}.row-cols-lg-2>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:50%}.row-cols-lg-3>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:33.33333%}.row-cols-lg-4>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:25%}.row-cols-lg-5>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:20%}.row-cols-lg-6>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:16.66667%}.col-lg-auto{flex:0 0 auto;-webkit-flex:0 0 auto;width:auto}.col-lg-1{flex:0 0 auto;-webkit-flex:0 0 auto;width:8.33333%}.col-lg-2{flex:0 0 auto;-webkit-flex:0 0 auto;width:16.66667%}.col-lg-3{flex:0 0 auto;-webkit-flex:0 0 auto;width:25%}.col-lg-4{flex:0 0 auto;-webkit-flex:0 0 auto;width:33.33333%}.col-lg-5{flex:0 0 auto;-webkit-flex:0 0 auto;width:41.66667%}.col-lg-6{flex:0 0 auto;-webkit-flex:0 0 auto;width:50%}.col-lg-7{flex:0 0 auto;-webkit-flex:0 0 auto;width:58.33333%}.col-lg-8{flex:0 0 auto;-webkit-flex:0 0 auto;width:66.66667%}.col-lg-9{flex:0 0 auto;-webkit-flex:0 0 auto;width:75%}.col-lg-10{flex:0 0 auto;-webkit-flex:0 0 auto;width:83.33333%}.col-lg-11{flex:0 0 auto;-webkit-flex:0 0 auto;width:91.66667%}.col-lg-12{flex:0 0 auto;-webkit-flex:0 0 auto;width:100%}.offset-lg-0{margin-left:0}.offset-lg-1{margin-left:8.33333%}.offset-lg-2{margin-left:16.66667%}.offset-lg-3{margin-left:25%}.offset-lg-4{margin-left:33.33333%}.offset-lg-5{margin-left:41.66667%}.offset-lg-6{margin-left:50%}.offset-lg-7{margin-left:58.33333%}.offset-lg-8{margin-left:66.66667%}.offset-lg-9{margin-left:75%}.offset-lg-10{margin-left:83.33333%}.offset-lg-11{margin-left:91.66667%}.g-lg-0,.gx-lg-0{--bs-gutter-x: 0}.g-lg-0,.gy-lg-0{--bs-gutter-y: 0}.g-lg-1,.gx-lg-1{--bs-gutter-x: .25rem}.g-lg-1,.gy-lg-1{--bs-gutter-y: .25rem}.g-lg-2,.gx-lg-2{--bs-gutter-x: .5rem}.g-lg-2,.gy-lg-2{--bs-gutter-y: .5rem}.g-lg-3,.gx-lg-3{--bs-gutter-x: 1rem}.g-lg-3,.gy-lg-3{--bs-gutter-y: 1rem}.g-lg-4,.gx-lg-4{--bs-gutter-x: 1.5rem}.g-lg-4,.gy-lg-4{--bs-gutter-y: 1.5rem}.g-lg-5,.gx-lg-5{--bs-gutter-x: 3rem}.g-lg-5,.gy-lg-5{--bs-gutter-y: 3rem}}@media (min-width: 1200px){.col-xl{flex:1 0 0%;-webkit-flex:1 0 0%}.row-cols-xl-auto>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:auto}.row-cols-xl-1>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:100%}.row-cols-xl-2>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:50%}.row-cols-xl-3>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:33.33333%}.row-cols-xl-4>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:25%}.row-cols-xl-5>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:20%}.row-cols-xl-6>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:16.66667%}.col-xl-auto{flex:0 0 auto;-webkit-flex:0 0 auto;width:auto}.col-xl-1{flex:0 0 auto;-webkit-flex:0 0 auto;width:8.33333%}.col-xl-2{flex:0 0 auto;-webkit-flex:0 0 auto;width:16.66667%}.col-xl-3{flex:0 0 auto;-webkit-flex:0 0 auto;width:25%}.col-xl-4{flex:0 0 auto;-webkit-flex:0 0 auto;width:33.33333%}.col-xl-5{flex:0 0 auto;-webkit-flex:0 0 auto;width:41.66667%}.col-xl-6{flex:0 0 auto;-webkit-flex:0 0 auto;width:50%}.col-xl-7{flex:0 0 auto;-webkit-flex:0 0 auto;width:58.33333%}.col-xl-8{flex:0 0 auto;-webkit-flex:0 0 auto;width:66.66667%}.col-xl-9{flex:0 0 auto;-webkit-flex:0 0 auto;width:75%}.col-xl-10{flex:0 0 auto;-webkit-flex:0 0 auto;width:83.33333%}.col-xl-11{flex:0 0 auto;-webkit-flex:0 0 auto;width:91.66667%}.col-xl-12{flex:0 0 auto;-webkit-flex:0 0 auto;width:100%}.offset-xl-0{margin-left:0}.offset-xl-1{margin-left:8.33333%}.offset-xl-2{margin-left:16.66667%}.offset-xl-3{margin-left:25%}.offset-xl-4{margin-left:33.33333%}.offset-xl-5{margin-left:41.66667%}.offset-xl-6{margin-left:50%}.offset-xl-7{margin-left:58.33333%}.offset-xl-8{margin-left:66.66667%}.offset-xl-9{margin-left:75%}.offset-xl-10{margin-left:83.33333%}.offset-xl-11{margin-left:91.66667%}.g-xl-0,.gx-xl-0{--bs-gutter-x: 0}.g-xl-0,.gy-xl-0{--bs-gutter-y: 0}.g-xl-1,.gx-xl-1{--bs-gutter-x: .25rem}.g-xl-1,.gy-xl-1{--bs-gutter-y: .25rem}.g-xl-2,.gx-xl-2{--bs-gutter-x: .5rem}.g-xl-2,.gy-xl-2{--bs-gutter-y: .5rem}.g-xl-3,.gx-xl-3{--bs-gutter-x: 1rem}.g-xl-3,.gy-xl-3{--bs-gutter-y: 1rem}.g-xl-4,.gx-xl-4{--bs-gutter-x: 1.5rem}.g-xl-4,.gy-xl-4{--bs-gutter-y: 1.5rem}.g-xl-5,.gx-xl-5{--bs-gutter-x: 3rem}.g-xl-5,.gy-xl-5{--bs-gutter-y: 3rem}}@media (min-width: 1400px){.col-xxl{flex:1 0 0%;-webkit-flex:1 0 0%}.row-cols-xxl-auto>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:auto}.row-cols-xxl-1>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:100%}.row-cols-xxl-2>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:50%}.row-cols-xxl-3>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:33.33333%}.row-cols-xxl-4>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:25%}.row-cols-xxl-5>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:20%}.row-cols-xxl-6>*{flex:0 0 auto;-webkit-flex:0 0 auto;width:16.66667%}.col-xxl-auto{flex:0 0 auto;-webkit-flex:0 0 auto;width:auto}.col-xxl-1{flex:0 0 auto;-webkit-flex:0 0 auto;width:8.33333%}.col-xxl-2{flex:0 0 auto;-webkit-flex:0 0 auto;width:16.66667%}.col-xxl-3{flex:0 0 auto;-webkit-flex:0 0 auto;width:25%}.col-xxl-4{flex:0 0 auto;-webkit-flex:0 0 auto;width:33.33333%}.col-xxl-5{flex:0 0 auto;-webkit-flex:0 0 auto;width:41.66667%}.col-xxl-6{flex:0 0 auto;-webkit-flex:0 0 auto;width:50%}.col-xxl-7{flex:0 0 auto;-webkit-flex:0 0 auto;width:58.33333%}.col-xxl-8{flex:0 0 auto;-webkit-flex:0 0 auto;width:66.66667%}.col-xxl-9{flex:0 0 auto;-webkit-flex:0 0 auto;width:75%}.col-xxl-10{flex:0 0 auto;-webkit-flex:0 0 auto;width:83.33333%}.col-xxl-11{flex:0 0 auto;-webkit-flex:0 0 auto;width:91.66667%}.col-xxl-12{flex:0 0 auto;-webkit-flex:0 0 auto;width:100%}.offset-xxl-0{margin-left:0}.offset-xxl-1{margin-left:8.33333%}.offset-xxl-2{margin-left:16.66667%}.offset-xxl-3{margin-left:25%}.offset-xxl-4{margin-left:33.33333%}.offset-xxl-5{margin-left:41.66667%}.offset-xxl-6{margin-left:50%}.offset-xxl-7{margin-left:58.33333%}.offset-xxl-8{margin-left:66.66667%}.offset-xxl-9{margin-left:75%}.offset-xxl-10{margin-left:83.33333%}.offset-xxl-11{margin-left:91.66667%}.g-xxl-0,.gx-xxl-0{--bs-gutter-x: 0}.g-xxl-0,.gy-xxl-0{--bs-gutter-y: 0}.g-xxl-1,.gx-xxl-1{--bs-gutter-x: .25rem}.g-xxl-1,.gy-xxl-1{--bs-gutter-y: .25rem}.g-xxl-2,.gx-xxl-2{--bs-gutter-x: .5rem}.g-xxl-2,.gy-xxl-2{--bs-gutter-y: .5rem}.g-xxl-3,.gx-xxl-3{--bs-gutter-x: 1rem}.g-xxl-3,.gy-xxl-3{--bs-gutter-y: 1rem}.g-xxl-4,.gx-xxl-4{--bs-gutter-x: 1.5rem}.g-xxl-4,.gy-xxl-4{--bs-gutter-y: 1.5rem}.g-xxl-5,.gx-xxl-5{--bs-gutter-x: 3rem}.g-xxl-5,.gy-xxl-5{--bs-gutter-y: 3rem}}.table{--bs-table-color-type: initial;--bs-table-bg-type: initial;--bs-table-color-state: initial;--bs-table-bg-state: initial;--bs-table-color: var(--bs-body-color);--bs-table-bg: var(--bs-body-bg);--bs-table-border-color: var(--bs-border-color);--bs-table-accent-bg: rgba(0,0,0,0);--bs-table-striped-color: var(--bs-body-color);--bs-table-striped-bg: rgba(0,123,194,0.06);--bs-table-active-color: var(--bs-body-color);--bs-table-active-bg: rgba(0,0,0,0.1);--bs-table-hover-color: var(--bs-body-color);--bs-table-hover-bg: rgba(0,123,194,0.1);width:100%;margin-bottom:1rem;vertical-align:top;border-color:var(--bs-table-border-color)}.table>:not(caption)>*>*{padding:.5rem .5rem;color:var(--bs-table-color-state, var(--bs-table-color-type, var(--bs-table-color)));background-color:var(--bs-table-bg);border-bottom-width:var(--bs-border-width);box-shadow:inset 0 0 0 9999px var(--bs-table-bg-state, var(--bs-table-bg-type, var(--bs-table-accent-bg)))}.table>tbody{vertical-align:inherit}.table>thead{vertical-align:bottom}.table-group-divider{border-top:calc(var(--bs-border-width) * 2) solid currentcolor}.caption-top{caption-side:top}.table-sm>:not(caption)>*>*{padding:.25rem .25rem}.table-bordered>:not(caption)>*{border-width:var(--bs-border-width) 0}.table-bordered>:not(caption)>*>*{border-width:0 var(--bs-border-width)}.table-borderless>:not(caption)>*>*{border-bottom-width:0}.table-borderless>:not(:first-child){border-top-width:0}.table-striped>tbody>tr:nth-of-type(even)>*{--bs-table-color-type: var(--bs-table-striped-color);--bs-table-bg-type: var(--bs-table-striped-bg)}.table-striped-columns>:not(caption)>tr>:nth-child(even){--bs-table-color-type: var(--bs-table-striped-color);--bs-table-bg-type: var(--bs-table-striped-bg)}.table-active{--bs-table-color-state: var(--bs-table-active-color);--bs-table-bg-state: var(--bs-table-active-bg)}.table-hover>tbody>tr:hover>*{--bs-table-color-state: var(--bs-table-hover-color);--bs-table-bg-state: var(--bs-table-hover-bg)}.table-primary{--bs-table-color: #000;--bs-table-bg: #cce5f3;--bs-table-border-color: #b8cedb;--bs-table-striped-bg: #c2dae7;--bs-table-striped-color: #000;--bs-table-active-bg: #b8cedb;--bs-table-active-color: #000;--bs-table-hover-bg: #bdd4e1;--bs-table-hover-color: #000;color:var(--bs-table-color);border-color:var(--bs-table-border-color)}.table-secondary{--bs-table-color: #000;--bs-table-bg: #d9d9d9;--bs-table-border-color: #c3c3c3;--bs-table-striped-bg: #cecece;--bs-table-striped-color: #000;--bs-table-active-bg: #c3c3c3;--bs-table-active-color: #000;--bs-table-hover-bg: #c9c9c9;--bs-table-hover-color: #000;color:var(--bs-table-color);border-color:var(--bs-table-border-color)}.table-success{--bs-table-color: #000;--bs-table-bg: #cce7d1;--bs-table-border-color: #b8d0bc;--bs-table-striped-bg: #c2dbc7;--bs-table-striped-color: #000;--bs-table-active-bg: #b8d0bc;--bs-table-active-color: #000;--bs-table-hover-bg: #bdd6c1;--bs-table-hover-color: #000;color:var(--bs-table-color);border-color:var(--bs-table-border-color)}.table-info{--bs-table-color: #000;--bs-table-bg: #cdf4fa;--bs-table-border-color: #b9dce1;--bs-table-striped-bg: #c3e8ee;--bs-table-striped-color: #000;--bs-table-active-bg: #b9dce1;--bs-table-active-color: #000;--bs-table-hover-bg: #bee2e7;--bs-table-hover-color: #000;color:var(--bs-table-color);border-color:var(--bs-table-border-color)}.table-warning{--bs-table-color: #000;--bs-table-bg: #fef1d4;--bs-table-border-color: #e5d9bf;--bs-table-striped-bg: #f1e5c9;--bs-table-striped-color: #000;--bs-table-active-bg: #e5d9bf;--bs-table-active-color: #000;--bs-table-hover-bg: #ebdfc4;--bs-table-hover-color: #000;color:var(--bs-table-color);border-color:var(--bs-table-border-color)}.table-danger{--bs-table-color: #000;--bs-table-bg: #f3cccc;--bs-table-border-color: #dbb8b8;--bs-table-striped-bg: #e7c2c2;--bs-table-striped-color: #000;--bs-table-active-bg: #dbb8b8;--bs-table-active-color: #000;--bs-table-hover-bg: #e1bdbd;--bs-table-hover-color: #000;color:var(--bs-table-color);border-color:var(--bs-table-border-color)}.table-light{--bs-table-color: #000;--bs-table-bg: #f8f8f8;--bs-table-border-color: #dfdfdf;--bs-table-striped-bg: #ececec;--bs-table-striped-color: #000;--bs-table-active-bg: #dfdfdf;--bs-table-active-color: #000;--bs-table-hover-bg: #e5e5e5;--bs-table-hover-color: #000;color:var(--bs-table-color);border-color:var(--bs-table-border-color)}.table-dark{--bs-table-color: #fff;--bs-table-bg: #202020;--bs-table-border-color: #363636;--bs-table-striped-bg: #2b2b2b;--bs-table-striped-color: #fff;--bs-table-active-bg: #363636;--bs-table-active-color: #fff;--bs-table-hover-bg: #313131;--bs-table-hover-color: #fff;color:var(--bs-table-color);border-color:var(--bs-table-border-color)}.table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch}@media (max-width: 575.98px){.table-responsive-sm{overflow-x:auto;-webkit-overflow-scrolling:touch}}@media (max-width: 767.98px){.table-responsive-md{overflow-x:auto;-webkit-overflow-scrolling:touch}}@media (max-width: 991.98px){.table-responsive-lg{overflow-x:auto;-webkit-overflow-scrolling:touch}}@media (max-width: 1199.98px){.table-responsive-xl{overflow-x:auto;-webkit-overflow-scrolling:touch}}@media (max-width: 1399.98px){.table-responsive-xxl{overflow-x:auto;-webkit-overflow-scrolling:touch}}.form-label,.shiny-input-container .control-label{margin-bottom:.5rem}.col-form-label{padding-top:calc(.375rem + var(--bs-border-width));padding-bottom:calc(.375rem + var(--bs-border-width));margin-bottom:0;font-size:inherit;line-height:1.5}.col-form-label-lg{padding-top:calc(.5rem + var(--bs-border-width));padding-bottom:calc(.5rem + var(--bs-border-width));font-size:1.25rem}.col-form-label-sm{padding-top:calc(.25rem + var(--bs-border-width));padding-bottom:calc(.25rem + var(--bs-border-width));font-size:.875rem}.form-text,.help-text,.help-block{margin-top:.25rem;font-size:.875em;color:#707782}.form-control{display:block;width:100%;padding:.375rem .75rem;font-size:.9375rem;font-weight:400;line-height:1.5;color:var(--bs-body-color);appearance:none;-webkit-appearance:none;-moz-appearance:none;-ms-appearance:none;-o-appearance:none;background-color:var(--bs-body-bg);background-clip:padding-box;border:var(--bs-border-width) solid #8D959E;border-radius:var(--bs-border-radius);transition:border-color 0.15s ease-in-out,box-shadow 0.15s ease-in-out}@media (prefers-reduced-motion: reduce){.form-control{transition:none}}.form-control[type="file"]{overflow:hidden}.form-control[type="file"]:not(:disabled):not([readonly]){cursor:pointer}.form-control:focus{color:var(--bs-body-color);background-color:var(--bs-body-bg);border-color:#80bde1;outline:0;box-shadow:0 0 0 .25rem rgba(0,123,194,0.25)}.form-control::-webkit-date-and-time-value{min-width:85px;height:1.5em;margin:0}.form-control::-webkit-datetime-edit{display:block;padding:0}.form-control::placeholder{color:var(--bs-secondary-color);opacity:1}.form-control:disabled{background-color:var(--bs-secondary-bg);opacity:1}.form-control::file-selector-button{padding:.375rem .75rem;margin:-.375rem -.75rem;margin-inline-end:.75rem;color:var(--bs-body-color);background-color:var(--bs-tertiary-bg);pointer-events:none;border-color:inherit;border-style:solid;border-width:0;border-inline-end-width:var(--bs-border-width);border-radius:0;transition:color 0.15s ease-in-out,background-color 0.15s ease-in-out,border-color 0.15s ease-in-out,box-shadow 0.15s ease-in-out}@media (prefers-reduced-motion: reduce){.form-control::file-selector-button{transition:none}}.form-control:hover:not(:disabled):not([readonly])::file-selector-button{background-color:var(--bs-secondary-bg)}.form-control-plaintext{display:block;width:100%;padding:.375rem 0;margin-bottom:0;line-height:1.5;color:var(--bs-body-color);background-color:transparent;border:solid transparent;border-width:var(--bs-border-width) 0}.form-control-plaintext:focus{outline:0}.form-control-plaintext.form-control-sm,.form-control-plaintext.form-control-lg{padding-right:0;padding-left:0}.form-control-sm{min-height:calc(1.5em + .5rem + calc(var(--bs-border-width) * 2));padding:.25rem .5rem;font-size:.875rem;border-radius:var(--bs-border-radius-sm)}.form-control-sm::file-selector-button{padding:.25rem .5rem;margin:-.25rem -.5rem;margin-inline-end:.5rem}.form-control-lg{min-height:calc(1.5em + 1rem + calc(var(--bs-border-width) * 2));padding:.5rem 1rem;font-size:1.25rem;border-radius:var(--bs-border-radius-lg)}.form-control-lg::file-selector-button{padding:.5rem 1rem;margin:-.5rem -1rem;margin-inline-end:1rem}textarea.form-control{min-height:calc(1.5em + .75rem + calc(var(--bs-border-width) * 2))}textarea.form-control-sm{min-height:calc(1.5em + .5rem + calc(var(--bs-border-width) * 2))}textarea.form-control-lg{min-height:calc(1.5em + 1rem + calc(var(--bs-border-width) * 2))}.form-control-color{width:3rem;height:calc(1.5em + .75rem + calc(var(--bs-border-width) * 2));padding:.375rem}.form-control-color:not(:disabled):not([readonly]){cursor:pointer}.form-control-color::-moz-color-swatch{border:0 !important;border-radius:var(--bs-border-radius)}.form-control-color::-webkit-color-swatch{border:0 !important;border-radius:var(--bs-border-radius)}.form-control-color.form-control-sm{height:calc(1.5em + .5rem + calc(var(--bs-border-width) * 2))}.form-control-color.form-control-lg{height:calc(1.5em + 1rem + calc(var(--bs-border-width) * 2))}.form-select{--bs-form-select-bg-img: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23343A46' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e");display:block;width:100%;padding:.375rem 2.25rem .375rem .75rem;font-size:.9375rem;font-weight:400;line-height:1.5;color:var(--bs-body-color);appearance:none;-webkit-appearance:none;-moz-appearance:none;-ms-appearance:none;-o-appearance:none;background-color:var(--bs-body-bg);background-image:var(--bs-form-select-bg-img),var(--bs-form-select-bg-icon, none);background-repeat:no-repeat;background-position:right .75rem center;background-size:16px 12px;border:var(--bs-border-width) solid #8D959E;border-radius:var(--bs-border-radius);transition:border-color 0.15s ease-in-out,box-shadow 0.15s ease-in-out}@media (prefers-reduced-motion: reduce){.form-select{transition:none}}.form-select:focus{border-color:#80bde1;outline:0;box-shadow:0 0 0 .25rem rgba(0,123,194,0.25)}.form-select[multiple],.form-select[size]:not([size="1"]){padding-right:.75rem;background-image:none}.form-select:disabled{background-color:var(--bs-secondary-bg)}.form-select:-moz-focusring{color:transparent;text-shadow:0 0 0 var(--bs-body-color)}.form-select-sm{padding-top:.25rem;padding-bottom:.25rem;padding-left:.5rem;font-size:.875rem;border-radius:var(--bs-border-radius-sm)}.form-select-lg{padding-top:.5rem;padding-bottom:.5rem;padding-left:1rem;font-size:1.25rem;border-radius:var(--bs-border-radius-lg)}[data-bs-theme="dark"] .form-select{--bs-form-select-bg-img: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23dee2e6' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e")}.form-check,.shiny-input-container .checkbox,.shiny-input-container .radio{display:block;min-height:1.5rem;padding-left:0;margin-bottom:.25rem}.form-check .form-check-input,.form-check .shiny-input-container .checkbox input,.form-check .shiny-input-container .radio input,.shiny-input-container .checkbox .form-check-input,.shiny-input-container .checkbox .shiny-input-container .checkbox input,.shiny-input-container .checkbox .shiny-input-container .radio input,.shiny-input-container .radio .form-check-input,.shiny-input-container .radio .shiny-input-container .checkbox input,.shiny-input-container .radio .shiny-input-container .radio input{float:left;margin-left:0}.form-check-reverse{padding-right:0;padding-left:0;text-align:right}.form-check-reverse .form-check-input{float:right;margin-right:0;margin-left:0}.form-check-input,.shiny-input-container .checkbox input,.shiny-input-container .checkbox-inline input,.shiny-input-container .radio input,.shiny-input-container .radio-inline input{--bs-form-check-bg: var(--bs-body-bg);width:1.2em;height:1.2em;margin-top:.15em;vertical-align:top;appearance:none;-webkit-appearance:none;-moz-appearance:none;-ms-appearance:none;-o-appearance:none;background-color:var(--bs-form-check-bg);background-image:var(--bs-form-check-bg-image);background-repeat:no-repeat;background-position:center;background-size:contain;border:var(--bs-border-width) solid var(--bs-border-color);print-color-adjust:exact}.form-check-input[type="checkbox"],.shiny-input-container .checkbox input[type="checkbox"],.shiny-input-container .checkbox-inline input[type="checkbox"],.shiny-input-container .radio input[type="checkbox"],.shiny-input-container .radio-inline input[type="checkbox"]{border-radius:2px}.form-check-input[type="radio"],.shiny-input-container .checkbox input[type="radio"],.shiny-input-container .checkbox-inline input[type="radio"],.shiny-input-container .radio input[type="radio"],.shiny-input-container .radio-inline input[type="radio"]{border-radius:50%}.form-check-input:active,.shiny-input-container .checkbox input:active,.shiny-input-container .checkbox-inline input:active,.shiny-input-container .radio input:active,.shiny-input-container .radio-inline input:active{filter:brightness(90%)}.form-check-input:focus,.shiny-input-container .checkbox input:focus,.shiny-input-container .checkbox-inline input:focus,.shiny-input-container .radio input:focus,.shiny-input-container .radio-inline input:focus{border-color:#80bde1;outline:0;box-shadow:0 0 0 .25rem rgba(0,123,194,0.25)}.form-check-input:checked,.shiny-input-container .checkbox input:checked,.shiny-input-container .checkbox-inline input:checked,.shiny-input-container .radio input:checked,.shiny-input-container .radio-inline input:checked{background-color:#007bc2;border-color:#007bc2}.form-check-input:checked[type="checkbox"],.shiny-input-container .checkbox input:checked[type="checkbox"],.shiny-input-container .checkbox-inline input:checked[type="checkbox"],.shiny-input-container .radio input:checked[type="checkbox"],.shiny-input-container .radio-inline input:checked[type="checkbox"]{--bs-form-check-bg-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3e%3cpath fill='none' stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='m6 10 3 3 6-6'/%3e%3c/svg%3e")}.form-check-input:checked[type="radio"],.shiny-input-container .checkbox input:checked[type="radio"],.shiny-input-container .checkbox-inline input:checked[type="radio"],.shiny-input-container .radio input:checked[type="radio"],.shiny-input-container .radio-inline input:checked[type="radio"]{--bs-form-check-bg-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='2' fill='%23fff'/%3e%3c/svg%3e")}.form-check-input[type="checkbox"]:indeterminate,.shiny-input-container .checkbox input[type="checkbox"]:indeterminate,.shiny-input-container .checkbox-inline input[type="checkbox"]:indeterminate,.shiny-input-container .radio input[type="checkbox"]:indeterminate,.shiny-input-container .radio-inline input[type="checkbox"]:indeterminate{background-color:#007bc2;border-color:#007bc2;--bs-form-check-bg-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3e%3cpath fill='none' stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='M6 10h8'/%3e%3c/svg%3e")}.form-check-input:disabled,.shiny-input-container .checkbox input:disabled,.shiny-input-container .checkbox-inline input:disabled,.shiny-input-container .radio input:disabled,.shiny-input-container .radio-inline input:disabled{pointer-events:none;filter:none;opacity:.5}.form-check-input[disabled]~.form-check-label,.form-check-input[disabled]~span,.form-check-input:disabled~.form-check-label,.form-check-input:disabled~span,.shiny-input-container .checkbox input[disabled]~.form-check-label,.shiny-input-container .checkbox input[disabled]~span,.shiny-input-container .checkbox input:disabled~.form-check-label,.shiny-input-container .checkbox input:disabled~span,.shiny-input-container .checkbox-inline input[disabled]~.form-check-label,.shiny-input-container .checkbox-inline input[disabled]~span,.shiny-input-container .checkbox-inline input:disabled~.form-check-label,.shiny-input-container .checkbox-inline input:disabled~span,.shiny-input-container .radio input[disabled]~.form-check-label,.shiny-input-container .radio input[disabled]~span,.shiny-input-container .radio input:disabled~.form-check-label,.shiny-input-container .radio input:disabled~span,.shiny-input-container .radio-inline input[disabled]~.form-check-label,.shiny-input-container .radio-inline input[disabled]~span,.shiny-input-container .radio-inline input:disabled~.form-check-label,.shiny-input-container .radio-inline input:disabled~span{cursor:default;opacity:.5}.form-check-label,.shiny-input-container .checkbox label,.shiny-input-container .checkbox-inline label,.shiny-input-container .radio label,.shiny-input-container .radio-inline label{cursor:pointer}.form-switch{padding-left:2.5em}.form-switch .form-check-input{--bs-form-switch-bg: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='rgba%280,0,0,0.25%29'/%3e%3c/svg%3e");width:2em;margin-left:-2.5em;background-image:var(--bs-form-switch-bg);background-position:left center;border-radius:2em;transition:background-position 0.15s ease-in-out}@media (prefers-reduced-motion: reduce){.form-switch .form-check-input{transition:none}}.form-switch .form-check-input:focus{--bs-form-switch-bg: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='%2380bde1'/%3e%3c/svg%3e")}.form-switch .form-check-input:checked{background-position:right center;--bs-form-switch-bg: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='%23fff'/%3e%3c/svg%3e")}.form-switch.form-check-reverse{padding-right:2.5em;padding-left:0}.form-switch.form-check-reverse .form-check-input{margin-right:-2.5em;margin-left:0}.form-check-inline{display:inline-block;margin-right:1rem}.btn-check{position:absolute;clip:rect(0, 0, 0, 0);pointer-events:none}.btn-check[disabled]+.btn,.btn-check:disabled+.btn{pointer-events:none;filter:none;opacity:.65}[data-bs-theme="dark"] .form-switch .form-check-input:not(:checked):not(:focus){--bs-form-switch-bg: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='rgba%28255,255,255,0.25%29'/%3e%3c/svg%3e")}.form-range{width:100%;height:1.5rem;padding:0;appearance:none;-webkit-appearance:none;-moz-appearance:none;-ms-appearance:none;-o-appearance:none;background-color:transparent}.form-range:focus{outline:0}.form-range:focus::-webkit-slider-thumb{box-shadow:0 0 0 1px #fff,0 0 0 .25rem rgba(0,123,194,0.25)}.form-range:focus::-moz-range-thumb{box-shadow:0 0 0 1px #fff,0 0 0 .25rem rgba(0,123,194,0.25)}.form-range::-moz-focus-outer{border:0}.form-range::-webkit-slider-thumb{width:1rem;height:1rem;margin-top:-.25rem;appearance:none;-webkit-appearance:none;-moz-appearance:none;-ms-appearance:none;-o-appearance:none;background-color:#007bc2;border:0;border-radius:1rem;transition:background-color 0.15s ease-in-out,border-color 0.15s ease-in-out,box-shadow 0.15s ease-in-out}@media (prefers-reduced-motion: reduce){.form-range::-webkit-slider-thumb{transition:none}}.form-range::-webkit-slider-thumb:active{background-color:#b3d7ed}.form-range::-webkit-slider-runnable-track{width:100%;height:.5rem;color:transparent;cursor:pointer;background-color:var(--bs-tertiary-bg);border-color:transparent;border-radius:1rem}.form-range::-moz-range-thumb{width:1rem;height:1rem;appearance:none;-webkit-appearance:none;-moz-appearance:none;-ms-appearance:none;-o-appearance:none;background-color:#007bc2;border:0;border-radius:1rem;transition:background-color 0.15s ease-in-out,border-color 0.15s ease-in-out,box-shadow 0.15s ease-in-out}@media (prefers-reduced-motion: reduce){.form-range::-moz-range-thumb{transition:none}}.form-range::-moz-range-thumb:active{background-color:#b3d7ed}.form-range::-moz-range-track{width:100%;height:.5rem;color:transparent;cursor:pointer;background-color:var(--bs-tertiary-bg);border-color:transparent;border-radius:1rem}.form-range:disabled{pointer-events:none}.form-range:disabled::-webkit-slider-thumb{background-color:var(--bs-secondary-color)}.form-range:disabled::-moz-range-thumb{background-color:var(--bs-secondary-color)}.form-floating{position:relative}.form-floating>.form-control,.form-floating>.form-control-plaintext,.form-floating>.form-select{height:calc(3.5rem + calc(var(--bs-border-width) * 2));min-height:calc(3.5rem + calc(var(--bs-border-width) * 2));line-height:1.25}.form-floating>label{position:absolute;top:0;left:0;z-index:2;height:100%;padding:1rem .75rem;overflow:hidden;text-align:start;text-overflow:ellipsis;white-space:nowrap;pointer-events:none;border:var(--bs-border-width) solid transparent;transform-origin:0 0;transition:opacity 0.1s ease-in-out,transform 0.1s ease-in-out}@media (prefers-reduced-motion: reduce){.form-floating>label{transition:none}}.form-floating>.form-control,.form-floating>.form-control-plaintext{padding:1rem .75rem}.form-floating>.form-control::placeholder,.form-floating>.form-control-plaintext::placeholder{color:transparent}.form-floating>.form-control:focus,.form-floating>.form-control:not(:placeholder-shown),.form-floating>.form-control-plaintext:focus,.form-floating>.form-control-plaintext:not(:placeholder-shown){padding-top:1.625rem;padding-bottom:.625rem}.form-floating>.form-control:-webkit-autofill,.form-floating>.form-control-plaintext:-webkit-autofill{padding-top:1.625rem;padding-bottom:.625rem}.form-floating>.form-select{padding-top:1.625rem;padding-bottom:.625rem}.form-floating>.form-control:focus~label,.form-floating>.form-control:not(:placeholder-shown)~label,.form-floating>.form-control-plaintext~label,.form-floating>.form-select~label{color:rgba(var(--bs-body-color-rgb), .65);transform:scale(0.85) translateY(-0.5rem) translateX(0.15rem)}.form-floating>.form-control:focus~label::after,.form-floating>.form-control:not(:placeholder-shown)~label::after,.form-floating>.form-control-plaintext~label::after,.form-floating>.form-select~label::after{position:absolute;inset:1rem .375rem;z-index:-1;height:1.5em;content:"";background-color:var(--bs-body-bg);border-radius:var(--bs-border-radius)}.form-floating>.form-control:-webkit-autofill~label{color:rgba(var(--bs-body-color-rgb), .65);transform:scale(0.85) translateY(-0.5rem) translateX(0.15rem)}.form-floating>.form-control-plaintext~label{border-width:var(--bs-border-width) 0}.form-floating>:disabled~label,.form-floating>.form-control:disabled~label{color:#707782}.form-floating>:disabled~label::after,.form-floating>.form-control:disabled~label::after{background-color:var(--bs-secondary-bg)}.input-group{position:relative;display:flex;display:-webkit-flex;flex-wrap:wrap;-webkit-flex-wrap:wrap;align-items:stretch;-webkit-align-items:stretch;width:100%}.input-group>.form-control,.input-group>.form-select,.input-group>.form-floating{position:relative;flex:1 1 auto;-webkit-flex:1 1 auto;width:1%;min-width:0}.input-group>.form-control:focus,.input-group>.form-select:focus,.input-group>.form-floating:focus-within{z-index:5}.input-group .btn{position:relative;z-index:2}.input-group .btn:focus{z-index:5}.input-group-text{display:flex;display:-webkit-flex;align-items:center;-webkit-align-items:center;padding:.375rem .75rem;font-size:.9375rem;font-weight:400;line-height:1.5;color:var(--bs-body-color);text-align:center;white-space:nowrap;background-color:var(--bs-tertiary-bg);border:var(--bs-border-width) solid #8D959E;border-radius:var(--bs-border-radius)}.input-group-lg>.form-control,.input-group-lg>.form-select,.input-group-lg>.input-group-text,.input-group-lg>.btn{padding:.5rem 1rem;font-size:1.25rem;border-radius:var(--bs-border-radius-lg)}.input-group-sm>.form-control,.input-group-sm>.form-select,.input-group-sm>.input-group-text,.input-group-sm>.btn{padding:.25rem .5rem;font-size:.875rem;border-radius:var(--bs-border-radius-sm)}.input-group-lg>.form-select,.input-group-sm>.form-select{padding-right:3rem}.input-group:not(.has-validation)>:not(:last-child):not(.dropdown-toggle):not(.dropdown-menu):not(.form-floating),.input-group:not(.has-validation)>.dropdown-toggle:nth-last-child(n + 3),.input-group:not(.has-validation)>.form-floating:not(:last-child)>.form-control,.input-group:not(.has-validation)>.form-floating:not(:last-child)>.form-select{border-top-right-radius:0;border-bottom-right-radius:0}.input-group.has-validation>:nth-last-child(n + 3):not(.dropdown-toggle):not(.dropdown-menu):not(.form-floating),.input-group.has-validation>.dropdown-toggle:nth-last-child(n + 4),.input-group.has-validation>.form-floating:nth-last-child(n + 3)>.form-control,.input-group.has-validation>.form-floating:nth-last-child(n + 3)>.form-select{border-top-right-radius:0;border-bottom-right-radius:0}.input-group>:not(:first-child):not(.dropdown-menu):not(.valid-tooltip):not(.valid-feedback):not(.invalid-tooltip):not(.invalid-feedback){margin-left:calc(var(--bs-border-width) * -1);border-top-left-radius:0;border-bottom-left-radius:0}.input-group>.form-floating:not(:first-child)>.form-control,.input-group>.form-floating:not(:first-child)>.form-select{border-top-left-radius:0;border-bottom-left-radius:0}.valid-feedback{display:none;width:100%;margin-top:.25rem;font-size:.875em;color:var(--bs-form-valid-color)}.valid-tooltip{position:absolute;top:100%;z-index:5;display:none;max-width:100%;padding:.25rem .5rem;margin-top:.1rem;font-size:.875rem;color:#fff;background-color:var(--bs-success);border-radius:var(--bs-border-radius)}.was-validated :valid~.valid-feedback,.was-validated :valid~.valid-tooltip,.is-valid~.valid-feedback,.is-valid~.valid-tooltip{display:block}.was-validated .form-control:valid,.form-control.is-valid{border-color:var(--bs-form-valid-border-color);padding-right:calc(1.5em + .75rem);background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3e%3cpath fill='%2300891a' d='M2.3 6.73.6 4.53c-.4-1.04.46-1.4 1.1-.8l1.1 1.4 3.4-3.8c.6-.63 1.6-.27 1.2.7l-4 4.6c-.43.5-.8.4-1.1.1z'/%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right calc(.375em + .1875rem) center;background-size:calc(.75em + .375rem) calc(.75em + .375rem)}.was-validated .form-control:valid:focus,.form-control.is-valid:focus{border-color:var(--bs-form-valid-border-color);box-shadow:0 0 0 .25rem rgba(var(--bs-success-rgb), 0.25)}.was-validated textarea.form-control:valid,textarea.form-control.is-valid{padding-right:calc(1.5em + .75rem);background-position:top calc(.375em + .1875rem) right calc(.375em + .1875rem)}.was-validated .form-select:valid,.form-select.is-valid{border-color:var(--bs-form-valid-border-color)}.was-validated .form-select:valid:not([multiple]):not([size]),.was-validated .form-select:valid:not([multiple])[size="1"],.form-select.is-valid:not([multiple]):not([size]),.form-select.is-valid:not([multiple])[size="1"]{--bs-form-select-bg-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3e%3cpath fill='%2300891a' d='M2.3 6.73.6 4.53c-.4-1.04.46-1.4 1.1-.8l1.1 1.4 3.4-3.8c.6-.63 1.6-.27 1.2.7l-4 4.6c-.43.5-.8.4-1.1.1z'/%3e%3c/svg%3e");padding-right:4.125rem;background-position:right .75rem center,center right 2.25rem;background-size:16px 12px,calc(.75em + .375rem) calc(.75em + .375rem)}.was-validated .form-select:valid:focus,.form-select.is-valid:focus{border-color:var(--bs-form-valid-border-color);box-shadow:0 0 0 .25rem rgba(var(--bs-success-rgb), 0.25)}.was-validated .form-control-color:valid,.form-control-color.is-valid{width:calc(3rem + calc(1.5em + .75rem))}.was-validated .form-check-input:valid,.form-check-input.is-valid{border-color:var(--bs-form-valid-border-color)}.was-validated .form-check-input:valid:checked,.form-check-input.is-valid:checked{background-color:var(--bs-form-valid-color)}.was-validated .form-check-input:valid:focus,.form-check-input.is-valid:focus{box-shadow:0 0 0 .25rem rgba(var(--bs-success-rgb), 0.25)}.was-validated .form-check-input:valid~.form-check-label,.form-check-input.is-valid~.form-check-label{color:var(--bs-form-valid-color)}.form-check-inline .form-check-input~.valid-feedback{margin-left:.5em}.was-validated .input-group>.form-control:not(:focus):valid,.input-group>.form-control:not(:focus).is-valid,.was-validated .input-group>.form-select:not(:focus):valid,.input-group>.form-select:not(:focus).is-valid,.was-validated .input-group>.form-floating:not(:focus-within):valid,.input-group>.form-floating:not(:focus-within).is-valid{z-index:3}.invalid-feedback{display:none;width:100%;margin-top:.25rem;font-size:.875em;color:var(--bs-form-invalid-color)}.invalid-tooltip{position:absolute;top:100%;z-index:5;display:none;max-width:100%;padding:.25rem .5rem;margin-top:.1rem;font-size:.875rem;color:#fff;background-color:var(--bs-danger);border-radius:var(--bs-border-radius)}.was-validated :invalid~.invalid-feedback,.was-validated :invalid~.invalid-tooltip,.is-invalid~.invalid-feedback,.is-invalid~.invalid-tooltip{display:block}.was-validated .form-control:invalid,.form-control.is-invalid{border-color:var(--bs-form-invalid-border-color);padding-right:calc(1.5em + .75rem);background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12' width='12' height='12' fill='none' stroke='%23c10000'%3e%3ccircle cx='6' cy='6' r='4.5'/%3e%3cpath stroke-linejoin='round' d='M5.8 3.6h.4L6 6.5z'/%3e%3ccircle cx='6' cy='8.2' r='.6' fill='%23c10000' stroke='none'/%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right calc(.375em + .1875rem) center;background-size:calc(.75em + .375rem) calc(.75em + .375rem)}.was-validated .form-control:invalid:focus,.form-control.is-invalid:focus{border-color:var(--bs-form-invalid-border-color);box-shadow:0 0 0 .25rem rgba(var(--bs-danger-rgb), 0.25)}.was-validated textarea.form-control:invalid,textarea.form-control.is-invalid{padding-right:calc(1.5em + .75rem);background-position:top calc(.375em + .1875rem) right calc(.375em + .1875rem)}.was-validated .form-select:invalid,.form-select.is-invalid{border-color:var(--bs-form-invalid-border-color)}.was-validated .form-select:invalid:not([multiple]):not([size]),.was-validated .form-select:invalid:not([multiple])[size="1"],.form-select.is-invalid:not([multiple]):not([size]),.form-select.is-invalid:not([multiple])[size="1"]{--bs-form-select-bg-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12' width='12' height='12' fill='none' stroke='%23c10000'%3e%3ccircle cx='6' cy='6' r='4.5'/%3e%3cpath stroke-linejoin='round' d='M5.8 3.6h.4L6 6.5z'/%3e%3ccircle cx='6' cy='8.2' r='.6' fill='%23c10000' stroke='none'/%3e%3c/svg%3e");padding-right:4.125rem;background-position:right .75rem center,center right 2.25rem;background-size:16px 12px,calc(.75em + .375rem) calc(.75em + .375rem)}.was-validated .form-select:invalid:focus,.form-select.is-invalid:focus{border-color:var(--bs-form-invalid-border-color);box-shadow:0 0 0 .25rem rgba(var(--bs-danger-rgb), 0.25)}.was-validated .form-control-color:invalid,.form-control-color.is-invalid{width:calc(3rem + calc(1.5em + .75rem))}.was-validated .form-check-input:invalid,.form-check-input.is-invalid{border-color:var(--bs-form-invalid-border-color)}.was-validated .form-check-input:invalid:checked,.form-check-input.is-invalid:checked{background-color:var(--bs-form-invalid-color)}.was-validated .form-check-input:invalid:focus,.form-check-input.is-invalid:focus{box-shadow:0 0 0 .25rem rgba(var(--bs-danger-rgb), 0.25)}.was-validated .form-check-input:invalid~.form-check-label,.form-check-input.is-invalid~.form-check-label{color:var(--bs-form-invalid-color)}.form-check-inline .form-check-input~.invalid-feedback{margin-left:.5em}.was-validated .input-group>.form-control:not(:focus):invalid,.input-group>.form-control:not(:focus).is-invalid,.was-validated .input-group>.form-select:not(:focus):invalid,.input-group>.form-select:not(:focus).is-invalid,.was-validated .input-group>.form-floating:not(:focus-within):invalid,.input-group>.form-floating:not(:focus-within).is-invalid{z-index:4}.btn{--bs-btn-padding-x: 2em;--bs-btn-padding-y: .75em;--bs-btn-font-family: ;--bs-btn-font-size:.9375rem;--bs-btn-font-weight: 500;--bs-btn-line-height: 1.5;--bs-btn-color: var(--bs-body-color);--bs-btn-bg: transparent;--bs-btn-border-width: var(--bs-border-width);--bs-btn-border-color: transparent;--bs-btn-border-radius: var(--bs-border-radius);--bs-btn-hover-border-color: transparent;--bs-btn-box-shadow: inset 0 1px 0 rgba(255,255,255,0.15),0 1px 1px rgba(0,0,0,0.075);--bs-btn-disabled-opacity: .65;--bs-btn-focus-box-shadow: 0 0 0 .25rem rgba(var(--bs-btn-focus-shadow-rgb), .5);display:inline-block;padding:var(--bs-btn-padding-y) var(--bs-btn-padding-x);font-family:var(--bs-btn-font-family);font-size:var(--bs-btn-font-size);font-weight:var(--bs-btn-font-weight);line-height:var(--bs-btn-line-height);color:var(--bs-btn-color);text-align:center;text-decoration:none;-webkit-text-decoration:none;-moz-text-decoration:none;-ms-text-decoration:none;-o-text-decoration:none;vertical-align:middle;cursor:pointer;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-o-user-select:none;border:var(--bs-btn-border-width) solid var(--bs-btn-border-color);border-radius:var(--bs-btn-border-radius);background-color:var(--bs-btn-bg);transition:color 0.15s ease-in-out,background-color 0.15s ease-in-out,border-color 0.15s ease-in-out,box-shadow 0.15s ease-in-out}@media (prefers-reduced-motion: reduce){.btn{transition:none}}.btn:hover{color:var(--bs-btn-hover-color);background-color:var(--bs-btn-hover-bg);border-color:var(--bs-btn-hover-border-color)}.btn-check+.btn:hover{color:var(--bs-btn-color);background-color:var(--bs-btn-bg);border-color:var(--bs-btn-border-color)}.btn:focus-visible{color:var(--bs-btn-hover-color);background-color:var(--bs-btn-hover-bg);border-color:var(--bs-btn-hover-border-color);outline:0;box-shadow:var(--bs-btn-focus-box-shadow)}.btn-check:focus-visible+.btn{border-color:var(--bs-btn-hover-border-color);outline:0;box-shadow:var(--bs-btn-focus-box-shadow)}.btn-check:checked+.btn,:not(.btn-check)+.btn:active,.btn:first-child:active,.btn.active,.btn.show,.btn.in{color:var(--bs-btn-active-color);background-color:var(--bs-btn-active-bg);border-color:var(--bs-btn-active-border-color)}.btn-check:checked+.btn:focus-visible,:not(.btn-check)+.btn:active:focus-visible,.btn:first-child:active:focus-visible,.btn.active:focus-visible,.btn.show:focus-visible,.btn.in:focus-visible{box-shadow:var(--bs-btn-focus-box-shadow)}.btn:disabled,.btn.disabled,fieldset:disabled .btn{color:var(--bs-btn-disabled-color);pointer-events:none;background-color:var(--bs-btn-disabled-bg);border-color:var(--bs-btn-disabled-border-color);opacity:var(--bs-btn-disabled-opacity)}.btn-default{--bs-btn-color: #000;--bs-btn-bg: #dee2e6;--bs-btn-border-color: #dee2e6;--bs-btn-hover-color: #000;--bs-btn-hover-bg: #e3e6ea;--bs-btn-hover-border-color: #e1e5e9;--bs-btn-focus-shadow-rgb: 189,192,196;--bs-btn-active-color: #000;--bs-btn-active-bg: #e5e8eb;--bs-btn-active-border-color: #e1e5e9;--bs-btn-active-shadow: inset 0 3px 5px rgba(0,0,0,0.125);--bs-btn-disabled-color: #000;--bs-btn-disabled-bg: #dee2e6;--bs-btn-disabled-border-color: #dee2e6}.btn-primary{--bs-btn-color: #fff;--bs-btn-bg: #007bc2;--bs-btn-border-color: #007bc2;--bs-btn-hover-color: #fff;--bs-btn-hover-bg: #0069a5;--bs-btn-hover-border-color: #00629b;--bs-btn-focus-shadow-rgb: 38,143,203;--bs-btn-active-color: #fff;--bs-btn-active-bg: #00629b;--bs-btn-active-border-color: #005c92;--bs-btn-active-shadow: inset 0 3px 5px rgba(0,0,0,0.125);--bs-btn-disabled-color: #fff;--bs-btn-disabled-bg: #007bc2;--bs-btn-disabled-border-color: #007bc2}.btn-secondary{--bs-btn-color: #fff;--bs-btn-bg: #404040;--bs-btn-border-color: #404040;--bs-btn-hover-color: #fff;--bs-btn-hover-bg: #363636;--bs-btn-hover-border-color: #333;--bs-btn-focus-shadow-rgb: 93,93,93;--bs-btn-active-color: #fff;--bs-btn-active-bg: #333;--bs-btn-active-border-color: #303030;--bs-btn-active-shadow: inset 0 3px 5px rgba(0,0,0,0.125);--bs-btn-disabled-color: #fff;--bs-btn-disabled-bg: #404040;--bs-btn-disabled-border-color: #404040}.btn-success{--bs-btn-color: #fff;--bs-btn-bg: #00891a;--bs-btn-border-color: #00891a;--bs-btn-hover-color: #fff;--bs-btn-hover-bg: #007416;--bs-btn-hover-border-color: #006e15;--bs-btn-focus-shadow-rgb: 38,155,60;--bs-btn-active-color: #fff;--bs-btn-active-bg: #006e15;--bs-btn-active-border-color: #006714;--bs-btn-active-shadow: inset 0 3px 5px rgba(0,0,0,0.125);--bs-btn-disabled-color: #fff;--bs-btn-disabled-bg: #00891a;--bs-btn-disabled-border-color: #00891a}.btn-info{--bs-btn-color: #000;--bs-btn-bg: #03c7e8;--bs-btn-border-color: #03c7e8;--bs-btn-hover-color: #000;--bs-btn-hover-bg: #29cfeb;--bs-btn-hover-border-color: #1ccdea;--bs-btn-focus-shadow-rgb: 3,169,197;--bs-btn-active-color: #000;--bs-btn-active-bg: #35d2ed;--bs-btn-active-border-color: #1ccdea;--bs-btn-active-shadow: inset 0 3px 5px rgba(0,0,0,0.125);--bs-btn-disabled-color: #000;--bs-btn-disabled-bg: #03c7e8;--bs-btn-disabled-border-color: #03c7e8}.btn-warning{--bs-btn-color: #000;--bs-btn-bg: #f9b928;--bs-btn-border-color: #f9b928;--bs-btn-hover-color: #000;--bs-btn-hover-bg: #fac448;--bs-btn-hover-border-color: #fac03e;--bs-btn-focus-shadow-rgb: 212,157,34;--bs-btn-active-color: #000;--bs-btn-active-bg: #fac753;--bs-btn-active-border-color: #fac03e;--bs-btn-active-shadow: inset 0 3px 5px rgba(0,0,0,0.125);--bs-btn-disabled-color: #000;--bs-btn-disabled-bg: #f9b928;--bs-btn-disabled-border-color: #f9b928}.btn-danger{--bs-btn-color: #fff;--bs-btn-bg: #c10000;--bs-btn-border-color: #c10000;--bs-btn-hover-color: #fff;--bs-btn-hover-bg: #a40000;--bs-btn-hover-border-color: #9a0000;--bs-btn-focus-shadow-rgb: 202,38,38;--bs-btn-active-color: #fff;--bs-btn-active-bg: #9a0000;--bs-btn-active-border-color: #910000;--bs-btn-active-shadow: inset 0 3px 5px rgba(0,0,0,0.125);--bs-btn-disabled-color: #fff;--bs-btn-disabled-bg: #c10000;--bs-btn-disabled-border-color: #c10000}.btn-light{--bs-btn-color: #000;--bs-btn-bg: #f8f8f8;--bs-btn-border-color: #f8f8f8;--bs-btn-hover-color: #000;--bs-btn-hover-bg: #d3d3d3;--bs-btn-hover-border-color: #c6c6c6;--bs-btn-focus-shadow-rgb: 211,211,211;--bs-btn-active-color: #000;--bs-btn-active-bg: #c6c6c6;--bs-btn-active-border-color: #bababa;--bs-btn-active-shadow: inset 0 3px 5px rgba(0,0,0,0.125);--bs-btn-disabled-color: #000;--bs-btn-disabled-bg: #f8f8f8;--bs-btn-disabled-border-color: #f8f8f8}.btn-dark{--bs-btn-color: #fff;--bs-btn-bg: #202020;--bs-btn-border-color: #202020;--bs-btn-hover-color: #fff;--bs-btn-hover-bg: #414141;--bs-btn-hover-border-color: #363636;--bs-btn-focus-shadow-rgb: 65,65,65;--bs-btn-active-color: #fff;--bs-btn-active-bg: #4d4d4d;--bs-btn-active-border-color: #363636;--bs-btn-active-shadow: inset 0 3px 5px rgba(0,0,0,0.125);--bs-btn-disabled-color: #fff;--bs-btn-disabled-bg: #202020;--bs-btn-disabled-border-color: #202020}.btn-outline-default{--bs-btn-color: #dee2e6;--bs-btn-border-color: #dee2e6;--bs-btn-hover-color: #000;--bs-btn-hover-bg: #dee2e6;--bs-btn-hover-border-color: #dee2e6;--bs-btn-focus-shadow-rgb: 222,226,230;--bs-btn-active-color: #000;--bs-btn-active-bg: #dee2e6;--bs-btn-active-border-color: #dee2e6;--bs-btn-active-shadow: inset 0 3px 5px rgba(0,0,0,0.125);--bs-btn-disabled-color: #dee2e6;--bs-btn-disabled-bg: transparent;--bs-btn-disabled-border-color: #dee2e6;--bs-btn-bg: transparent;--bs-gradient: none}.btn-outline-primary{--bs-btn-color: #007bc2;--bs-btn-border-color: #007bc2;--bs-btn-hover-color: #fff;--bs-btn-hover-bg: #007bc2;--bs-btn-hover-border-color: #007bc2;--bs-btn-focus-shadow-rgb: 0,123,194;--bs-btn-active-color: #fff;--bs-btn-active-bg: #007bc2;--bs-btn-active-border-color: #007bc2;--bs-btn-active-shadow: inset 0 3px 5px rgba(0,0,0,0.125);--bs-btn-disabled-color: #007bc2;--bs-btn-disabled-bg: transparent;--bs-btn-disabled-border-color: #007bc2;--bs-btn-bg: transparent;--bs-gradient: none}.btn-outline-secondary{--bs-btn-color: #404040;--bs-btn-border-color: #404040;--bs-btn-hover-color: #fff;--bs-btn-hover-bg: #404040;--bs-btn-hover-border-color: #404040;--bs-btn-focus-shadow-rgb: 64,64,64;--bs-btn-active-color: #fff;--bs-btn-active-bg: #404040;--bs-btn-active-border-color: #404040;--bs-btn-active-shadow: inset 0 3px 5px rgba(0,0,0,0.125);--bs-btn-disabled-color: #404040;--bs-btn-disabled-bg: transparent;--bs-btn-disabled-border-color: #404040;--bs-btn-bg: transparent;--bs-gradient: none}.btn-outline-success{--bs-btn-color: #00891a;--bs-btn-border-color: #00891a;--bs-btn-hover-color: #fff;--bs-btn-hover-bg: #00891a;--bs-btn-hover-border-color: #00891a;--bs-btn-focus-shadow-rgb: 0,137,26;--bs-btn-active-color: #fff;--bs-btn-active-bg: #00891a;--bs-btn-active-border-color: #00891a;--bs-btn-active-shadow: inset 0 3px 5px rgba(0,0,0,0.125);--bs-btn-disabled-color: #00891a;--bs-btn-disabled-bg: transparent;--bs-btn-disabled-border-color: #00891a;--bs-btn-bg: transparent;--bs-gradient: none}.btn-outline-info{--bs-btn-color: #03c7e8;--bs-btn-border-color: #03c7e8;--bs-btn-hover-color: #000;--bs-btn-hover-bg: #03c7e8;--bs-btn-hover-border-color: #03c7e8;--bs-btn-focus-shadow-rgb: 3,199,232;--bs-btn-active-color: #000;--bs-btn-active-bg: #03c7e8;--bs-btn-active-border-color: #03c7e8;--bs-btn-active-shadow: inset 0 3px 5px rgba(0,0,0,0.125);--bs-btn-disabled-color: #03c7e8;--bs-btn-disabled-bg: transparent;--bs-btn-disabled-border-color: #03c7e8;--bs-btn-bg: transparent;--bs-gradient: none}.btn-outline-warning{--bs-btn-color: #f9b928;--bs-btn-border-color: #f9b928;--bs-btn-hover-color: #000;--bs-btn-hover-bg: #f9b928;--bs-btn-hover-border-color: #f9b928;--bs-btn-focus-shadow-rgb: 249,185,40;--bs-btn-active-color: #000;--bs-btn-active-bg: #f9b928;--bs-btn-active-border-color: #f9b928;--bs-btn-active-shadow: inset 0 3px 5px rgba(0,0,0,0.125);--bs-btn-disabled-color: #f9b928;--bs-btn-disabled-bg: transparent;--bs-btn-disabled-border-color: #f9b928;--bs-btn-bg: transparent;--bs-gradient: none}.btn-outline-danger{--bs-btn-color: #c10000;--bs-btn-border-color: #c10000;--bs-btn-hover-color: #fff;--bs-btn-hover-bg: #c10000;--bs-btn-hover-border-color: #c10000;--bs-btn-focus-shadow-rgb: 193,0,0;--bs-btn-active-color: #fff;--bs-btn-active-bg: #c10000;--bs-btn-active-border-color: #c10000;--bs-btn-active-shadow: inset 0 3px 5px rgba(0,0,0,0.125);--bs-btn-disabled-color: #c10000;--bs-btn-disabled-bg: transparent;--bs-btn-disabled-border-color: #c10000;--bs-btn-bg: transparent;--bs-gradient: none}.btn-outline-light{--bs-btn-color: #f8f8f8;--bs-btn-border-color: #f8f8f8;--bs-btn-hover-color: #000;--bs-btn-hover-bg: #f8f8f8;--bs-btn-hover-border-color: #f8f8f8;--bs-btn-focus-shadow-rgb: 248,248,248;--bs-btn-active-color: #000;--bs-btn-active-bg: #f8f8f8;--bs-btn-active-border-color: #f8f8f8;--bs-btn-active-shadow: inset 0 3px 5px rgba(0,0,0,0.125);--bs-btn-disabled-color: #f8f8f8;--bs-btn-disabled-bg: transparent;--bs-btn-disabled-border-color: #f8f8f8;--bs-btn-bg: transparent;--bs-gradient: none}.btn-outline-dark{--bs-btn-color: #202020;--bs-btn-border-color: #202020;--bs-btn-hover-color: #fff;--bs-btn-hover-bg: #202020;--bs-btn-hover-border-color: #202020;--bs-btn-focus-shadow-rgb: 32,32,32;--bs-btn-active-color: #fff;--bs-btn-active-bg: #202020;--bs-btn-active-border-color: #202020;--bs-btn-active-shadow: inset 0 3px 5px rgba(0,0,0,0.125);--bs-btn-disabled-color: #202020;--bs-btn-disabled-bg: transparent;--bs-btn-disabled-border-color: #202020;--bs-btn-bg: transparent;--bs-gradient: none}.btn-link{--bs-btn-font-weight: 400;--bs-btn-color: var(--bs-link-color);--bs-btn-bg: transparent;--bs-btn-border-color: transparent;--bs-btn-hover-color: var(--bs-link-hover-color);--bs-btn-hover-border-color: transparent;--bs-btn-active-color: var(--bs-link-hover-color);--bs-btn-active-border-color: transparent;--bs-btn-disabled-color: #707782;--bs-btn-disabled-border-color: transparent;--bs-btn-box-shadow: 0 0 0 #000;--bs-btn-focus-shadow-rgb: 38,143,203;text-decoration:underline;-webkit-text-decoration:underline;-moz-text-decoration:underline;-ms-text-decoration:underline;-o-text-decoration:underline}.btn-link:focus-visible{color:var(--bs-btn-color)}.btn-link:hover{color:var(--bs-btn-hover-color)}.btn-lg,.btn-group-lg>.btn{--bs-btn-padding-y: .5rem;--bs-btn-padding-x: 1rem;--bs-btn-font-size:1.25rem;--bs-btn-border-radius: var(--bs-border-radius-lg)}.btn-sm,.btn-group-sm>.btn{--bs-btn-padding-y: .25rem;--bs-btn-padding-x: .5rem;--bs-btn-font-size:.875rem;--bs-btn-border-radius: var(--bs-border-radius-sm)}.fade{transition:opacity 0.15s linear}@media (prefers-reduced-motion: reduce){.fade{transition:none}}.fade:not(.show):not(.in){opacity:0}.collapse:not(.show):not(.in){display:none}.collapsing{height:0;overflow:hidden;transition:height 0.35s ease}@media (prefers-reduced-motion: reduce){.collapsing{transition:none}}.collapsing.collapse-horizontal{width:0;height:auto;transition:width 0.35s ease}@media (prefers-reduced-motion: reduce){.collapsing.collapse-horizontal{transition:none}}.dropup,.dropend,.dropdown,.dropstart,.dropup-center,.dropdown-center{position:relative}.dropdown-toggle{white-space:nowrap}.dropdown-toggle::after{display:inline-block;margin-left:.255em;vertical-align:.255em;content:"";border-top:.3em solid;border-right:.3em solid transparent;border-bottom:0;border-left:.3em solid transparent}.dropdown-toggle:empty::after{margin-left:0}.dropdown-menu{--bs-dropdown-zindex: 1000;--bs-dropdown-min-width: 10rem;--bs-dropdown-padding-x: 0;--bs-dropdown-padding-y: .5rem;--bs-dropdown-spacer: .125rem;--bs-dropdown-font-size:1rem;--bs-dropdown-color: var(--bs-body-color);--bs-dropdown-bg: var(--bs-body-bg);--bs-dropdown-border-color: var(--bs-border-color-translucent);--bs-dropdown-border-radius: var(--bs-border-radius);--bs-dropdown-border-width: var(--bs-border-width);--bs-dropdown-inner-border-radius: calc(var(--bs-border-radius) - var(--bs-border-width));--bs-dropdown-divider-bg: var(--bs-border-color-translucent);--bs-dropdown-divider-margin-y: .5rem;--bs-dropdown-box-shadow: 0px 1px 2px RGBA(var(--bslib-box-shadow-color-rgb), 0.1),0px 3px 7px RGBA(var(--bslib-box-shadow-color-rgb), 0.1),0px 12px 30px RGBA(var(--bslib-box-shadow-color-rgb), 0.08);--bs-dropdown-link-color: var(--bs-body-color);--bs-dropdown-link-hover-color: var(--bs-body-color);--bs-dropdown-link-hover-bg: var(--bs-tertiary-bg);--bs-dropdown-link-active-color: #fff;--bs-dropdown-link-active-bg: #007bc2;--bs-dropdown-link-disabled-color: var(--bs-tertiary-color);--bs-dropdown-item-padding-x: 1rem;--bs-dropdown-item-padding-y: .25rem;--bs-dropdown-header-color: #707782;--bs-dropdown-header-padding-x: 1rem;--bs-dropdown-header-padding-y: .5rem;position:absolute;z-index:var(--bs-dropdown-zindex);display:none;min-width:var(--bs-dropdown-min-width);padding:var(--bs-dropdown-padding-y) var(--bs-dropdown-padding-x);margin:0;font-size:var(--bs-dropdown-font-size);color:var(--bs-dropdown-color);text-align:left;list-style:none;background-color:var(--bs-dropdown-bg);background-clip:padding-box;border:var(--bs-dropdown-border-width) solid var(--bs-dropdown-border-color);border-radius:var(--bs-dropdown-border-radius)}.dropdown-menu[data-bs-popper]{top:100%;left:0;margin-top:var(--bs-dropdown-spacer)}.dropdown-menu-start{--bs-position: start}.dropdown-menu-start[data-bs-popper]{right:auto;left:0}.dropdown-menu-end{--bs-position: end}.dropdown-menu-end[data-bs-popper]{right:0;left:auto}@media (min-width: 576px){.dropdown-menu-sm-start{--bs-position: start}.dropdown-menu-sm-start[data-bs-popper]{right:auto;left:0}.dropdown-menu-sm-end{--bs-position: end}.dropdown-menu-sm-end[data-bs-popper]{right:0;left:auto}}@media (min-width: 768px){.dropdown-menu-md-start{--bs-position: start}.dropdown-menu-md-start[data-bs-popper]{right:auto;left:0}.dropdown-menu-md-end{--bs-position: end}.dropdown-menu-md-end[data-bs-popper]{right:0;left:auto}}@media (min-width: 992px){.dropdown-menu-lg-start{--bs-position: start}.dropdown-menu-lg-start[data-bs-popper]{right:auto;left:0}.dropdown-menu-lg-end{--bs-position: end}.dropdown-menu-lg-end[data-bs-popper]{right:0;left:auto}}@media (min-width: 1200px){.dropdown-menu-xl-start{--bs-position: start}.dropdown-menu-xl-start[data-bs-popper]{right:auto;left:0}.dropdown-menu-xl-end{--bs-position: end}.dropdown-menu-xl-end[data-bs-popper]{right:0;left:auto}}@media (min-width: 1400px){.dropdown-menu-xxl-start{--bs-position: start}.dropdown-menu-xxl-start[data-bs-popper]{right:auto;left:0}.dropdown-menu-xxl-end{--bs-position: end}.dropdown-menu-xxl-end[data-bs-popper]{right:0;left:auto}}.dropup .dropdown-menu[data-bs-popper]{top:auto;bottom:100%;margin-top:0;margin-bottom:var(--bs-dropdown-spacer)}.dropup .dropdown-toggle::after{display:inline-block;margin-left:.255em;vertical-align:.255em;content:"";border-top:0;border-right:.3em solid transparent;border-bottom:.3em solid;border-left:.3em solid transparent}.dropup .dropdown-toggle:empty::after{margin-left:0}.dropend .dropdown-menu[data-bs-popper]{top:0;right:auto;left:100%;margin-top:0;margin-left:var(--bs-dropdown-spacer)}.dropend .dropdown-toggle::after{display:inline-block;margin-left:.255em;vertical-align:.255em;content:"";border-top:.3em solid transparent;border-right:0;border-bottom:.3em solid transparent;border-left:.3em solid}.dropend .dropdown-toggle:empty::after{margin-left:0}.dropend .dropdown-toggle::after{vertical-align:0}.dropstart .dropdown-menu[data-bs-popper]{top:0;right:100%;left:auto;margin-top:0;margin-right:var(--bs-dropdown-spacer)}.dropstart .dropdown-toggle::after{display:inline-block;margin-left:.255em;vertical-align:.255em;content:""}.dropstart .dropdown-toggle::after{display:none}.dropstart .dropdown-toggle::before{display:inline-block;margin-right:.255em;vertical-align:.255em;content:"";border-top:.3em solid transparent;border-right:.3em solid;border-bottom:.3em solid transparent}.dropstart .dropdown-toggle:empty::after{margin-left:0}.dropstart .dropdown-toggle::before{vertical-align:0}.dropdown-divider,.dropdown-menu>li.divider{height:0;margin:var(--bs-dropdown-divider-margin-y) 0;overflow:hidden;border-top:1px solid var(--bs-dropdown-divider-bg);opacity:1}.dropdown-item,.dropdown-menu>li>a{display:block;width:100%;padding:var(--bs-dropdown-item-padding-y) var(--bs-dropdown-item-padding-x);clear:both;font-weight:400;color:var(--bs-dropdown-link-color);text-align:inherit;text-decoration:none;-webkit-text-decoration:none;-moz-text-decoration:none;-ms-text-decoration:none;-o-text-decoration:none;white-space:nowrap;background-color:transparent;border:0;border-radius:var(--bs-dropdown-item-border-radius, 0)}.dropdown-item:hover,.dropdown-menu>li>a:hover,.dropdown-item:focus,.dropdown-menu>li>a:focus{color:var(--bs-dropdown-link-hover-color);background-color:var(--bs-dropdown-link-hover-bg)}.dropdown-item.active,.dropdown-menu>li>a.active,.dropdown-item:active,.dropdown-menu>li>a:active{color:var(--bs-dropdown-link-active-color);text-decoration:none;background-color:var(--bs-dropdown-link-active-bg)}.dropdown-item.disabled,.dropdown-menu>li>a.disabled,.dropdown-item:disabled,.dropdown-menu>li>a:disabled{color:var(--bs-dropdown-link-disabled-color);pointer-events:none;background-color:transparent}.dropdown-menu.show,.dropdown-menu.in{display:block}.dropdown-header{display:block;padding:var(--bs-dropdown-header-padding-y) var(--bs-dropdown-header-padding-x);margin-bottom:0;font-size:.875rem;color:var(--bs-dropdown-header-color);white-space:nowrap}.dropdown-item-text{display:block;padding:var(--bs-dropdown-item-padding-y) var(--bs-dropdown-item-padding-x);color:var(--bs-dropdown-link-color)}.dropdown-menu-dark{--bs-dropdown-color: #dee2e6;--bs-dropdown-bg: #343A46;--bs-dropdown-border-color: var(--bs-border-color-translucent);--bs-dropdown-box-shadow: ;--bs-dropdown-link-color: #dee2e6;--bs-dropdown-link-hover-color: #fff;--bs-dropdown-divider-bg: var(--bs-border-color-translucent);--bs-dropdown-link-hover-bg: rgba(255,255,255,0.15);--bs-dropdown-link-active-color: #fff;--bs-dropdown-link-active-bg: #007bc2;--bs-dropdown-link-disabled-color: #8D959E;--bs-dropdown-header-color: #8D959E}.btn-group,.btn-group-vertical{position:relative;display:inline-flex;vertical-align:middle}.btn-group>.btn,.btn-group-vertical>.btn{position:relative;flex:1 1 auto;-webkit-flex:1 1 auto}.btn-group>.btn-check:checked+.btn,.btn-group>.btn-check:focus+.btn,.btn-group>.btn:hover,.btn-group>.btn:focus,.btn-group>.btn:active,.btn-group>.btn.active,.btn-group-vertical>.btn-check:checked+.btn,.btn-group-vertical>.btn-check:focus+.btn,.btn-group-vertical>.btn:hover,.btn-group-vertical>.btn:focus,.btn-group-vertical>.btn:active,.btn-group-vertical>.btn.active{z-index:1}.btn-toolbar{display:flex;display:-webkit-flex;flex-wrap:wrap;-webkit-flex-wrap:wrap;justify-content:flex-start;-webkit-justify-content:flex-start}.btn-toolbar .input-group{width:auto}.btn-group{border-radius:var(--bs-border-radius)}.btn-group>:not(.btn-check:first-child)+.btn,.btn-group>.btn-group:not(:first-child){margin-left:calc(var(--bs-border-width) * -1)}.btn-group>.btn:not(:last-child):not(.dropdown-toggle),.btn-group>.btn.dropdown-toggle-split:first-child,.btn-group>.btn-group:not(:last-child)>.btn{border-top-right-radius:0;border-bottom-right-radius:0}.btn-group>.btn:nth-child(n + 3),.btn-group>:not(.btn-check)+.btn,.btn-group>.btn-group:not(:first-child)>.btn{border-top-left-radius:0;border-bottom-left-radius:0}.dropdown-toggle-split{padding-right:1.5em;padding-left:1.5em}.dropdown-toggle-split::after,.dropup .dropdown-toggle-split::after,.dropend .dropdown-toggle-split::after{margin-left:0}.dropstart .dropdown-toggle-split::before{margin-right:0}.btn-sm+.dropdown-toggle-split,.btn-group-sm>.btn+.dropdown-toggle-split{padding-right:.375rem;padding-left:.375rem}.btn-lg+.dropdown-toggle-split,.btn-group-lg>.btn+.dropdown-toggle-split{padding-right:.75rem;padding-left:.75rem}.btn-group-vertical{flex-direction:column;-webkit-flex-direction:column;align-items:flex-start;-webkit-align-items:flex-start;justify-content:center;-webkit-justify-content:center}.btn-group-vertical>.btn,.btn-group-vertical>.btn-group{width:100%}.btn-group-vertical>.btn:not(:first-child),.btn-group-vertical>.btn-group:not(:first-child){margin-top:calc(var(--bs-border-width) * -1)}.btn-group-vertical>.btn:not(:last-child):not(.dropdown-toggle),.btn-group-vertical>.btn-group:not(:last-child)>.btn{border-bottom-right-radius:0;border-bottom-left-radius:0}.btn-group-vertical>.btn~.btn,.btn-group-vertical>.btn-group:not(:first-child)>.btn{border-top-left-radius:0;border-top-right-radius:0}.nav{--bs-nav-link-padding-x: 1rem;--bs-nav-link-padding-y: .5rem;--bs-nav-link-font-weight: ;--bs-nav-link-color: var(--bs-link-color);--bs-nav-link-hover-color: var(--bs-link-hover-color);--bs-nav-link-disabled-color: var(--bs-secondary-color);display:flex;display:-webkit-flex;flex-wrap:wrap;-webkit-flex-wrap:wrap;padding-left:0;margin-bottom:0;list-style:none}.nav-link,.nav-tabs>li>a,.nav-pills>li>a,:where(ul.nav.navbar-nav > li)>a{display:block;padding:var(--bs-nav-link-padding-y) var(--bs-nav-link-padding-x);font-size:var(--bs-nav-link-font-size);font-weight:var(--bs-nav-link-font-weight);color:var(--bs-nav-link-color);text-decoration:none;-webkit-text-decoration:none;-moz-text-decoration:none;-ms-text-decoration:none;-o-text-decoration:none;background:none;border:0;transition:color 0.15s ease-in-out,background-color 0.15s ease-in-out,border-color 0.15s ease-in-out}@media (prefers-reduced-motion: reduce){.nav-link,.nav-tabs>li>a,.nav-pills>li>a,:where(ul.nav.navbar-nav > li)>a{transition:none}}.nav-link:hover,.nav-tabs>li>a:hover,.nav-pills>li>a:hover,:where(ul.nav.navbar-nav > li)>a:hover,.nav-link:focus,.nav-tabs>li>a:focus,.nav-pills>li>a:focus,:where(ul.nav.navbar-nav > li)>a:focus{color:var(--bs-nav-link-hover-color)}.nav-link:focus-visible,.nav-tabs>li>a:focus-visible,.nav-pills>li>a:focus-visible,:where(ul.nav.navbar-nav > li)>a:focus-visible{outline:0;box-shadow:0 0 0 .25rem rgba(0,123,194,0.25)}.nav-link.disabled,.nav-tabs>li>a.disabled,.nav-pills>li>a.disabled,:where(ul.nav.navbar-nav > li)>a.disabled,.nav-link:disabled,.nav-tabs>li>a:disabled,.nav-pills>li>a:disabled,:where(ul.nav.navbar-nav > li)>a:disabled{color:var(--bs-nav-link-disabled-color);pointer-events:none;cursor:default}.nav-tabs{--bs-nav-tabs-border-width: var(--bs-border-width);--bs-nav-tabs-border-color: var(--bs-border-color);--bs-nav-tabs-border-radius: var(--bs-border-radius);--bs-nav-tabs-link-hover-border-color: var(--bs-secondary-bg) var(--bs-secondary-bg) var(--bs-border-color);--bs-nav-tabs-link-active-color: var(--bs-emphasis-color);--bs-nav-tabs-link-active-bg: var(--bs-body-bg);--bs-nav-tabs-link-active-border-color: var(--bs-border-color) var(--bs-border-color) var(--bs-body-bg);border-bottom:var(--bs-nav-tabs-border-width) solid var(--bs-nav-tabs-border-color)}.nav-tabs .nav-link,.nav-tabs>li>a,.nav-tabs .nav-pills>li>a,.nav-tabs :where(ul.nav.navbar-nav > li)>a{margin-bottom:calc(-1 * var(--bs-nav-tabs-border-width));border:var(--bs-nav-tabs-border-width) solid transparent;border-top-left-radius:var(--bs-nav-tabs-border-radius);border-top-right-radius:var(--bs-nav-tabs-border-radius)}.nav-tabs .nav-link:hover,.nav-tabs>li>a:hover,.nav-tabs .nav-pills>li>a:hover,.nav-tabs :where(ul.nav.navbar-nav > li)>a:hover,.nav-tabs .nav-link:focus,.nav-tabs>li>a:focus,.nav-tabs .nav-pills>li>a:focus,.nav-tabs :where(ul.nav.navbar-nav > li)>a:focus{isolation:isolate;border-color:var(--bs-nav-tabs-link-hover-border-color)}.nav-tabs .nav-link.active,.nav-tabs>li>a.active,.nav-tabs .nav-pills>li>a.active,.nav-tabs :where(ul.nav.navbar-nav > li)>a.active,.nav-tabs .nav-item.show .nav-link,.nav-tabs .nav-item.in .nav-link,.nav-tabs .nav-item.show .nav-tabs>li>a,.nav-tabs .nav-item.in .nav-tabs>li>a,.nav-tabs .nav-item.show .nav-pills>li>a,.nav-tabs .nav-item.in .nav-pills>li>a,.nav-tabs>li.show .nav-link,.nav-tabs>li.in .nav-link,.nav-tabs>li.show .nav-tabs>li>a,.nav-tabs>li.in .nav-tabs>li>a,.nav-tabs>li.show .nav-pills>li>a,.nav-tabs>li.in .nav-pills>li>a,.nav-tabs .nav-pills>li.show .nav-link,.nav-tabs .nav-pills>li.in .nav-link,.nav-tabs .nav-pills>li.show .nav-tabs>li>a,.nav-tabs .nav-pills>li.in .nav-tabs>li>a,.nav-tabs .nav-pills>li.show .nav-pills>li>a,.nav-tabs .nav-pills>li.in .nav-pills>li>a,.nav-tabs .nav-item.show :where(ul.nav.navbar-nav > li)>a,.nav-tabs .nav-item.in :where(ul.nav.navbar-nav > li)>a,.nav-tabs>li.show :where(ul.nav.navbar-nav > li)>a,.nav-tabs>li.in :where(ul.nav.navbar-nav > li)>a,.nav-tabs .nav-pills>li.show :where(ul.nav.navbar-nav > li)>a,.nav-tabs .nav-pills>li.in :where(ul.nav.navbar-nav > li)>a,.nav-tabs .show:where(ul.nav.navbar-nav > li):not(.dropdown) .nav-link,.nav-tabs .in:where(ul.nav.navbar-nav > li):not(.dropdown) .nav-link,.nav-tabs .show:where(ul.nav.navbar-nav > li):not(.dropdown) .nav-tabs>li>a,.nav-tabs .in:where(ul.nav.navbar-nav > li):not(.dropdown) .nav-tabs>li>a,.nav-tabs .show:where(ul.nav.navbar-nav > li):not(.dropdown) .nav-pills>li>a,.nav-tabs .in:where(ul.nav.navbar-nav > li):not(.dropdown) .nav-pills>li>a,.nav-tabs .show:where(ul.nav.navbar-nav > li):not(.dropdown) :where(ul.nav.navbar-nav > li)>a,.nav-tabs .in:where(ul.nav.navbar-nav > li):not(.dropdown) :where(ul.nav.navbar-nav > li)>a{color:var(--bs-nav-tabs-link-active-color);background-color:var(--bs-nav-tabs-link-active-bg);border-color:var(--bs-nav-tabs-link-active-border-color)}.nav-tabs .dropdown-menu{margin-top:calc(-1 * var(--bs-nav-tabs-border-width));border-top-left-radius:0;border-top-right-radius:0}.nav-pills{--bs-nav-pills-border-radius: var(--bs-border-radius);--bs-nav-pills-link-active-color: #fff;--bs-nav-pills-link-active-bg: #007bc2}.nav-pills .nav-link,.nav-pills .nav-tabs>li>a,.nav-pills>li>a,.nav-pills :where(ul.nav.navbar-nav > li)>a{border-radius:var(--bs-nav-pills-border-radius)}.nav-pills .nav-link.active,.nav-pills .nav-tabs>li>a.active,.nav-pills>li>a.active,.nav-pills :where(ul.nav.navbar-nav > li)>a.active,.nav-pills .show>.nav-link,.nav-pills .in>.nav-link,.nav-pills .nav-tabs>li.show>a,.nav-pills .nav-tabs>li.in>a,.nav-pills>li.show>a,.nav-pills>li.in>a,.nav-pills .show:where(ul.nav.navbar-nav > li)>a,.nav-pills .in:where(ul.nav.navbar-nav > li)>a{color:var(--bs-nav-pills-link-active-color);background-color:var(--bs-nav-pills-link-active-bg)}.nav-underline{--bs-nav-underline-gap: 1rem;--bs-nav-underline-border-width: .125rem;--bs-nav-underline-link-active-color: var(--bs-emphasis-color);gap:var(--bs-nav-underline-gap)}.nav-underline .nav-link,.nav-underline .nav-tabs>li>a,.nav-underline .nav-pills>li>a,.nav-underline :where(ul.nav.navbar-nav > li)>a{padding-right:0;padding-left:0;border-bottom:var(--bs-nav-underline-border-width) solid transparent}.nav-underline .nav-link:hover,.nav-underline .nav-tabs>li>a:hover,.nav-underline .nav-pills>li>a:hover,.nav-underline :where(ul.nav.navbar-nav > li)>a:hover,.nav-underline .nav-link:focus,.nav-underline .nav-tabs>li>a:focus,.nav-underline .nav-pills>li>a:focus,.nav-underline :where(ul.nav.navbar-nav > li)>a:focus{border-bottom-color:currentcolor}.nav-underline .nav-link.active,.nav-underline .nav-tabs>li>a.active,.nav-underline .nav-pills>li>a.active,.nav-underline :where(ul.nav.navbar-nav > li)>a.active,.nav-underline .show>.nav-link,.nav-underline .in>.nav-link,.nav-underline .nav-tabs>li.show>a,.nav-underline .nav-tabs>li.in>a,.nav-underline .nav-pills>li.show>a,.nav-underline .nav-pills>li.in>a,.nav-underline .show:where(ul.nav.navbar-nav > li)>a,.nav-underline .in:where(ul.nav.navbar-nav > li)>a{font-weight:700;color:var(--bs-nav-underline-link-active-color);border-bottom-color:currentcolor}.nav-fill>.nav-link,.nav-tabs>li.nav-fill>a,.nav-pills>li.nav-fill>a,.nav-fill:where(ul.nav.navbar-nav > li)>a,.nav-fill .nav-item,.nav-fill .nav-tabs>li,.nav-fill .nav-pills>li,.nav-fill :where(ul.nav.navbar-nav > li):not(.dropdown){flex:1 1 auto;-webkit-flex:1 1 auto;text-align:center}.nav-justified>.nav-link,.nav-tabs>li.nav-justified>a,.nav-pills>li.nav-justified>a,.nav-justified:where(ul.nav.navbar-nav > li)>a,.nav-justified .nav-item,.nav-justified .nav-tabs>li,.nav-justified .nav-pills>li,.nav-justified :where(ul.nav.navbar-nav > li):not(.dropdown){flex-basis:0;-webkit-flex-basis:0;flex-grow:1;-webkit-flex-grow:1;text-align:center}.nav-fill .nav-item .nav-link,.nav-fill .nav-tabs>li .nav-link,.nav-fill .nav-tabs>li>a,.nav-fill .nav-pills>li .nav-link,.nav-fill .nav-pills>li>a,.nav-fill .nav-item :where(ul.nav.navbar-nav > li)>a,.nav-fill .nav-tabs>li :where(ul.nav.navbar-nav > li)>a,.nav-fill .nav-pills>li :where(ul.nav.navbar-nav > li)>a,.nav-fill :where(ul.nav.navbar-nav > li):not(.dropdown) .nav-link,.nav-fill :where(ul.nav.navbar-nav > li):not(.dropdown) :where(ul.nav.navbar-nav > li)>a,.nav-justified .nav-item .nav-link,.nav-justified .nav-tabs>li .nav-link,.nav-justified .nav-tabs>li>a,.nav-justified .nav-pills>li .nav-link,.nav-justified .nav-pills>li>a,.nav-justified .nav-item :where(ul.nav.navbar-nav > li)>a,.nav-justified .nav-tabs>li :where(ul.nav.navbar-nav > li)>a,.nav-justified .nav-pills>li :where(ul.nav.navbar-nav > li)>a,.nav-justified :where(ul.nav.navbar-nav > li):not(.dropdown) .nav-link,.nav-justified :where(ul.nav.navbar-nav > li):not(.dropdown) :where(ul.nav.navbar-nav > li)>a{width:100%}.tab-content>.tab-pane{display:none}.tab-content>.active{display:block}.navbar{--bs-navbar-padding-x: .66rem;--bs-navbar-padding-y: .5rem;--bs-navbar-color: rgba(var(--bs-emphasis-color-rgb), 0.65);--bs-navbar-hover-color: rgba(var(--bs-emphasis-color-rgb), 0.8);--bs-navbar-disabled-color: rgba(var(--bs-emphasis-color-rgb), 0.3);--bs-navbar-active-color: rgba(var(--bs-emphasis-color-rgb), 1);--bs-navbar-brand-padding-y: .3125rem;--bs-navbar-brand-margin-end: 1rem;--bs-navbar-brand-font-size: 1.25rem;--bs-navbar-brand-color: rgba(var(--bs-emphasis-color-rgb), 1);--bs-navbar-brand-hover-color: rgba(var(--bs-emphasis-color-rgb), 1);--bs-navbar-nav-link-padding-x: .5rem;--bs-navbar-toggler-padding-y: .25rem;--bs-navbar-toggler-padding-x: .75rem;--bs-navbar-toggler-font-size: 1.25rem;--bs-navbar-toggler-icon-bg: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%2829,31,33,0.75%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");--bs-navbar-toggler-border-color: rgba(var(--bs-emphasis-color-rgb), 0.15);--bs-navbar-toggler-border-radius: var(--bs-border-radius);--bs-navbar-toggler-focus-width: .25rem;--bs-navbar-toggler-transition: box-shadow 0.15s ease-in-out;position:relative;display:flex;display:-webkit-flex;flex-wrap:wrap;-webkit-flex-wrap:wrap;align-items:center;-webkit-align-items:center;justify-content:space-between;-webkit-justify-content:space-between;padding:var(--bs-navbar-padding-y) var(--bs-navbar-padding-x)}.navbar>.container,.navbar>.container-fluid,.navbar>.container-sm,.navbar>.container-md,.navbar>.container-lg,.navbar>.container-xl,.navbar>.container-xxl{display:flex;display:-webkit-flex;flex-wrap:inherit;-webkit-flex-wrap:inherit;align-items:center;-webkit-align-items:center;justify-content:space-between;-webkit-justify-content:space-between}.navbar-brand{padding-top:var(--bs-navbar-brand-padding-y);padding-bottom:var(--bs-navbar-brand-padding-y);margin-right:var(--bs-navbar-brand-margin-end);font-size:var(--bs-navbar-brand-font-size);color:var(--bs-navbar-brand-color);text-decoration:none;-webkit-text-decoration:none;-moz-text-decoration:none;-ms-text-decoration:none;-o-text-decoration:none;white-space:nowrap}.navbar-brand:hover,.navbar-brand:focus{color:var(--bs-navbar-brand-hover-color)}.navbar-nav{--bs-nav-link-padding-x: 0;--bs-nav-link-padding-y: .5rem;--bs-nav-link-font-weight: ;--bs-nav-link-color: var(--bs-navbar-color);--bs-nav-link-hover-color: var(--bs-navbar-hover-color);--bs-nav-link-disabled-color: var(--bs-navbar-disabled-color);display:flex;display:-webkit-flex;flex-direction:column;-webkit-flex-direction:column;padding-left:0;margin-bottom:0;list-style:none}.navbar-nav .nav-link.active,.navbar-nav .nav-tabs>li>a.active,.navbar-nav .nav-pills>li>a.active,.navbar-nav :where(ul.nav.navbar-nav > li)>a.active,.navbar-nav .nav-link.show,.navbar-nav .nav-link.in,.navbar-nav .nav-tabs>li>a.show,.navbar-nav .nav-tabs>li>a.in,.navbar-nav .nav-pills>li>a.show,.navbar-nav .nav-pills>li>a.in,.navbar-nav :where(ul.nav.navbar-nav > li)>a.show,.navbar-nav :where(ul.nav.navbar-nav > li)>a.in{color:var(--bs-navbar-active-color)}.navbar-nav .dropdown-menu{position:static}.navbar-text{padding-top:.5rem;padding-bottom:.5rem;color:var(--bs-navbar-color)}.navbar-text a,.navbar-text a:hover,.navbar-text a:focus{color:var(--bs-navbar-active-color)}.navbar-collapse{flex-basis:100%;-webkit-flex-basis:100%;flex-grow:1;-webkit-flex-grow:1;align-items:center;-webkit-align-items:center}.navbar-toggler,.navbar-toggle{padding:var(--bs-navbar-toggler-padding-y) var(--bs-navbar-toggler-padding-x);font-size:var(--bs-navbar-toggler-font-size);line-height:1;color:var(--bs-navbar-color);background-color:transparent;border:var(--bs-border-width) solid var(--bs-navbar-toggler-border-color);border-radius:var(--bs-navbar-toggler-border-radius);transition:var(--bs-navbar-toggler-transition)}@media (prefers-reduced-motion: reduce){.navbar-toggler,.navbar-toggle{transition:none}}.navbar-toggler:hover,.navbar-toggle:hover{text-decoration:none}.navbar-toggler:focus,.navbar-toggle:focus{text-decoration:none;outline:0;box-shadow:0 0 0 var(--bs-navbar-toggler-focus-width)}.navbar-toggler-icon,.navbar-toggle>.icon-bar:last-child{display:inline-block;width:1.5em;height:1.5em;vertical-align:middle;background-image:var(--bs-navbar-toggler-icon-bg);background-repeat:no-repeat;background-position:center;background-size:100%}.navbar-nav-scroll{max-height:var(--bs-scroll-height, 75vh);overflow-y:auto}@media (min-width: 576px){.navbar-expand-sm{flex-wrap:nowrap;-webkit-flex-wrap:nowrap;justify-content:flex-start;-webkit-justify-content:flex-start}.navbar-expand-sm .navbar-nav{flex-direction:row;-webkit-flex-direction:row}.navbar-expand-sm .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-sm .navbar-nav .nav-link,.navbar-expand-sm .navbar-nav .nav-tabs>li>a,.navbar-expand-sm .navbar-nav .nav-pills>li>a,.navbar-expand-sm .navbar-nav :where(ul.nav.navbar-nav > li)>a{padding-right:var(--bs-navbar-nav-link-padding-x);padding-left:var(--bs-navbar-nav-link-padding-x)}.navbar-expand-sm .navbar-nav-scroll{overflow:visible}.navbar-expand-sm .navbar-collapse{display:flex !important;display:-webkit-flex !important;flex-basis:auto;-webkit-flex-basis:auto}.navbar-expand-sm .navbar-toggler,.navbar-expand-sm .navbar-toggle{display:none}.navbar-expand-sm .offcanvas{position:static;z-index:auto;flex-grow:1;-webkit-flex-grow:1;width:auto !important;height:auto !important;visibility:visible !important;background-color:transparent !important;border:0 !important;transform:none !important;transition:none}.navbar-expand-sm .offcanvas .offcanvas-header{display:none}.navbar-expand-sm .offcanvas .offcanvas-body{display:flex;display:-webkit-flex;flex-grow:0;-webkit-flex-grow:0;padding:0;overflow-y:visible}}@media (min-width: 768px){.navbar-expand-md{flex-wrap:nowrap;-webkit-flex-wrap:nowrap;justify-content:flex-start;-webkit-justify-content:flex-start}.navbar-expand-md .navbar-nav{flex-direction:row;-webkit-flex-direction:row}.navbar-expand-md .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-md .navbar-nav .nav-link,.navbar-expand-md .navbar-nav .nav-tabs>li>a,.navbar-expand-md .navbar-nav .nav-pills>li>a,.navbar-expand-md .navbar-nav :where(ul.nav.navbar-nav > li)>a{padding-right:var(--bs-navbar-nav-link-padding-x);padding-left:var(--bs-navbar-nav-link-padding-x)}.navbar-expand-md .navbar-nav-scroll{overflow:visible}.navbar-expand-md .navbar-collapse{display:flex !important;display:-webkit-flex !important;flex-basis:auto;-webkit-flex-basis:auto}.navbar-expand-md .navbar-toggler,.navbar-expand-md .navbar-toggle{display:none}.navbar-expand-md .offcanvas{position:static;z-index:auto;flex-grow:1;-webkit-flex-grow:1;width:auto !important;height:auto !important;visibility:visible !important;background-color:transparent !important;border:0 !important;transform:none !important;transition:none}.navbar-expand-md .offcanvas .offcanvas-header{display:none}.navbar-expand-md .offcanvas .offcanvas-body{display:flex;display:-webkit-flex;flex-grow:0;-webkit-flex-grow:0;padding:0;overflow-y:visible}}@media (min-width: 992px){.navbar-expand-lg,.navbar:not(.navbar-expand):not(.navbar-expand-sm):not(.navbar-expand-md):not(.navbar-expand-lg):not(.navbar-expand-xl){flex-wrap:nowrap;-webkit-flex-wrap:nowrap;justify-content:flex-start;-webkit-justify-content:flex-start}.navbar-expand-lg .navbar-nav,.navbar:not(.navbar-expand):not(.navbar-expand-sm):not(.navbar-expand-md):not(.navbar-expand-lg):not(.navbar-expand-xl) .navbar-nav{flex-direction:row;-webkit-flex-direction:row}.navbar-expand-lg .navbar-nav .dropdown-menu,.navbar:not(.navbar-expand):not(.navbar-expand-sm):not(.navbar-expand-md):not(.navbar-expand-lg):not(.navbar-expand-xl) .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-lg .navbar-nav .nav-link,.navbar-expand-lg .navbar-nav .nav-tabs>li>a,.navbar-expand-lg .navbar-nav .nav-pills>li>a,.navbar-expand-lg .navbar-nav :where(ul.nav.navbar-nav > li)>a,.navbar:not(.navbar-expand):not(.navbar-expand-sm):not(.navbar-expand-md):not(.navbar-expand-lg):not(.navbar-expand-xl) .navbar-nav .nav-link,.navbar:not(.navbar-expand):not(.navbar-expand-sm):not(.navbar-expand-md):not(.navbar-expand-lg):not(.navbar-expand-xl) .navbar-nav .nav-tabs>li>a,.navbar:not(.navbar-expand):not(.navbar-expand-sm):not(.navbar-expand-md):not(.navbar-expand-lg):not(.navbar-expand-xl) .navbar-nav .nav-pills>li>a,.navbar:not(.navbar-expand):not(.navbar-expand-sm):not(.navbar-expand-md):not(.navbar-expand-lg):not(.navbar-expand-xl) .navbar-nav :where(ul.nav.navbar-nav > li)>a{padding-right:var(--bs-navbar-nav-link-padding-x);padding-left:var(--bs-navbar-nav-link-padding-x)}.navbar-expand-lg .navbar-nav-scroll,.navbar:not(.navbar-expand):not(.navbar-expand-sm):not(.navbar-expand-md):not(.navbar-expand-lg):not(.navbar-expand-xl) .navbar-nav-scroll{overflow:visible}.navbar-expand-lg .navbar-collapse,.navbar:not(.navbar-expand):not(.navbar-expand-sm):not(.navbar-expand-md):not(.navbar-expand-lg):not(.navbar-expand-xl) .navbar-collapse{display:flex !important;display:-webkit-flex !important;flex-basis:auto;-webkit-flex-basis:auto}.navbar-expand-lg .navbar-toggler,.navbar-expand-lg .navbar-toggle,.navbar:not(.navbar-expand):not(.navbar-expand-sm):not(.navbar-expand-md):not(.navbar-expand-lg):not(.navbar-expand-xl) .navbar-toggler,.navbar:not(.navbar-expand):not(.navbar-expand-sm):not(.navbar-expand-md):not(.navbar-expand-lg):not(.navbar-expand-xl) .navbar-toggle{display:none}.navbar-expand-lg .offcanvas,.navbar:not(.navbar-expand):not(.navbar-expand-sm):not(.navbar-expand-md):not(.navbar-expand-lg):not(.navbar-expand-xl) .offcanvas{position:static;z-index:auto;flex-grow:1;-webkit-flex-grow:1;width:auto !important;height:auto !important;visibility:visible !important;background-color:transparent !important;border:0 !important;transform:none !important;transition:none}.navbar-expand-lg .offcanvas .offcanvas-header,.navbar:not(.navbar-expand):not(.navbar-expand-sm):not(.navbar-expand-md):not(.navbar-expand-lg):not(.navbar-expand-xl) .offcanvas .offcanvas-header{display:none}.navbar-expand-lg .offcanvas .offcanvas-body,.navbar:not(.navbar-expand):not(.navbar-expand-sm):not(.navbar-expand-md):not(.navbar-expand-lg):not(.navbar-expand-xl) .offcanvas .offcanvas-body{display:flex;display:-webkit-flex;flex-grow:0;-webkit-flex-grow:0;padding:0;overflow-y:visible}}@media (min-width: 1200px){.navbar-expand-xl{flex-wrap:nowrap;-webkit-flex-wrap:nowrap;justify-content:flex-start;-webkit-justify-content:flex-start}.navbar-expand-xl .navbar-nav{flex-direction:row;-webkit-flex-direction:row}.navbar-expand-xl .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-xl .navbar-nav .nav-link,.navbar-expand-xl .navbar-nav .nav-tabs>li>a,.navbar-expand-xl .navbar-nav .nav-pills>li>a,.navbar-expand-xl .navbar-nav :where(ul.nav.navbar-nav > li)>a{padding-right:var(--bs-navbar-nav-link-padding-x);padding-left:var(--bs-navbar-nav-link-padding-x)}.navbar-expand-xl .navbar-nav-scroll{overflow:visible}.navbar-expand-xl .navbar-collapse{display:flex !important;display:-webkit-flex !important;flex-basis:auto;-webkit-flex-basis:auto}.navbar-expand-xl .navbar-toggler,.navbar-expand-xl .navbar-toggle{display:none}.navbar-expand-xl .offcanvas{position:static;z-index:auto;flex-grow:1;-webkit-flex-grow:1;width:auto !important;height:auto !important;visibility:visible !important;background-color:transparent !important;border:0 !important;transform:none !important;transition:none}.navbar-expand-xl .offcanvas .offcanvas-header{display:none}.navbar-expand-xl .offcanvas .offcanvas-body{display:flex;display:-webkit-flex;flex-grow:0;-webkit-flex-grow:0;padding:0;overflow-y:visible}}@media (min-width: 1400px){.navbar-expand-xxl{flex-wrap:nowrap;-webkit-flex-wrap:nowrap;justify-content:flex-start;-webkit-justify-content:flex-start}.navbar-expand-xxl .navbar-nav{flex-direction:row;-webkit-flex-direction:row}.navbar-expand-xxl .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-xxl .navbar-nav .nav-link,.navbar-expand-xxl .navbar-nav .nav-tabs>li>a,.navbar-expand-xxl .navbar-nav .nav-pills>li>a,.navbar-expand-xxl .navbar-nav :where(ul.nav.navbar-nav > li)>a{padding-right:var(--bs-navbar-nav-link-padding-x);padding-left:var(--bs-navbar-nav-link-padding-x)}.navbar-expand-xxl .navbar-nav-scroll{overflow:visible}.navbar-expand-xxl .navbar-collapse{display:flex !important;display:-webkit-flex !important;flex-basis:auto;-webkit-flex-basis:auto}.navbar-expand-xxl .navbar-toggler,.navbar-expand-xxl .navbar-toggle{display:none}.navbar-expand-xxl .offcanvas{position:static;z-index:auto;flex-grow:1;-webkit-flex-grow:1;width:auto !important;height:auto !important;visibility:visible !important;background-color:transparent !important;border:0 !important;transform:none !important;transition:none}.navbar-expand-xxl .offcanvas .offcanvas-header{display:none}.navbar-expand-xxl .offcanvas .offcanvas-body{display:flex;display:-webkit-flex;flex-grow:0;-webkit-flex-grow:0;padding:0;overflow-y:visible}}.navbar-expand{flex-wrap:nowrap;-webkit-flex-wrap:nowrap;justify-content:flex-start;-webkit-justify-content:flex-start}.navbar-expand .navbar-nav{flex-direction:row;-webkit-flex-direction:row}.navbar-expand .navbar-nav .dropdown-menu{position:absolute}.navbar-expand .navbar-nav .nav-link,.navbar-expand .navbar-nav .nav-tabs>li>a,.navbar-expand .navbar-nav .nav-pills>li>a,.navbar-expand .navbar-nav :where(ul.nav.navbar-nav > li)>a{padding-right:var(--bs-navbar-nav-link-padding-x);padding-left:var(--bs-navbar-nav-link-padding-x)}.navbar-expand .navbar-nav-scroll{overflow:visible}.navbar-expand .navbar-collapse{display:flex !important;display:-webkit-flex !important;flex-basis:auto;-webkit-flex-basis:auto}.navbar-expand .navbar-toggler,.navbar-expand .navbar-toggle{display:none}.navbar-expand .offcanvas{position:static;z-index:auto;flex-grow:1;-webkit-flex-grow:1;width:auto !important;height:auto !important;visibility:visible !important;background-color:transparent !important;border:0 !important;transform:none !important;transition:none}.navbar-expand .offcanvas .offcanvas-header{display:none}.navbar-expand .offcanvas .offcanvas-body{display:flex;display:-webkit-flex;flex-grow:0;-webkit-flex-grow:0;padding:0;overflow-y:visible}.navbar-dark,.navbar.navbar-inverse,.navbar[data-bs-theme="dark"]{--bs-navbar-color: rgba(var(--bs-emphasis-color-rgb), 0.55);--bs-navbar-hover-color: rgba(var(--bs-emphasis-color-rgb), 0.75);--bs-navbar-disabled-color: rgba(var(--bs-emphasis-color-rgb), 0.25);--bs-navbar-active-color: rgba(var(--bs-emphasis-color-rgb), 1);--bs-navbar-brand-color: rgba(var(--bs-emphasis-color-rgb), 1);--bs-navbar-brand-hover-color: rgba(var(--bs-emphasis-color-rgb), 1);--bs-navbar-toggler-border-color: rgba(var(--bs-emphasis-color-rgb), 0.1);--bs-navbar-toggler-icon-bg: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28255,255,255,0.75%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e")}[data-bs-theme="dark"] .navbar-toggler-icon,[data-bs-theme="dark"] .navbar-toggle>.icon-bar:last-child{--bs-navbar-toggler-icon-bg: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28255,255,255,0.75%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e")}.card,.well{--bs-card-spacer-y: 1rem;--bs-card-spacer-x: 1rem;--bs-card-title-spacer-y: .5rem;--bs-card-title-color: ;--bs-card-subtitle-color: ;--bs-card-border-width: var(--bs-border-width);--bs-card-border-color: var(--bs-border-color-translucent);--bs-card-border-radius: 8px;--bs-card-box-shadow: ;--bs-card-inner-border-radius: calc(8px - (var(--bs-border-width)));--bs-card-cap-padding-y: .5rem;--bs-card-cap-padding-x: 1rem;--bs-card-cap-bg: rgba(var(--bs-body-color-rgb), 0.03);--bs-card-cap-color: ;--bs-card-height: ;--bs-card-color: ;--bs-card-bg: var(--bs-body-bg);--bs-card-img-overlay-padding: 1rem;--bs-card-group-margin: .75rem;position:relative;display:flex;display:-webkit-flex;flex-direction:column;-webkit-flex-direction:column;min-width:0;height:var(--bs-card-height);color:var(--bs-body-color);word-wrap:break-word;background-color:var(--bs-card-bg);background-clip:border-box;border:var(--bs-card-border-width) solid var(--bs-card-border-color);border-radius:var(--bs-card-border-radius)}.card>hr,.well>hr{margin-right:0;margin-left:0}.card>.list-group,.well>.list-group{border-top:inherit;border-bottom:inherit}.card>.list-group:first-child,.well>.list-group:first-child{border-top-width:0;border-top-left-radius:var(--bs-card-inner-border-radius);border-top-right-radius:var(--bs-card-inner-border-radius)}.card>.list-group:last-child,.well>.list-group:last-child{border-bottom-width:0;border-bottom-right-radius:var(--bs-card-inner-border-radius);border-bottom-left-radius:var(--bs-card-inner-border-radius)}.card>.card-header+.list-group,.well>.card-header+.list-group,.card>.list-group+.card-footer,.well>.list-group+.card-footer{border-top:0}.card-body{flex:1 1 auto;-webkit-flex:1 1 auto;padding:var(--bs-card-spacer-y) var(--bs-card-spacer-x);color:var(--bs-card-color)}.card-title{margin-bottom:var(--bs-card-title-spacer-y);color:var(--bs-card-title-color)}.card-subtitle{margin-top:calc(-.5 * var(--bs-card-title-spacer-y));margin-bottom:0;color:var(--bs-card-subtitle-color)}.card-text:last-child{margin-bottom:0}.card-link+.card-link{margin-left:var(--bs-card-spacer-x)}.card-header{padding:var(--bs-card-cap-padding-y) var(--bs-card-cap-padding-x);margin-bottom:0;color:var(--bs-card-cap-color);background-color:var(--bs-card-cap-bg);border-bottom:var(--bs-card-border-width) solid var(--bs-card-border-color)}.card-header:first-child{border-radius:var(--bs-card-inner-border-radius) var(--bs-card-inner-border-radius) 0 0}.card-footer{padding:var(--bs-card-cap-padding-y) var(--bs-card-cap-padding-x);color:var(--bs-card-cap-color);background-color:var(--bs-card-cap-bg);border-top:var(--bs-card-border-width) solid var(--bs-card-border-color)}.card-footer:last-child{border-radius:0 0 var(--bs-card-inner-border-radius) var(--bs-card-inner-border-radius)}.card-header-tabs{margin-right:calc(-.5 * var(--bs-card-cap-padding-x));margin-bottom:calc(-1 * var(--bs-card-cap-padding-y));margin-left:calc(-.5 * var(--bs-card-cap-padding-x));border-bottom:0}.card-header-tabs .nav-link.active,.card-header-tabs .nav-tabs>li>a.active,.card-header-tabs .nav-pills>li>a.active,.card-header-tabs :where(ul.nav.navbar-nav > li)>a.active{background-color:var(--bs-card-bg);border-bottom-color:var(--bs-card-bg)}.card-header-pills{margin-right:calc(-.5 * var(--bs-card-cap-padding-x));margin-left:calc(-.5 * var(--bs-card-cap-padding-x))}.card-img-overlay{position:absolute;top:0;right:0;bottom:0;left:0;padding:var(--bs-card-img-overlay-padding);border-radius:var(--bs-card-inner-border-radius)}.card-img,.card-img-top,.card-img-bottom{width:100%}.card-img,.card-img-top{border-top-left-radius:var(--bs-card-inner-border-radius);border-top-right-radius:var(--bs-card-inner-border-radius)}.card-img,.card-img-bottom{border-bottom-right-radius:var(--bs-card-inner-border-radius);border-bottom-left-radius:var(--bs-card-inner-border-radius)}.card-group>.card,.card-group>.well{margin-bottom:var(--bs-card-group-margin)}@media (min-width: 576px){.card-group{display:flex;display:-webkit-flex;flex-flow:row wrap;-webkit-flex-flow:row wrap}.card-group>.card,.card-group>.well{flex:1 0 0%;-webkit-flex:1 0 0%;margin-bottom:0}.card-group>.card+.card,.card-group>.well+.card,.card-group>.card+.well,.card-group>.well+.well{margin-left:0;border-left:0}.card-group>.card:not(:last-child),.card-group>.well:not(:last-child){border-top-right-radius:0;border-bottom-right-radius:0}.card-group>.card:not(:last-child) .card-img-top,.card-group>.well:not(:last-child) .card-img-top,.card-group>.card:not(:last-child) .card-header,.card-group>.well:not(:last-child) .card-header{border-top-right-radius:0}.card-group>.card:not(:last-child) .card-img-bottom,.card-group>.well:not(:last-child) .card-img-bottom,.card-group>.card:not(:last-child) .card-footer,.card-group>.well:not(:last-child) .card-footer{border-bottom-right-radius:0}.card-group>.card:not(:first-child),.card-group>.well:not(:first-child){border-top-left-radius:0;border-bottom-left-radius:0}.card-group>.card:not(:first-child) .card-img-top,.card-group>.well:not(:first-child) .card-img-top,.card-group>.card:not(:first-child) .card-header,.card-group>.well:not(:first-child) .card-header{border-top-left-radius:0}.card-group>.card:not(:first-child) .card-img-bottom,.card-group>.well:not(:first-child) .card-img-bottom,.card-group>.card:not(:first-child) .card-footer,.card-group>.well:not(:first-child) .card-footer{border-bottom-left-radius:0}}.accordion{--bs-accordion-color: var(--bs-body-color);--bs-accordion-bg: var(--bs-body-bg);--bs-accordion-transition: color 0.15s ease-in-out,background-color 0.15s ease-in-out,border-color 0.15s ease-in-out,box-shadow 0.15s ease-in-out,border-radius 0.15s ease;--bs-accordion-border-color: var(--bs-border-color);--bs-accordion-border-width: var(--bs-border-width);--bs-accordion-border-radius: var(--bs-border-radius);--bs-accordion-inner-border-radius: calc(var(--bs-border-radius) - (var(--bs-border-width)));--bs-accordion-btn-padding-x: 1.25rem;--bs-accordion-btn-padding-y: 1rem;--bs-accordion-btn-color: var(--bs-body-color);--bs-accordion-btn-bg: var(--bs-accordion-bg);--bs-accordion-btn-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%231D1F21'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");--bs-accordion-btn-icon-width: 1.25rem;--bs-accordion-btn-icon-transform: rotate(-180deg);--bs-accordion-btn-icon-transition: transform 0.2s ease-in-out;--bs-accordion-btn-active-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%2300314e'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");--bs-accordion-btn-focus-border-color: #80bde1;--bs-accordion-btn-focus-box-shadow: 0 0 0 .25rem rgba(0,123,194,0.25);--bs-accordion-body-padding-x: 1.25rem;--bs-accordion-body-padding-y: 1rem;--bs-accordion-active-color: ;--bs-accordion-active-bg: }.accordion-button{position:relative;display:flex;display:-webkit-flex;align-items:center;-webkit-align-items:center;width:100%;padding:var(--bs-accordion-btn-padding-y) var(--bs-accordion-btn-padding-x);font-size:1rem;color:var(--bs-accordion-btn-color);text-align:left;background-color:var(--bs-accordion-btn-bg);border:0;border-radius:0;overflow-anchor:none;transition:var(--bs-accordion-transition)}@media (prefers-reduced-motion: reduce){.accordion-button{transition:none}}.accordion-button:not(.collapsed){color:var(--bs-accordion-active-color);background-color:var(--bs-accordion-active-bg);box-shadow:inset 0 calc(-1 * var(--bs-accordion-border-width)) 0 var(--bs-accordion-border-color)}.accordion-button:not(.collapsed)::after{background-image:var(--bs-accordion-btn-active-icon);transform:var(--bs-accordion-btn-icon-transform)}.accordion-button::after{flex-shrink:0;-webkit-flex-shrink:0;width:var(--bs-accordion-btn-icon-width);height:var(--bs-accordion-btn-icon-width);margin-left:auto;content:"";background-image:var(--bs-accordion-btn-icon);background-repeat:no-repeat;background-size:var(--bs-accordion-btn-icon-width);transition:var(--bs-accordion-btn-icon-transition)}@media (prefers-reduced-motion: reduce){.accordion-button::after{transition:none}}.accordion-button:hover{z-index:2}.accordion-button:focus{z-index:3;border-color:var(--bs-accordion-btn-focus-border-color);outline:0;box-shadow:var(--bs-accordion-btn-focus-box-shadow)}.accordion-header{margin-bottom:0}.accordion-item{color:var(--bs-accordion-color);background-color:var(--bs-accordion-bg);border:var(--bs-accordion-border-width) solid var(--bs-accordion-border-color)}.accordion-item:first-of-type{border-top-left-radius:var(--bs-accordion-border-radius);border-top-right-radius:var(--bs-accordion-border-radius)}.accordion-item:first-of-type .accordion-button{border-top-left-radius:var(--bs-accordion-inner-border-radius);border-top-right-radius:var(--bs-accordion-inner-border-radius)}.accordion-item:not(:first-of-type){border-top:0}.accordion-item:last-of-type{border-bottom-right-radius:var(--bs-accordion-border-radius);border-bottom-left-radius:var(--bs-accordion-border-radius)}.accordion-item:last-of-type .accordion-button.collapsed{border-bottom-right-radius:var(--bs-accordion-inner-border-radius);border-bottom-left-radius:var(--bs-accordion-inner-border-radius)}.accordion-item:last-of-type .accordion-collapse{border-bottom-right-radius:var(--bs-accordion-border-radius);border-bottom-left-radius:var(--bs-accordion-border-radius)}.accordion-body{padding:var(--bs-accordion-body-padding-y) var(--bs-accordion-body-padding-x)}.accordion-flush .accordion-collapse{border-width:0}.accordion-flush .accordion-item{border-right:0;border-left:0;border-radius:0}.accordion-flush .accordion-item:first-child{border-top:0}.accordion-flush .accordion-item:last-child{border-bottom:0}.accordion-flush .accordion-item .accordion-button,.accordion-flush .accordion-item .accordion-button.collapsed{border-radius:0}[data-bs-theme="dark"] .accordion-button::after{--bs-accordion-btn-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%2366b0da'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");--bs-accordion-btn-active-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%2366b0da'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e")}.breadcrumb{--bs-breadcrumb-padding-x: 0;--bs-breadcrumb-padding-y: 0;--bs-breadcrumb-margin-bottom: 1rem;--bs-breadcrumb-bg: ;--bs-breadcrumb-border-radius: ;--bs-breadcrumb-divider-color: var(--bs-secondary-color);--bs-breadcrumb-item-padding-x: .5rem;--bs-breadcrumb-item-active-color: var(--bs-secondary-color);display:flex;display:-webkit-flex;flex-wrap:wrap;-webkit-flex-wrap:wrap;padding:var(--bs-breadcrumb-padding-y) var(--bs-breadcrumb-padding-x);margin-bottom:var(--bs-breadcrumb-margin-bottom);font-size:var(--bs-breadcrumb-font-size);list-style:none;background-color:var(--bs-breadcrumb-bg);border-radius:var(--bs-breadcrumb-border-radius)}.breadcrumb-item+.breadcrumb-item{padding-left:var(--bs-breadcrumb-item-padding-x)}.breadcrumb-item+.breadcrumb-item::before{float:left;padding-right:var(--bs-breadcrumb-item-padding-x);color:var(--bs-breadcrumb-divider-color);content:var(--bs-breadcrumb-divider, "/") /* rtl: var(--bs-breadcrumb-divider, "/") */}.breadcrumb-item.active{color:var(--bs-breadcrumb-item-active-color)}.pagination{--bs-pagination-padding-x: .75rem;--bs-pagination-padding-y: .375rem;--bs-pagination-font-size:1rem;--bs-pagination-color: var(--bs-link-color);--bs-pagination-bg: var(--bs-body-bg);--bs-pagination-border-width: var(--bs-border-width);--bs-pagination-border-color: var(--bs-border-color);--bs-pagination-border-radius: var(--bs-border-radius);--bs-pagination-hover-color: var(--bs-link-hover-color);--bs-pagination-hover-bg: var(--bs-tertiary-bg);--bs-pagination-hover-border-color: var(--bs-border-color);--bs-pagination-focus-color: var(--bs-link-hover-color);--bs-pagination-focus-bg: var(--bs-secondary-bg);--bs-pagination-focus-box-shadow: 0 0 0 .25rem rgba(0,123,194,0.25);--bs-pagination-active-color: #fff;--bs-pagination-active-bg: #007bc2;--bs-pagination-active-border-color: #007bc2;--bs-pagination-disabled-color: var(--bs-secondary-color);--bs-pagination-disabled-bg: var(--bs-secondary-bg);--bs-pagination-disabled-border-color: var(--bs-border-color);display:flex;display:-webkit-flex;padding-left:0;list-style:none}.page-link{position:relative;display:block;padding:var(--bs-pagination-padding-y) var(--bs-pagination-padding-x);font-size:var(--bs-pagination-font-size);color:var(--bs-pagination-color);text-decoration:none;-webkit-text-decoration:none;-moz-text-decoration:none;-ms-text-decoration:none;-o-text-decoration:none;background-color:var(--bs-pagination-bg);border:var(--bs-pagination-border-width) solid var(--bs-pagination-border-color);transition:color 0.15s ease-in-out,background-color 0.15s ease-in-out,border-color 0.15s ease-in-out,box-shadow 0.15s ease-in-out}@media (prefers-reduced-motion: reduce){.page-link{transition:none}}.page-link:hover{z-index:2;color:var(--bs-pagination-hover-color);background-color:var(--bs-pagination-hover-bg);border-color:var(--bs-pagination-hover-border-color)}.page-link:focus{z-index:3;color:var(--bs-pagination-focus-color);background-color:var(--bs-pagination-focus-bg);outline:0;box-shadow:var(--bs-pagination-focus-box-shadow)}.page-link.active,.active>.page-link{z-index:3;color:var(--bs-pagination-active-color);background-color:var(--bs-pagination-active-bg);border-color:var(--bs-pagination-active-border-color)}.page-link.disabled,.disabled>.page-link{color:var(--bs-pagination-disabled-color);pointer-events:none;background-color:var(--bs-pagination-disabled-bg);border-color:var(--bs-pagination-disabled-border-color)}.page-item:not(:first-child) .page-link{margin-left:calc(var(--bs-border-width) * -1)}.page-item:first-child .page-link{border-top-left-radius:var(--bs-pagination-border-radius);border-bottom-left-radius:var(--bs-pagination-border-radius)}.page-item:last-child .page-link{border-top-right-radius:var(--bs-pagination-border-radius);border-bottom-right-radius:var(--bs-pagination-border-radius)}.pagination-lg{--bs-pagination-padding-x: 1.5rem;--bs-pagination-padding-y: .75rem;--bs-pagination-font-size:1.25rem;--bs-pagination-border-radius: var(--bs-border-radius-lg)}.pagination-sm{--bs-pagination-padding-x: .5rem;--bs-pagination-padding-y: .25rem;--bs-pagination-font-size:.875rem;--bs-pagination-border-radius: var(--bs-border-radius-sm)}.badge{--bs-badge-padding-x: .65em;--bs-badge-padding-y: .35em;--bs-badge-font-size:.75em;--bs-badge-font-weight: 700;--bs-badge-color: #fff;--bs-badge-border-radius: var(--bs-border-radius);display:inline-block;padding:var(--bs-badge-padding-y) var(--bs-badge-padding-x);font-size:var(--bs-badge-font-size);font-weight:var(--bs-badge-font-weight);line-height:1;color:var(--bs-badge-color);text-align:center;white-space:nowrap;vertical-align:baseline;border-radius:var(--bs-badge-border-radius)}.badge:empty{display:none}.btn .badge{position:relative;top:-1px}.alert{--bs-alert-bg: transparent;--bs-alert-padding-x: 1rem;--bs-alert-padding-y: 1rem;--bs-alert-margin-bottom: 1rem;--bs-alert-color: inherit;--bs-alert-border-color: transparent;--bs-alert-border: var(--bs-border-width) solid var(--bs-alert-border-color);--bs-alert-border-radius: var(--bs-border-radius);--bs-alert-link-color: inherit;position:relative;padding:var(--bs-alert-padding-y) var(--bs-alert-padding-x);margin-bottom:var(--bs-alert-margin-bottom);color:var(--bs-alert-color);background-color:var(--bs-alert-bg);border:var(--bs-alert-border);border-radius:var(--bs-alert-border-radius)}.alert-heading{color:inherit}.alert-link{font-weight:700;color:var(--bs-alert-link-color)}.alert-dismissible{padding-right:3rem}.alert-dismissible .btn-close{position:absolute;top:0;right:0;z-index:2;padding:1.25rem 1rem}.alert-default{--bs-alert-color: var(--bs-default-text-emphasis);--bs-alert-bg: var(--bs-default-bg-subtle);--bs-alert-border-color: var(--bs-default-border-subtle);--bs-alert-link-color: var(--bs-default-text-emphasis)}.alert-primary{--bs-alert-color: var(--bs-primary-text-emphasis);--bs-alert-bg: var(--bs-primary-bg-subtle);--bs-alert-border-color: var(--bs-primary-border-subtle);--bs-alert-link-color: var(--bs-primary-text-emphasis)}.alert-secondary{--bs-alert-color: var(--bs-secondary-text-emphasis);--bs-alert-bg: var(--bs-secondary-bg-subtle);--bs-alert-border-color: var(--bs-secondary-border-subtle);--bs-alert-link-color: var(--bs-secondary-text-emphasis)}.alert-success{--bs-alert-color: var(--bs-success-text-emphasis);--bs-alert-bg: var(--bs-success-bg-subtle);--bs-alert-border-color: var(--bs-success-border-subtle);--bs-alert-link-color: var(--bs-success-text-emphasis)}.alert-info{--bs-alert-color: var(--bs-info-text-emphasis);--bs-alert-bg: var(--bs-info-bg-subtle);--bs-alert-border-color: var(--bs-info-border-subtle);--bs-alert-link-color: var(--bs-info-text-emphasis)}.alert-warning{--bs-alert-color: var(--bs-warning-text-emphasis);--bs-alert-bg: var(--bs-warning-bg-subtle);--bs-alert-border-color: var(--bs-warning-border-subtle);--bs-alert-link-color: var(--bs-warning-text-emphasis)}.alert-danger{--bs-alert-color: var(--bs-danger-text-emphasis);--bs-alert-bg: var(--bs-danger-bg-subtle);--bs-alert-border-color: var(--bs-danger-border-subtle);--bs-alert-link-color: var(--bs-danger-text-emphasis)}.alert-light{--bs-alert-color: var(--bs-light-text-emphasis);--bs-alert-bg: var(--bs-light-bg-subtle);--bs-alert-border-color: var(--bs-light-border-subtle);--bs-alert-link-color: var(--bs-light-text-emphasis)}.alert-dark{--bs-alert-color: var(--bs-dark-text-emphasis);--bs-alert-bg: var(--bs-dark-bg-subtle);--bs-alert-border-color: var(--bs-dark-border-subtle);--bs-alert-link-color: var(--bs-dark-text-emphasis)}@keyframes progress-bar-stripes{0%{background-position-x:1rem}}.progress,.progress-stacked{--bs-progress-height: 1rem;--bs-progress-font-size:.75rem;--bs-progress-bg: var(--bs-secondary-bg);--bs-progress-border-radius: var(--bs-border-radius);--bs-progress-box-shadow: var(--bs-box-shadow-inset);--bs-progress-bar-color: #fff;--bs-progress-bar-bg: #007bc2;--bs-progress-bar-transition: width 0.6s ease;display:flex;display:-webkit-flex;height:var(--bs-progress-height);overflow:hidden;font-size:var(--bs-progress-font-size);background-color:var(--bs-progress-bg);border-radius:var(--bs-progress-border-radius)}.progress-bar{display:flex;display:-webkit-flex;flex-direction:column;-webkit-flex-direction:column;justify-content:center;-webkit-justify-content:center;overflow:hidden;color:var(--bs-progress-bar-color);text-align:center;white-space:nowrap;background-color:var(--bs-progress-bar-bg);transition:var(--bs-progress-bar-transition)}@media (prefers-reduced-motion: reduce){.progress-bar{transition:none}}.progress-bar-striped{background-image:linear-gradient(45deg, rgba(255,255,255,0.15) 25%, transparent 25%, transparent 50%, rgba(255,255,255,0.15) 50%, rgba(255,255,255,0.15) 75%, transparent 75%, transparent);background-size:var(--bs-progress-height) var(--bs-progress-height)}.progress-stacked>.progress{overflow:visible}.progress-stacked>.progress>.progress-bar{width:100%}.progress-bar-animated{animation:1s linear infinite progress-bar-stripes}@media (prefers-reduced-motion: reduce){.progress-bar-animated{animation:none}}.list-group{--bs-list-group-color: var(--bs-body-color);--bs-list-group-bg: var(--bs-body-bg);--bs-list-group-border-color: var(--bs-border-color);--bs-list-group-border-width: var(--bs-border-width);--bs-list-group-border-radius: var(--bs-border-radius);--bs-list-group-item-padding-x: 1rem;--bs-list-group-item-padding-y: .5rem;--bs-list-group-action-color: var(--bs-secondary-color);--bs-list-group-action-hover-color: var(--bs-emphasis-color);--bs-list-group-action-hover-bg: var(--bs-tertiary-bg);--bs-list-group-action-active-color: var(--bs-body-color);--bs-list-group-action-active-bg: var(--bs-secondary-bg);--bs-list-group-disabled-color: var(--bs-secondary-color);--bs-list-group-disabled-bg: var(--bs-body-bg);--bs-list-group-active-color: #fff;--bs-list-group-active-bg: #007bc2;--bs-list-group-active-border-color: #007bc2;display:flex;display:-webkit-flex;flex-direction:column;-webkit-flex-direction:column;padding-left:0;margin-bottom:0;border-radius:var(--bs-list-group-border-radius)}.list-group-numbered{list-style-type:none;counter-reset:section}.list-group-numbered>.list-group-item::before{content:counters(section, ".") ". ";counter-increment:section}.list-group-item-action{width:100%;color:var(--bs-list-group-action-color);text-align:inherit}.list-group-item-action:hover,.list-group-item-action:focus{z-index:1;color:var(--bs-list-group-action-hover-color);text-decoration:none;background-color:var(--bs-list-group-action-hover-bg)}.list-group-item-action:active{color:var(--bs-list-group-action-active-color);background-color:var(--bs-list-group-action-active-bg)}.list-group-item{position:relative;display:block;padding:var(--bs-list-group-item-padding-y) var(--bs-list-group-item-padding-x);color:var(--bs-list-group-color);text-decoration:none;-webkit-text-decoration:none;-moz-text-decoration:none;-ms-text-decoration:none;-o-text-decoration:none;background-color:var(--bs-list-group-bg);border:var(--bs-list-group-border-width) solid var(--bs-list-group-border-color)}.list-group-item:first-child{border-top-left-radius:inherit;border-top-right-radius:inherit}.list-group-item:last-child{border-bottom-right-radius:inherit;border-bottom-left-radius:inherit}.list-group-item.disabled,.list-group-item:disabled{color:var(--bs-list-group-disabled-color);pointer-events:none;background-color:var(--bs-list-group-disabled-bg)}.list-group-item.active{z-index:2;color:var(--bs-list-group-active-color);background-color:var(--bs-list-group-active-bg);border-color:var(--bs-list-group-active-border-color)}.list-group-item+.list-group-item{border-top-width:0}.list-group-item+.list-group-item.active{margin-top:calc(-1 * var(--bs-list-group-border-width));border-top-width:var(--bs-list-group-border-width)}.list-group-horizontal{flex-direction:row;-webkit-flex-direction:row}.list-group-horizontal>.list-group-item:first-child:not(:last-child){border-bottom-left-radius:var(--bs-list-group-border-radius);border-top-right-radius:0}.list-group-horizontal>.list-group-item:last-child:not(:first-child){border-top-right-radius:var(--bs-list-group-border-radius);border-bottom-left-radius:0}.list-group-horizontal>.list-group-item.active{margin-top:0}.list-group-horizontal>.list-group-item+.list-group-item{border-top-width:var(--bs-list-group-border-width);border-left-width:0}.list-group-horizontal>.list-group-item+.list-group-item.active{margin-left:calc(-1 * var(--bs-list-group-border-width));border-left-width:var(--bs-list-group-border-width)}@media (min-width: 576px){.list-group-horizontal-sm{flex-direction:row;-webkit-flex-direction:row}.list-group-horizontal-sm>.list-group-item:first-child:not(:last-child){border-bottom-left-radius:var(--bs-list-group-border-radius);border-top-right-radius:0}.list-group-horizontal-sm>.list-group-item:last-child:not(:first-child){border-top-right-radius:var(--bs-list-group-border-radius);border-bottom-left-radius:0}.list-group-horizontal-sm>.list-group-item.active{margin-top:0}.list-group-horizontal-sm>.list-group-item+.list-group-item{border-top-width:var(--bs-list-group-border-width);border-left-width:0}.list-group-horizontal-sm>.list-group-item+.list-group-item.active{margin-left:calc(-1 * var(--bs-list-group-border-width));border-left-width:var(--bs-list-group-border-width)}}@media (min-width: 768px){.list-group-horizontal-md{flex-direction:row;-webkit-flex-direction:row}.list-group-horizontal-md>.list-group-item:first-child:not(:last-child){border-bottom-left-radius:var(--bs-list-group-border-radius);border-top-right-radius:0}.list-group-horizontal-md>.list-group-item:last-child:not(:first-child){border-top-right-radius:var(--bs-list-group-border-radius);border-bottom-left-radius:0}.list-group-horizontal-md>.list-group-item.active{margin-top:0}.list-group-horizontal-md>.list-group-item+.list-group-item{border-top-width:var(--bs-list-group-border-width);border-left-width:0}.list-group-horizontal-md>.list-group-item+.list-group-item.active{margin-left:calc(-1 * var(--bs-list-group-border-width));border-left-width:var(--bs-list-group-border-width)}}@media (min-width: 992px){.list-group-horizontal-lg{flex-direction:row;-webkit-flex-direction:row}.list-group-horizontal-lg>.list-group-item:first-child:not(:last-child){border-bottom-left-radius:var(--bs-list-group-border-radius);border-top-right-radius:0}.list-group-horizontal-lg>.list-group-item:last-child:not(:first-child){border-top-right-radius:var(--bs-list-group-border-radius);border-bottom-left-radius:0}.list-group-horizontal-lg>.list-group-item.active{margin-top:0}.list-group-horizontal-lg>.list-group-item+.list-group-item{border-top-width:var(--bs-list-group-border-width);border-left-width:0}.list-group-horizontal-lg>.list-group-item+.list-group-item.active{margin-left:calc(-1 * var(--bs-list-group-border-width));border-left-width:var(--bs-list-group-border-width)}}@media (min-width: 1200px){.list-group-horizontal-xl{flex-direction:row;-webkit-flex-direction:row}.list-group-horizontal-xl>.list-group-item:first-child:not(:last-child){border-bottom-left-radius:var(--bs-list-group-border-radius);border-top-right-radius:0}.list-group-horizontal-xl>.list-group-item:last-child:not(:first-child){border-top-right-radius:var(--bs-list-group-border-radius);border-bottom-left-radius:0}.list-group-horizontal-xl>.list-group-item.active{margin-top:0}.list-group-horizontal-xl>.list-group-item+.list-group-item{border-top-width:var(--bs-list-group-border-width);border-left-width:0}.list-group-horizontal-xl>.list-group-item+.list-group-item.active{margin-left:calc(-1 * var(--bs-list-group-border-width));border-left-width:var(--bs-list-group-border-width)}}@media (min-width: 1400px){.list-group-horizontal-xxl{flex-direction:row;-webkit-flex-direction:row}.list-group-horizontal-xxl>.list-group-item:first-child:not(:last-child){border-bottom-left-radius:var(--bs-list-group-border-radius);border-top-right-radius:0}.list-group-horizontal-xxl>.list-group-item:last-child:not(:first-child){border-top-right-radius:var(--bs-list-group-border-radius);border-bottom-left-radius:0}.list-group-horizontal-xxl>.list-group-item.active{margin-top:0}.list-group-horizontal-xxl>.list-group-item+.list-group-item{border-top-width:var(--bs-list-group-border-width);border-left-width:0}.list-group-horizontal-xxl>.list-group-item+.list-group-item.active{margin-left:calc(-1 * var(--bs-list-group-border-width));border-left-width:var(--bs-list-group-border-width)}}.list-group-flush{border-radius:0}.list-group-flush>.list-group-item{border-width:0 0 var(--bs-list-group-border-width)}.list-group-flush>.list-group-item:last-child{border-bottom-width:0}.list-group-item-default{--bs-list-group-color: var(--bs-default-text-emphasis);--bs-list-group-bg: var(--bs-default-bg-subtle);--bs-list-group-border-color: var(--bs-default-border-subtle);--bs-list-group-action-hover-color: var(--bs-emphasis-color);--bs-list-group-action-hover-bg: var(--bs-default-border-subtle);--bs-list-group-action-active-color: var(--bs-emphasis-color);--bs-list-group-action-active-bg: var(--bs-default-border-subtle);--bs-list-group-active-color: var(--bs-default-bg-subtle);--bs-list-group-active-bg: var(--bs-default-text-emphasis);--bs-list-group-active-border-color: var(--bs-default-text-emphasis)}.list-group-item-primary{--bs-list-group-color: var(--bs-primary-text-emphasis);--bs-list-group-bg: var(--bs-primary-bg-subtle);--bs-list-group-border-color: var(--bs-primary-border-subtle);--bs-list-group-action-hover-color: var(--bs-emphasis-color);--bs-list-group-action-hover-bg: var(--bs-primary-border-subtle);--bs-list-group-action-active-color: var(--bs-emphasis-color);--bs-list-group-action-active-bg: var(--bs-primary-border-subtle);--bs-list-group-active-color: var(--bs-primary-bg-subtle);--bs-list-group-active-bg: var(--bs-primary-text-emphasis);--bs-list-group-active-border-color: var(--bs-primary-text-emphasis)}.list-group-item-secondary{--bs-list-group-color: var(--bs-secondary-text-emphasis);--bs-list-group-bg: var(--bs-secondary-bg-subtle);--bs-list-group-border-color: var(--bs-secondary-border-subtle);--bs-list-group-action-hover-color: var(--bs-emphasis-color);--bs-list-group-action-hover-bg: var(--bs-secondary-border-subtle);--bs-list-group-action-active-color: var(--bs-emphasis-color);--bs-list-group-action-active-bg: var(--bs-secondary-border-subtle);--bs-list-group-active-color: var(--bs-secondary-bg-subtle);--bs-list-group-active-bg: var(--bs-secondary-text-emphasis);--bs-list-group-active-border-color: var(--bs-secondary-text-emphasis)}.list-group-item-success{--bs-list-group-color: var(--bs-success-text-emphasis);--bs-list-group-bg: var(--bs-success-bg-subtle);--bs-list-group-border-color: var(--bs-success-border-subtle);--bs-list-group-action-hover-color: var(--bs-emphasis-color);--bs-list-group-action-hover-bg: var(--bs-success-border-subtle);--bs-list-group-action-active-color: var(--bs-emphasis-color);--bs-list-group-action-active-bg: var(--bs-success-border-subtle);--bs-list-group-active-color: var(--bs-success-bg-subtle);--bs-list-group-active-bg: var(--bs-success-text-emphasis);--bs-list-group-active-border-color: var(--bs-success-text-emphasis)}.list-group-item-info{--bs-list-group-color: var(--bs-info-text-emphasis);--bs-list-group-bg: var(--bs-info-bg-subtle);--bs-list-group-border-color: var(--bs-info-border-subtle);--bs-list-group-action-hover-color: var(--bs-emphasis-color);--bs-list-group-action-hover-bg: var(--bs-info-border-subtle);--bs-list-group-action-active-color: var(--bs-emphasis-color);--bs-list-group-action-active-bg: var(--bs-info-border-subtle);--bs-list-group-active-color: var(--bs-info-bg-subtle);--bs-list-group-active-bg: var(--bs-info-text-emphasis);--bs-list-group-active-border-color: var(--bs-info-text-emphasis)}.list-group-item-warning{--bs-list-group-color: var(--bs-warning-text-emphasis);--bs-list-group-bg: var(--bs-warning-bg-subtle);--bs-list-group-border-color: var(--bs-warning-border-subtle);--bs-list-group-action-hover-color: var(--bs-emphasis-color);--bs-list-group-action-hover-bg: var(--bs-warning-border-subtle);--bs-list-group-action-active-color: var(--bs-emphasis-color);--bs-list-group-action-active-bg: var(--bs-warning-border-subtle);--bs-list-group-active-color: var(--bs-warning-bg-subtle);--bs-list-group-active-bg: var(--bs-warning-text-emphasis);--bs-list-group-active-border-color: var(--bs-warning-text-emphasis)}.list-group-item-danger{--bs-list-group-color: var(--bs-danger-text-emphasis);--bs-list-group-bg: var(--bs-danger-bg-subtle);--bs-list-group-border-color: var(--bs-danger-border-subtle);--bs-list-group-action-hover-color: var(--bs-emphasis-color);--bs-list-group-action-hover-bg: var(--bs-danger-border-subtle);--bs-list-group-action-active-color: var(--bs-emphasis-color);--bs-list-group-action-active-bg: var(--bs-danger-border-subtle);--bs-list-group-active-color: var(--bs-danger-bg-subtle);--bs-list-group-active-bg: var(--bs-danger-text-emphasis);--bs-list-group-active-border-color: var(--bs-danger-text-emphasis)}.list-group-item-light{--bs-list-group-color: var(--bs-light-text-emphasis);--bs-list-group-bg: var(--bs-light-bg-subtle);--bs-list-group-border-color: var(--bs-light-border-subtle);--bs-list-group-action-hover-color: var(--bs-emphasis-color);--bs-list-group-action-hover-bg: var(--bs-light-border-subtle);--bs-list-group-action-active-color: var(--bs-emphasis-color);--bs-list-group-action-active-bg: var(--bs-light-border-subtle);--bs-list-group-active-color: var(--bs-light-bg-subtle);--bs-list-group-active-bg: var(--bs-light-text-emphasis);--bs-list-group-active-border-color: var(--bs-light-text-emphasis)}.list-group-item-dark{--bs-list-group-color: var(--bs-dark-text-emphasis);--bs-list-group-bg: var(--bs-dark-bg-subtle);--bs-list-group-border-color: var(--bs-dark-border-subtle);--bs-list-group-action-hover-color: var(--bs-emphasis-color);--bs-list-group-action-hover-bg: var(--bs-dark-border-subtle);--bs-list-group-action-active-color: var(--bs-emphasis-color);--bs-list-group-action-active-bg: var(--bs-dark-border-subtle);--bs-list-group-active-color: var(--bs-dark-bg-subtle);--bs-list-group-active-bg: var(--bs-dark-text-emphasis);--bs-list-group-active-border-color: var(--bs-dark-text-emphasis)}.btn-close{--bs-btn-close-color: #000;--bs-btn-close-bg: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23000'%3e%3cpath d='M.293.293a1 1 0 0 1 1.414 0L8 6.586 14.293.293a1 1 0 1 1 1.414 1.414L9.414 8l6.293 6.293a1 1 0 0 1-1.414 1.414L8 9.414l-6.293 6.293a1 1 0 0 1-1.414-1.414L6.586 8 .293 1.707a1 1 0 0 1 0-1.414z'/%3e%3c/svg%3e");--bs-btn-close-opacity: .5;--bs-btn-close-hover-opacity: .75;--bs-btn-close-focus-shadow: 0 0 0 .25rem rgba(0,123,194,0.25);--bs-btn-close-focus-opacity: 1;--bs-btn-close-disabled-opacity: .25;--bs-btn-close-white-filter: invert(1) grayscale(100%) brightness(200%);box-sizing:content-box;width:1em;height:1em;padding:.25em .25em;color:var(--bs-btn-close-color);background:transparent var(--bs-btn-close-bg) center/1em auto no-repeat;border:0;border-radius:3px;opacity:var(--bs-btn-close-opacity)}.btn-close:hover{color:var(--bs-btn-close-color);text-decoration:none;opacity:var(--bs-btn-close-hover-opacity)}.btn-close:focus{outline:0;box-shadow:var(--bs-btn-close-focus-shadow);opacity:var(--bs-btn-close-focus-opacity)}.btn-close:disabled,.btn-close.disabled{pointer-events:none;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-o-user-select:none;opacity:var(--bs-btn-close-disabled-opacity)}.btn-close-white{filter:var(--bs-btn-close-white-filter)}[data-bs-theme="dark"] .btn-close{filter:var(--bs-btn-close-white-filter)}.toast{--bs-toast-zindex: 1090;--bs-toast-padding-x: .75rem;--bs-toast-padding-y: .5rem;--bs-toast-spacing: 1.5rem;--bs-toast-max-width: 350px;--bs-toast-font-size:.875rem;--bs-toast-color: ;--bs-toast-bg: rgba(var(--bs-body-bg-rgb), 0.85);--bs-toast-border-width: var(--bs-border-width);--bs-toast-border-color: var(--bs-border-color-translucent);--bs-toast-border-radius: var(--bs-border-radius);--bs-toast-box-shadow: var(--bs-box-shadow);--bs-toast-header-color: var(--bs-secondary-color);--bs-toast-header-bg: rgba(var(--bs-body-bg-rgb), 0.85);--bs-toast-header-border-color: var(--bs-border-color-translucent);width:var(--bs-toast-max-width);max-width:100%;font-size:var(--bs-toast-font-size);color:var(--bs-toast-color);pointer-events:auto;background-color:var(--bs-toast-bg);background-clip:padding-box;border:var(--bs-toast-border-width) solid var(--bs-toast-border-color);box-shadow:var(--bs-toast-box-shadow);border-radius:var(--bs-toast-border-radius)}.toast.showing{opacity:0}.toast:not(.show):not(.in){display:none}.toast-container{--bs-toast-zindex: 1090;position:absolute;z-index:var(--bs-toast-zindex);width:max-content;width:-webkit-max-content;width:-moz-max-content;width:-ms-max-content;width:-o-max-content;max-width:100%;pointer-events:none}.toast-container>:not(:last-child){margin-bottom:var(--bs-toast-spacing)}.toast-header{display:flex;display:-webkit-flex;align-items:center;-webkit-align-items:center;padding:var(--bs-toast-padding-y) var(--bs-toast-padding-x);color:var(--bs-toast-header-color);background-color:var(--bs-toast-header-bg);background-clip:padding-box;border-bottom:var(--bs-toast-border-width) solid var(--bs-toast-header-border-color);border-top-left-radius:calc(var(--bs-toast-border-radius) - var(--bs-toast-border-width));border-top-right-radius:calc(var(--bs-toast-border-radius) - var(--bs-toast-border-width))}.toast-header .btn-close{margin-right:calc(-.5 * var(--bs-toast-padding-x));margin-left:var(--bs-toast-padding-x)}.toast-body{padding:var(--bs-toast-padding-x);word-wrap:break-word}.modal{--bs-modal-zindex: 1055;--bs-modal-width: 500px;--bs-modal-padding: 1rem;--bs-modal-margin: .5rem;--bs-modal-color: ;--bs-modal-bg: var(--bs-body-bg);--bs-modal-border-color: var(--bs-border-color-translucent);--bs-modal-border-width: var(--bs-border-width);--bs-modal-border-radius: var(--bs-border-radius-lg);--bs-modal-box-shadow: 0px 1px 2px RGBA(var(--bslib-box-shadow-color-rgb), 0.1),0px 2px 3px RGBA(var(--bslib-box-shadow-color-rgb), 0.1),0px 3px 8px RGBA(var(--bslib-box-shadow-color-rgb), 0.1);--bs-modal-inner-border-radius: calc(var(--bs-border-radius-lg) - (var(--bs-border-width)));--bs-modal-header-padding-x: 1rem;--bs-modal-header-padding-y: 1rem;--bs-modal-header-padding: 1.5rem;--bs-modal-header-border-color: var(--bs-border-color);--bs-modal-header-border-width: none;--bs-modal-title-line-height: 1.5;--bs-modal-footer-gap: .5rem;--bs-modal-footer-bg: ;--bs-modal-footer-border-color: var(--bs-border-color);--bs-modal-footer-border-width: none;position:fixed;top:0;left:0;z-index:var(--bs-modal-zindex);display:none;width:100%;height:100%;overflow-x:hidden;overflow-y:auto;outline:0}.modal-dialog{position:relative;width:auto;margin:var(--bs-modal-margin);pointer-events:none}.modal.fade .modal-dialog{transition:transform 0.3s ease-out;transform:translate(0, -50px)}@media (prefers-reduced-motion: reduce){.modal.fade .modal-dialog{transition:none}}.modal.show .modal-dialog,.modal.in .modal-dialog{transform:none}.modal.modal-static .modal-dialog{transform:scale(1.02)}.modal-dialog-scrollable{height:calc(100% - var(--bs-modal-margin) * 2)}.modal-dialog-scrollable .modal-content{max-height:100%;overflow:hidden}.modal-dialog-scrollable .modal-body{overflow-y:auto}.modal-dialog-centered{display:flex;display:-webkit-flex;align-items:center;-webkit-align-items:center;min-height:calc(100% - var(--bs-modal-margin) * 2)}.modal-content{position:relative;display:flex;display:-webkit-flex;flex-direction:column;-webkit-flex-direction:column;width:100%;color:var(--bs-modal-color);pointer-events:auto;background-color:var(--bs-modal-bg);background-clip:padding-box;border:var(--bs-modal-border-width) solid var(--bs-modal-border-color);border-radius:var(--bs-modal-border-radius);outline:0}.modal-backdrop{--bs-backdrop-zindex: 1050;--bs-backdrop-bg: #464646;--bs-backdrop-opacity: .5;position:fixed;top:0;left:0;z-index:var(--bs-backdrop-zindex);width:100vw;height:100vh;background-color:var(--bs-backdrop-bg)}.modal-backdrop.fade{opacity:0}.modal-backdrop.show,.modal-backdrop.in{opacity:var(--bs-backdrop-opacity)}.modal-header{display:flex;display:-webkit-flex;flex-shrink:0;-webkit-flex-shrink:0;align-items:center;-webkit-align-items:center;justify-content:space-between;-webkit-justify-content:space-between;padding:var(--bs-modal-header-padding);border-bottom:var(--bs-modal-header-border-width) solid var(--bs-modal-header-border-color);border-top-left-radius:var(--bs-modal-inner-border-radius);border-top-right-radius:var(--bs-modal-inner-border-radius)}.modal-header .btn-close{padding:calc(var(--bs-modal-header-padding-y) * .5) calc(var(--bs-modal-header-padding-x) * .5);margin:calc(-.5 * var(--bs-modal-header-padding-y)) calc(-.5 * var(--bs-modal-header-padding-x)) calc(-.5 * var(--bs-modal-header-padding-y)) auto}.modal-title{margin-bottom:0;line-height:var(--bs-modal-title-line-height)}.modal-body{position:relative;flex:1 1 auto;-webkit-flex:1 1 auto;padding:var(--bs-modal-padding)}.modal-footer{display:flex;display:-webkit-flex;flex-shrink:0;-webkit-flex-shrink:0;flex-wrap:wrap;-webkit-flex-wrap:wrap;align-items:center;-webkit-align-items:center;justify-content:flex-end;-webkit-justify-content:flex-end;padding:calc(var(--bs-modal-padding) - var(--bs-modal-footer-gap) * .5);background-color:var(--bs-modal-footer-bg);border-top:var(--bs-modal-footer-border-width) solid var(--bs-modal-footer-border-color);border-bottom-right-radius:var(--bs-modal-inner-border-radius);border-bottom-left-radius:var(--bs-modal-inner-border-radius)}.modal-footer>*{margin:calc(var(--bs-modal-footer-gap) * .5)}@media (min-width: 576px){.modal{--bs-modal-margin: 10%;--bs-modal-box-shadow: 0px 1px 2px RGBA(var(--bslib-box-shadow-color-rgb), 0.1),0px 3px 7px RGBA(var(--bslib-box-shadow-color-rgb), 0.1),0px 12px 30px RGBA(var(--bslib-box-shadow-color-rgb), 0.08)}.modal-dialog{max-width:var(--bs-modal-width);margin-right:auto;margin-left:auto}.modal-sm{--bs-modal-width: 300px}}@media (min-width: 992px){.modal-lg,.modal-xl{--bs-modal-width: 800px}}@media (min-width: 1200px){.modal-xl{--bs-modal-width: 1140px}}.modal-fullscreen{width:100vw;max-width:none;height:100%;margin:0}.modal-fullscreen .modal-content{height:100%;border:0;border-radius:0}.modal-fullscreen .modal-header,.modal-fullscreen .modal-footer{border-radius:0}.modal-fullscreen .modal-body{overflow-y:auto}@media (max-width: 575.98px){.modal-fullscreen-sm-down{width:100vw;max-width:none;height:100%;margin:0}.modal-fullscreen-sm-down .modal-content{height:100%;border:0;border-radius:0}.modal-fullscreen-sm-down .modal-header,.modal-fullscreen-sm-down .modal-footer{border-radius:0}.modal-fullscreen-sm-down .modal-body{overflow-y:auto}}@media (max-width: 767.98px){.modal-fullscreen-md-down{width:100vw;max-width:none;height:100%;margin:0}.modal-fullscreen-md-down .modal-content{height:100%;border:0;border-radius:0}.modal-fullscreen-md-down .modal-header,.modal-fullscreen-md-down .modal-footer{border-radius:0}.modal-fullscreen-md-down .modal-body{overflow-y:auto}}@media (max-width: 991.98px){.modal-fullscreen-lg-down{width:100vw;max-width:none;height:100%;margin:0}.modal-fullscreen-lg-down .modal-content{height:100%;border:0;border-radius:0}.modal-fullscreen-lg-down .modal-header,.modal-fullscreen-lg-down .modal-footer{border-radius:0}.modal-fullscreen-lg-down .modal-body{overflow-y:auto}}@media (max-width: 1199.98px){.modal-fullscreen-xl-down{width:100vw;max-width:none;height:100%;margin:0}.modal-fullscreen-xl-down .modal-content{height:100%;border:0;border-radius:0}.modal-fullscreen-xl-down .modal-header,.modal-fullscreen-xl-down .modal-footer{border-radius:0}.modal-fullscreen-xl-down .modal-body{overflow-y:auto}}@media (max-width: 1399.98px){.modal-fullscreen-xxl-down{width:100vw;max-width:none;height:100%;margin:0}.modal-fullscreen-xxl-down .modal-content{height:100%;border:0;border-radius:0}.modal-fullscreen-xxl-down .modal-header,.modal-fullscreen-xxl-down .modal-footer{border-radius:0}.modal-fullscreen-xxl-down .modal-body{overflow-y:auto}}.tooltip{--bs-tooltip-zindex: 1080;--bs-tooltip-max-width: 200px;--bs-tooltip-padding-x: .5rem;--bs-tooltip-padding-y: .25rem;--bs-tooltip-margin: ;--bs-tooltip-font-size:.875rem;--bs-tooltip-color: var(--bs-body-bg);--bs-tooltip-bg: var(--bs-emphasis-color);--bs-tooltip-border-radius: var(--bs-border-radius);--bs-tooltip-opacity: .9;--bs-tooltip-arrow-width: .8rem;--bs-tooltip-arrow-height: .4rem;z-index:var(--bs-tooltip-zindex);display:block;margin:var(--bs-tooltip-margin);font-family:"Open Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;font-style:normal;font-weight:400;line-height:1.5;text-align:left;text-align:start;text-decoration:none;text-shadow:none;text-transform:none;letter-spacing:normal;word-break:normal;white-space:normal;word-spacing:normal;line-break:auto;font-size:var(--bs-tooltip-font-size);word-wrap:break-word;opacity:0}.tooltip.show,.tooltip.in{opacity:var(--bs-tooltip-opacity)}.tooltip .tooltip-arrow{display:block;width:var(--bs-tooltip-arrow-width);height:var(--bs-tooltip-arrow-height)}.tooltip .tooltip-arrow::before{position:absolute;content:"";border-color:transparent;border-style:solid}.bs-tooltip-top .tooltip-arrow,.bs-tooltip-auto[data-popper-placement^="top"] .tooltip-arrow{bottom:calc(-1 * var(--bs-tooltip-arrow-height))}.bs-tooltip-top .tooltip-arrow::before,.bs-tooltip-auto[data-popper-placement^="top"] .tooltip-arrow::before{top:-1px;border-width:var(--bs-tooltip-arrow-height) calc(var(--bs-tooltip-arrow-width) * .5) 0;border-top-color:var(--bs-tooltip-bg)}.bs-tooltip-end .tooltip-arrow,.bs-tooltip-auto[data-popper-placement^="right"] .tooltip-arrow{left:calc(-1 * var(--bs-tooltip-arrow-height));width:var(--bs-tooltip-arrow-height);height:var(--bs-tooltip-arrow-width)}.bs-tooltip-end .tooltip-arrow::before,.bs-tooltip-auto[data-popper-placement^="right"] .tooltip-arrow::before{right:-1px;border-width:calc(var(--bs-tooltip-arrow-width) * .5) var(--bs-tooltip-arrow-height) calc(var(--bs-tooltip-arrow-width) * .5) 0;border-right-color:var(--bs-tooltip-bg)}.bs-tooltip-bottom .tooltip-arrow,.bs-tooltip-auto[data-popper-placement^="bottom"] .tooltip-arrow{top:calc(-1 * var(--bs-tooltip-arrow-height))}.bs-tooltip-bottom .tooltip-arrow::before,.bs-tooltip-auto[data-popper-placement^="bottom"] .tooltip-arrow::before{bottom:-1px;border-width:0 calc(var(--bs-tooltip-arrow-width) * .5) var(--bs-tooltip-arrow-height);border-bottom-color:var(--bs-tooltip-bg)}.bs-tooltip-start .tooltip-arrow,.bs-tooltip-auto[data-popper-placement^="left"] .tooltip-arrow{right:calc(-1 * var(--bs-tooltip-arrow-height));width:var(--bs-tooltip-arrow-height);height:var(--bs-tooltip-arrow-width)}.bs-tooltip-start .tooltip-arrow::before,.bs-tooltip-auto[data-popper-placement^="left"] .tooltip-arrow::before{left:-1px;border-width:calc(var(--bs-tooltip-arrow-width) * .5) 0 calc(var(--bs-tooltip-arrow-width) * .5) var(--bs-tooltip-arrow-height);border-left-color:var(--bs-tooltip-bg)}.tooltip-inner{max-width:var(--bs-tooltip-max-width);padding:var(--bs-tooltip-padding-y) var(--bs-tooltip-padding-x);color:var(--bs-tooltip-color);text-align:center;background-color:var(--bs-tooltip-bg);border-radius:var(--bs-tooltip-border-radius)}.popover{--bs-popover-zindex: 1070;--bs-popover-max-width: 276px;--bs-popover-font-size:.875rem;--bs-popover-bg: var(--bs-body-bg);--bs-popover-border-width: var(--bs-border-width);--bs-popover-border-color: var(--bs-border-color-translucent);--bs-popover-border-radius: var(--bs-border-radius-lg);--bs-popover-inner-border-radius: calc(var(--bs-border-radius-lg) - var(--bs-border-width));--bs-popover-box-shadow: 0px 1px 2px RGBA(var(--bslib-box-shadow-color-rgb), 0.1),0px 3px 7px RGBA(var(--bslib-box-shadow-color-rgb), 0.1),0px 12px 30px RGBA(var(--bslib-box-shadow-color-rgb), 0.08);--bs-popover-header-padding-x: 1rem;--bs-popover-header-padding-y: .5rem;--bs-popover-header-font-size:1rem;--bs-popover-header-color: inherit;--bs-popover-header-bg: var(--bs-secondary-bg);--bs-popover-body-padding-x: 1rem;--bs-popover-body-padding-y: 1rem;--bs-popover-body-color: var(--bs-body-color);--bs-popover-arrow-width: 1rem;--bs-popover-arrow-height: .5rem;--bs-popover-arrow-border: var(--bs-popover-border-color);z-index:var(--bs-popover-zindex);display:block;max-width:var(--bs-popover-max-width);font-family:"Open Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;font-style:normal;font-weight:400;line-height:1.5;text-align:left;text-align:start;text-decoration:none;text-shadow:none;text-transform:none;letter-spacing:normal;word-break:normal;white-space:normal;word-spacing:normal;line-break:auto;font-size:var(--bs-popover-font-size);word-wrap:break-word;background-color:var(--bs-popover-bg);background-clip:padding-box;border:var(--bs-popover-border-width) solid var(--bs-popover-border-color);border-radius:var(--bs-popover-border-radius)}.popover .popover-arrow{display:block;width:var(--bs-popover-arrow-width);height:var(--bs-popover-arrow-height)}.popover .popover-arrow::before,.popover .popover-arrow::after{position:absolute;display:block;content:"";border-color:transparent;border-style:solid;border-width:0}.bs-popover-top>.popover-arrow,.bs-popover-auto[data-popper-placement^="top"]>.popover-arrow{bottom:calc(-1 * (var(--bs-popover-arrow-height)) - var(--bs-popover-border-width))}.bs-popover-top>.popover-arrow::before,.bs-popover-auto[data-popper-placement^="top"]>.popover-arrow::before,.bs-popover-top>.popover-arrow::after,.bs-popover-auto[data-popper-placement^="top"]>.popover-arrow::after{border-width:var(--bs-popover-arrow-height) calc(var(--bs-popover-arrow-width) * .5) 0}.bs-popover-top>.popover-arrow::before,.bs-popover-auto[data-popper-placement^="top"]>.popover-arrow::before{bottom:0;border-top-color:var(--bs-popover-arrow-border)}.bs-popover-top>.popover-arrow::after,.bs-popover-auto[data-popper-placement^="top"]>.popover-arrow::after{bottom:var(--bs-popover-border-width);border-top-color:var(--bs-popover-bg)}.bs-popover-end>.popover-arrow,.bs-popover-auto[data-popper-placement^="right"]>.popover-arrow{left:calc(-1 * (var(--bs-popover-arrow-height)) - var(--bs-popover-border-width));width:var(--bs-popover-arrow-height);height:var(--bs-popover-arrow-width)}.bs-popover-end>.popover-arrow::before,.bs-popover-auto[data-popper-placement^="right"]>.popover-arrow::before,.bs-popover-end>.popover-arrow::after,.bs-popover-auto[data-popper-placement^="right"]>.popover-arrow::after{border-width:calc(var(--bs-popover-arrow-width) * .5) var(--bs-popover-arrow-height) calc(var(--bs-popover-arrow-width) * .5) 0}.bs-popover-end>.popover-arrow::before,.bs-popover-auto[data-popper-placement^="right"]>.popover-arrow::before{left:0;border-right-color:var(--bs-popover-arrow-border)}.bs-popover-end>.popover-arrow::after,.bs-popover-auto[data-popper-placement^="right"]>.popover-arrow::after{left:var(--bs-popover-border-width);border-right-color:var(--bs-popover-bg)}.bs-popover-bottom>.popover-arrow,.bs-popover-auto[data-popper-placement^="bottom"]>.popover-arrow{top:calc(-1 * (var(--bs-popover-arrow-height)) - var(--bs-popover-border-width))}.bs-popover-bottom>.popover-arrow::before,.bs-popover-auto[data-popper-placement^="bottom"]>.popover-arrow::before,.bs-popover-bottom>.popover-arrow::after,.bs-popover-auto[data-popper-placement^="bottom"]>.popover-arrow::after{border-width:0 calc(var(--bs-popover-arrow-width) * .5) var(--bs-popover-arrow-height)}.bs-popover-bottom>.popover-arrow::before,.bs-popover-auto[data-popper-placement^="bottom"]>.popover-arrow::before{top:0;border-bottom-color:var(--bs-popover-arrow-border)}.bs-popover-bottom>.popover-arrow::after,.bs-popover-auto[data-popper-placement^="bottom"]>.popover-arrow::after{top:var(--bs-popover-border-width);border-bottom-color:var(--bs-popover-bg)}.bs-popover-bottom .popover-header::before,.bs-popover-auto[data-popper-placement^="bottom"] .popover-header::before{position:absolute;top:0;left:50%;display:block;width:var(--bs-popover-arrow-width);margin-left:calc(-.5 * var(--bs-popover-arrow-width));content:"";border-bottom:var(--bs-popover-border-width) solid var(--bs-popover-header-bg)}.bs-popover-start>.popover-arrow,.bs-popover-auto[data-popper-placement^="left"]>.popover-arrow{right:calc(-1 * (var(--bs-popover-arrow-height)) - var(--bs-popover-border-width));width:var(--bs-popover-arrow-height);height:var(--bs-popover-arrow-width)}.bs-popover-start>.popover-arrow::before,.bs-popover-auto[data-popper-placement^="left"]>.popover-arrow::before,.bs-popover-start>.popover-arrow::after,.bs-popover-auto[data-popper-placement^="left"]>.popover-arrow::after{border-width:calc(var(--bs-popover-arrow-width) * .5) 0 calc(var(--bs-popover-arrow-width) * .5) var(--bs-popover-arrow-height)}.bs-popover-start>.popover-arrow::before,.bs-popover-auto[data-popper-placement^="left"]>.popover-arrow::before{right:0;border-left-color:var(--bs-popover-arrow-border)}.bs-popover-start>.popover-arrow::after,.bs-popover-auto[data-popper-placement^="left"]>.popover-arrow::after{right:var(--bs-popover-border-width);border-left-color:var(--bs-popover-bg)}.popover-header{padding:var(--bs-popover-header-padding-y) var(--bs-popover-header-padding-x);margin-bottom:0;font-size:var(--bs-popover-header-font-size);color:var(--bs-popover-header-color);background-color:var(--bs-popover-header-bg);border-bottom:var(--bs-popover-border-width) solid var(--bs-popover-border-color);border-top-left-radius:var(--bs-popover-inner-border-radius);border-top-right-radius:var(--bs-popover-inner-border-radius)}.popover-header:empty{display:none}.popover-body{padding:var(--bs-popover-body-padding-y) var(--bs-popover-body-padding-x);color:var(--bs-popover-body-color)}.carousel{position:relative}.carousel.pointer-event{touch-action:pan-y;-webkit-touch-action:pan-y;-moz-touch-action:pan-y;-ms-touch-action:pan-y;-o-touch-action:pan-y}.carousel-inner{position:relative;width:100%;overflow:hidden}.carousel-inner::after{display:block;clear:both;content:""}.carousel-item{position:relative;display:none;float:left;width:100%;margin-right:-100%;backface-visibility:hidden;-webkit-backface-visibility:hidden;-moz-backface-visibility:hidden;-ms-backface-visibility:hidden;-o-backface-visibility:hidden;transition:transform .6s ease-in-out}@media (prefers-reduced-motion: reduce){.carousel-item{transition:none}}.carousel-item.active,.carousel-item-next,.carousel-item-prev{display:block}.carousel-item-next:not(.carousel-item-start),.active.carousel-item-end{transform:translateX(100%)}.carousel-item-prev:not(.carousel-item-end),.active.carousel-item-start{transform:translateX(-100%)}.carousel-fade .carousel-item{opacity:0;transition-property:opacity;transform:none}.carousel-fade .carousel-item.active,.carousel-fade .carousel-item-next.carousel-item-start,.carousel-fade .carousel-item-prev.carousel-item-end{z-index:1;opacity:1}.carousel-fade .active.carousel-item-start,.carousel-fade .active.carousel-item-end{z-index:0;opacity:0;transition:opacity 0s .6s}@media (prefers-reduced-motion: reduce){.carousel-fade .active.carousel-item-start,.carousel-fade .active.carousel-item-end{transition:none}}.carousel-control-prev,.carousel-control-next{position:absolute;top:0;bottom:0;z-index:1;display:flex;display:-webkit-flex;align-items:center;-webkit-align-items:center;justify-content:center;-webkit-justify-content:center;width:15%;padding:0;color:#fff;text-align:center;background:none;border:0;opacity:.5;transition:opacity 0.15s ease}@media (prefers-reduced-motion: reduce){.carousel-control-prev,.carousel-control-next{transition:none}}.carousel-control-prev:hover,.carousel-control-prev:focus,.carousel-control-next:hover,.carousel-control-next:focus{color:#fff;text-decoration:none;outline:0;opacity:.9}.carousel-control-prev{left:0}.carousel-control-next{right:0}.carousel-control-prev-icon,.carousel-control-next-icon{display:inline-block;width:2rem;height:2rem;background-repeat:no-repeat;background-position:50%;background-size:100% 100%}.carousel-control-prev-icon{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23fff'%3e%3cpath d='M11.354 1.646a.5.5 0 0 1 0 .708L5.707 8l5.647 5.646a.5.5 0 0 1-.708.708l-6-6a.5.5 0 0 1 0-.708l6-6a.5.5 0 0 1 .708 0z'/%3e%3c/svg%3e")}.carousel-control-next-icon{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23fff'%3e%3cpath d='M4.646 1.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708L10.293 8 4.646 2.354a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e")}.carousel-indicators{position:absolute;right:0;bottom:0;left:0;z-index:2;display:flex;display:-webkit-flex;justify-content:center;-webkit-justify-content:center;padding:0;margin-right:15%;margin-bottom:1rem;margin-left:15%}.carousel-indicators [data-bs-target]{box-sizing:content-box;flex:0 1 auto;-webkit-flex:0 1 auto;width:30px;height:3px;padding:0;margin-right:3px;margin-left:3px;text-indent:-999px;cursor:pointer;background-color:#fff;background-clip:padding-box;border:0;border-top:10px solid transparent;border-bottom:10px solid transparent;opacity:.5;transition:opacity 0.6s ease}@media (prefers-reduced-motion: reduce){.carousel-indicators [data-bs-target]{transition:none}}.carousel-indicators .active{opacity:1}.carousel-caption{position:absolute;right:15%;bottom:1.25rem;left:15%;padding-top:1.25rem;padding-bottom:1.25rem;color:#fff;text-align:center}.carousel-dark .carousel-control-prev-icon,.carousel-dark .carousel-control-next-icon{filter:invert(1) grayscale(100)}.carousel-dark .carousel-indicators [data-bs-target]{background-color:#000}.carousel-dark .carousel-caption{color:#000}[data-bs-theme="dark"] .carousel .carousel-control-prev-icon,[data-bs-theme="dark"] .carousel .carousel-control-next-icon,[data-bs-theme="dark"].carousel .carousel-control-prev-icon,[data-bs-theme="dark"].carousel .carousel-control-next-icon{filter:invert(1) grayscale(100)}[data-bs-theme="dark"] .carousel .carousel-indicators [data-bs-target],[data-bs-theme="dark"].carousel .carousel-indicators [data-bs-target]{background-color:#000}[data-bs-theme="dark"] .carousel .carousel-caption,[data-bs-theme="dark"].carousel .carousel-caption{color:#000}.spinner-grow,.spinner-border{display:inline-block;width:var(--bs-spinner-width);height:var(--bs-spinner-height);vertical-align:var(--bs-spinner-vertical-align);border-radius:50%;animation:var(--bs-spinner-animation-speed) linear infinite var(--bs-spinner-animation-name)}@keyframes spinner-border{to{transform:rotate(360deg) /* rtl:ignore */}}.spinner-border{--bs-spinner-width: 2rem;--bs-spinner-height: 2rem;--bs-spinner-vertical-align: -.125em;--bs-spinner-border-width: .25em;--bs-spinner-animation-speed: .75s;--bs-spinner-animation-name: spinner-border;border:var(--bs-spinner-border-width) solid currentcolor;border-right-color:transparent}.spinner-border-sm{--bs-spinner-width: 1rem;--bs-spinner-height: 1rem;--bs-spinner-border-width: .2em}@keyframes spinner-grow{0%{transform:scale(0)}50%{opacity:1;transform:none}}.spinner-grow{--bs-spinner-width: 2rem;--bs-spinner-height: 2rem;--bs-spinner-vertical-align: -.125em;--bs-spinner-animation-speed: .75s;--bs-spinner-animation-name: spinner-grow;background-color:currentcolor;opacity:0}.spinner-grow-sm{--bs-spinner-width: 1rem;--bs-spinner-height: 1rem}@media (prefers-reduced-motion: reduce){.spinner-border,.spinner-grow{--bs-spinner-animation-speed: 1.5s}}.offcanvas,.offcanvas-xxl,.offcanvas-xl,.offcanvas-lg,.offcanvas-md,.offcanvas-sm{--bs-offcanvas-zindex: 1045;--bs-offcanvas-width: 400px;--bs-offcanvas-height: 30vh;--bs-offcanvas-padding-x: 1rem;--bs-offcanvas-padding-y: 1rem;--bs-offcanvas-color: var(--bs-body-color);--bs-offcanvas-bg: var(--bs-body-bg);--bs-offcanvas-border-width: var(--bs-border-width);--bs-offcanvas-border-color: var(--bs-border-color-translucent);--bs-offcanvas-box-shadow: 0px 1px 2px RGBA(var(--bslib-box-shadow-color-rgb), 0.1),0px 2px 3px RGBA(var(--bslib-box-shadow-color-rgb), 0.1),0px 3px 8px RGBA(var(--bslib-box-shadow-color-rgb), 0.1);--bs-offcanvas-transition: transform .3s ease-in-out;--bs-offcanvas-title-line-height: 1.5}@media (max-width: 575.98px){.offcanvas-sm{position:fixed;bottom:0;z-index:var(--bs-offcanvas-zindex);display:flex;display:-webkit-flex;flex-direction:column;-webkit-flex-direction:column;max-width:100%;color:var(--bs-offcanvas-color);visibility:hidden;background-color:var(--bs-offcanvas-bg);background-clip:padding-box;outline:0;transition:var(--bs-offcanvas-transition)}}@media (max-width: 575.98px) and (prefers-reduced-motion: reduce){.offcanvas-sm{transition:none}}@media (max-width: 575.98px){.offcanvas-sm.offcanvas-start{top:0;left:0;width:var(--bs-offcanvas-width);border-right:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateX(-100%)}.offcanvas-sm.offcanvas-end{top:0;right:0;width:var(--bs-offcanvas-width);border-left:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateX(100%)}.offcanvas-sm.offcanvas-top{top:0;right:0;left:0;height:var(--bs-offcanvas-height);max-height:100%;border-bottom:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateY(-100%)}.offcanvas-sm.offcanvas-bottom{right:0;left:0;height:var(--bs-offcanvas-height);max-height:100%;border-top:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateY(100%)}.offcanvas-sm.showing,.offcanvas-sm.show:not(.hiding),.offcanvas-sm.in:not(.hiding){transform:none}.offcanvas-sm.showing,.offcanvas-sm.hiding,.offcanvas-sm.show,.offcanvas-sm.in{visibility:visible}}@media (min-width: 576px){.offcanvas-sm{--bs-offcanvas-height: auto;--bs-offcanvas-border-width: 0;background-color:transparent !important}.offcanvas-sm .offcanvas-header{display:none}.offcanvas-sm .offcanvas-body{display:flex;display:-webkit-flex;flex-grow:0;-webkit-flex-grow:0;padding:0;overflow-y:visible;background-color:transparent !important}}@media (max-width: 767.98px){.offcanvas-md{position:fixed;bottom:0;z-index:var(--bs-offcanvas-zindex);display:flex;display:-webkit-flex;flex-direction:column;-webkit-flex-direction:column;max-width:100%;color:var(--bs-offcanvas-color);visibility:hidden;background-color:var(--bs-offcanvas-bg);background-clip:padding-box;outline:0;transition:var(--bs-offcanvas-transition)}}@media (max-width: 767.98px) and (prefers-reduced-motion: reduce){.offcanvas-md{transition:none}}@media (max-width: 767.98px){.offcanvas-md.offcanvas-start{top:0;left:0;width:var(--bs-offcanvas-width);border-right:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateX(-100%)}.offcanvas-md.offcanvas-end{top:0;right:0;width:var(--bs-offcanvas-width);border-left:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateX(100%)}.offcanvas-md.offcanvas-top{top:0;right:0;left:0;height:var(--bs-offcanvas-height);max-height:100%;border-bottom:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateY(-100%)}.offcanvas-md.offcanvas-bottom{right:0;left:0;height:var(--bs-offcanvas-height);max-height:100%;border-top:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateY(100%)}.offcanvas-md.showing,.offcanvas-md.show:not(.hiding),.offcanvas-md.in:not(.hiding){transform:none}.offcanvas-md.showing,.offcanvas-md.hiding,.offcanvas-md.show,.offcanvas-md.in{visibility:visible}}@media (min-width: 768px){.offcanvas-md{--bs-offcanvas-height: auto;--bs-offcanvas-border-width: 0;background-color:transparent !important}.offcanvas-md .offcanvas-header{display:none}.offcanvas-md .offcanvas-body{display:flex;display:-webkit-flex;flex-grow:0;-webkit-flex-grow:0;padding:0;overflow-y:visible;background-color:transparent !important}}@media (max-width: 991.98px){.offcanvas-lg{position:fixed;bottom:0;z-index:var(--bs-offcanvas-zindex);display:flex;display:-webkit-flex;flex-direction:column;-webkit-flex-direction:column;max-width:100%;color:var(--bs-offcanvas-color);visibility:hidden;background-color:var(--bs-offcanvas-bg);background-clip:padding-box;outline:0;transition:var(--bs-offcanvas-transition)}}@media (max-width: 991.98px) and (prefers-reduced-motion: reduce){.offcanvas-lg{transition:none}}@media (max-width: 991.98px){.offcanvas-lg.offcanvas-start{top:0;left:0;width:var(--bs-offcanvas-width);border-right:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateX(-100%)}.offcanvas-lg.offcanvas-end{top:0;right:0;width:var(--bs-offcanvas-width);border-left:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateX(100%)}.offcanvas-lg.offcanvas-top{top:0;right:0;left:0;height:var(--bs-offcanvas-height);max-height:100%;border-bottom:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateY(-100%)}.offcanvas-lg.offcanvas-bottom{right:0;left:0;height:var(--bs-offcanvas-height);max-height:100%;border-top:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateY(100%)}.offcanvas-lg.showing,.offcanvas-lg.show:not(.hiding),.offcanvas-lg.in:not(.hiding){transform:none}.offcanvas-lg.showing,.offcanvas-lg.hiding,.offcanvas-lg.show,.offcanvas-lg.in{visibility:visible}}@media (min-width: 992px){.offcanvas-lg{--bs-offcanvas-height: auto;--bs-offcanvas-border-width: 0;background-color:transparent !important}.offcanvas-lg .offcanvas-header{display:none}.offcanvas-lg .offcanvas-body{display:flex;display:-webkit-flex;flex-grow:0;-webkit-flex-grow:0;padding:0;overflow-y:visible;background-color:transparent !important}}@media (max-width: 1199.98px){.offcanvas-xl{position:fixed;bottom:0;z-index:var(--bs-offcanvas-zindex);display:flex;display:-webkit-flex;flex-direction:column;-webkit-flex-direction:column;max-width:100%;color:var(--bs-offcanvas-color);visibility:hidden;background-color:var(--bs-offcanvas-bg);background-clip:padding-box;outline:0;transition:var(--bs-offcanvas-transition)}}@media (max-width: 1199.98px) and (prefers-reduced-motion: reduce){.offcanvas-xl{transition:none}}@media (max-width: 1199.98px){.offcanvas-xl.offcanvas-start{top:0;left:0;width:var(--bs-offcanvas-width);border-right:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateX(-100%)}.offcanvas-xl.offcanvas-end{top:0;right:0;width:var(--bs-offcanvas-width);border-left:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateX(100%)}.offcanvas-xl.offcanvas-top{top:0;right:0;left:0;height:var(--bs-offcanvas-height);max-height:100%;border-bottom:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateY(-100%)}.offcanvas-xl.offcanvas-bottom{right:0;left:0;height:var(--bs-offcanvas-height);max-height:100%;border-top:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateY(100%)}.offcanvas-xl.showing,.offcanvas-xl.show:not(.hiding),.offcanvas-xl.in:not(.hiding){transform:none}.offcanvas-xl.showing,.offcanvas-xl.hiding,.offcanvas-xl.show,.offcanvas-xl.in{visibility:visible}}@media (min-width: 1200px){.offcanvas-xl{--bs-offcanvas-height: auto;--bs-offcanvas-border-width: 0;background-color:transparent !important}.offcanvas-xl .offcanvas-header{display:none}.offcanvas-xl .offcanvas-body{display:flex;display:-webkit-flex;flex-grow:0;-webkit-flex-grow:0;padding:0;overflow-y:visible;background-color:transparent !important}}@media (max-width: 1399.98px){.offcanvas-xxl{position:fixed;bottom:0;z-index:var(--bs-offcanvas-zindex);display:flex;display:-webkit-flex;flex-direction:column;-webkit-flex-direction:column;max-width:100%;color:var(--bs-offcanvas-color);visibility:hidden;background-color:var(--bs-offcanvas-bg);background-clip:padding-box;outline:0;transition:var(--bs-offcanvas-transition)}}@media (max-width: 1399.98px) and (prefers-reduced-motion: reduce){.offcanvas-xxl{transition:none}}@media (max-width: 1399.98px){.offcanvas-xxl.offcanvas-start{top:0;left:0;width:var(--bs-offcanvas-width);border-right:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateX(-100%)}.offcanvas-xxl.offcanvas-end{top:0;right:0;width:var(--bs-offcanvas-width);border-left:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateX(100%)}.offcanvas-xxl.offcanvas-top{top:0;right:0;left:0;height:var(--bs-offcanvas-height);max-height:100%;border-bottom:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateY(-100%)}.offcanvas-xxl.offcanvas-bottom{right:0;left:0;height:var(--bs-offcanvas-height);max-height:100%;border-top:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateY(100%)}.offcanvas-xxl.showing,.offcanvas-xxl.show:not(.hiding),.offcanvas-xxl.in:not(.hiding){transform:none}.offcanvas-xxl.showing,.offcanvas-xxl.hiding,.offcanvas-xxl.show,.offcanvas-xxl.in{visibility:visible}}@media (min-width: 1400px){.offcanvas-xxl{--bs-offcanvas-height: auto;--bs-offcanvas-border-width: 0;background-color:transparent !important}.offcanvas-xxl .offcanvas-header{display:none}.offcanvas-xxl .offcanvas-body{display:flex;display:-webkit-flex;flex-grow:0;-webkit-flex-grow:0;padding:0;overflow-y:visible;background-color:transparent !important}}.offcanvas{position:fixed;bottom:0;z-index:var(--bs-offcanvas-zindex);display:flex;display:-webkit-flex;flex-direction:column;-webkit-flex-direction:column;max-width:100%;color:var(--bs-offcanvas-color);visibility:hidden;background-color:var(--bs-offcanvas-bg);background-clip:padding-box;outline:0;transition:var(--bs-offcanvas-transition)}@media (prefers-reduced-motion: reduce){.offcanvas{transition:none}}.offcanvas.offcanvas-start{top:0;left:0;width:var(--bs-offcanvas-width);border-right:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateX(-100%)}.offcanvas.offcanvas-end{top:0;right:0;width:var(--bs-offcanvas-width);border-left:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateX(100%)}.offcanvas.offcanvas-top{top:0;right:0;left:0;height:var(--bs-offcanvas-height);max-height:100%;border-bottom:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateY(-100%)}.offcanvas.offcanvas-bottom{right:0;left:0;height:var(--bs-offcanvas-height);max-height:100%;border-top:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateY(100%)}.offcanvas.showing,.offcanvas.show:not(.hiding),.offcanvas.in:not(.hiding){transform:none}.offcanvas.showing,.offcanvas.hiding,.offcanvas.show,.offcanvas.in{visibility:visible}.offcanvas-backdrop{position:fixed;top:0;left:0;z-index:1040;width:100vw;height:100vh;background-color:#464646}.offcanvas-backdrop.fade{opacity:0}.offcanvas-backdrop.show,.offcanvas-backdrop.in{opacity:.5}.offcanvas-header{display:flex;display:-webkit-flex;align-items:center;-webkit-align-items:center;justify-content:space-between;-webkit-justify-content:space-between;padding:var(--bs-offcanvas-padding-y) var(--bs-offcanvas-padding-x)}.offcanvas-header .btn-close{padding:calc(var(--bs-offcanvas-padding-y) * .5) calc(var(--bs-offcanvas-padding-x) * .5);margin-top:calc(-.5 * var(--bs-offcanvas-padding-y));margin-right:calc(-.5 * var(--bs-offcanvas-padding-x));margin-bottom:calc(-.5 * var(--bs-offcanvas-padding-y))}.offcanvas-title{margin-bottom:0;line-height:var(--bs-offcanvas-title-line-height)}.offcanvas-body{flex-grow:1;-webkit-flex-grow:1;padding:var(--bs-offcanvas-padding-y) var(--bs-offcanvas-padding-x);overflow-y:auto}.placeholder{display:inline-block;min-height:1em;vertical-align:middle;cursor:wait;background-color:currentcolor;opacity:.5}.placeholder.btn::before{display:inline-block;content:""}.placeholder-xs{min-height:.6em}.placeholder-sm{min-height:.8em}.placeholder-lg{min-height:1.2em}.placeholder-glow .placeholder{animation:placeholder-glow 2s ease-in-out infinite}@keyframes placeholder-glow{50%{opacity:.2}}.placeholder-wave{mask-image:linear-gradient(130deg, #000 55%, rgba(0,0,0,0.8) 75%, #000 95%);-webkit-mask-image:linear-gradient(130deg, #000 55%, rgba(0,0,0,0.8) 75%, #000 95%);mask-size:200% 100%;-webkit-mask-size:200% 100%;animation:placeholder-wave 2s linear infinite}@keyframes placeholder-wave{100%{mask-position:-200% 0%;-webkit-mask-position:-200% 0%}}.clearfix::after{display:block;clear:both;content:""}.text-bg-default{color:#000 !important;background-color:RGBA(var(--bs-default-rgb), var(--bs-bg-opacity, 1)) !important}.text-bg-primary{color:#fff !important;background-color:RGBA(var(--bs-primary-rgb), var(--bs-bg-opacity, 1)) !important}.text-bg-secondary{color:#fff !important;background-color:RGBA(var(--bs-secondary-rgb), var(--bs-bg-opacity, 1)) !important}.text-bg-success{color:#fff !important;background-color:RGBA(var(--bs-success-rgb), var(--bs-bg-opacity, 1)) !important}.text-bg-info{color:#000 !important;background-color:RGBA(var(--bs-info-rgb), var(--bs-bg-opacity, 1)) !important}.text-bg-warning{color:#000 !important;background-color:RGBA(var(--bs-warning-rgb), var(--bs-bg-opacity, 1)) !important}.text-bg-danger{color:#fff !important;background-color:RGBA(var(--bs-danger-rgb), var(--bs-bg-opacity, 1)) !important}.text-bg-light{color:#000 !important;background-color:RGBA(var(--bs-light-rgb), var(--bs-bg-opacity, 1)) !important}.text-bg-dark{color:#fff !important;background-color:RGBA(var(--bs-dark-rgb), var(--bs-bg-opacity, 1)) !important}.link-default{color:RGBA(var(--bs-default-rgb), var(--bs-link-opacity, 1)) !important;text-decoration-color:RGBA(var(--bs-default-rgb), var(--bs-link-underline-opacity, 1)) !important}.link-default:hover,.link-default:focus{color:RGBA(229,232,235, var(--bs-link-opacity, 1)) !important;text-decoration-color:RGBA(229,232,235, var(--bs-link-underline-opacity, 1)) !important}.link-primary{color:RGBA(var(--bs-primary-rgb), var(--bs-link-opacity, 1)) !important;text-decoration-color:RGBA(var(--bs-primary-rgb), var(--bs-link-underline-opacity, 1)) !important}.link-primary:hover,.link-primary:focus{color:RGBA(0,98,155, var(--bs-link-opacity, 1)) !important;text-decoration-color:RGBA(0,98,155, var(--bs-link-underline-opacity, 1)) !important}.link-secondary{color:RGBA(var(--bs-secondary-rgb), var(--bs-link-opacity, 1)) !important;text-decoration-color:RGBA(var(--bs-secondary-rgb), var(--bs-link-underline-opacity, 1)) !important}.link-secondary:hover,.link-secondary:focus{color:RGBA(51,51,51, var(--bs-link-opacity, 1)) !important;text-decoration-color:RGBA(51,51,51, var(--bs-link-underline-opacity, 1)) !important}.link-success{color:RGBA(var(--bs-success-rgb), var(--bs-link-opacity, 1)) !important;text-decoration-color:RGBA(var(--bs-success-rgb), var(--bs-link-underline-opacity, 1)) !important}.link-success:hover,.link-success:focus{color:RGBA(0,110,21, var(--bs-link-opacity, 1)) !important;text-decoration-color:RGBA(0,110,21, var(--bs-link-underline-opacity, 1)) !important}.link-info{color:RGBA(var(--bs-info-rgb), var(--bs-link-opacity, 1)) !important;text-decoration-color:RGBA(var(--bs-info-rgb), var(--bs-link-underline-opacity, 1)) !important}.link-info:hover,.link-info:focus{color:RGBA(53,210,237, var(--bs-link-opacity, 1)) !important;text-decoration-color:RGBA(53,210,237, var(--bs-link-underline-opacity, 1)) !important}.link-warning{color:RGBA(var(--bs-warning-rgb), var(--bs-link-opacity, 1)) !important;text-decoration-color:RGBA(var(--bs-warning-rgb), var(--bs-link-underline-opacity, 1)) !important}.link-warning:hover,.link-warning:focus{color:RGBA(250,199,83, var(--bs-link-opacity, 1)) !important;text-decoration-color:RGBA(250,199,83, var(--bs-link-underline-opacity, 1)) !important}.link-danger{color:RGBA(var(--bs-danger-rgb), var(--bs-link-opacity, 1)) !important;text-decoration-color:RGBA(var(--bs-danger-rgb), var(--bs-link-underline-opacity, 1)) !important}.link-danger:hover,.link-danger:focus{color:RGBA(154,0,0, var(--bs-link-opacity, 1)) !important;text-decoration-color:RGBA(154,0,0, var(--bs-link-underline-opacity, 1)) !important}.link-light{color:RGBA(var(--bs-light-rgb), var(--bs-link-opacity, 1)) !important;text-decoration-color:RGBA(var(--bs-light-rgb), var(--bs-link-underline-opacity, 1)) !important}.link-light:hover,.link-light:focus{color:RGBA(249,249,249, var(--bs-link-opacity, 1)) !important;text-decoration-color:RGBA(249,249,249, var(--bs-link-underline-opacity, 1)) !important}.link-dark{color:RGBA(var(--bs-dark-rgb), var(--bs-link-opacity, 1)) !important;text-decoration-color:RGBA(var(--bs-dark-rgb), var(--bs-link-underline-opacity, 1)) !important}.link-dark:hover,.link-dark:focus{color:RGBA(26,26,26, var(--bs-link-opacity, 1)) !important;text-decoration-color:RGBA(26,26,26, var(--bs-link-underline-opacity, 1)) !important}.link-body-emphasis{color:RGBA(var(--bs-emphasis-color-rgb), var(--bs-link-opacity, 1)) !important;text-decoration-color:RGBA(var(--bs-emphasis-color-rgb), var(--bs-link-underline-opacity, 1)) !important}.link-body-emphasis:hover,.link-body-emphasis:focus{color:RGBA(var(--bs-emphasis-color-rgb), var(--bs-link-opacity, 0.75)) !important;text-decoration-color:RGBA(var(--bs-emphasis-color-rgb), var(--bs-link-underline-opacity, 0.75)) !important}.focus-ring:focus{outline:0;box-shadow:var(--bs-focus-ring-x, 0) var(--bs-focus-ring-y, 0) var(--bs-focus-ring-blur, 0) var(--bs-focus-ring-width) var(--bs-focus-ring-color)}.icon-link{display:inline-flex;gap:.375rem;align-items:center;-webkit-align-items:center;text-decoration-color:rgba(var(--bs-link-color-rgb), var(--bs-link-opacity, 0.5));text-underline-offset:.25em;backface-visibility:hidden;-webkit-backface-visibility:hidden;-moz-backface-visibility:hidden;-ms-backface-visibility:hidden;-o-backface-visibility:hidden}.icon-link>.bi{flex-shrink:0;-webkit-flex-shrink:0;width:1em;height:1em;fill:currentcolor;transition:0.2s ease-in-out transform}@media (prefers-reduced-motion: reduce){.icon-link>.bi{transition:none}}.icon-link-hover:hover>.bi,.icon-link-hover:focus-visible>.bi{transform:var(--bs-icon-link-transform, translate3d(0.25em, 0, 0))}.ratio{position:relative;width:100%}.ratio::before{display:block;padding-top:var(--bs-aspect-ratio);content:""}.ratio>*{position:absolute;top:0;left:0;width:100%;height:100%}.ratio-1x1{--bs-aspect-ratio: 100%}.ratio-4x3{--bs-aspect-ratio: calc(3 / 4 * 100%)}.ratio-16x9{--bs-aspect-ratio: calc(9 / 16 * 100%)}.ratio-21x9{--bs-aspect-ratio: calc(9 / 21 * 100%)}.fixed-top,.navbar-fixed-top{position:fixed;top:0;right:0;left:0;z-index:1030}.fixed-bottom,.navbar-fixed-bottom{position:fixed;right:0;bottom:0;left:0;z-index:1030}.sticky-top,.navbar-sticky-top{position:sticky;top:0;z-index:1020}.sticky-bottom{position:sticky;bottom:0;z-index:1020}@media (min-width: 576px){.sticky-sm-top{position:sticky;top:0;z-index:1020}.sticky-sm-bottom{position:sticky;bottom:0;z-index:1020}}@media (min-width: 768px){.sticky-md-top{position:sticky;top:0;z-index:1020}.sticky-md-bottom{position:sticky;bottom:0;z-index:1020}}@media (min-width: 992px){.sticky-lg-top{position:sticky;top:0;z-index:1020}.sticky-lg-bottom{position:sticky;bottom:0;z-index:1020}}@media (min-width: 1200px){.sticky-xl-top{position:sticky;top:0;z-index:1020}.sticky-xl-bottom{position:sticky;bottom:0;z-index:1020}}@media (min-width: 1400px){.sticky-xxl-top{position:sticky;top:0;z-index:1020}.sticky-xxl-bottom{position:sticky;bottom:0;z-index:1020}}.hstack{display:flex;display:-webkit-flex;flex-direction:row;-webkit-flex-direction:row;align-items:center;-webkit-align-items:center;align-self:stretch;-webkit-align-self:stretch}.vstack{display:flex;display:-webkit-flex;flex:1 1 auto;-webkit-flex:1 1 auto;flex-direction:column;-webkit-flex-direction:column;align-self:stretch;-webkit-align-self:stretch}.visually-hidden,.visually-hidden-focusable:not(:focus):not(:focus-within){width:1px !important;height:1px !important;padding:0 !important;margin:-1px !important;overflow:hidden !important;clip:rect(0, 0, 0, 0) !important;white-space:nowrap !important;border:0 !important}.visually-hidden:not(caption),.visually-hidden-focusable:not(:focus):not(:focus-within):not(caption){position:absolute !important}.stretched-link::after{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;content:""}.text-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vr{display:inline-block;align-self:stretch;-webkit-align-self:stretch;width:var(--bs-border-width);min-height:1em;background-color:currentcolor;opacity:.25}.align-baseline{vertical-align:baseline !important}.align-top{vertical-align:top !important}.align-middle{vertical-align:middle !important}.align-bottom{vertical-align:bottom !important}.align-text-bottom{vertical-align:text-bottom !important}.align-text-top{vertical-align:text-top !important}.float-start,.float-left{float:left !important}.float-end,.float-right{float:right !important}.float-none{float:none !important}.object-fit-contain{object-fit:contain !important}.object-fit-cover{object-fit:cover !important}.object-fit-fill{object-fit:fill !important}.object-fit-scale{object-fit:scale-down !important}.object-fit-none{object-fit:none !important}.opacity-0{opacity:0 !important}.opacity-25{opacity:.25 !important}.opacity-50{opacity:.5 !important}.opacity-75{opacity:.75 !important}.opacity-100{opacity:1 !important}.overflow-auto{overflow:auto !important}.overflow-hidden{overflow:hidden !important}.overflow-visible{overflow:visible !important}.overflow-scroll{overflow:scroll !important}.overflow-x-auto{overflow-x:auto !important}.overflow-x-hidden{overflow-x:hidden !important}.overflow-x-visible{overflow-x:visible !important}.overflow-x-scroll{overflow-x:scroll !important}.overflow-y-auto{overflow-y:auto !important}.overflow-y-hidden{overflow-y:hidden !important}.overflow-y-visible{overflow-y:visible !important}.overflow-y-scroll{overflow-y:scroll !important}.d-inline{display:inline !important}.d-inline-block{display:inline-block !important}.d-block{display:block !important}.d-grid{display:grid !important}.d-inline-grid{display:inline-grid !important}.d-table{display:table !important}.d-table-row{display:table-row !important}.d-table-cell{display:table-cell !important}.d-flex{display:flex !important}.d-inline-flex{display:inline-flex !important}.d-none{display:none !important}.shadow{box-shadow:0px 1px 2px RGBA(var(--bslib-box-shadow-color-rgb), 0.1),0px 3px 7px RGBA(var(--bslib-box-shadow-color-rgb), 0.1),0px 12px 30px RGBA(var(--bslib-box-shadow-color-rgb), 0.08) !important}.shadow-sm{box-shadow:0px 1px 2px RGBA(var(--bslib-box-shadow-color-rgb), 0.1),0px 2px 3px RGBA(var(--bslib-box-shadow-color-rgb), 0.1),0px 3px 8px RGBA(var(--bslib-box-shadow-color-rgb), 0.1) !important}.shadow-lg{box-shadow:0px 16px 48px RGBA(var(--bslib-box-shadow-color-rgb), 0.1),0px 2px 3px RGBA(var(--bslib-box-shadow-color-rgb), 0.1),0px 16px 46px RGBA(var(--bslib-box-shadow-color-rgb), 0.1) !important}.shadow-none{box-shadow:none !important}.focus-ring-default{--bs-focus-ring-color: rgba(var(--bs-default-rgb), var(--bs-focus-ring-opacity))}.focus-ring-primary{--bs-focus-ring-color: rgba(var(--bs-primary-rgb), var(--bs-focus-ring-opacity))}.focus-ring-secondary{--bs-focus-ring-color: rgba(var(--bs-secondary-rgb), var(--bs-focus-ring-opacity))}.focus-ring-success{--bs-focus-ring-color: rgba(var(--bs-success-rgb), var(--bs-focus-ring-opacity))}.focus-ring-info{--bs-focus-ring-color: rgba(var(--bs-info-rgb), var(--bs-focus-ring-opacity))}.focus-ring-warning{--bs-focus-ring-color: rgba(var(--bs-warning-rgb), var(--bs-focus-ring-opacity))}.focus-ring-danger{--bs-focus-ring-color: rgba(var(--bs-danger-rgb), var(--bs-focus-ring-opacity))}.focus-ring-light{--bs-focus-ring-color: rgba(var(--bs-light-rgb), var(--bs-focus-ring-opacity))}.focus-ring-dark{--bs-focus-ring-color: rgba(var(--bs-dark-rgb), var(--bs-focus-ring-opacity))}.position-static{position:static !important}.position-relative{position:relative !important}.position-absolute{position:absolute !important}.position-fixed{position:fixed !important}.position-sticky{position:sticky !important}.top-0{top:0 !important}.top-50{top:50% !important}.top-100{top:100% !important}.bottom-0{bottom:0 !important}.bottom-50{bottom:50% !important}.bottom-100{bottom:100% !important}.start-0{left:0 !important}.start-50{left:50% !important}.start-100{left:100% !important}.end-0{right:0 !important}.end-50{right:50% !important}.end-100{right:100% !important}.translate-middle{transform:translate(-50%, -50%) !important}.translate-middle-x{transform:translateX(-50%) !important}.translate-middle-y{transform:translateY(-50%) !important}.border{border:var(--bs-border-width) var(--bs-border-style) var(--bs-border-color) !important}.border-0{border:0 !important}.border-top{border-top:var(--bs-border-width) var(--bs-border-style) var(--bs-border-color) !important}.border-top-0{border-top:0 !important}.border-end{border-right:var(--bs-border-width) var(--bs-border-style) var(--bs-border-color) !important}.border-end-0{border-right:0 !important}.border-bottom{border-bottom:var(--bs-border-width) var(--bs-border-style) var(--bs-border-color) !important}.border-bottom-0{border-bottom:0 !important}.border-start{border-left:var(--bs-border-width) var(--bs-border-style) var(--bs-border-color) !important}.border-start-0{border-left:0 !important}.border-default{--bs-border-opacity: 1;border-color:rgba(var(--bs-default-rgb), var(--bs-border-opacity)) !important}.border-primary{--bs-border-opacity: 1;border-color:rgba(var(--bs-primary-rgb), var(--bs-border-opacity)) !important}.border-secondary{--bs-border-opacity: 1;border-color:rgba(var(--bs-secondary-rgb), var(--bs-border-opacity)) !important}.border-success{--bs-border-opacity: 1;border-color:rgba(var(--bs-success-rgb), var(--bs-border-opacity)) !important}.border-info{--bs-border-opacity: 1;border-color:rgba(var(--bs-info-rgb), var(--bs-border-opacity)) !important}.border-warning{--bs-border-opacity: 1;border-color:rgba(var(--bs-warning-rgb), var(--bs-border-opacity)) !important}.border-danger{--bs-border-opacity: 1;border-color:rgba(var(--bs-danger-rgb), var(--bs-border-opacity)) !important}.border-light{--bs-border-opacity: 1;border-color:rgba(var(--bs-light-rgb), var(--bs-border-opacity)) !important}.border-dark{--bs-border-opacity: 1;border-color:rgba(var(--bs-dark-rgb), var(--bs-border-opacity)) !important}.border-black{--bs-border-opacity: 1;border-color:rgba(var(--bs-black-rgb), var(--bs-border-opacity)) !important}.border-white{--bs-border-opacity: 1;border-color:rgba(var(--bs-white-rgb), var(--bs-border-opacity)) !important}.border-primary-subtle{border-color:var(--bs-primary-border-subtle) !important}.border-secondary-subtle{border-color:var(--bs-secondary-border-subtle) !important}.border-success-subtle{border-color:var(--bs-success-border-subtle) !important}.border-info-subtle{border-color:var(--bs-info-border-subtle) !important}.border-warning-subtle{border-color:var(--bs-warning-border-subtle) !important}.border-danger-subtle{border-color:var(--bs-danger-border-subtle) !important}.border-light-subtle{border-color:var(--bs-light-border-subtle) !important}.border-dark-subtle{border-color:var(--bs-dark-border-subtle) !important}.border-1{border-width:1px !important}.border-2{border-width:2px !important}.border-3{border-width:3px !important}.border-4{border-width:4px !important}.border-5{border-width:5px !important}.border-opacity-10{--bs-border-opacity: .1}.border-opacity-25{--bs-border-opacity: .25}.border-opacity-50{--bs-border-opacity: .5}.border-opacity-75{--bs-border-opacity: .75}.border-opacity-100{--bs-border-opacity: 1}.w-25{width:25% !important}.w-50{width:50% !important}.w-75{width:75% !important}.w-100{width:100% !important}.w-auto{width:auto !important}.mw-100{max-width:100% !important}.vw-100{width:100vw !important}.min-vw-100{min-width:100vw !important}.h-25{height:25% !important}.h-50{height:50% !important}.h-75{height:75% !important}.h-100{height:100% !important}.h-auto{height:auto !important}.mh-100{max-height:100% !important}.vh-100{height:100vh !important}.min-vh-100{min-height:100vh !important}.flex-fill{flex:1 1 auto !important}.flex-row{flex-direction:row !important}.flex-column{flex-direction:column !important}.flex-row-reverse{flex-direction:row-reverse !important}.flex-column-reverse{flex-direction:column-reverse !important}.flex-grow-0{flex-grow:0 !important}.flex-grow-1{flex-grow:1 !important}.flex-shrink-0{flex-shrink:0 !important}.flex-shrink-1{flex-shrink:1 !important}.flex-wrap{flex-wrap:wrap !important}.flex-nowrap{flex-wrap:nowrap !important}.flex-wrap-reverse{flex-wrap:wrap-reverse !important}.justify-content-start{justify-content:flex-start !important}.justify-content-end{justify-content:flex-end !important}.justify-content-center{justify-content:center !important}.justify-content-between{justify-content:space-between !important}.justify-content-around{justify-content:space-around !important}.justify-content-evenly{justify-content:space-evenly !important}.align-items-start{align-items:flex-start !important}.align-items-end{align-items:flex-end !important}.align-items-center{align-items:center !important}.align-items-baseline{align-items:baseline !important}.align-items-stretch{align-items:stretch !important}.align-content-start{align-content:flex-start !important}.align-content-end{align-content:flex-end !important}.align-content-center{align-content:center !important}.align-content-between{align-content:space-between !important}.align-content-around{align-content:space-around !important}.align-content-stretch{align-content:stretch !important}.align-self-auto{align-self:auto !important}.align-self-start{align-self:flex-start !important}.align-self-end{align-self:flex-end !important}.align-self-center{align-self:center !important}.align-self-baseline{align-self:baseline !important}.align-self-stretch{align-self:stretch !important}.order-first{order:-1 !important}.order-0{order:0 !important}.order-1{order:1 !important}.order-2{order:2 !important}.order-3{order:3 !important}.order-4{order:4 !important}.order-5{order:5 !important}.order-last{order:6 !important}.m-0{margin:0 !important}.m-1{margin:.25rem !important}.m-2{margin:.5rem !important}.m-3{margin:1rem !important}.m-4{margin:1.5rem !important}.m-5{margin:3rem !important}.m-auto{margin:auto !important}.mx-0{margin-right:0 !important;margin-left:0 !important}.mx-1{margin-right:.25rem !important;margin-left:.25rem !important}.mx-2{margin-right:.5rem !important;margin-left:.5rem !important}.mx-3{margin-right:1rem !important;margin-left:1rem !important}.mx-4{margin-right:1.5rem !important;margin-left:1.5rem !important}.mx-5{margin-right:3rem !important;margin-left:3rem !important}.mx-auto{margin-right:auto !important;margin-left:auto !important}.my-0{margin-top:0 !important;margin-bottom:0 !important}.my-1{margin-top:.25rem !important;margin-bottom:.25rem !important}.my-2{margin-top:.5rem !important;margin-bottom:.5rem !important}.my-3{margin-top:1rem !important;margin-bottom:1rem !important}.my-4{margin-top:1.5rem !important;margin-bottom:1.5rem !important}.my-5{margin-top:3rem !important;margin-bottom:3rem !important}.my-auto{margin-top:auto !important;margin-bottom:auto !important}.mt-0{margin-top:0 !important}.mt-1{margin-top:.25rem !important}.mt-2{margin-top:.5rem !important}.mt-3{margin-top:1rem !important}.mt-4{margin-top:1.5rem !important}.mt-5{margin-top:3rem !important}.mt-auto{margin-top:auto !important}.me-0{margin-right:0 !important}.me-1{margin-right:.25rem !important}.me-2{margin-right:.5rem !important}.me-3{margin-right:1rem !important}.me-4{margin-right:1.5rem !important}.me-5{margin-right:3rem !important}.me-auto{margin-right:auto !important}.mb-0{margin-bottom:0 !important}.mb-1{margin-bottom:.25rem !important}.mb-2{margin-bottom:.5rem !important}.mb-3{margin-bottom:1rem !important}.mb-4{margin-bottom:1.5rem !important}.mb-5{margin-bottom:3rem !important}.mb-auto{margin-bottom:auto !important}.ms-0{margin-left:0 !important}.ms-1{margin-left:.25rem !important}.ms-2{margin-left:.5rem !important}.ms-3{margin-left:1rem !important}.ms-4{margin-left:1.5rem !important}.ms-5{margin-left:3rem !important}.ms-auto{margin-left:auto !important}.p-0{padding:0 !important}.p-1{padding:.25rem !important}.p-2{padding:.5rem !important}.p-3{padding:1rem !important}.p-4{padding:1.5rem !important}.p-5{padding:3rem !important}.px-0{padding-right:0 !important;padding-left:0 !important}.px-1{padding-right:.25rem !important;padding-left:.25rem !important}.px-2{padding-right:.5rem !important;padding-left:.5rem !important}.px-3{padding-right:1rem !important;padding-left:1rem !important}.px-4{padding-right:1.5rem !important;padding-left:1.5rem !important}.px-5{padding-right:3rem !important;padding-left:3rem !important}.py-0{padding-top:0 !important;padding-bottom:0 !important}.py-1{padding-top:.25rem !important;padding-bottom:.25rem !important}.py-2{padding-top:.5rem !important;padding-bottom:.5rem !important}.py-3{padding-top:1rem !important;padding-bottom:1rem !important}.py-4{padding-top:1.5rem !important;padding-bottom:1.5rem !important}.py-5{padding-top:3rem !important;padding-bottom:3rem !important}.pt-0{padding-top:0 !important}.pt-1{padding-top:.25rem !important}.pt-2{padding-top:.5rem !important}.pt-3{padding-top:1rem !important}.pt-4{padding-top:1.5rem !important}.pt-5{padding-top:3rem !important}.pe-0{padding-right:0 !important}.pe-1{padding-right:.25rem !important}.pe-2{padding-right:.5rem !important}.pe-3{padding-right:1rem !important}.pe-4{padding-right:1.5rem !important}.pe-5{padding-right:3rem !important}.pb-0{padding-bottom:0 !important}.pb-1{padding-bottom:.25rem !important}.pb-2{padding-bottom:.5rem !important}.pb-3{padding-bottom:1rem !important}.pb-4{padding-bottom:1.5rem !important}.pb-5{padding-bottom:3rem !important}.ps-0{padding-left:0 !important}.ps-1{padding-left:.25rem !important}.ps-2{padding-left:.5rem !important}.ps-3{padding-left:1rem !important}.ps-4{padding-left:1.5rem !important}.ps-5{padding-left:3rem !important}.gap-0{gap:0 !important}.gap-1{gap:.25rem !important}.gap-2{gap:.5rem !important}.gap-3{gap:1rem !important}.gap-4{gap:1.5rem !important}.gap-5{gap:3rem !important}.row-gap-0{row-gap:0 !important}.row-gap-1{row-gap:.25rem !important}.row-gap-2{row-gap:.5rem !important}.row-gap-3{row-gap:1rem !important}.row-gap-4{row-gap:1.5rem !important}.row-gap-5{row-gap:3rem !important}.column-gap-0{column-gap:0 !important}.column-gap-1{column-gap:.25rem !important}.column-gap-2{column-gap:.5rem !important}.column-gap-3{column-gap:1rem !important}.column-gap-4{column-gap:1.5rem !important}.column-gap-5{column-gap:3rem !important}.font-monospace{font-family:var(--bs-font-monospace) !important}.fs-1{font-size:calc(1.335rem + 1.02vw) !important}.fs-2{font-size:calc(1.325rem + .9vw) !important}.fs-3{font-size:calc(1.3rem + .6vw) !important}.fs-4{font-size:calc(1.275rem + .3vw) !important}.fs-5{font-size:1.25rem !important}.fs-6{font-size:1rem !important}.fst-italic{font-style:italic !important}.fst-normal{font-style:normal !important}.fw-lighter{font-weight:lighter !important}.fw-light{font-weight:300 !important}.fw-normal{font-weight:400 !important}.fw-medium{font-weight:500 !important}.fw-semibold{font-weight:600 !important}.fw-bold{font-weight:700 !important}.fw-bolder{font-weight:bolder !important}.lh-1{line-height:1 !important}.lh-sm{line-height:1.25 !important}.lh-base{line-height:1.5 !important}.lh-lg{line-height:2 !important}.text-start{text-align:left !important}.text-end{text-align:right !important}.text-center{text-align:center !important}.text-decoration-none{text-decoration:none !important}.text-decoration-underline{text-decoration:underline !important}.text-decoration-line-through{text-decoration:line-through !important}.text-lowercase{text-transform:lowercase !important}.text-uppercase{text-transform:uppercase !important}.text-capitalize{text-transform:capitalize !important}.text-wrap{white-space:normal !important}.text-nowrap{white-space:nowrap !important}.text-break{word-wrap:break-word !important;word-break:break-word !important}.text-default{--bs-text-opacity: 1;color:rgba(var(--bs-default-rgb), var(--bs-text-opacity)) !important}.text-primary{--bs-text-opacity: 1;color:rgba(var(--bs-primary-rgb), var(--bs-text-opacity)) !important}.text-secondary{--bs-text-opacity: 1;color:rgba(var(--bs-secondary-rgb), var(--bs-text-opacity)) !important}.text-success{--bs-text-opacity: 1;color:rgba(var(--bs-success-rgb), var(--bs-text-opacity)) !important}.text-info{--bs-text-opacity: 1;color:rgba(var(--bs-info-rgb), var(--bs-text-opacity)) !important}.text-warning{--bs-text-opacity: 1;color:rgba(var(--bs-warning-rgb), var(--bs-text-opacity)) !important}.text-danger{--bs-text-opacity: 1;color:rgba(var(--bs-danger-rgb), var(--bs-text-opacity)) !important}.text-light{--bs-text-opacity: 1;color:rgba(var(--bs-light-rgb), var(--bs-text-opacity)) !important}.text-dark{--bs-text-opacity: 1;color:rgba(var(--bs-dark-rgb), var(--bs-text-opacity)) !important}.text-black{--bs-text-opacity: 1;color:rgba(var(--bs-black-rgb), var(--bs-text-opacity)) !important}.text-white{--bs-text-opacity: 1;color:rgba(var(--bs-white-rgb), var(--bs-text-opacity)) !important}.text-body{--bs-text-opacity: 1;color:rgba(var(--bs-body-color-rgb), var(--bs-text-opacity)) !important}.text-muted,.help-text,.help-block{--bs-text-opacity: 1;color:var(--bs-secondary-color) !important}.text-black-50{--bs-text-opacity: 1;color:rgba(0,0,0,0.5) !important}.text-white-50{--bs-text-opacity: 1;color:rgba(255,255,255,0.5) !important}.text-body-secondary{--bs-text-opacity: 1;color:var(--bs-secondary-color) !important}.text-body-tertiary{--bs-text-opacity: 1;color:var(--bs-tertiary-color) !important}.text-body-emphasis{--bs-text-opacity: 1;color:var(--bs-emphasis-color) !important}.text-reset{--bs-text-opacity: 1;color:inherit !important}.text-opacity-25{--bs-text-opacity: .25}.text-opacity-50{--bs-text-opacity: .5}.text-opacity-75{--bs-text-opacity: .75}.text-opacity-100{--bs-text-opacity: 1}.text-primary-emphasis{color:var(--bs-primary-text-emphasis) !important}.text-secondary-emphasis{color:var(--bs-secondary-text-emphasis) !important}.text-success-emphasis{color:var(--bs-success-text-emphasis) !important}.text-info-emphasis{color:var(--bs-info-text-emphasis) !important}.text-warning-emphasis{color:var(--bs-warning-text-emphasis) !important}.text-danger-emphasis{color:var(--bs-danger-text-emphasis) !important}.text-light-emphasis{color:var(--bs-light-text-emphasis) !important}.text-dark-emphasis{color:var(--bs-dark-text-emphasis) !important}.link-opacity-10{--bs-link-opacity: .1}.link-opacity-10-hover:hover{--bs-link-opacity: .1}.link-opacity-25{--bs-link-opacity: .25}.link-opacity-25-hover:hover{--bs-link-opacity: .25}.link-opacity-50{--bs-link-opacity: .5}.link-opacity-50-hover:hover{--bs-link-opacity: .5}.link-opacity-75{--bs-link-opacity: .75}.link-opacity-75-hover:hover{--bs-link-opacity: .75}.link-opacity-100{--bs-link-opacity: 1}.link-opacity-100-hover:hover{--bs-link-opacity: 1}.link-offset-1{text-underline-offset:.125em !important}.link-offset-1-hover:hover{text-underline-offset:.125em !important}.link-offset-2{text-underline-offset:.25em !important}.link-offset-2-hover:hover{text-underline-offset:.25em !important}.link-offset-3{text-underline-offset:.375em !important}.link-offset-3-hover:hover{text-underline-offset:.375em !important}.link-underline-default{--bs-link-underline-opacity: 1;text-decoration-color:rgba(var(--bs-default-rgb), var(--bs-link-underline-opacity)) !important}.link-underline-primary{--bs-link-underline-opacity: 1;text-decoration-color:rgba(var(--bs-primary-rgb), var(--bs-link-underline-opacity)) !important}.link-underline-secondary{--bs-link-underline-opacity: 1;text-decoration-color:rgba(var(--bs-secondary-rgb), var(--bs-link-underline-opacity)) !important}.link-underline-success{--bs-link-underline-opacity: 1;text-decoration-color:rgba(var(--bs-success-rgb), var(--bs-link-underline-opacity)) !important}.link-underline-info{--bs-link-underline-opacity: 1;text-decoration-color:rgba(var(--bs-info-rgb), var(--bs-link-underline-opacity)) !important}.link-underline-warning{--bs-link-underline-opacity: 1;text-decoration-color:rgba(var(--bs-warning-rgb), var(--bs-link-underline-opacity)) !important}.link-underline-danger{--bs-link-underline-opacity: 1;text-decoration-color:rgba(var(--bs-danger-rgb), var(--bs-link-underline-opacity)) !important}.link-underline-light{--bs-link-underline-opacity: 1;text-decoration-color:rgba(var(--bs-light-rgb), var(--bs-link-underline-opacity)) !important}.link-underline-dark{--bs-link-underline-opacity: 1;text-decoration-color:rgba(var(--bs-dark-rgb), var(--bs-link-underline-opacity)) !important}.link-underline{--bs-link-underline-opacity: 1;text-decoration-color:rgba(var(--bs-link-color-rgb), var(--bs-link-underline-opacity, 1)) !important}.link-underline-opacity-0{--bs-link-underline-opacity: 0}.link-underline-opacity-0-hover:hover{--bs-link-underline-opacity: 0}.link-underline-opacity-10{--bs-link-underline-opacity: .1}.link-underline-opacity-10-hover:hover{--bs-link-underline-opacity: .1}.link-underline-opacity-25{--bs-link-underline-opacity: .25}.link-underline-opacity-25-hover:hover{--bs-link-underline-opacity: .25}.link-underline-opacity-50{--bs-link-underline-opacity: .5}.link-underline-opacity-50-hover:hover{--bs-link-underline-opacity: .5}.link-underline-opacity-75{--bs-link-underline-opacity: .75}.link-underline-opacity-75-hover:hover{--bs-link-underline-opacity: .75}.link-underline-opacity-100{--bs-link-underline-opacity: 1}.link-underline-opacity-100-hover:hover{--bs-link-underline-opacity: 1}.bg-default{--bs-bg-opacity: 1;background-color:rgba(var(--bs-default-rgb), var(--bs-bg-opacity)) !important}.bg-primary{--bs-bg-opacity: 1;background-color:rgba(var(--bs-primary-rgb), var(--bs-bg-opacity)) !important}.bg-secondary{--bs-bg-opacity: 1;background-color:rgba(var(--bs-secondary-rgb), var(--bs-bg-opacity)) !important}.bg-success{--bs-bg-opacity: 1;background-color:rgba(var(--bs-success-rgb), var(--bs-bg-opacity)) !important}.bg-info{--bs-bg-opacity: 1;background-color:rgba(var(--bs-info-rgb), var(--bs-bg-opacity)) !important}.bg-warning{--bs-bg-opacity: 1;background-color:rgba(var(--bs-warning-rgb), var(--bs-bg-opacity)) !important}.bg-danger{--bs-bg-opacity: 1;background-color:rgba(var(--bs-danger-rgb), var(--bs-bg-opacity)) !important}.bg-light{--bs-bg-opacity: 1;background-color:rgba(var(--bs-light-rgb), var(--bs-bg-opacity)) !important}.bg-dark{--bs-bg-opacity: 1;background-color:rgba(var(--bs-dark-rgb), var(--bs-bg-opacity)) !important}.bg-black{--bs-bg-opacity: 1;background-color:rgba(var(--bs-black-rgb), var(--bs-bg-opacity)) !important}.bg-white{--bs-bg-opacity: 1;background-color:rgba(var(--bs-white-rgb), var(--bs-bg-opacity)) !important}.bg-body{--bs-bg-opacity: 1;background-color:rgba(var(--bs-body-bg-rgb), var(--bs-bg-opacity)) !important}.bg-transparent{--bs-bg-opacity: 1;background-color:rgba(0,0,0,0) !important}.bg-body-secondary{--bs-bg-opacity: 1;background-color:rgba(var(--bs-secondary-bg-rgb), var(--bs-bg-opacity)) !important}.bg-body-tertiary{--bs-bg-opacity: 1;background-color:rgba(var(--bs-tertiary-bg-rgb), var(--bs-bg-opacity)) !important}.bg-opacity-10{--bs-bg-opacity: .1}.bg-opacity-25{--bs-bg-opacity: .25}.bg-opacity-50{--bs-bg-opacity: .5}.bg-opacity-75{--bs-bg-opacity: .75}.bg-opacity-100{--bs-bg-opacity: 1}.bg-primary-subtle{background-color:var(--bs-primary-bg-subtle) !important}.bg-secondary-subtle{background-color:var(--bs-secondary-bg-subtle) !important}.bg-success-subtle{background-color:var(--bs-success-bg-subtle) !important}.bg-info-subtle{background-color:var(--bs-info-bg-subtle) !important}.bg-warning-subtle{background-color:var(--bs-warning-bg-subtle) !important}.bg-danger-subtle{background-color:var(--bs-danger-bg-subtle) !important}.bg-light-subtle{background-color:var(--bs-light-bg-subtle) !important}.bg-dark-subtle{background-color:var(--bs-dark-bg-subtle) !important}.bg-gradient{background-image:var(--bs-gradient) !important}.user-select-all{user-select:all !important}.user-select-auto{user-select:auto !important}.user-select-none{user-select:none !important}.pe-none{pointer-events:none !important}.pe-auto{pointer-events:auto !important}.rounded{border-radius:var(--bs-border-radius) !important}.rounded-0{border-radius:0 !important}.rounded-1{border-radius:var(--bs-border-radius-sm) !important}.rounded-2{border-radius:var(--bs-border-radius) !important}.rounded-3{border-radius:var(--bs-border-radius-lg) !important}.rounded-4{border-radius:var(--bs-border-radius-xl) !important}.rounded-5{border-radius:var(--bs-border-radius-xxl) !important}.rounded-circle{border-radius:50% !important}.rounded-pill{border-radius:var(--bs-border-radius-pill) !important}.rounded-top{border-top-left-radius:var(--bs-border-radius) !important;border-top-right-radius:var(--bs-border-radius) !important}.rounded-top-0{border-top-left-radius:0 !important;border-top-right-radius:0 !important}.rounded-top-1{border-top-left-radius:var(--bs-border-radius-sm) !important;border-top-right-radius:var(--bs-border-radius-sm) !important}.rounded-top-2{border-top-left-radius:var(--bs-border-radius) !important;border-top-right-radius:var(--bs-border-radius) !important}.rounded-top-3{border-top-left-radius:var(--bs-border-radius-lg) !important;border-top-right-radius:var(--bs-border-radius-lg) !important}.rounded-top-4{border-top-left-radius:var(--bs-border-radius-xl) !important;border-top-right-radius:var(--bs-border-radius-xl) !important}.rounded-top-5{border-top-left-radius:var(--bs-border-radius-xxl) !important;border-top-right-radius:var(--bs-border-radius-xxl) !important}.rounded-top-circle{border-top-left-radius:50% !important;border-top-right-radius:50% !important}.rounded-top-pill{border-top-left-radius:var(--bs-border-radius-pill) !important;border-top-right-radius:var(--bs-border-radius-pill) !important}.rounded-end{border-top-right-radius:var(--bs-border-radius) !important;border-bottom-right-radius:var(--bs-border-radius) !important}.rounded-end-0{border-top-right-radius:0 !important;border-bottom-right-radius:0 !important}.rounded-end-1{border-top-right-radius:var(--bs-border-radius-sm) !important;border-bottom-right-radius:var(--bs-border-radius-sm) !important}.rounded-end-2{border-top-right-radius:var(--bs-border-radius) !important;border-bottom-right-radius:var(--bs-border-radius) !important}.rounded-end-3{border-top-right-radius:var(--bs-border-radius-lg) !important;border-bottom-right-radius:var(--bs-border-radius-lg) !important}.rounded-end-4{border-top-right-radius:var(--bs-border-radius-xl) !important;border-bottom-right-radius:var(--bs-border-radius-xl) !important}.rounded-end-5{border-top-right-radius:var(--bs-border-radius-xxl) !important;border-bottom-right-radius:var(--bs-border-radius-xxl) !important}.rounded-end-circle{border-top-right-radius:50% !important;border-bottom-right-radius:50% !important}.rounded-end-pill{border-top-right-radius:var(--bs-border-radius-pill) !important;border-bottom-right-radius:var(--bs-border-radius-pill) !important}.rounded-bottom{border-bottom-right-radius:var(--bs-border-radius) !important;border-bottom-left-radius:var(--bs-border-radius) !important}.rounded-bottom-0{border-bottom-right-radius:0 !important;border-bottom-left-radius:0 !important}.rounded-bottom-1{border-bottom-right-radius:var(--bs-border-radius-sm) !important;border-bottom-left-radius:var(--bs-border-radius-sm) !important}.rounded-bottom-2{border-bottom-right-radius:var(--bs-border-radius) !important;border-bottom-left-radius:var(--bs-border-radius) !important}.rounded-bottom-3{border-bottom-right-radius:var(--bs-border-radius-lg) !important;border-bottom-left-radius:var(--bs-border-radius-lg) !important}.rounded-bottom-4{border-bottom-right-radius:var(--bs-border-radius-xl) !important;border-bottom-left-radius:var(--bs-border-radius-xl) !important}.rounded-bottom-5{border-bottom-right-radius:var(--bs-border-radius-xxl) !important;border-bottom-left-radius:var(--bs-border-radius-xxl) !important}.rounded-bottom-circle{border-bottom-right-radius:50% !important;border-bottom-left-radius:50% !important}.rounded-bottom-pill{border-bottom-right-radius:var(--bs-border-radius-pill) !important;border-bottom-left-radius:var(--bs-border-radius-pill) !important}.rounded-start{border-bottom-left-radius:var(--bs-border-radius) !important;border-top-left-radius:var(--bs-border-radius) !important}.rounded-start-0{border-bottom-left-radius:0 !important;border-top-left-radius:0 !important}.rounded-start-1{border-bottom-left-radius:var(--bs-border-radius-sm) !important;border-top-left-radius:var(--bs-border-radius-sm) !important}.rounded-start-2{border-bottom-left-radius:var(--bs-border-radius) !important;border-top-left-radius:var(--bs-border-radius) !important}.rounded-start-3{border-bottom-left-radius:var(--bs-border-radius-lg) !important;border-top-left-radius:var(--bs-border-radius-lg) !important}.rounded-start-4{border-bottom-left-radius:var(--bs-border-radius-xl) !important;border-top-left-radius:var(--bs-border-radius-xl) !important}.rounded-start-5{border-bottom-left-radius:var(--bs-border-radius-xxl) !important;border-top-left-radius:var(--bs-border-radius-xxl) !important}.rounded-start-circle{border-bottom-left-radius:50% !important;border-top-left-radius:50% !important}.rounded-start-pill{border-bottom-left-radius:var(--bs-border-radius-pill) !important;border-top-left-radius:var(--bs-border-radius-pill) !important}.visible{visibility:visible !important}.invisible{visibility:hidden !important}.z-n1{z-index:-1 !important}.z-0{z-index:0 !important}.z-1{z-index:1 !important}.z-2{z-index:2 !important}.z-3{z-index:3 !important}@media (min-width: 576px){.float-sm-start{float:left !important}.float-sm-end{float:right !important}.float-sm-none{float:none !important}.object-fit-sm-contain{object-fit:contain !important}.object-fit-sm-cover{object-fit:cover !important}.object-fit-sm-fill{object-fit:fill !important}.object-fit-sm-scale{object-fit:scale-down !important}.object-fit-sm-none{object-fit:none !important}.d-sm-inline{display:inline !important}.d-sm-inline-block{display:inline-block !important}.d-sm-block{display:block !important}.d-sm-grid{display:grid !important}.d-sm-inline-grid{display:inline-grid !important}.d-sm-table{display:table !important}.d-sm-table-row{display:table-row !important}.d-sm-table-cell{display:table-cell !important}.d-sm-flex{display:flex !important}.d-sm-inline-flex{display:inline-flex !important}.d-sm-none{display:none !important}.flex-sm-fill{flex:1 1 auto !important}.flex-sm-row{flex-direction:row !important}.flex-sm-column{flex-direction:column !important}.flex-sm-row-reverse{flex-direction:row-reverse !important}.flex-sm-column-reverse{flex-direction:column-reverse !important}.flex-sm-grow-0{flex-grow:0 !important}.flex-sm-grow-1{flex-grow:1 !important}.flex-sm-shrink-0{flex-shrink:0 !important}.flex-sm-shrink-1{flex-shrink:1 !important}.flex-sm-wrap{flex-wrap:wrap !important}.flex-sm-nowrap{flex-wrap:nowrap !important}.flex-sm-wrap-reverse{flex-wrap:wrap-reverse !important}.justify-content-sm-start{justify-content:flex-start !important}.justify-content-sm-end{justify-content:flex-end !important}.justify-content-sm-center{justify-content:center !important}.justify-content-sm-between{justify-content:space-between !important}.justify-content-sm-around{justify-content:space-around !important}.justify-content-sm-evenly{justify-content:space-evenly !important}.align-items-sm-start{align-items:flex-start !important}.align-items-sm-end{align-items:flex-end !important}.align-items-sm-center{align-items:center !important}.align-items-sm-baseline{align-items:baseline !important}.align-items-sm-stretch{align-items:stretch !important}.align-content-sm-start{align-content:flex-start !important}.align-content-sm-end{align-content:flex-end !important}.align-content-sm-center{align-content:center !important}.align-content-sm-between{align-content:space-between !important}.align-content-sm-around{align-content:space-around !important}.align-content-sm-stretch{align-content:stretch !important}.align-self-sm-auto{align-self:auto !important}.align-self-sm-start{align-self:flex-start !important}.align-self-sm-end{align-self:flex-end !important}.align-self-sm-center{align-self:center !important}.align-self-sm-baseline{align-self:baseline !important}.align-self-sm-stretch{align-self:stretch !important}.order-sm-first{order:-1 !important}.order-sm-0{order:0 !important}.order-sm-1{order:1 !important}.order-sm-2{order:2 !important}.order-sm-3{order:3 !important}.order-sm-4{order:4 !important}.order-sm-5{order:5 !important}.order-sm-last{order:6 !important}.m-sm-0{margin:0 !important}.m-sm-1{margin:.25rem !important}.m-sm-2{margin:.5rem !important}.m-sm-3{margin:1rem !important}.m-sm-4{margin:1.5rem !important}.m-sm-5{margin:3rem !important}.m-sm-auto{margin:auto !important}.mx-sm-0{margin-right:0 !important;margin-left:0 !important}.mx-sm-1{margin-right:.25rem !important;margin-left:.25rem !important}.mx-sm-2{margin-right:.5rem !important;margin-left:.5rem !important}.mx-sm-3{margin-right:1rem !important;margin-left:1rem !important}.mx-sm-4{margin-right:1.5rem !important;margin-left:1.5rem !important}.mx-sm-5{margin-right:3rem !important;margin-left:3rem !important}.mx-sm-auto{margin-right:auto !important;margin-left:auto !important}.my-sm-0{margin-top:0 !important;margin-bottom:0 !important}.my-sm-1{margin-top:.25rem !important;margin-bottom:.25rem !important}.my-sm-2{margin-top:.5rem !important;margin-bottom:.5rem !important}.my-sm-3{margin-top:1rem !important;margin-bottom:1rem !important}.my-sm-4{margin-top:1.5rem !important;margin-bottom:1.5rem !important}.my-sm-5{margin-top:3rem !important;margin-bottom:3rem !important}.my-sm-auto{margin-top:auto !important;margin-bottom:auto !important}.mt-sm-0{margin-top:0 !important}.mt-sm-1{margin-top:.25rem !important}.mt-sm-2{margin-top:.5rem !important}.mt-sm-3{margin-top:1rem !important}.mt-sm-4{margin-top:1.5rem !important}.mt-sm-5{margin-top:3rem !important}.mt-sm-auto{margin-top:auto !important}.me-sm-0{margin-right:0 !important}.me-sm-1{margin-right:.25rem !important}.me-sm-2{margin-right:.5rem !important}.me-sm-3{margin-right:1rem !important}.me-sm-4{margin-right:1.5rem !important}.me-sm-5{margin-right:3rem !important}.me-sm-auto{margin-right:auto !important}.mb-sm-0{margin-bottom:0 !important}.mb-sm-1{margin-bottom:.25rem !important}.mb-sm-2{margin-bottom:.5rem !important}.mb-sm-3{margin-bottom:1rem !important}.mb-sm-4{margin-bottom:1.5rem !important}.mb-sm-5{margin-bottom:3rem !important}.mb-sm-auto{margin-bottom:auto !important}.ms-sm-0{margin-left:0 !important}.ms-sm-1{margin-left:.25rem !important}.ms-sm-2{margin-left:.5rem !important}.ms-sm-3{margin-left:1rem !important}.ms-sm-4{margin-left:1.5rem !important}.ms-sm-5{margin-left:3rem !important}.ms-sm-auto{margin-left:auto !important}.p-sm-0{padding:0 !important}.p-sm-1{padding:.25rem !important}.p-sm-2{padding:.5rem !important}.p-sm-3{padding:1rem !important}.p-sm-4{padding:1.5rem !important}.p-sm-5{padding:3rem !important}.px-sm-0{padding-right:0 !important;padding-left:0 !important}.px-sm-1{padding-right:.25rem !important;padding-left:.25rem !important}.px-sm-2{padding-right:.5rem !important;padding-left:.5rem !important}.px-sm-3{padding-right:1rem !important;padding-left:1rem !important}.px-sm-4{padding-right:1.5rem !important;padding-left:1.5rem !important}.px-sm-5{padding-right:3rem !important;padding-left:3rem !important}.py-sm-0{padding-top:0 !important;padding-bottom:0 !important}.py-sm-1{padding-top:.25rem !important;padding-bottom:.25rem !important}.py-sm-2{padding-top:.5rem !important;padding-bottom:.5rem !important}.py-sm-3{padding-top:1rem !important;padding-bottom:1rem !important}.py-sm-4{padding-top:1.5rem !important;padding-bottom:1.5rem !important}.py-sm-5{padding-top:3rem !important;padding-bottom:3rem !important}.pt-sm-0{padding-top:0 !important}.pt-sm-1{padding-top:.25rem !important}.pt-sm-2{padding-top:.5rem !important}.pt-sm-3{padding-top:1rem !important}.pt-sm-4{padding-top:1.5rem !important}.pt-sm-5{padding-top:3rem !important}.pe-sm-0{padding-right:0 !important}.pe-sm-1{padding-right:.25rem !important}.pe-sm-2{padding-right:.5rem !important}.pe-sm-3{padding-right:1rem !important}.pe-sm-4{padding-right:1.5rem !important}.pe-sm-5{padding-right:3rem !important}.pb-sm-0{padding-bottom:0 !important}.pb-sm-1{padding-bottom:.25rem !important}.pb-sm-2{padding-bottom:.5rem !important}.pb-sm-3{padding-bottom:1rem !important}.pb-sm-4{padding-bottom:1.5rem !important}.pb-sm-5{padding-bottom:3rem !important}.ps-sm-0{padding-left:0 !important}.ps-sm-1{padding-left:.25rem !important}.ps-sm-2{padding-left:.5rem !important}.ps-sm-3{padding-left:1rem !important}.ps-sm-4{padding-left:1.5rem !important}.ps-sm-5{padding-left:3rem !important}.gap-sm-0{gap:0 !important}.gap-sm-1{gap:.25rem !important}.gap-sm-2{gap:.5rem !important}.gap-sm-3{gap:1rem !important}.gap-sm-4{gap:1.5rem !important}.gap-sm-5{gap:3rem !important}.row-gap-sm-0{row-gap:0 !important}.row-gap-sm-1{row-gap:.25rem !important}.row-gap-sm-2{row-gap:.5rem !important}.row-gap-sm-3{row-gap:1rem !important}.row-gap-sm-4{row-gap:1.5rem !important}.row-gap-sm-5{row-gap:3rem !important}.column-gap-sm-0{column-gap:0 !important}.column-gap-sm-1{column-gap:.25rem !important}.column-gap-sm-2{column-gap:.5rem !important}.column-gap-sm-3{column-gap:1rem !important}.column-gap-sm-4{column-gap:1.5rem !important}.column-gap-sm-5{column-gap:3rem !important}.text-sm-start{text-align:left !important}.text-sm-end{text-align:right !important}.text-sm-center{text-align:center !important}}@media (min-width: 768px){.float-md-start{float:left !important}.float-md-end{float:right !important}.float-md-none{float:none !important}.object-fit-md-contain{object-fit:contain !important}.object-fit-md-cover{object-fit:cover !important}.object-fit-md-fill{object-fit:fill !important}.object-fit-md-scale{object-fit:scale-down !important}.object-fit-md-none{object-fit:none !important}.d-md-inline{display:inline !important}.d-md-inline-block{display:inline-block !important}.d-md-block{display:block !important}.d-md-grid{display:grid !important}.d-md-inline-grid{display:inline-grid !important}.d-md-table{display:table !important}.d-md-table-row{display:table-row !important}.d-md-table-cell{display:table-cell !important}.d-md-flex{display:flex !important}.d-md-inline-flex{display:inline-flex !important}.d-md-none{display:none !important}.flex-md-fill{flex:1 1 auto !important}.flex-md-row{flex-direction:row !important}.flex-md-column{flex-direction:column !important}.flex-md-row-reverse{flex-direction:row-reverse !important}.flex-md-column-reverse{flex-direction:column-reverse !important}.flex-md-grow-0{flex-grow:0 !important}.flex-md-grow-1{flex-grow:1 !important}.flex-md-shrink-0{flex-shrink:0 !important}.flex-md-shrink-1{flex-shrink:1 !important}.flex-md-wrap{flex-wrap:wrap !important}.flex-md-nowrap{flex-wrap:nowrap !important}.flex-md-wrap-reverse{flex-wrap:wrap-reverse !important}.justify-content-md-start{justify-content:flex-start !important}.justify-content-md-end{justify-content:flex-end !important}.justify-content-md-center{justify-content:center !important}.justify-content-md-between{justify-content:space-between !important}.justify-content-md-around{justify-content:space-around !important}.justify-content-md-evenly{justify-content:space-evenly !important}.align-items-md-start{align-items:flex-start !important}.align-items-md-end{align-items:flex-end !important}.align-items-md-center{align-items:center !important}.align-items-md-baseline{align-items:baseline !important}.align-items-md-stretch{align-items:stretch !important}.align-content-md-start{align-content:flex-start !important}.align-content-md-end{align-content:flex-end !important}.align-content-md-center{align-content:center !important}.align-content-md-between{align-content:space-between !important}.align-content-md-around{align-content:space-around !important}.align-content-md-stretch{align-content:stretch !important}.align-self-md-auto{align-self:auto !important}.align-self-md-start{align-self:flex-start !important}.align-self-md-end{align-self:flex-end !important}.align-self-md-center{align-self:center !important}.align-self-md-baseline{align-self:baseline !important}.align-self-md-stretch{align-self:stretch !important}.order-md-first{order:-1 !important}.order-md-0{order:0 !important}.order-md-1{order:1 !important}.order-md-2{order:2 !important}.order-md-3{order:3 !important}.order-md-4{order:4 !important}.order-md-5{order:5 !important}.order-md-last{order:6 !important}.m-md-0{margin:0 !important}.m-md-1{margin:.25rem !important}.m-md-2{margin:.5rem !important}.m-md-3{margin:1rem !important}.m-md-4{margin:1.5rem !important}.m-md-5{margin:3rem !important}.m-md-auto{margin:auto !important}.mx-md-0{margin-right:0 !important;margin-left:0 !important}.mx-md-1{margin-right:.25rem !important;margin-left:.25rem !important}.mx-md-2{margin-right:.5rem !important;margin-left:.5rem !important}.mx-md-3{margin-right:1rem !important;margin-left:1rem !important}.mx-md-4{margin-right:1.5rem !important;margin-left:1.5rem !important}.mx-md-5{margin-right:3rem !important;margin-left:3rem !important}.mx-md-auto{margin-right:auto !important;margin-left:auto !important}.my-md-0{margin-top:0 !important;margin-bottom:0 !important}.my-md-1{margin-top:.25rem !important;margin-bottom:.25rem !important}.my-md-2{margin-top:.5rem !important;margin-bottom:.5rem !important}.my-md-3{margin-top:1rem !important;margin-bottom:1rem !important}.my-md-4{margin-top:1.5rem !important;margin-bottom:1.5rem !important}.my-md-5{margin-top:3rem !important;margin-bottom:3rem !important}.my-md-auto{margin-top:auto !important;margin-bottom:auto !important}.mt-md-0{margin-top:0 !important}.mt-md-1{margin-top:.25rem !important}.mt-md-2{margin-top:.5rem !important}.mt-md-3{margin-top:1rem !important}.mt-md-4{margin-top:1.5rem !important}.mt-md-5{margin-top:3rem !important}.mt-md-auto{margin-top:auto !important}.me-md-0{margin-right:0 !important}.me-md-1{margin-right:.25rem !important}.me-md-2{margin-right:.5rem !important}.me-md-3{margin-right:1rem !important}.me-md-4{margin-right:1.5rem !important}.me-md-5{margin-right:3rem !important}.me-md-auto{margin-right:auto !important}.mb-md-0{margin-bottom:0 !important}.mb-md-1{margin-bottom:.25rem !important}.mb-md-2{margin-bottom:.5rem !important}.mb-md-3{margin-bottom:1rem !important}.mb-md-4{margin-bottom:1.5rem !important}.mb-md-5{margin-bottom:3rem !important}.mb-md-auto{margin-bottom:auto !important}.ms-md-0{margin-left:0 !important}.ms-md-1{margin-left:.25rem !important}.ms-md-2{margin-left:.5rem !important}.ms-md-3{margin-left:1rem !important}.ms-md-4{margin-left:1.5rem !important}.ms-md-5{margin-left:3rem !important}.ms-md-auto{margin-left:auto !important}.p-md-0{padding:0 !important}.p-md-1{padding:.25rem !important}.p-md-2{padding:.5rem !important}.p-md-3{padding:1rem !important}.p-md-4{padding:1.5rem !important}.p-md-5{padding:3rem !important}.px-md-0{padding-right:0 !important;padding-left:0 !important}.px-md-1{padding-right:.25rem !important;padding-left:.25rem !important}.px-md-2{padding-right:.5rem !important;padding-left:.5rem !important}.px-md-3{padding-right:1rem !important;padding-left:1rem !important}.px-md-4{padding-right:1.5rem !important;padding-left:1.5rem !important}.px-md-5{padding-right:3rem !important;padding-left:3rem !important}.py-md-0{padding-top:0 !important;padding-bottom:0 !important}.py-md-1{padding-top:.25rem !important;padding-bottom:.25rem !important}.py-md-2{padding-top:.5rem !important;padding-bottom:.5rem !important}.py-md-3{padding-top:1rem !important;padding-bottom:1rem !important}.py-md-4{padding-top:1.5rem !important;padding-bottom:1.5rem !important}.py-md-5{padding-top:3rem !important;padding-bottom:3rem !important}.pt-md-0{padding-top:0 !important}.pt-md-1{padding-top:.25rem !important}.pt-md-2{padding-top:.5rem !important}.pt-md-3{padding-top:1rem !important}.pt-md-4{padding-top:1.5rem !important}.pt-md-5{padding-top:3rem !important}.pe-md-0{padding-right:0 !important}.pe-md-1{padding-right:.25rem !important}.pe-md-2{padding-right:.5rem !important}.pe-md-3{padding-right:1rem !important}.pe-md-4{padding-right:1.5rem !important}.pe-md-5{padding-right:3rem !important}.pb-md-0{padding-bottom:0 !important}.pb-md-1{padding-bottom:.25rem !important}.pb-md-2{padding-bottom:.5rem !important}.pb-md-3{padding-bottom:1rem !important}.pb-md-4{padding-bottom:1.5rem !important}.pb-md-5{padding-bottom:3rem !important}.ps-md-0{padding-left:0 !important}.ps-md-1{padding-left:.25rem !important}.ps-md-2{padding-left:.5rem !important}.ps-md-3{padding-left:1rem !important}.ps-md-4{padding-left:1.5rem !important}.ps-md-5{padding-left:3rem !important}.gap-md-0{gap:0 !important}.gap-md-1{gap:.25rem !important}.gap-md-2{gap:.5rem !important}.gap-md-3{gap:1rem !important}.gap-md-4{gap:1.5rem !important}.gap-md-5{gap:3rem !important}.row-gap-md-0{row-gap:0 !important}.row-gap-md-1{row-gap:.25rem !important}.row-gap-md-2{row-gap:.5rem !important}.row-gap-md-3{row-gap:1rem !important}.row-gap-md-4{row-gap:1.5rem !important}.row-gap-md-5{row-gap:3rem !important}.column-gap-md-0{column-gap:0 !important}.column-gap-md-1{column-gap:.25rem !important}.column-gap-md-2{column-gap:.5rem !important}.column-gap-md-3{column-gap:1rem !important}.column-gap-md-4{column-gap:1.5rem !important}.column-gap-md-5{column-gap:3rem !important}.text-md-start{text-align:left !important}.text-md-end{text-align:right !important}.text-md-center{text-align:center !important}}@media (min-width: 992px){.float-lg-start{float:left !important}.float-lg-end{float:right !important}.float-lg-none{float:none !important}.object-fit-lg-contain{object-fit:contain !important}.object-fit-lg-cover{object-fit:cover !important}.object-fit-lg-fill{object-fit:fill !important}.object-fit-lg-scale{object-fit:scale-down !important}.object-fit-lg-none{object-fit:none !important}.d-lg-inline{display:inline !important}.d-lg-inline-block{display:inline-block !important}.d-lg-block{display:block !important}.d-lg-grid{display:grid !important}.d-lg-inline-grid{display:inline-grid !important}.d-lg-table{display:table !important}.d-lg-table-row{display:table-row !important}.d-lg-table-cell{display:table-cell !important}.d-lg-flex{display:flex !important}.d-lg-inline-flex{display:inline-flex !important}.d-lg-none{display:none !important}.flex-lg-fill{flex:1 1 auto !important}.flex-lg-row{flex-direction:row !important}.flex-lg-column{flex-direction:column !important}.flex-lg-row-reverse{flex-direction:row-reverse !important}.flex-lg-column-reverse{flex-direction:column-reverse !important}.flex-lg-grow-0{flex-grow:0 !important}.flex-lg-grow-1{flex-grow:1 !important}.flex-lg-shrink-0{flex-shrink:0 !important}.flex-lg-shrink-1{flex-shrink:1 !important}.flex-lg-wrap{flex-wrap:wrap !important}.flex-lg-nowrap{flex-wrap:nowrap !important}.flex-lg-wrap-reverse{flex-wrap:wrap-reverse !important}.justify-content-lg-start{justify-content:flex-start !important}.justify-content-lg-end{justify-content:flex-end !important}.justify-content-lg-center{justify-content:center !important}.justify-content-lg-between{justify-content:space-between !important}.justify-content-lg-around{justify-content:space-around !important}.justify-content-lg-evenly{justify-content:space-evenly !important}.align-items-lg-start{align-items:flex-start !important}.align-items-lg-end{align-items:flex-end !important}.align-items-lg-center{align-items:center !important}.align-items-lg-baseline{align-items:baseline !important}.align-items-lg-stretch{align-items:stretch !important}.align-content-lg-start{align-content:flex-start !important}.align-content-lg-end{align-content:flex-end !important}.align-content-lg-center{align-content:center !important}.align-content-lg-between{align-content:space-between !important}.align-content-lg-around{align-content:space-around !important}.align-content-lg-stretch{align-content:stretch !important}.align-self-lg-auto{align-self:auto !important}.align-self-lg-start{align-self:flex-start !important}.align-self-lg-end{align-self:flex-end !important}.align-self-lg-center{align-self:center !important}.align-self-lg-baseline{align-self:baseline !important}.align-self-lg-stretch{align-self:stretch !important}.order-lg-first{order:-1 !important}.order-lg-0{order:0 !important}.order-lg-1{order:1 !important}.order-lg-2{order:2 !important}.order-lg-3{order:3 !important}.order-lg-4{order:4 !important}.order-lg-5{order:5 !important}.order-lg-last{order:6 !important}.m-lg-0{margin:0 !important}.m-lg-1{margin:.25rem !important}.m-lg-2{margin:.5rem !important}.m-lg-3{margin:1rem !important}.m-lg-4{margin:1.5rem !important}.m-lg-5{margin:3rem !important}.m-lg-auto{margin:auto !important}.mx-lg-0{margin-right:0 !important;margin-left:0 !important}.mx-lg-1{margin-right:.25rem !important;margin-left:.25rem !important}.mx-lg-2{margin-right:.5rem !important;margin-left:.5rem !important}.mx-lg-3{margin-right:1rem !important;margin-left:1rem !important}.mx-lg-4{margin-right:1.5rem !important;margin-left:1.5rem !important}.mx-lg-5{margin-right:3rem !important;margin-left:3rem !important}.mx-lg-auto{margin-right:auto !important;margin-left:auto !important}.my-lg-0{margin-top:0 !important;margin-bottom:0 !important}.my-lg-1{margin-top:.25rem !important;margin-bottom:.25rem !important}.my-lg-2{margin-top:.5rem !important;margin-bottom:.5rem !important}.my-lg-3{margin-top:1rem !important;margin-bottom:1rem !important}.my-lg-4{margin-top:1.5rem !important;margin-bottom:1.5rem !important}.my-lg-5{margin-top:3rem !important;margin-bottom:3rem !important}.my-lg-auto{margin-top:auto !important;margin-bottom:auto !important}.mt-lg-0{margin-top:0 !important}.mt-lg-1{margin-top:.25rem !important}.mt-lg-2{margin-top:.5rem !important}.mt-lg-3{margin-top:1rem !important}.mt-lg-4{margin-top:1.5rem !important}.mt-lg-5{margin-top:3rem !important}.mt-lg-auto{margin-top:auto !important}.me-lg-0{margin-right:0 !important}.me-lg-1{margin-right:.25rem !important}.me-lg-2{margin-right:.5rem !important}.me-lg-3{margin-right:1rem !important}.me-lg-4{margin-right:1.5rem !important}.me-lg-5{margin-right:3rem !important}.me-lg-auto{margin-right:auto !important}.mb-lg-0{margin-bottom:0 !important}.mb-lg-1{margin-bottom:.25rem !important}.mb-lg-2{margin-bottom:.5rem !important}.mb-lg-3{margin-bottom:1rem !important}.mb-lg-4{margin-bottom:1.5rem !important}.mb-lg-5{margin-bottom:3rem !important}.mb-lg-auto{margin-bottom:auto !important}.ms-lg-0{margin-left:0 !important}.ms-lg-1{margin-left:.25rem !important}.ms-lg-2{margin-left:.5rem !important}.ms-lg-3{margin-left:1rem !important}.ms-lg-4{margin-left:1.5rem !important}.ms-lg-5{margin-left:3rem !important}.ms-lg-auto{margin-left:auto !important}.p-lg-0{padding:0 !important}.p-lg-1{padding:.25rem !important}.p-lg-2{padding:.5rem !important}.p-lg-3{padding:1rem !important}.p-lg-4{padding:1.5rem !important}.p-lg-5{padding:3rem !important}.px-lg-0{padding-right:0 !important;padding-left:0 !important}.px-lg-1{padding-right:.25rem !important;padding-left:.25rem !important}.px-lg-2{padding-right:.5rem !important;padding-left:.5rem !important}.px-lg-3{padding-right:1rem !important;padding-left:1rem !important}.px-lg-4{padding-right:1.5rem !important;padding-left:1.5rem !important}.px-lg-5{padding-right:3rem !important;padding-left:3rem !important}.py-lg-0{padding-top:0 !important;padding-bottom:0 !important}.py-lg-1{padding-top:.25rem !important;padding-bottom:.25rem !important}.py-lg-2{padding-top:.5rem !important;padding-bottom:.5rem !important}.py-lg-3{padding-top:1rem !important;padding-bottom:1rem !important}.py-lg-4{padding-top:1.5rem !important;padding-bottom:1.5rem !important}.py-lg-5{padding-top:3rem !important;padding-bottom:3rem !important}.pt-lg-0{padding-top:0 !important}.pt-lg-1{padding-top:.25rem !important}.pt-lg-2{padding-top:.5rem !important}.pt-lg-3{padding-top:1rem !important}.pt-lg-4{padding-top:1.5rem !important}.pt-lg-5{padding-top:3rem !important}.pe-lg-0{padding-right:0 !important}.pe-lg-1{padding-right:.25rem !important}.pe-lg-2{padding-right:.5rem !important}.pe-lg-3{padding-right:1rem !important}.pe-lg-4{padding-right:1.5rem !important}.pe-lg-5{padding-right:3rem !important}.pb-lg-0{padding-bottom:0 !important}.pb-lg-1{padding-bottom:.25rem !important}.pb-lg-2{padding-bottom:.5rem !important}.pb-lg-3{padding-bottom:1rem !important}.pb-lg-4{padding-bottom:1.5rem !important}.pb-lg-5{padding-bottom:3rem !important}.ps-lg-0{padding-left:0 !important}.ps-lg-1{padding-left:.25rem !important}.ps-lg-2{padding-left:.5rem !important}.ps-lg-3{padding-left:1rem !important}.ps-lg-4{padding-left:1.5rem !important}.ps-lg-5{padding-left:3rem !important}.gap-lg-0{gap:0 !important}.gap-lg-1{gap:.25rem !important}.gap-lg-2{gap:.5rem !important}.gap-lg-3{gap:1rem !important}.gap-lg-4{gap:1.5rem !important}.gap-lg-5{gap:3rem !important}.row-gap-lg-0{row-gap:0 !important}.row-gap-lg-1{row-gap:.25rem !important}.row-gap-lg-2{row-gap:.5rem !important}.row-gap-lg-3{row-gap:1rem !important}.row-gap-lg-4{row-gap:1.5rem !important}.row-gap-lg-5{row-gap:3rem !important}.column-gap-lg-0{column-gap:0 !important}.column-gap-lg-1{column-gap:.25rem !important}.column-gap-lg-2{column-gap:.5rem !important}.column-gap-lg-3{column-gap:1rem !important}.column-gap-lg-4{column-gap:1.5rem !important}.column-gap-lg-5{column-gap:3rem !important}.text-lg-start{text-align:left !important}.text-lg-end{text-align:right !important}.text-lg-center{text-align:center !important}}@media (min-width: 1200px){.float-xl-start{float:left !important}.float-xl-end{float:right !important}.float-xl-none{float:none !important}.object-fit-xl-contain{object-fit:contain !important}.object-fit-xl-cover{object-fit:cover !important}.object-fit-xl-fill{object-fit:fill !important}.object-fit-xl-scale{object-fit:scale-down !important}.object-fit-xl-none{object-fit:none !important}.d-xl-inline{display:inline !important}.d-xl-inline-block{display:inline-block !important}.d-xl-block{display:block !important}.d-xl-grid{display:grid !important}.d-xl-inline-grid{display:inline-grid !important}.d-xl-table{display:table !important}.d-xl-table-row{display:table-row !important}.d-xl-table-cell{display:table-cell !important}.d-xl-flex{display:flex !important}.d-xl-inline-flex{display:inline-flex !important}.d-xl-none{display:none !important}.flex-xl-fill{flex:1 1 auto !important}.flex-xl-row{flex-direction:row !important}.flex-xl-column{flex-direction:column !important}.flex-xl-row-reverse{flex-direction:row-reverse !important}.flex-xl-column-reverse{flex-direction:column-reverse !important}.flex-xl-grow-0{flex-grow:0 !important}.flex-xl-grow-1{flex-grow:1 !important}.flex-xl-shrink-0{flex-shrink:0 !important}.flex-xl-shrink-1{flex-shrink:1 !important}.flex-xl-wrap{flex-wrap:wrap !important}.flex-xl-nowrap{flex-wrap:nowrap !important}.flex-xl-wrap-reverse{flex-wrap:wrap-reverse !important}.justify-content-xl-start{justify-content:flex-start !important}.justify-content-xl-end{justify-content:flex-end !important}.justify-content-xl-center{justify-content:center !important}.justify-content-xl-between{justify-content:space-between !important}.justify-content-xl-around{justify-content:space-around !important}.justify-content-xl-evenly{justify-content:space-evenly !important}.align-items-xl-start{align-items:flex-start !important}.align-items-xl-end{align-items:flex-end !important}.align-items-xl-center{align-items:center !important}.align-items-xl-baseline{align-items:baseline !important}.align-items-xl-stretch{align-items:stretch !important}.align-content-xl-start{align-content:flex-start !important}.align-content-xl-end{align-content:flex-end !important}.align-content-xl-center{align-content:center !important}.align-content-xl-between{align-content:space-between !important}.align-content-xl-around{align-content:space-around !important}.align-content-xl-stretch{align-content:stretch !important}.align-self-xl-auto{align-self:auto !important}.align-self-xl-start{align-self:flex-start !important}.align-self-xl-end{align-self:flex-end !important}.align-self-xl-center{align-self:center !important}.align-self-xl-baseline{align-self:baseline !important}.align-self-xl-stretch{align-self:stretch !important}.order-xl-first{order:-1 !important}.order-xl-0{order:0 !important}.order-xl-1{order:1 !important}.order-xl-2{order:2 !important}.order-xl-3{order:3 !important}.order-xl-4{order:4 !important}.order-xl-5{order:5 !important}.order-xl-last{order:6 !important}.m-xl-0{margin:0 !important}.m-xl-1{margin:.25rem !important}.m-xl-2{margin:.5rem !important}.m-xl-3{margin:1rem !important}.m-xl-4{margin:1.5rem !important}.m-xl-5{margin:3rem !important}.m-xl-auto{margin:auto !important}.mx-xl-0{margin-right:0 !important;margin-left:0 !important}.mx-xl-1{margin-right:.25rem !important;margin-left:.25rem !important}.mx-xl-2{margin-right:.5rem !important;margin-left:.5rem !important}.mx-xl-3{margin-right:1rem !important;margin-left:1rem !important}.mx-xl-4{margin-right:1.5rem !important;margin-left:1.5rem !important}.mx-xl-5{margin-right:3rem !important;margin-left:3rem !important}.mx-xl-auto{margin-right:auto !important;margin-left:auto !important}.my-xl-0{margin-top:0 !important;margin-bottom:0 !important}.my-xl-1{margin-top:.25rem !important;margin-bottom:.25rem !important}.my-xl-2{margin-top:.5rem !important;margin-bottom:.5rem !important}.my-xl-3{margin-top:1rem !important;margin-bottom:1rem !important}.my-xl-4{margin-top:1.5rem !important;margin-bottom:1.5rem !important}.my-xl-5{margin-top:3rem !important;margin-bottom:3rem !important}.my-xl-auto{margin-top:auto !important;margin-bottom:auto !important}.mt-xl-0{margin-top:0 !important}.mt-xl-1{margin-top:.25rem !important}.mt-xl-2{margin-top:.5rem !important}.mt-xl-3{margin-top:1rem !important}.mt-xl-4{margin-top:1.5rem !important}.mt-xl-5{margin-top:3rem !important}.mt-xl-auto{margin-top:auto !important}.me-xl-0{margin-right:0 !important}.me-xl-1{margin-right:.25rem !important}.me-xl-2{margin-right:.5rem !important}.me-xl-3{margin-right:1rem !important}.me-xl-4{margin-right:1.5rem !important}.me-xl-5{margin-right:3rem !important}.me-xl-auto{margin-right:auto !important}.mb-xl-0{margin-bottom:0 !important}.mb-xl-1{margin-bottom:.25rem !important}.mb-xl-2{margin-bottom:.5rem !important}.mb-xl-3{margin-bottom:1rem !important}.mb-xl-4{margin-bottom:1.5rem !important}.mb-xl-5{margin-bottom:3rem !important}.mb-xl-auto{margin-bottom:auto !important}.ms-xl-0{margin-left:0 !important}.ms-xl-1{margin-left:.25rem !important}.ms-xl-2{margin-left:.5rem !important}.ms-xl-3{margin-left:1rem !important}.ms-xl-4{margin-left:1.5rem !important}.ms-xl-5{margin-left:3rem !important}.ms-xl-auto{margin-left:auto !important}.p-xl-0{padding:0 !important}.p-xl-1{padding:.25rem !important}.p-xl-2{padding:.5rem !important}.p-xl-3{padding:1rem !important}.p-xl-4{padding:1.5rem !important}.p-xl-5{padding:3rem !important}.px-xl-0{padding-right:0 !important;padding-left:0 !important}.px-xl-1{padding-right:.25rem !important;padding-left:.25rem !important}.px-xl-2{padding-right:.5rem !important;padding-left:.5rem !important}.px-xl-3{padding-right:1rem !important;padding-left:1rem !important}.px-xl-4{padding-right:1.5rem !important;padding-left:1.5rem !important}.px-xl-5{padding-right:3rem !important;padding-left:3rem !important}.py-xl-0{padding-top:0 !important;padding-bottom:0 !important}.py-xl-1{padding-top:.25rem !important;padding-bottom:.25rem !important}.py-xl-2{padding-top:.5rem !important;padding-bottom:.5rem !important}.py-xl-3{padding-top:1rem !important;padding-bottom:1rem !important}.py-xl-4{padding-top:1.5rem !important;padding-bottom:1.5rem !important}.py-xl-5{padding-top:3rem !important;padding-bottom:3rem !important}.pt-xl-0{padding-top:0 !important}.pt-xl-1{padding-top:.25rem !important}.pt-xl-2{padding-top:.5rem !important}.pt-xl-3{padding-top:1rem !important}.pt-xl-4{padding-top:1.5rem !important}.pt-xl-5{padding-top:3rem !important}.pe-xl-0{padding-right:0 !important}.pe-xl-1{padding-right:.25rem !important}.pe-xl-2{padding-right:.5rem !important}.pe-xl-3{padding-right:1rem !important}.pe-xl-4{padding-right:1.5rem !important}.pe-xl-5{padding-right:3rem !important}.pb-xl-0{padding-bottom:0 !important}.pb-xl-1{padding-bottom:.25rem !important}.pb-xl-2{padding-bottom:.5rem !important}.pb-xl-3{padding-bottom:1rem !important}.pb-xl-4{padding-bottom:1.5rem !important}.pb-xl-5{padding-bottom:3rem !important}.ps-xl-0{padding-left:0 !important}.ps-xl-1{padding-left:.25rem !important}.ps-xl-2{padding-left:.5rem !important}.ps-xl-3{padding-left:1rem !important}.ps-xl-4{padding-left:1.5rem !important}.ps-xl-5{padding-left:3rem !important}.gap-xl-0{gap:0 !important}.gap-xl-1{gap:.25rem !important}.gap-xl-2{gap:.5rem !important}.gap-xl-3{gap:1rem !important}.gap-xl-4{gap:1.5rem !important}.gap-xl-5{gap:3rem !important}.row-gap-xl-0{row-gap:0 !important}.row-gap-xl-1{row-gap:.25rem !important}.row-gap-xl-2{row-gap:.5rem !important}.row-gap-xl-3{row-gap:1rem !important}.row-gap-xl-4{row-gap:1.5rem !important}.row-gap-xl-5{row-gap:3rem !important}.column-gap-xl-0{column-gap:0 !important}.column-gap-xl-1{column-gap:.25rem !important}.column-gap-xl-2{column-gap:.5rem !important}.column-gap-xl-3{column-gap:1rem !important}.column-gap-xl-4{column-gap:1.5rem !important}.column-gap-xl-5{column-gap:3rem !important}.text-xl-start{text-align:left !important}.text-xl-end{text-align:right !important}.text-xl-center{text-align:center !important}}@media (min-width: 1400px){.float-xxl-start{float:left !important}.float-xxl-end{float:right !important}.float-xxl-none{float:none !important}.object-fit-xxl-contain{object-fit:contain !important}.object-fit-xxl-cover{object-fit:cover !important}.object-fit-xxl-fill{object-fit:fill !important}.object-fit-xxl-scale{object-fit:scale-down !important}.object-fit-xxl-none{object-fit:none !important}.d-xxl-inline{display:inline !important}.d-xxl-inline-block{display:inline-block !important}.d-xxl-block{display:block !important}.d-xxl-grid{display:grid !important}.d-xxl-inline-grid{display:inline-grid !important}.d-xxl-table{display:table !important}.d-xxl-table-row{display:table-row !important}.d-xxl-table-cell{display:table-cell !important}.d-xxl-flex{display:flex !important}.d-xxl-inline-flex{display:inline-flex !important}.d-xxl-none{display:none !important}.flex-xxl-fill{flex:1 1 auto !important}.flex-xxl-row{flex-direction:row !important}.flex-xxl-column{flex-direction:column !important}.flex-xxl-row-reverse{flex-direction:row-reverse !important}.flex-xxl-column-reverse{flex-direction:column-reverse !important}.flex-xxl-grow-0{flex-grow:0 !important}.flex-xxl-grow-1{flex-grow:1 !important}.flex-xxl-shrink-0{flex-shrink:0 !important}.flex-xxl-shrink-1{flex-shrink:1 !important}.flex-xxl-wrap{flex-wrap:wrap !important}.flex-xxl-nowrap{flex-wrap:nowrap !important}.flex-xxl-wrap-reverse{flex-wrap:wrap-reverse !important}.justify-content-xxl-start{justify-content:flex-start !important}.justify-content-xxl-end{justify-content:flex-end !important}.justify-content-xxl-center{justify-content:center !important}.justify-content-xxl-between{justify-content:space-between !important}.justify-content-xxl-around{justify-content:space-around !important}.justify-content-xxl-evenly{justify-content:space-evenly !important}.align-items-xxl-start{align-items:flex-start !important}.align-items-xxl-end{align-items:flex-end !important}.align-items-xxl-center{align-items:center !important}.align-items-xxl-baseline{align-items:baseline !important}.align-items-xxl-stretch{align-items:stretch !important}.align-content-xxl-start{align-content:flex-start !important}.align-content-xxl-end{align-content:flex-end !important}.align-content-xxl-center{align-content:center !important}.align-content-xxl-between{align-content:space-between !important}.align-content-xxl-around{align-content:space-around !important}.align-content-xxl-stretch{align-content:stretch !important}.align-self-xxl-auto{align-self:auto !important}.align-self-xxl-start{align-self:flex-start !important}.align-self-xxl-end{align-self:flex-end !important}.align-self-xxl-center{align-self:center !important}.align-self-xxl-baseline{align-self:baseline !important}.align-self-xxl-stretch{align-self:stretch !important}.order-xxl-first{order:-1 !important}.order-xxl-0{order:0 !important}.order-xxl-1{order:1 !important}.order-xxl-2{order:2 !important}.order-xxl-3{order:3 !important}.order-xxl-4{order:4 !important}.order-xxl-5{order:5 !important}.order-xxl-last{order:6 !important}.m-xxl-0{margin:0 !important}.m-xxl-1{margin:.25rem !important}.m-xxl-2{margin:.5rem !important}.m-xxl-3{margin:1rem !important}.m-xxl-4{margin:1.5rem !important}.m-xxl-5{margin:3rem !important}.m-xxl-auto{margin:auto !important}.mx-xxl-0{margin-right:0 !important;margin-left:0 !important}.mx-xxl-1{margin-right:.25rem !important;margin-left:.25rem !important}.mx-xxl-2{margin-right:.5rem !important;margin-left:.5rem !important}.mx-xxl-3{margin-right:1rem !important;margin-left:1rem !important}.mx-xxl-4{margin-right:1.5rem !important;margin-left:1.5rem !important}.mx-xxl-5{margin-right:3rem !important;margin-left:3rem !important}.mx-xxl-auto{margin-right:auto !important;margin-left:auto !important}.my-xxl-0{margin-top:0 !important;margin-bottom:0 !important}.my-xxl-1{margin-top:.25rem !important;margin-bottom:.25rem !important}.my-xxl-2{margin-top:.5rem !important;margin-bottom:.5rem !important}.my-xxl-3{margin-top:1rem !important;margin-bottom:1rem !important}.my-xxl-4{margin-top:1.5rem !important;margin-bottom:1.5rem !important}.my-xxl-5{margin-top:3rem !important;margin-bottom:3rem !important}.my-xxl-auto{margin-top:auto !important;margin-bottom:auto !important}.mt-xxl-0{margin-top:0 !important}.mt-xxl-1{margin-top:.25rem !important}.mt-xxl-2{margin-top:.5rem !important}.mt-xxl-3{margin-top:1rem !important}.mt-xxl-4{margin-top:1.5rem !important}.mt-xxl-5{margin-top:3rem !important}.mt-xxl-auto{margin-top:auto !important}.me-xxl-0{margin-right:0 !important}.me-xxl-1{margin-right:.25rem !important}.me-xxl-2{margin-right:.5rem !important}.me-xxl-3{margin-right:1rem !important}.me-xxl-4{margin-right:1.5rem !important}.me-xxl-5{margin-right:3rem !important}.me-xxl-auto{margin-right:auto !important}.mb-xxl-0{margin-bottom:0 !important}.mb-xxl-1{margin-bottom:.25rem !important}.mb-xxl-2{margin-bottom:.5rem !important}.mb-xxl-3{margin-bottom:1rem !important}.mb-xxl-4{margin-bottom:1.5rem !important}.mb-xxl-5{margin-bottom:3rem !important}.mb-xxl-auto{margin-bottom:auto !important}.ms-xxl-0{margin-left:0 !important}.ms-xxl-1{margin-left:.25rem !important}.ms-xxl-2{margin-left:.5rem !important}.ms-xxl-3{margin-left:1rem !important}.ms-xxl-4{margin-left:1.5rem !important}.ms-xxl-5{margin-left:3rem !important}.ms-xxl-auto{margin-left:auto !important}.p-xxl-0{padding:0 !important}.p-xxl-1{padding:.25rem !important}.p-xxl-2{padding:.5rem !important}.p-xxl-3{padding:1rem !important}.p-xxl-4{padding:1.5rem !important}.p-xxl-5{padding:3rem !important}.px-xxl-0{padding-right:0 !important;padding-left:0 !important}.px-xxl-1{padding-right:.25rem !important;padding-left:.25rem !important}.px-xxl-2{padding-right:.5rem !important;padding-left:.5rem !important}.px-xxl-3{padding-right:1rem !important;padding-left:1rem !important}.px-xxl-4{padding-right:1.5rem !important;padding-left:1.5rem !important}.px-xxl-5{padding-right:3rem !important;padding-left:3rem !important}.py-xxl-0{padding-top:0 !important;padding-bottom:0 !important}.py-xxl-1{padding-top:.25rem !important;padding-bottom:.25rem !important}.py-xxl-2{padding-top:.5rem !important;padding-bottom:.5rem !important}.py-xxl-3{padding-top:1rem !important;padding-bottom:1rem !important}.py-xxl-4{padding-top:1.5rem !important;padding-bottom:1.5rem !important}.py-xxl-5{padding-top:3rem !important;padding-bottom:3rem !important}.pt-xxl-0{padding-top:0 !important}.pt-xxl-1{padding-top:.25rem !important}.pt-xxl-2{padding-top:.5rem !important}.pt-xxl-3{padding-top:1rem !important}.pt-xxl-4{padding-top:1.5rem !important}.pt-xxl-5{padding-top:3rem !important}.pe-xxl-0{padding-right:0 !important}.pe-xxl-1{padding-right:.25rem !important}.pe-xxl-2{padding-right:.5rem !important}.pe-xxl-3{padding-right:1rem !important}.pe-xxl-4{padding-right:1.5rem !important}.pe-xxl-5{padding-right:3rem !important}.pb-xxl-0{padding-bottom:0 !important}.pb-xxl-1{padding-bottom:.25rem !important}.pb-xxl-2{padding-bottom:.5rem !important}.pb-xxl-3{padding-bottom:1rem !important}.pb-xxl-4{padding-bottom:1.5rem !important}.pb-xxl-5{padding-bottom:3rem !important}.ps-xxl-0{padding-left:0 !important}.ps-xxl-1{padding-left:.25rem !important}.ps-xxl-2{padding-left:.5rem !important}.ps-xxl-3{padding-left:1rem !important}.ps-xxl-4{padding-left:1.5rem !important}.ps-xxl-5{padding-left:3rem !important}.gap-xxl-0{gap:0 !important}.gap-xxl-1{gap:.25rem !important}.gap-xxl-2{gap:.5rem !important}.gap-xxl-3{gap:1rem !important}.gap-xxl-4{gap:1.5rem !important}.gap-xxl-5{gap:3rem !important}.row-gap-xxl-0{row-gap:0 !important}.row-gap-xxl-1{row-gap:.25rem !important}.row-gap-xxl-2{row-gap:.5rem !important}.row-gap-xxl-3{row-gap:1rem !important}.row-gap-xxl-4{row-gap:1.5rem !important}.row-gap-xxl-5{row-gap:3rem !important}.column-gap-xxl-0{column-gap:0 !important}.column-gap-xxl-1{column-gap:.25rem !important}.column-gap-xxl-2{column-gap:.5rem !important}.column-gap-xxl-3{column-gap:1rem !important}.column-gap-xxl-4{column-gap:1.5rem !important}.column-gap-xxl-5{column-gap:3rem !important}.text-xxl-start{text-align:left !important}.text-xxl-end{text-align:right !important}.text-xxl-center{text-align:center !important}}.bg-default{color:#000}.bg-primary{color:#fff}.bg-secondary{color:#fff}.bg-success{color:#fff}.bg-info{color:#000}.bg-warning{color:#000}.bg-danger{color:#fff}.bg-light{color:#000}.bg-dark{color:#fff}@media (min-width: 1200px){.fs-1{font-size:2.1rem !important}.fs-2{font-size:2rem !important}.fs-3{font-size:1.75rem !important}.fs-4{font-size:1.5rem !important}}@media print{.d-print-inline{display:inline !important}.d-print-inline-block{display:inline-block !important}.d-print-block{display:block !important}.d-print-grid{display:grid !important}.d-print-inline-grid{display:inline-grid !important}.d-print-table{display:table !important}.d-print-table-row{display:table-row !important}.d-print-table-cell{display:table-cell !important}.d-print-flex{display:flex !important}.d-print-inline-flex{display:inline-flex !important}.d-print-none{display:none !important}}.table th[align=left]{text-align:left}.table th[align=right]{text-align:right}.table th[align=center]{text-align:center}.well{display:block;background-color:RGBA(var(--bs-emphasis-color-rgb, 0, 0, 0), 0.03);color:RGB(var(--bs-emphasis-color-rgb, 0, 0, 0));padding:1rem;border-radius:3px}.well-lg{padding:1.5rem;border-radius:.5rem}.well-sm{padding:0.5rem;border-radius:.25rem}.dropdown-menu>li.active>a{color:#fff;text-decoration:none;background-color:#007bc2}.navbar .nav.nav-underline{--bs-navbar-nav-link-padding-x: 0}.navbar:not(.fixed-bottom):not(.navbar-fixed-bottom):not(.navbar-fixed-bottom)+div>.tab-content>.tab-pane{--bslib-navbar-margin: 20px;margin-top:var(--bslib-navbar-margin)}ul.nav.navbar-nav{flex:1;-webkit-flex:1}ul.nav.navbar-nav.navbar-right{flex:unset;-webkit-flex:unset;display:flex;display:-webkit-flex;justify-content:flex-end;-webkit-justify-content:flex-end}:where(ul.nav.navbar-nav > li).active>a,:where(ul.nav.navbar-nav > li).show>a,.in:where(ul.nav.navbar-nav > li)>a{color:var(--bs-navbar-active-color)}:where(ul.nav.navbar-nav > li).bslib-nav-item{color:var(--bs-navbar-active-color)}.navbar.navbar-default{background-color:var(--bslib-navbar-default-bg, var(--bs-light)) !important}.navbar.navbar-inverse{background-color:var(--bslib-navbar-inverse-bg, var(--bs-dark)) !important;--bs-emphasis-color: white;--bs-emphasis-color-rgb: 255, 255, 255}[data-bs-theme="dark"] .navbar.navbar-default{background-color:var(--bslib-navbar-default-bg, var(--bs-dark)) !important}.navbar-toggle>.icon-bar{display:none}@media (max-width: 991.98px){.navbar-header{width:100%;display:flex;flex-direction:row;align-items:center;justify-content:space-between}.navbar-header .navbar-toggle{order:2}}.nav-tabs>li.active>a{color:var(--bs-emphasis-color);background-color:var(--bs-body-bg);border-color:var(--bs-border-color) var(--bs-border-color) var(--bs-body-bg)}.nav-pills>li.active>a{color:#fff;background-color:#007bc2}.nav-stacked{flex-direction:column;-webkit-flex-direction:column}.progress-bar-default{background-color:#dee2e6;color:#000}.progress-bar-primary{background-color:#007bc2;color:#fff}.progress-bar-secondary{background-color:#404040;color:#fff}.progress-bar-success{background-color:#00891a;color:#fff}.progress-bar-info{background-color:#03c7e8;color:#000}.progress-bar-warning{background-color:#f9b928;color:#000}.progress-bar-danger{background-color:#c10000;color:#fff}.progress-bar-light{background-color:#f8f8f8;color:#000}.progress-bar-dark{background-color:#202020;color:#fff}.datatables thead .form-group.has-feedback+div{background-color:var(--bs-body-bg) !important;color:var(--bs-body-color) !important;border-color:var(--bs-border-color) !important;border-width:var(--bs-border-width);border-radius:var(--bs-border-radius);border-style:var(--bs-border-style)}@font-face{font-family:'Glyphicons Halflings';src:url("fonts/bootstrap/glyphicons-halflings-regular.eot");src:url("fonts/bootstrap/glyphicons-halflings-regular.eot?#iefix") format("embedded-opentype"),url("fonts/bootstrap/glyphicons-halflings-regular.woff2") format("woff2"),url("fonts/bootstrap/glyphicons-halflings-regular.woff") format("woff"),url("fonts/bootstrap/glyphicons-halflings-regular.ttf") format("truetype"),url("fonts/bootstrap/glyphicons-halflings-regular.svg#glyphicons_halflingsregular") format("svg")}.glyphicon{position:relative;top:1px;display:inline-block;font-family:'Glyphicons Halflings';font-style:normal;font-weight:normal;line-height:1;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.glyphicon-asterisk:before{content:"\2a"}.glyphicon-plus:before{content:"\2b"}.glyphicon-euro:before,.glyphicon-eur:before{content:"\20ac"}.glyphicon-minus:before{content:"\2212"}.glyphicon-cloud:before{content:"\2601"}.glyphicon-envelope:before{content:"\2709"}.glyphicon-pencil:before{content:"\270f"}.glyphicon-glass:before{content:"\e001"}.glyphicon-music:before{content:"\e002"}.glyphicon-search:before{content:"\e003"}.glyphicon-heart:before{content:"\e005"}.glyphicon-star:before{content:"\e006"}.glyphicon-star-empty:before{content:"\e007"}.glyphicon-user:before{content:"\e008"}.glyphicon-film:before{content:"\e009"}.glyphicon-th-large:before{content:"\e010"}.glyphicon-th:before{content:"\e011"}.glyphicon-th-list:before{content:"\e012"}.glyphicon-ok:before{content:"\e013"}.glyphicon-remove:before{content:"\e014"}.glyphicon-zoom-in:before{content:"\e015"}.glyphicon-zoom-out:before{content:"\e016"}.glyphicon-off:before{content:"\e017"}.glyphicon-signal:before{content:"\e018"}.glyphicon-cog:before{content:"\e019"}.glyphicon-trash:before{content:"\e020"}.glyphicon-home:before{content:"\e021"}.glyphicon-file:before{content:"\e022"}.glyphicon-time:before{content:"\e023"}.glyphicon-road:before{content:"\e024"}.glyphicon-download-alt:before{content:"\e025"}.glyphicon-download:before{content:"\e026"}.glyphicon-upload:before{content:"\e027"}.glyphicon-inbox:before{content:"\e028"}.glyphicon-play-circle:before{content:"\e029"}.glyphicon-repeat:before{content:"\e030"}.glyphicon-refresh:before{content:"\e031"}.glyphicon-list-alt:before{content:"\e032"}.glyphicon-lock:before{content:"\e033"}.glyphicon-flag:before{content:"\e034"}.glyphicon-headphones:before{content:"\e035"}.glyphicon-volume-off:before{content:"\e036"}.glyphicon-volume-down:before{content:"\e037"}.glyphicon-volume-up:before{content:"\e038"}.glyphicon-qrcode:before{content:"\e039"}.glyphicon-barcode:before{content:"\e040"}.glyphicon-tag:before{content:"\e041"}.glyphicon-tags:before{content:"\e042"}.glyphicon-book:before{content:"\e043"}.glyphicon-bookmark:before{content:"\e044"}.glyphicon-print:before{content:"\e045"}.glyphicon-camera:before{content:"\e046"}.glyphicon-font:before{content:"\e047"}.glyphicon-bold:before{content:"\e048"}.glyphicon-italic:before{content:"\e049"}.glyphicon-text-height:before{content:"\e050"}.glyphicon-text-width:before{content:"\e051"}.glyphicon-align-left:before{content:"\e052"}.glyphicon-align-center:before{content:"\e053"}.glyphicon-align-right:before{content:"\e054"}.glyphicon-align-justify:before{content:"\e055"}.glyphicon-list:before{content:"\e056"}.glyphicon-indent-left:before{content:"\e057"}.glyphicon-indent-right:before{content:"\e058"}.glyphicon-facetime-video:before{content:"\e059"}.glyphicon-picture:before{content:"\e060"}.glyphicon-map-marker:before{content:"\e062"}.glyphicon-adjust:before{content:"\e063"}.glyphicon-tint:before{content:"\e064"}.glyphicon-edit:before{content:"\e065"}.glyphicon-share:before{content:"\e066"}.glyphicon-check:before{content:"\e067"}.glyphicon-move:before{content:"\e068"}.glyphicon-step-backward:before{content:"\e069"}.glyphicon-fast-backward:before{content:"\e070"}.glyphicon-backward:before{content:"\e071"}.glyphicon-play:before{content:"\e072"}.glyphicon-pause:before{content:"\e073"}.glyphicon-stop:before{content:"\e074"}.glyphicon-forward:before{content:"\e075"}.glyphicon-fast-forward:before{content:"\e076"}.glyphicon-step-forward:before{content:"\e077"}.glyphicon-eject:before{content:"\e078"}.glyphicon-chevron-left:before{content:"\e079"}.glyphicon-chevron-right:before{content:"\e080"}.glyphicon-plus-sign:before{content:"\e081"}.glyphicon-minus-sign:before{content:"\e082"}.glyphicon-remove-sign:before{content:"\e083"}.glyphicon-ok-sign:before{content:"\e084"}.glyphicon-question-sign:before{content:"\e085"}.glyphicon-info-sign:before{content:"\e086"}.glyphicon-screenshot:before{content:"\e087"}.glyphicon-remove-circle:before{content:"\e088"}.glyphicon-ok-circle:before{content:"\e089"}.glyphicon-ban-circle:before{content:"\e090"}.glyphicon-arrow-left:before{content:"\e091"}.glyphicon-arrow-right:before{content:"\e092"}.glyphicon-arrow-up:before{content:"\e093"}.glyphicon-arrow-down:before{content:"\e094"}.glyphicon-share-alt:before{content:"\e095"}.glyphicon-resize-full:before{content:"\e096"}.glyphicon-resize-small:before{content:"\e097"}.glyphicon-exclamation-sign:before{content:"\e101"}.glyphicon-gift:before{content:"\e102"}.glyphicon-leaf:before{content:"\e103"}.glyphicon-fire:before{content:"\e104"}.glyphicon-eye-open:before{content:"\e105"}.glyphicon-eye-close:before{content:"\e106"}.glyphicon-warning-sign:before{content:"\e107"}.glyphicon-plane:before{content:"\e108"}.glyphicon-calendar:before{content:"\e109"}.glyphicon-random:before{content:"\e110"}.glyphicon-comment:before{content:"\e111"}.glyphicon-magnet:before{content:"\e112"}.glyphicon-chevron-up:before{content:"\e113"}.glyphicon-chevron-down:before{content:"\e114"}.glyphicon-retweet:before{content:"\e115"}.glyphicon-shopping-cart:before{content:"\e116"}.glyphicon-folder-close:before{content:"\e117"}.glyphicon-folder-open:before{content:"\e118"}.glyphicon-resize-vertical:before{content:"\e119"}.glyphicon-resize-horizontal:before{content:"\e120"}.glyphicon-hdd:before{content:"\e121"}.glyphicon-bullhorn:before{content:"\e122"}.glyphicon-bell:before{content:"\e123"}.glyphicon-certificate:before{content:"\e124"}.glyphicon-thumbs-up:before{content:"\e125"}.glyphicon-thumbs-down:before{content:"\e126"}.glyphicon-hand-right:before{content:"\e127"}.glyphicon-hand-left:before{content:"\e128"}.glyphicon-hand-up:before{content:"\e129"}.glyphicon-hand-down:before{content:"\e130"}.glyphicon-circle-arrow-right:before{content:"\e131"}.glyphicon-circle-arrow-left:before{content:"\e132"}.glyphicon-circle-arrow-up:before{content:"\e133"}.glyphicon-circle-arrow-down:before{content:"\e134"}.glyphicon-globe:before{content:"\e135"}.glyphicon-wrench:before{content:"\e136"}.glyphicon-tasks:before{content:"\e137"}.glyphicon-filter:before{content:"\e138"}.glyphicon-briefcase:before{content:"\e139"}.glyphicon-fullscreen:before{content:"\e140"}.glyphicon-dashboard:before{content:"\e141"}.glyphicon-paperclip:before{content:"\e142"}.glyphicon-heart-empty:before{content:"\e143"}.glyphicon-link:before{content:"\e144"}.glyphicon-phone:before{content:"\e145"}.glyphicon-pushpin:before{content:"\e146"}.glyphicon-usd:before{content:"\e148"}.glyphicon-gbp:before{content:"\e149"}.glyphicon-sort:before{content:"\e150"}.glyphicon-sort-by-alphabet:before{content:"\e151"}.glyphicon-sort-by-alphabet-alt:before{content:"\e152"}.glyphicon-sort-by-order:before{content:"\e153"}.glyphicon-sort-by-order-alt:before{content:"\e154"}.glyphicon-sort-by-attributes:before{content:"\e155"}.glyphicon-sort-by-attributes-alt:before{content:"\e156"}.glyphicon-unchecked:before{content:"\e157"}.glyphicon-expand:before{content:"\e158"}.glyphicon-collapse-down:before{content:"\e159"}.glyphicon-collapse-up:before{content:"\e160"}.glyphicon-log-in:before{content:"\e161"}.glyphicon-flash:before{content:"\e162"}.glyphicon-log-out:before{content:"\e163"}.glyphicon-new-window:before{content:"\e164"}.glyphicon-record:before{content:"\e165"}.glyphicon-save:before{content:"\e166"}.glyphicon-open:before{content:"\e167"}.glyphicon-saved:before{content:"\e168"}.glyphicon-import:before{content:"\e169"}.glyphicon-export:before{content:"\e170"}.glyphicon-send:before{content:"\e171"}.glyphicon-floppy-disk:before{content:"\e172"}.glyphicon-floppy-saved:before{content:"\e173"}.glyphicon-floppy-remove:before{content:"\e174"}.glyphicon-floppy-save:before{content:"\e175"}.glyphicon-floppy-open:before{content:"\e176"}.glyphicon-credit-card:before{content:"\e177"}.glyphicon-transfer:before{content:"\e178"}.glyphicon-cutlery:before{content:"\e179"}.glyphicon-header:before{content:"\e180"}.glyphicon-compressed:before{content:"\e181"}.glyphicon-earphone:before{content:"\e182"}.glyphicon-phone-alt:before{content:"\e183"}.glyphicon-tower:before{content:"\e184"}.glyphicon-stats:before{content:"\e185"}.glyphicon-sd-video:before{content:"\e186"}.glyphicon-hd-video:before{content:"\e187"}.glyphicon-subtitles:before{content:"\e188"}.glyphicon-sound-stereo:before{content:"\e189"}.glyphicon-sound-dolby:before{content:"\e190"}.glyphicon-sound-5-1:before{content:"\e191"}.glyphicon-sound-6-1:before{content:"\e192"}.glyphicon-sound-7-1:before{content:"\e193"}.glyphicon-copyright-mark:before{content:"\e194"}.glyphicon-registration-mark:before{content:"\e195"}.glyphicon-cloud-download:before{content:"\e197"}.glyphicon-cloud-upload:before{content:"\e198"}.glyphicon-tree-conifer:before{content:"\e199"}.glyphicon-tree-deciduous:before{content:"\e200"}.glyphicon-cd:before{content:"\e201"}.glyphicon-save-file:before{content:"\e202"}.glyphicon-open-file:before{content:"\e203"}.glyphicon-level-up:before{content:"\e204"}.glyphicon-copy:before{content:"\e205"}.glyphicon-paste:before{content:"\e206"}.glyphicon-alert:before{content:"\e209"}.glyphicon-equalizer:before{content:"\e210"}.glyphicon-king:before{content:"\e211"}.glyphicon-queen:before{content:"\e212"}.glyphicon-pawn:before{content:"\e213"}.glyphicon-bishop:before{content:"\e214"}.glyphicon-knight:before{content:"\e215"}.glyphicon-baby-formula:before{content:"\e216"}.glyphicon-tent:before{content:"\26fa"}.glyphicon-blackboard:before{content:"\e218"}.glyphicon-bed:before{content:"\e219"}.glyphicon-apple:before{content:"\f8ff"}.glyphicon-erase:before{content:"\e221"}.glyphicon-hourglass:before{content:"\231b"}.glyphicon-lamp:before{content:"\e223"}.glyphicon-duplicate:before{content:"\e224"}.glyphicon-piggy-bank:before{content:"\e225"}.glyphicon-scissors:before{content:"\e226"}.glyphicon-bitcoin:before{content:"\e227"}.glyphicon-btc:before{content:"\e227"}.glyphicon-xbt:before{content:"\e227"}.glyphicon-yen:before{content:"\00a5"}.glyphicon-jpy:before{content:"\00a5"}.glyphicon-ruble:before{content:"\20bd"}.glyphicon-rub:before{content:"\20bd"}.glyphicon-scale:before{content:"\e230"}.glyphicon-ice-lolly:before{content:"\e231"}.glyphicon-ice-lolly-tasted:before{content:"\e232"}.glyphicon-education:before{content:"\e233"}.glyphicon-option-horizontal:before{content:"\e234"}.glyphicon-option-vertical:before{content:"\e235"}.glyphicon-menu-hamburger:before{content:"\e236"}.glyphicon-modal-window:before{content:"\e237"}.glyphicon-oil:before{content:"\e238"}.glyphicon-grain:before{content:"\e239"}.glyphicon-sunglasses:before{content:"\e240"}.glyphicon-text-size:before{content:"\e241"}.glyphicon-text-color:before{content:"\e242"}.glyphicon-text-background:before{content:"\e243"}.glyphicon-object-align-top:before{content:"\e244"}.glyphicon-object-align-bottom:before{content:"\e245"}.glyphicon-object-align-horizontal:before{content:"\e246"}.glyphicon-object-align-left:before{content:"\e247"}.glyphicon-object-align-vertical:before{content:"\e248"}.glyphicon-object-align-right:before{content:"\e249"}.glyphicon-triangle-right:before{content:"\e250"}.glyphicon-triangle-left:before{content:"\e251"}.glyphicon-triangle-bottom:before{content:"\e252"}.glyphicon-triangle-top:before{content:"\e253"}.glyphicon-console:before{content:"\e254"}.glyphicon-superscript:before{content:"\e255"}.glyphicon-subscript:before{content:"\e256"}.glyphicon-menu-left:before{content:"\e257"}.glyphicon-menu-right:before{content:"\e258"}.glyphicon-menu-down:before{content:"\e259"}.glyphicon-menu-up:before{content:"\e260"}.form-group{margin-bottom:1rem}.input-daterange .input-group-addon.input-group-prepend.input-group-append{padding:inherit;line-height:inherit;text-shadow:inherit;border-width:0}.input-daterange .input-group-addon.input-group-prepend.input-group-append .input-group-text{border-radius:0}.shiny-input-checkboxgroup .checkbox-inline,.shiny-input-radiogroup .radio-inline{cursor:pointer}.shiny-input-checkboxgroup label~.shiny-options-group,.shiny-input-radiogroup label~.shiny-options-group{margin-top:calc(-.15em - var(--bs-border-width))}pre.shiny-code{padding:0.5rem}:where(.section.level1, section.level1){margin-top:1.5rem}:where(.section.level2, section.level2){margin-top:1.5rem}:where(.section.level3, section.level3){margin-top:1.5rem}:where(.section.level4, section.level4){margin-top:1rem}:where(.section.level5, section.level5){margin-top:1rem}:where(.section.level6, section.level6){margin-top:1rem}:root{--bslib-spacer: 1rem;--bslib-mb-spacer: var(--bslib-spacer, 1rem)}.bslib-mb-spacing{margin-bottom:var(--bslib-mb-spacer)}.bslib-gap-spacing{gap:var(--bslib-mb-spacer)}.bslib-gap-spacing>.bslib-mb-spacing,.bslib-gap-spacing>.form-group,.bslib-gap-spacing>p,.bslib-gap-spacing>pre{margin-bottom:0}.html-fill-container>.html-fill-item.bslib-mb-spacing{margin-bottom:0}.tab-content>.tab-pane.html-fill-container{display:none}.tab-content>.active.html-fill-container{display:flex}.tab-content.html-fill-container{padding:0}.bg-blue{--bslib-color-bg: #007bc2;--bslib-color-fg: #fff;background-color:var(--bslib-color-bg);color:var(--bslib-color-fg)}.text-blue{--bslib-color-fg: #007bc2;color:var(--bslib-color-fg)}.bg-indigo{--bslib-color-bg: #4b00c1;--bslib-color-fg: #fff;background-color:var(--bslib-color-bg);color:var(--bslib-color-fg)}.text-indigo{--bslib-color-fg: #4b00c1;color:var(--bslib-color-fg)}.bg-purple{--bslib-color-bg: #74149c;--bslib-color-fg: #fff;background-color:var(--bslib-color-bg);color:var(--bslib-color-fg)}.text-purple{--bslib-color-fg: #74149c;color:var(--bslib-color-fg)}.bg-pink{--bslib-color-bg: #bf007f;--bslib-color-fg: #fff;background-color:var(--bslib-color-bg);color:var(--bslib-color-fg)}.text-pink{--bslib-color-fg: #bf007f;color:var(--bslib-color-fg)}.bg-red{--bslib-color-bg: #c10000;--bslib-color-fg: #fff;background-color:var(--bslib-color-bg);color:var(--bslib-color-fg)}.text-red{--bslib-color-fg: #c10000;color:var(--bslib-color-fg)}.bg-orange{--bslib-color-bg: #f45100;--bslib-color-fg: #000;background-color:var(--bslib-color-bg);color:var(--bslib-color-fg)}.text-orange{--bslib-color-fg: #f45100;color:var(--bslib-color-fg)}.bg-yellow{--bslib-color-bg: #f9b928;--bslib-color-fg: #000;background-color:var(--bslib-color-bg);color:var(--bslib-color-fg)}.text-yellow{--bslib-color-fg: #f9b928;color:var(--bslib-color-fg)}.bg-green{--bslib-color-bg: #00891a;--bslib-color-fg: #fff;background-color:var(--bslib-color-bg);color:var(--bslib-color-fg)}.text-green{--bslib-color-fg: #00891a;color:var(--bslib-color-fg)}.bg-teal{--bslib-color-bg: #00bf7f;--bslib-color-fg: #000;background-color:var(--bslib-color-bg);color:var(--bslib-color-fg)}.text-teal{--bslib-color-fg: #00bf7f;color:var(--bslib-color-fg)}.bg-cyan{--bslib-color-bg: #03c7e8;--bslib-color-fg: #000;background-color:var(--bslib-color-bg);color:var(--bslib-color-fg)}.text-cyan{--bslib-color-fg: #03c7e8;color:var(--bslib-color-fg)}.text-default{--bslib-color-fg: #dee2e6}.bg-default{--bslib-color-bg: #dee2e6;--bslib-color-fg: #000}.text-primary{--bslib-color-fg: #007bc2}.bg-primary{--bslib-color-bg: #007bc2;--bslib-color-fg: #fff}.text-secondary{--bslib-color-fg: #404040}.bg-secondary{--bslib-color-bg: #404040;--bslib-color-fg: #fff}.text-success{--bslib-color-fg: #00891a}.bg-success{--bslib-color-bg: #00891a;--bslib-color-fg: #fff}.text-info{--bslib-color-fg: #03c7e8}.bg-info{--bslib-color-bg: #03c7e8;--bslib-color-fg: #000}.text-warning{--bslib-color-fg: #f9b928}.bg-warning{--bslib-color-bg: #f9b928;--bslib-color-fg: #000}.text-danger{--bslib-color-fg: #c10000}.bg-danger{--bslib-color-bg: #c10000;--bslib-color-fg: #fff}.text-light{--bslib-color-fg: #f8f8f8}.bg-light{--bslib-color-bg: #f8f8f8;--bslib-color-fg: #000}.text-dark{--bslib-color-fg: #202020}.bg-dark{--bslib-color-bg: #202020;--bslib-color-fg: #fff}.bg-gradient-blue-indigo{--bslib-color-fg: #fff;--bslib-color-bg: #1e4ac2;background:linear-gradient(var(--bg-gradient-deg, 140deg), #007bc2 var(--bg-gradient-start, 36%), #4b00c1 var(--bg-gradient-end, 180%)) #1e4ac2;color:#fff}.bg-gradient-blue-purple{--bslib-color-fg: #fff;--bslib-color-bg: #2e52b3;background:linear-gradient(var(--bg-gradient-deg, 140deg), #007bc2 var(--bg-gradient-start, 36%), #74149c var(--bg-gradient-end, 180%)) #2e52b3;color:#fff}.bg-gradient-blue-pink{--bslib-color-fg: #fff;--bslib-color-bg: #4c4aa7;background:linear-gradient(var(--bg-gradient-deg, 140deg), #007bc2 var(--bg-gradient-start, 36%), #bf007f var(--bg-gradient-end, 180%)) #4c4aa7;color:#fff}.bg-gradient-blue-red{--bslib-color-fg: #fff;--bslib-color-bg: #4d4a74;background:linear-gradient(var(--bg-gradient-deg, 140deg), #007bc2 var(--bg-gradient-start, 36%), #c10000 var(--bg-gradient-end, 180%)) #4d4a74;color:#fff}.bg-gradient-blue-orange{--bslib-color-fg: #fff;--bslib-color-bg: #626a74;background:linear-gradient(var(--bg-gradient-deg, 140deg), #007bc2 var(--bg-gradient-start, 36%), #f45100 var(--bg-gradient-end, 180%)) #626a74;color:#fff}.bg-gradient-blue-yellow{--bslib-color-fg: #000;--bslib-color-bg: #649484;background:linear-gradient(var(--bg-gradient-deg, 140deg), #007bc2 var(--bg-gradient-start, 36%), #f9b928 var(--bg-gradient-end, 180%)) #649484;color:#000}.bg-gradient-blue-green{--bslib-color-fg: #fff;--bslib-color-bg: #00817f;background:linear-gradient(var(--bg-gradient-deg, 140deg), #007bc2 var(--bg-gradient-start, 36%), #00891a var(--bg-gradient-end, 180%)) #00817f;color:#fff}.bg-gradient-blue-teal{--bslib-color-fg: #000;--bslib-color-bg: #0096a7;background:linear-gradient(var(--bg-gradient-deg, 140deg), #007bc2 var(--bg-gradient-start, 36%), #00bf7f var(--bg-gradient-end, 180%)) #0096a7;color:#000}.bg-gradient-blue-cyan{--bslib-color-fg: #000;--bslib-color-bg: #0199d1;background:linear-gradient(var(--bg-gradient-deg, 140deg), #007bc2 var(--bg-gradient-start, 36%), #03c7e8 var(--bg-gradient-end, 180%)) #0199d1;color:#000}.bg-gradient-indigo-blue{--bslib-color-fg: #fff;--bslib-color-bg: #2d31c1;background:linear-gradient(var(--bg-gradient-deg, 140deg), #4b00c1 var(--bg-gradient-start, 36%), #007bc2 var(--bg-gradient-end, 180%)) #2d31c1;color:#fff}.bg-gradient-indigo-purple{--bslib-color-fg: #fff;--bslib-color-bg: #5b08b2;background:linear-gradient(var(--bg-gradient-deg, 140deg), #4b00c1 var(--bg-gradient-start, 36%), #74149c var(--bg-gradient-end, 180%)) #5b08b2;color:#fff}.bg-gradient-indigo-pink{--bslib-color-fg: #fff;--bslib-color-bg: #7900a7;background:linear-gradient(var(--bg-gradient-deg, 140deg), #4b00c1 var(--bg-gradient-start, 36%), #bf007f var(--bg-gradient-end, 180%)) #7900a7;color:#fff}.bg-gradient-indigo-red{--bslib-color-fg: #fff;--bslib-color-bg: #7a0074;background:linear-gradient(var(--bg-gradient-deg, 140deg), #4b00c1 var(--bg-gradient-start, 36%), #c10000 var(--bg-gradient-end, 180%)) #7a0074;color:#fff}.bg-gradient-indigo-orange{--bslib-color-fg: #fff;--bslib-color-bg: #8f2074;background:linear-gradient(var(--bg-gradient-deg, 140deg), #4b00c1 var(--bg-gradient-start, 36%), #f45100 var(--bg-gradient-end, 180%)) #8f2074;color:#fff}.bg-gradient-indigo-yellow{--bslib-color-fg: #fff;--bslib-color-bg: #914a84;background:linear-gradient(var(--bg-gradient-deg, 140deg), #4b00c1 var(--bg-gradient-start, 36%), #f9b928 var(--bg-gradient-end, 180%)) #914a84;color:#fff}.bg-gradient-indigo-green{--bslib-color-fg: #fff;--bslib-color-bg: #2d377e;background:linear-gradient(var(--bg-gradient-deg, 140deg), #4b00c1 var(--bg-gradient-start, 36%), #00891a var(--bg-gradient-end, 180%)) #2d377e;color:#fff}.bg-gradient-indigo-teal{--bslib-color-fg: #fff;--bslib-color-bg: #2d4ca7;background:linear-gradient(var(--bg-gradient-deg, 140deg), #4b00c1 var(--bg-gradient-start, 36%), #00bf7f var(--bg-gradient-end, 180%)) #2d4ca7;color:#fff}.bg-gradient-indigo-cyan{--bslib-color-fg: #fff;--bslib-color-bg: #2e50d1;background:linear-gradient(var(--bg-gradient-deg, 140deg), #4b00c1 var(--bg-gradient-start, 36%), #03c7e8 var(--bg-gradient-end, 180%)) #2e50d1;color:#fff}.bg-gradient-purple-blue{--bslib-color-fg: #fff;--bslib-color-bg: #463dab;background:linear-gradient(var(--bg-gradient-deg, 140deg), #74149c var(--bg-gradient-start, 36%), #007bc2 var(--bg-gradient-end, 180%)) #463dab;color:#fff}.bg-gradient-purple-indigo{--bslib-color-fg: #fff;--bslib-color-bg: #640cab;background:linear-gradient(var(--bg-gradient-deg, 140deg), #74149c var(--bg-gradient-start, 36%), #4b00c1 var(--bg-gradient-end, 180%)) #640cab;color:#fff}.bg-gradient-purple-pink{--bslib-color-fg: #fff;--bslib-color-bg: #920c90;background:linear-gradient(var(--bg-gradient-deg, 140deg), #74149c var(--bg-gradient-start, 36%), #bf007f var(--bg-gradient-end, 180%)) #920c90;color:#fff}.bg-gradient-purple-red{--bslib-color-fg: #fff;--bslib-color-bg: #930c5e;background:linear-gradient(var(--bg-gradient-deg, 140deg), #74149c var(--bg-gradient-start, 36%), #c10000 var(--bg-gradient-end, 180%)) #930c5e;color:#fff}.bg-gradient-purple-orange{--bslib-color-fg: #fff;--bslib-color-bg: #a72c5e;background:linear-gradient(var(--bg-gradient-deg, 140deg), #74149c var(--bg-gradient-start, 36%), #f45100 var(--bg-gradient-end, 180%)) #a72c5e;color:#fff}.bg-gradient-purple-yellow{--bslib-color-fg: #fff;--bslib-color-bg: #a9566e;background:linear-gradient(var(--bg-gradient-deg, 140deg), #74149c var(--bg-gradient-start, 36%), #f9b928 var(--bg-gradient-end, 180%)) #a9566e;color:#fff}.bg-gradient-purple-green{--bslib-color-fg: #fff;--bslib-color-bg: #464368;background:linear-gradient(var(--bg-gradient-deg, 140deg), #74149c var(--bg-gradient-start, 36%), #00891a var(--bg-gradient-end, 180%)) #464368;color:#fff}.bg-gradient-purple-teal{--bslib-color-fg: #fff;--bslib-color-bg: #465890;background:linear-gradient(var(--bg-gradient-deg, 140deg), #74149c var(--bg-gradient-start, 36%), #00bf7f var(--bg-gradient-end, 180%)) #465890;color:#fff}.bg-gradient-purple-cyan{--bslib-color-fg: #fff;--bslib-color-bg: #475cba;background:linear-gradient(var(--bg-gradient-deg, 140deg), #74149c var(--bg-gradient-start, 36%), #03c7e8 var(--bg-gradient-end, 180%)) #475cba;color:#fff}.bg-gradient-pink-blue{--bslib-color-fg: #fff;--bslib-color-bg: #73319a;background:linear-gradient(var(--bg-gradient-deg, 140deg), #bf007f var(--bg-gradient-start, 36%), #007bc2 var(--bg-gradient-end, 180%)) #73319a;color:#fff}.bg-gradient-pink-indigo{--bslib-color-fg: #fff;--bslib-color-bg: #910099;background:linear-gradient(var(--bg-gradient-deg, 140deg), #bf007f var(--bg-gradient-start, 36%), #4b00c1 var(--bg-gradient-end, 180%)) #910099;color:#fff}.bg-gradient-pink-purple{--bslib-color-fg: #fff;--bslib-color-bg: #a1088b;background:linear-gradient(var(--bg-gradient-deg, 140deg), #bf007f var(--bg-gradient-start, 36%), #74149c var(--bg-gradient-end, 180%)) #a1088b;color:#fff}.bg-gradient-pink-red{--bslib-color-fg: #fff;--bslib-color-bg: #c0004c;background:linear-gradient(var(--bg-gradient-deg, 140deg), #bf007f var(--bg-gradient-start, 36%), #c10000 var(--bg-gradient-end, 180%)) #c0004c;color:#fff}.bg-gradient-pink-orange{--bslib-color-fg: #fff;--bslib-color-bg: #d4204c;background:linear-gradient(var(--bg-gradient-deg, 140deg), #bf007f var(--bg-gradient-start, 36%), #f45100 var(--bg-gradient-end, 180%)) #d4204c;color:#fff}.bg-gradient-pink-yellow{--bslib-color-fg: #000;--bslib-color-bg: #d64a5c;background:linear-gradient(var(--bg-gradient-deg, 140deg), #bf007f var(--bg-gradient-start, 36%), #f9b928 var(--bg-gradient-end, 180%)) #d64a5c;color:#000}.bg-gradient-pink-green{--bslib-color-fg: #fff;--bslib-color-bg: #733757;background:linear-gradient(var(--bg-gradient-deg, 140deg), #bf007f var(--bg-gradient-start, 36%), #00891a var(--bg-gradient-end, 180%)) #733757;color:#fff}.bg-gradient-pink-teal{--bslib-color-fg: #fff;--bslib-color-bg: #734c7f;background:linear-gradient(var(--bg-gradient-deg, 140deg), #bf007f var(--bg-gradient-start, 36%), #00bf7f var(--bg-gradient-end, 180%)) #734c7f;color:#fff}.bg-gradient-pink-cyan{--bslib-color-fg: #fff;--bslib-color-bg: #7450a9;background:linear-gradient(var(--bg-gradient-deg, 140deg), #bf007f var(--bg-gradient-start, 36%), #03c7e8 var(--bg-gradient-end, 180%)) #7450a9;color:#fff}.bg-gradient-red-blue{--bslib-color-fg: #fff;--bslib-color-bg: #74314e;background:linear-gradient(var(--bg-gradient-deg, 140deg), #c10000 var(--bg-gradient-start, 36%), #007bc2 var(--bg-gradient-end, 180%)) #74314e;color:#fff}.bg-gradient-red-indigo{--bslib-color-fg: #fff;--bslib-color-bg: #92004d;background:linear-gradient(var(--bg-gradient-deg, 140deg), #c10000 var(--bg-gradient-start, 36%), #4b00c1 var(--bg-gradient-end, 180%)) #92004d;color:#fff}.bg-gradient-red-purple{--bslib-color-fg: #fff;--bslib-color-bg: #a2083e;background:linear-gradient(var(--bg-gradient-deg, 140deg), #c10000 var(--bg-gradient-start, 36%), #74149c var(--bg-gradient-end, 180%)) #a2083e;color:#fff}.bg-gradient-red-pink{--bslib-color-fg: #fff;--bslib-color-bg: #c00033;background:linear-gradient(var(--bg-gradient-deg, 140deg), #c10000 var(--bg-gradient-start, 36%), #bf007f var(--bg-gradient-end, 180%)) #c00033;color:#fff}.bg-gradient-red-orange{--bslib-color-fg: #fff;--bslib-color-bg: #d52000;background:linear-gradient(var(--bg-gradient-deg, 140deg), #c10000 var(--bg-gradient-start, 36%), #f45100 var(--bg-gradient-end, 180%)) #d52000;color:#fff}.bg-gradient-red-yellow{--bslib-color-fg: #000;--bslib-color-bg: #d74a10;background:linear-gradient(var(--bg-gradient-deg, 140deg), #c10000 var(--bg-gradient-start, 36%), #f9b928 var(--bg-gradient-end, 180%)) #d74a10;color:#000}.bg-gradient-red-green{--bslib-color-fg: #fff;--bslib-color-bg: #74370a;background:linear-gradient(var(--bg-gradient-deg, 140deg), #c10000 var(--bg-gradient-start, 36%), #00891a var(--bg-gradient-end, 180%)) #74370a;color:#fff}.bg-gradient-red-teal{--bslib-color-fg: #fff;--bslib-color-bg: #744c33;background:linear-gradient(var(--bg-gradient-deg, 140deg), #c10000 var(--bg-gradient-start, 36%), #00bf7f var(--bg-gradient-end, 180%)) #744c33;color:#fff}.bg-gradient-red-cyan{--bslib-color-fg: #fff;--bslib-color-bg: #75505d;background:linear-gradient(var(--bg-gradient-deg, 140deg), #c10000 var(--bg-gradient-start, 36%), #03c7e8 var(--bg-gradient-end, 180%)) #75505d;color:#fff}.bg-gradient-orange-blue{--bslib-color-fg: #fff;--bslib-color-bg: #92624e;background:linear-gradient(var(--bg-gradient-deg, 140deg), #f45100 var(--bg-gradient-start, 36%), #007bc2 var(--bg-gradient-end, 180%)) #92624e;color:#fff}.bg-gradient-orange-indigo{--bslib-color-fg: #fff;--bslib-color-bg: #b0314d;background:linear-gradient(var(--bg-gradient-deg, 140deg), #f45100 var(--bg-gradient-start, 36%), #4b00c1 var(--bg-gradient-end, 180%)) #b0314d;color:#fff}.bg-gradient-orange-purple{--bslib-color-fg: #fff;--bslib-color-bg: #c1393e;background:linear-gradient(var(--bg-gradient-deg, 140deg), #f45100 var(--bg-gradient-start, 36%), #74149c var(--bg-gradient-end, 180%)) #c1393e;color:#fff}.bg-gradient-orange-pink{--bslib-color-fg: #fff;--bslib-color-bg: #df3133;background:linear-gradient(var(--bg-gradient-deg, 140deg), #f45100 var(--bg-gradient-start, 36%), #bf007f var(--bg-gradient-end, 180%)) #df3133;color:#fff}.bg-gradient-orange-red{--bslib-color-fg: #fff;--bslib-color-bg: #e03100;background:linear-gradient(var(--bg-gradient-deg, 140deg), #f45100 var(--bg-gradient-start, 36%), #c10000 var(--bg-gradient-end, 180%)) #e03100;color:#fff}.bg-gradient-orange-yellow{--bslib-color-fg: #000;--bslib-color-bg: #f67b10;background:linear-gradient(var(--bg-gradient-deg, 140deg), #f45100 var(--bg-gradient-start, 36%), #f9b928 var(--bg-gradient-end, 180%)) #f67b10;color:#000}.bg-gradient-orange-green{--bslib-color-fg: #fff;--bslib-color-bg: #92670a;background:linear-gradient(var(--bg-gradient-deg, 140deg), #f45100 var(--bg-gradient-start, 36%), #00891a var(--bg-gradient-end, 180%)) #92670a;color:#fff}.bg-gradient-orange-teal{--bslib-color-fg: #000;--bslib-color-bg: #927d33;background:linear-gradient(var(--bg-gradient-deg, 140deg), #f45100 var(--bg-gradient-start, 36%), #00bf7f var(--bg-gradient-end, 180%)) #927d33;color:#000}.bg-gradient-orange-cyan{--bslib-color-fg: #000;--bslib-color-bg: #94805d;background:linear-gradient(var(--bg-gradient-deg, 140deg), #f45100 var(--bg-gradient-start, 36%), #03c7e8 var(--bg-gradient-end, 180%)) #94805d;color:#000}.bg-gradient-yellow-blue{--bslib-color-fg: #000;--bslib-color-bg: #95a066;background:linear-gradient(var(--bg-gradient-deg, 140deg), #f9b928 var(--bg-gradient-start, 36%), #007bc2 var(--bg-gradient-end, 180%)) #95a066;color:#000}.bg-gradient-yellow-indigo{--bslib-color-fg: #000;--bslib-color-bg: #b36f65;background:linear-gradient(var(--bg-gradient-deg, 140deg), #f9b928 var(--bg-gradient-start, 36%), #4b00c1 var(--bg-gradient-end, 180%)) #b36f65;color:#000}.bg-gradient-yellow-purple{--bslib-color-fg: #000;--bslib-color-bg: #c47756;background:linear-gradient(var(--bg-gradient-deg, 140deg), #f9b928 var(--bg-gradient-start, 36%), #74149c var(--bg-gradient-end, 180%)) #c47756;color:#000}.bg-gradient-yellow-pink{--bslib-color-fg: #000;--bslib-color-bg: #e26f4b;background:linear-gradient(var(--bg-gradient-deg, 140deg), #f9b928 var(--bg-gradient-start, 36%), #bf007f var(--bg-gradient-end, 180%)) #e26f4b;color:#000}.bg-gradient-yellow-red{--bslib-color-fg: #000;--bslib-color-bg: #e36f18;background:linear-gradient(var(--bg-gradient-deg, 140deg), #f9b928 var(--bg-gradient-start, 36%), #c10000 var(--bg-gradient-end, 180%)) #e36f18;color:#000}.bg-gradient-yellow-orange{--bslib-color-fg: #000;--bslib-color-bg: #f78f18;background:linear-gradient(var(--bg-gradient-deg, 140deg), #f9b928 var(--bg-gradient-start, 36%), #f45100 var(--bg-gradient-end, 180%)) #f78f18;color:#000}.bg-gradient-yellow-green{--bslib-color-fg: #000;--bslib-color-bg: #95a622;background:linear-gradient(var(--bg-gradient-deg, 140deg), #f9b928 var(--bg-gradient-start, 36%), #00891a var(--bg-gradient-end, 180%)) #95a622;color:#000}.bg-gradient-yellow-teal{--bslib-color-fg: #000;--bslib-color-bg: #95bb4b;background:linear-gradient(var(--bg-gradient-deg, 140deg), #f9b928 var(--bg-gradient-start, 36%), #00bf7f var(--bg-gradient-end, 180%)) #95bb4b;color:#000}.bg-gradient-yellow-cyan{--bslib-color-fg: #000;--bslib-color-bg: #97bf75;background:linear-gradient(var(--bg-gradient-deg, 140deg), #f9b928 var(--bg-gradient-start, 36%), #03c7e8 var(--bg-gradient-end, 180%)) #97bf75;color:#000}.bg-gradient-green-blue{--bslib-color-fg: #fff;--bslib-color-bg: #00835d;background:linear-gradient(var(--bg-gradient-deg, 140deg), #00891a var(--bg-gradient-start, 36%), #007bc2 var(--bg-gradient-end, 180%)) #00835d;color:#fff}.bg-gradient-green-indigo{--bslib-color-fg: #fff;--bslib-color-bg: #1e525d;background:linear-gradient(var(--bg-gradient-deg, 140deg), #00891a var(--bg-gradient-start, 36%), #4b00c1 var(--bg-gradient-end, 180%)) #1e525d;color:#fff}.bg-gradient-green-purple{--bslib-color-fg: #fff;--bslib-color-bg: #2e5a4e;background:linear-gradient(var(--bg-gradient-deg, 140deg), #00891a var(--bg-gradient-start, 36%), #74149c var(--bg-gradient-end, 180%)) #2e5a4e;color:#fff}.bg-gradient-green-pink{--bslib-color-fg: #fff;--bslib-color-bg: #4c5242;background:linear-gradient(var(--bg-gradient-deg, 140deg), #00891a var(--bg-gradient-start, 36%), #bf007f var(--bg-gradient-end, 180%)) #4c5242;color:#fff}.bg-gradient-green-red{--bslib-color-fg: #fff;--bslib-color-bg: #4d5210;background:linear-gradient(var(--bg-gradient-deg, 140deg), #00891a var(--bg-gradient-start, 36%), #c10000 var(--bg-gradient-end, 180%)) #4d5210;color:#fff}.bg-gradient-green-orange{--bslib-color-fg: #fff;--bslib-color-bg: #627310;background:linear-gradient(var(--bg-gradient-deg, 140deg), #00891a var(--bg-gradient-start, 36%), #f45100 var(--bg-gradient-end, 180%)) #627310;color:#fff}.bg-gradient-green-yellow{--bslib-color-fg: #000;--bslib-color-bg: #649c20;background:linear-gradient(var(--bg-gradient-deg, 140deg), #00891a var(--bg-gradient-start, 36%), #f9b928 var(--bg-gradient-end, 180%)) #649c20;color:#000}.bg-gradient-green-teal{--bslib-color-fg: #000;--bslib-color-bg: #009f42;background:linear-gradient(var(--bg-gradient-deg, 140deg), #00891a var(--bg-gradient-start, 36%), #00bf7f var(--bg-gradient-end, 180%)) #009f42;color:#000}.bg-gradient-green-cyan{--bslib-color-fg: #000;--bslib-color-bg: #01a26c;background:linear-gradient(var(--bg-gradient-deg, 140deg), #00891a var(--bg-gradient-start, 36%), #03c7e8 var(--bg-gradient-end, 180%)) #01a26c;color:#000}.bg-gradient-teal-blue{--bslib-color-fg: #000;--bslib-color-bg: #00a49a;background:linear-gradient(var(--bg-gradient-deg, 140deg), #00bf7f var(--bg-gradient-start, 36%), #007bc2 var(--bg-gradient-end, 180%)) #00a49a;color:#000}.bg-gradient-teal-indigo{--bslib-color-fg: #fff;--bslib-color-bg: #1e7399;background:linear-gradient(var(--bg-gradient-deg, 140deg), #00bf7f var(--bg-gradient-start, 36%), #4b00c1 var(--bg-gradient-end, 180%)) #1e7399;color:#fff}.bg-gradient-teal-purple{--bslib-color-fg: #fff;--bslib-color-bg: #2e7b8b;background:linear-gradient(var(--bg-gradient-deg, 140deg), #00bf7f var(--bg-gradient-start, 36%), #74149c var(--bg-gradient-end, 180%)) #2e7b8b;color:#fff}.bg-gradient-teal-pink{--bslib-color-fg: #fff;--bslib-color-bg: #4c737f;background:linear-gradient(var(--bg-gradient-deg, 140deg), #00bf7f var(--bg-gradient-start, 36%), #bf007f var(--bg-gradient-end, 180%)) #4c737f;color:#fff}.bg-gradient-teal-red{--bslib-color-fg: #fff;--bslib-color-bg: #4d734c;background:linear-gradient(var(--bg-gradient-deg, 140deg), #00bf7f var(--bg-gradient-start, 36%), #c10000 var(--bg-gradient-end, 180%)) #4d734c;color:#fff}.bg-gradient-teal-orange{--bslib-color-fg: #000;--bslib-color-bg: #62934c;background:linear-gradient(var(--bg-gradient-deg, 140deg), #00bf7f var(--bg-gradient-start, 36%), #f45100 var(--bg-gradient-end, 180%)) #62934c;color:#000}.bg-gradient-teal-yellow{--bslib-color-fg: #000;--bslib-color-bg: #64bd5c;background:linear-gradient(var(--bg-gradient-deg, 140deg), #00bf7f var(--bg-gradient-start, 36%), #f9b928 var(--bg-gradient-end, 180%)) #64bd5c;color:#000}.bg-gradient-teal-green{--bslib-color-fg: #000;--bslib-color-bg: #00a957;background:linear-gradient(var(--bg-gradient-deg, 140deg), #00bf7f var(--bg-gradient-start, 36%), #00891a var(--bg-gradient-end, 180%)) #00a957;color:#000}.bg-gradient-teal-cyan{--bslib-color-fg: #000;--bslib-color-bg: #01c2a9;background:linear-gradient(var(--bg-gradient-deg, 140deg), #00bf7f var(--bg-gradient-start, 36%), #03c7e8 var(--bg-gradient-end, 180%)) #01c2a9;color:#000}.bg-gradient-cyan-blue{--bslib-color-fg: #000;--bslib-color-bg: #02a9d9;background:linear-gradient(var(--bg-gradient-deg, 140deg), #03c7e8 var(--bg-gradient-start, 36%), #007bc2 var(--bg-gradient-end, 180%)) #02a9d9;color:#000}.bg-gradient-cyan-indigo{--bslib-color-fg: #000;--bslib-color-bg: #2077d8;background:linear-gradient(var(--bg-gradient-deg, 140deg), #03c7e8 var(--bg-gradient-start, 36%), #4b00c1 var(--bg-gradient-end, 180%)) #2077d8;color:#000}.bg-gradient-cyan-purple{--bslib-color-fg: #000;--bslib-color-bg: #307fca;background:linear-gradient(var(--bg-gradient-deg, 140deg), #03c7e8 var(--bg-gradient-start, 36%), #74149c var(--bg-gradient-end, 180%)) #307fca;color:#000}.bg-gradient-cyan-pink{--bslib-color-fg: #000;--bslib-color-bg: #4e77be;background:linear-gradient(var(--bg-gradient-deg, 140deg), #03c7e8 var(--bg-gradient-start, 36%), #bf007f var(--bg-gradient-end, 180%)) #4e77be;color:#000}.bg-gradient-cyan-red{--bslib-color-fg: #fff;--bslib-color-bg: #4f778b;background:linear-gradient(var(--bg-gradient-deg, 140deg), #03c7e8 var(--bg-gradient-start, 36%), #c10000 var(--bg-gradient-end, 180%)) #4f778b;color:#fff}.bg-gradient-cyan-orange{--bslib-color-fg: #000;--bslib-color-bg: #63988b;background:linear-gradient(var(--bg-gradient-deg, 140deg), #03c7e8 var(--bg-gradient-start, 36%), #f45100 var(--bg-gradient-end, 180%)) #63988b;color:#000}.bg-gradient-cyan-yellow{--bslib-color-fg: #000;--bslib-color-bg: #65c19b;background:linear-gradient(var(--bg-gradient-deg, 140deg), #03c7e8 var(--bg-gradient-start, 36%), #f9b928 var(--bg-gradient-end, 180%)) #65c19b;color:#000}.bg-gradient-cyan-green{--bslib-color-fg: #000;--bslib-color-bg: #02ae96;background:linear-gradient(var(--bg-gradient-deg, 140deg), #03c7e8 var(--bg-gradient-start, 36%), #00891a var(--bg-gradient-end, 180%)) #02ae96;color:#000}.bg-gradient-cyan-teal{--bslib-color-fg: #000;--bslib-color-bg: #02c4be;background:linear-gradient(var(--bg-gradient-deg, 140deg), #03c7e8 var(--bg-gradient-start, 36%), #00bf7f var(--bg-gradient-end, 180%)) #02c4be;color:#000}.irs.irs--shiny{margin-top:3px}.irs.irs--shiny .irs-min,.irs.irs--shiny .irs-max,.irs.irs--shiny .irs-from,.irs.irs--shiny .irs-to,.irs.irs--shiny .irs-single{padding:3px 6px;top:-3px}.irs.irs--shiny .irs-handle{top:23px}.irs.irs--shiny .irs-bar{top:31px;height:3px;border:none}.irs.irs--shiny .irs-line{border-radius:8px}.irs.irs--shiny .irs-grid-pol{height:6px}.irs.irs--shiny .irs-grid-text{bottom:8px}.irs.irs--shiny .irs-handle:focus-visible,.irs.irs--shiny .irs-handle:active{color:#005688;background-color:#005688;border-color:#005688;outline:0;box-shadow:0 0 0 .25rem rgba(0,123,194,0.25)}.irs.irs--shiny~.slider-animate-container{text-align:left}.irs.irs--shiny~.slider-animate-container .slider-animate-button{opacity:1}.irs.irs--shiny.irs-with-grid~.slider-animate-container{margin-top:-5px}.irs.irs--shiny:not(.irs-with-grid)~.slider-animate-container{margin-top:5px}.table.dataTable{--dt-row-selected: var(--bs-primary-rgb, "0,123,194");--dt-row-selected-text: var(--bs-white-rgb, "255,255,255");--dt-row-selected-link: var(--bs-light-rgh, "248,248,248")}.table.dataTable.dataTable.table-striped>tbody>tr.odd:not(.selected)>*{box-shadow:none}.table.dataTable.dataTable.table-striped>tbody>tr.even:not(.selected)>*{box-shadow:inset 0 0 0 9999px var(--bs-table-striped-bg)}.table.dataTable.dataTable tbody td.active,.table.dataTable.dataTable tbody tr.active td{background-color:var(--bs-table-active-bg)}.table.dataTable.dataTable.table-hover>tbody>tr:hover:not(.selected)>*{box-shadow:inset 0 0 0 9999px var(--bs-table-hover-bg)}thead,tbody,tfoot,tr,td,th{border:none}.table>thead{border-bottom:1px solid var(--bs-table-color)}th{font-weight:600}.datatables .dataTables_wrapper div.dataTables_info{padding-top:calc(var(--bslib-spacer, 1rem) * 1.65);font-size:.95rem}.datatables .dataTables_paginate{padding-top:var(--bslib-spacer, 1rem)}.datatables .paginate_button a{font-size:.95rem}.datatables .dataTables_length,.datatables .dataTables_filter{padding-bottom:var(--bslib-spacer, 1rem)}.datatables .dataTables_wrapper .dt-row{max-width:100%;overflow:auto}.datatables .dataTables_wrapper .dataTables_length select,.datatables .dataTables_wrapper .dataTables_filter input{border:none;border-bottom:1px solid var(--bs-body-color);border-radius:0}.bslib-card-table-sm.bslib-card[data-full-screen="false"] .datatables .dataTables_wrapper{font-size:85%}.bslib-card-table-sm.bslib-card[data-full-screen="false"] .datatables .dataTables_wrapper .dataTables_length,.bslib-card-table-sm.bslib-card[data-full-screen="false"] .datatables .dataTables_wrapper .dataTables_filter,.bslib-card-table-sm.bslib-card[data-full-screen="false"] .datatables .dataTables_wrapper .dataTables_paginate{display:none}:root{--bslib-box-shadow-color-rgb: 29,31,33}[data-bs-theme="dark"]{--bslib-box-shadow-color-rgb: 0,0,0}.checkbox input,.radio input{margin-right:.35em}.shiny-input-container-inline .shiny-options-group{display:flex;flex-wrap:wrap;flex-direction:row;column-gap:1em}.shiny-input-container-inline .shiny-options-group .checkbox-inline,.shiny-input-container-inline .shiny-options-group .radio-inline{position:relative;padding-left:calc(1.2em + .35em * 2)}.shiny-input-container-inline .shiny-options-group .checkbox-inline input,.shiny-input-container-inline .shiny-options-group .radio-inline input{position:absolute;margin-top:0;left:0;top:calc(.15em + var(--bs-border-width))}.shiny-date-range-input .input-daterange .input-group-addon{margin-right:-1px}.btn-outline-default,.btn-default:not(.btn-primary,.btn-secondary,.btn-info,.btn-success,.btn-danger,.btn-warning,.btn-light,.btn-dark,.btn-link,[class*="btn-outline-"]){--bs-btn-color: #404040;--bs-btn-border-color: #404040;--bs-btn-hover-color: #fff;--bs-btn-hover-bg: #404040;--bs-btn-hover-border-color: #404040;--bs-btn-focus-shadow-rgb: 64,64,64;--bs-btn-active-color: #fff;--bs-btn-active-bg: #404040;--bs-btn-active-border-color: #404040;--bs-btn-active-shadow: inset 0 3px 5px rgba(0,0,0,0.125);--bs-btn-disabled-color: #404040;--bs-btn-disabled-bg: transparent;--bs-btn-disabled-border-color: #404040;--bs-btn-bg: transparent;--bs-gradient: none}[data-bs-theme="dark"] .btn-outline-default,[data-bs-theme="dark"] .btn-default:not(.btn-primary,.btn-secondary,.btn-info,.btn-success,.btn-danger,.btn-warning,.btn-light,.btn-dark,.btn-link,[class*="btn-outline-"]){--bs-btn-color: #dee2e6;--bs-btn-border-color: #dee2e6;--bs-btn-hover-color: #000;--bs-btn-hover-bg: #dee2e6;--bs-btn-hover-border-color: #dee2e6;--bs-btn-focus-shadow-rgb: 222,226,230;--bs-btn-active-color: #000;--bs-btn-active-bg: #dee2e6;--bs-btn-active-border-color: #dee2e6;--bs-btn-active-shadow: inset 0 3px 5px rgba(0,0,0,0.125);--bs-btn-disabled-color: #dee2e6;--bs-btn-disabled-bg: transparent;--bs-btn-disabled-border-color: #dee2e6;--bs-btn-bg: transparent;--bs-gradient: none}.selectize-control.plugin-remove_button .item{align-items:flex-start !important}.selectize-control.plugin-remove_button .item .remove{border-left:none !important}.bslib-card{box-shadow:var(--bslib-card-box-shadow, 0px 1px 2px RGBA(var(--bslib-box-shadow-color-rgb), 0.1),0px 3px 7px RGBA(var(--bslib-box-shadow-color-rgb), 0.1),0px 12px 30px RGBA(var(--bslib-box-shadow-color-rgb), 0.08))}.bslib-card .bslib-card{--bslib-card-box-shadow: }.bslib-card-box-shadow-sm{--bslib-card-box-shadow: var(--bslib-card-box-shadow-sm, 0px 1px 2px RGBA(var(--bslib-box-shadow-color-rgb), 0.1),0px 2px 3px RGBA(var(--bslib-box-shadow-color-rgb), 0.1),0px 3px 8px RGBA(var(--bslib-box-shadow-color-rgb), 0.1))}.bslib-card-box-shadow-md{--bslib-card-box-shadow: var(--bslib-card-box-shadow-md, 0px 1px 2px RGBA(var(--bslib-box-shadow-color-rgb), 0.1),0px 3px 7px RGBA(var(--bslib-box-shadow-color-rgb), 0.1),0px 12px 30px RGBA(var(--bslib-box-shadow-color-rgb), 0.08))}.bslib-card-box-shadow-lg{--bslib-card-box-shadow: var(--bslib-card-box-shadow-lg, 0px 16px 48px RGBA(var(--bslib-box-shadow-color-rgb), 0.1),0px 2px 3px RGBA(var(--bslib-box-shadow-color-rgb), 0.1),0px 16px 46px RGBA(var(--bslib-box-shadow-color-rgb), 0.1))}.bslib-card-box-shadow-none{--bslib-card-box-shadow: none}:root{--bslib-dashboard-sidebar-bg: var(--bs-body-bg);--bslib-dashboard-sidebar-main-bg: var(--bs-body-bg);--bslib-dashboard-main-bg: rgb(247, 247, 247);--bs-card-border-color: var(--bslib-dashboard-border-color-translucent, var(--bs-border-color-translucent));--bslib-sidebar-bg: var(--bs-body-bg);--bslib-sidebar-fg: var(--bs-color)}[data-bs-theme="dark"]{--bslib-dashboard-main-bg: rgb(20, 20, 24)}.bslib-card .card-header,.bslib-card .card-footer{background-color:transparent;font-size:0.9rem}.bslib-card .card-header{font-weight:600;line-height:1.375rem}.bslib-page-dashboard,.main:has(.tab-content>.bslib-page-dashboard.active){background-color:var(--bslib-dashboard-main-bg);--_main-bg: var(--bslib-dashboard-main-bg)}.bslib-page-navbar>.navbar,.bslib-page-dashboard>.navbar{--bslib-navbar-default-bg: var(--bs-body-bg);--bslib-navbar-inverse-bg: var(--bs-body-color)}.bslib-page-navbar>.navbar+div,.bslib-page-dashboard>.navbar+div{border-top:var(--bs-border-width) solid var(--bs-border-color-translucent)}.bslib-page-navbar>.navbar+div>.bslib-sidebar-layout,.bslib-page-navbar>.navbar+div>.tab-content>.tab-pane.active.html-fill-container>.bslib-sidebar-layout.html-fill-item,.bslib-page-dashboard>.navbar+div>.bslib-sidebar-layout,.bslib-page-dashboard>.navbar+div>.tab-content>.tab-pane.active.html-fill-container>.bslib-sidebar-layout.html-fill-item{border-top:none !important}.bslib-page-sidebar{--bslib-page-sidebar-title-bg: var(--bs-body-bg);--bslib-page-sidebar-title-color: var(--bs-body-color)}.bslib-page-sidebar .bslib-page-title{border-color:var(--bs-border-color-translucent)}.nav-underline{--bs-link-color: rgba(var(--bs-body-color-rgb), 0.65);--bs-link-hover-color: rgba(var(--bs-body-color-rgb), 0.8);--bs-nav-link-font-size: 0.875rem}.nav-underline .nav-link,.nav-underline :where(ul.nav.navbar-nav > li)>a,.nav-underline .nav-tabs>li>a,.nav-underline .nav-pills>li>a{padding-left:5px !important;padding-right:5px !important}.nav-underline .nav-link.active,.nav-underline :where(ul.nav.navbar-nav > li)>a.active,.nav-underline .nav-tabs>li>a.active,.nav-underline .nav-pills>li>a.active{font-weight:500}.navbar-collapse.show .nav-underline,.navbar-collapse.in .nav-underline,.navbar-collapse.collapsing .nav-underline{--bs-nav-underline-border-width: 0;--bs-nav-underline-gap: 0}.navbar .nav-underline .nav-link,.navbar .nav-underline :where(ul.nav.navbar-nav > li)>a,.navbar .nav-underline .nav-tabs>li>a,.navbar .nav-underline .nav-pills>li>a{padding-bottom:calc(var(--bs-navbar-padding-y, .5rem) * 2);margin-bottom:calc(var(--bs-navbar-padding-y, .5rem) * -1)}.bslib-value-box.default .value-box-showcase>i.bi{background:linear-gradient(140deg, #007bc2 36%, #74149c 180%) #007bc2;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.bslib-value-box.default .value-box-showcase>i.fa{background:linear-gradient(140deg, #007bc2 36%, #74149c 180%) #007bc2;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.bslib-value-box.default .value-box-showcase>i.fas{background:linear-gradient(140deg, #007bc2 36%, #74149c 180%) #007bc2;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.bslib-value-box.default .value-box-showcase>i.far{background:linear-gradient(140deg, #007bc2 36%, #74149c 180%) #007bc2;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.bslib-value-box.default .value-box-showcase>i.fab{background:linear-gradient(140deg, #007bc2 36%, #74149c 180%) #007bc2;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.bslib-value-box.default .value-box-showcase>i.material-icons{background:linear-gradient(140deg, #007bc2 36%, #74149c 180%) #007bc2;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.bslib-value-box.default .value-box-showcase>svg.bi{fill:url("#bslib---icon-gradient") #007bc2 !important}.bslib-value-box.default .value-box-showcase>svg.fa{fill:url("#bslib---icon-gradient") #007bc2 !important}.bslib-value-box.default .value-box-showcase>svg.fas{fill:url("#bslib---icon-gradient") #007bc2 !important}.bslib-value-box.default .value-box-showcase>svg.far{fill:url("#bslib---icon-gradient") #007bc2 !important}.bslib-value-box.default .value-box-showcase>svg.fab{fill:url("#bslib---icon-gradient") #007bc2 !important}.bslib-value-box.default .value-box-showcase>svg.material-icons{fill:url("#bslib---icon-gradient") #007bc2 !important}.bslib-value-box.text-info{color:#028097 !important}.bslib-value-box.text-info,.bslib-value-box.text-info.text-cyan{--bslib-color-fg: $cyan !important}.bslib-value-box.text-light{--bslib-color-fg: $gray-600 !important}.bslib-value-box.text-warning{color:#A87600 !important}.bslib-value-box.text-warning,.bslib-value-box.text-warning.text-yellow{--bslib-color-fg: $warning !important}.bslib-value-box.text-teal.text-teal{--bslib-color-fg: #008558}.modal-body,.modal-footer{padding:1.5rem}.modal-header .btn-close{align-self:start;display:flex}#shiny-modal-wrapper:has(~.modal-backdrop) .modal{backdrop-filter:blur(2px)}#shiny-notification-panel#shiny-notification-panel{position:fixed;bottom:calc(var(--bslib-spacer, 1rem) / 2);right:calc(var(--bslib-spacer, 1rem) / 2);width:450px;z-index:1090}.progress-message{margin-right:.6rem}.shiny-notification.shiny-notification{position:relative;opacity:0.96;padding:calc(var(--bslib-spacer, 1rem) * 2);margin:var(--bslib-spacer, 1rem);border:1px solid var(--bs-border-color-translucent);border-radius:8px;box-shadow:0px 1px 2px RGBA(var(--bslib-box-shadow-color-rgb), 0.1),0px 3px 7px RGBA(var(--bslib-box-shadow-color-rgb), 0.1),0px 12px 30px RGBA(var(--bslib-box-shadow-color-rgb), 0.08)}.shiny-notification.shiny-notification .shiny-notification-close{position:absolute;font-size:1.5em;width:2rem;height:2rem;top:0;right:0;bottom:unset;display:flex;align-items:center;justify-content:center;padding:0.25rem;cursor:pointer;font-weight:200;color:currentColor}.shiny-notification.shiny-notification .shiny-notification-close:hover{font-weight:normal}.shiny-notification.shiny-notification .shiny-notification-content-text :last-child{margin-bottom:0}
-
-/*# sourceMappingURL=data:application/json;base64,{
	"version": 3,
	"file": "stdin.css",
	"sources": [
		"stdin",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_functions.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/bslib-scss/functions.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/sass-utils/color-contrast.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/builtin/bs5/shiny/_variables.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/bs3compat/_defaults.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_variables.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_variables-dark.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_maps.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_mixins.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/vendor/_rfs.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/mixins/_deprecate.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/mixins/_breakpoints.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/mixins/_color-mode.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/mixins/_color-scheme.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/mixins/_image.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/mixins/_resize.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/mixins/_visually-hidden.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/mixins/_reset-text.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/mixins/_text-truncate.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/mixins/_utilities.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/mixins/_backdrop.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/mixins/_buttons.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/mixins/_caret.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/mixins/_pagination.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/mixins/_lists.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/mixins/_forms.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/mixins/_table-variants.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/mixins/_border-radius.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/mixins/_box-shadow.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/mixins/_gradients.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/mixins/_transition.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/mixins/_clearfix.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/mixins/_container.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/mixins/_grid.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/bs3compat/_declarations.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/builtin/bs5/shiny/_mixins.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/builtin/bs5/shiny/ionrangeslider/_variables.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/mixins/_banner.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_utilities.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_root.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_reboot.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_type.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_images.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_containers.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_grid.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_tables.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_forms.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/forms/_labels.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/forms/_form-text.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/forms/_form-control.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/forms/_form-select.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/forms/_form-check.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/forms/_form-range.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/forms/_floating-labels.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/forms/_input-group.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/forms/_validation.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_buttons.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_transitions.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_dropdown.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_button-group.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_nav.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_navbar.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_card.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_accordion.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_breadcrumb.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_pagination.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_badge.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_alert.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_progress.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_list-group.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_close.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_toasts.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_modal.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_tooltip.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_popover.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_carousel.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_spinners.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_offcanvas.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_placeholders.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_helpers.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/helpers/_clearfix.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/helpers/_color-bg.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/helpers/_colored-links.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/helpers/_focus-ring.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/helpers/_icon-link.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/helpers/_ratio.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/helpers/_position.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/helpers/_stacks.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/helpers/_visually-hidden.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/helpers/_stretched-link.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/helpers/_text-truncation.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/helpers/_vr.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/utilities/_api.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/bs3compat/_rules.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/bs3compat/_wells.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/bs3compat/_help_text.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/bs3compat/_dropdown_compat.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/bs3compat/_navbar_compat.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/bs3compat/_nav_compat.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/bs3compat/_progress_compat.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/bs3compat/_dt_compat.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/bs3compat/_glyphicons.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/bs3compat/_shiny_input.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/bs3compat/_shiny_misc.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/bs3compat/_headers.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/bslib-scss/bslib.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/bslib-scss/spacer.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/bslib-scss/tab-fill.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/bslib-scss/color-utilities.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/builtin/bs5/shiny/_rules.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/builtin/bs5/shiny/ionrangeslider/_rules.scss",
		"../../../../private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/builtin/bs5/shiny/tables/_rules.scss"
	],
	"sourcesContent": [
		"@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_functions.scss\";\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/bslib-scss/functions.scss\";\n$color-contrast-warnings: true !default;\n\n\n\n$bslib-preset-type: builtin;\n$bslib-preset-name: shiny;\n$web-font-path: \"font.css\" !default;\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/builtin/bs5/shiny/_variables.scss\";\n$enable-cssgrid: true !default;\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/bs3compat/_defaults.scss\";\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_variables.scss\";\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_variables-dark.scss\";\n$bootstrap-version: 5;\n$bslib-preset-name: null !default;\n$bslib-preset-type: null !default;\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_maps.scss\";\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_mixins.scss\";\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/bs3compat/_declarations.scss\";\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/builtin/bs5/shiny/_mixins.scss\";\n:root {\n--bslib-bootstrap-version: #{$bootstrap-version};\n--bslib-preset-name: #{$bslib-preset-name};\n--bslib-preset-type: #{$bslib-preset-type};\n}\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/mixins/_banner.scss\";\n@include bsBanner('')\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_utilities.scss\";\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_root.scss\";\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_reboot.scss\";\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_type.scss\";\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_images.scss\";\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_containers.scss\";\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_grid.scss\";\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_tables.scss\";\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_forms.scss\";\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_buttons.scss\";\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_transitions.scss\";\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_dropdown.scss\";\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_button-group.scss\";\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_nav.scss\";\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_navbar.scss\";\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_card.scss\";\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_accordion.scss\";\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_breadcrumb.scss\";\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_pagination.scss\";\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_badge.scss\";\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_alert.scss\";\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_progress.scss\";\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_list-group.scss\";\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_close.scss\";\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_toasts.scss\";\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_modal.scss\";\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_tooltip.scss\";\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_popover.scss\";\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_carousel.scss\";\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_spinners.scss\";\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_offcanvas.scss\";\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_placeholders.scss\";\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/_helpers.scss\";\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/lib/bs5/scss/utilities/_api.scss\";\n.table th[align=left] { text-align: left; }\n.table th[align=right] { text-align: right; }\n.table th[align=center] { text-align: center; }\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/bs3compat/_rules.scss\";\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/bslib-scss/bslib.scss\";\n@import \"/private/var/folders/t8/jxw4bftj35g15fcb6m4mfbc80000gn/T/RtmpJlStDd/temp_libpath7df31a4e4825/bslib/builtin/bs5/shiny/_rules.scss\";",
		"// Bootstrap functions\n//\n// Utility mixins and functions for evaluating source code across our variables, maps, and mixins.\n\n// Ascending\n// Used to evaluate Sass maps like our grid breakpoints.\n@mixin _assert-ascending($map, $map-name) {\n  $prev-key: null;\n  $prev-num: null;\n  @each $key, $num in $map {\n    @if $prev-num == null or unit($num) == \"%\" or unit($prev-num) == \"%\" {\n      // Do nothing\n    } @else if not comparable($prev-num, $num) {\n      @warn \"Potentially invalid value for #{$map-name}: This map must be in ascending order, but key '#{$key}' has value #{$num} whose unit makes it incomparable to #{$prev-num}, the value of the previous key '#{$prev-key}' !\";\n    } @else if $prev-num >= $num {\n      @warn \"Invalid value for #{$map-name}: This map must be in ascending order, but key '#{$key}' has value #{$num} which isn't greater than #{$prev-num}, the value of the previous key '#{$prev-key}' !\";\n    }\n    $prev-key: $key;\n    $prev-num: $num;\n  }\n}\n\n// Starts at zero\n// Used to ensure the min-width of the lowest breakpoint starts at 0.\n@mixin _assert-starts-at-zero($map, $map-name: \"$grid-breakpoints\") {\n  @if length($map) > 0 {\n    $values: map-values($map);\n    $first-value: nth($values, 1);\n    @if $first-value != 0 {\n      @warn \"First breakpoint in #{$map-name} must start at 0, but starts at #{$first-value}.\";\n    }\n  }\n}\n\n// Colors\n@function to-rgb($value) {\n  @return red($value), green($value), blue($value);\n}\n\n// stylelint-disable scss/dollar-variable-pattern\n@function rgba-css-var($identifier, $target) {\n  @if $identifier == \"body\" and $target == \"bg\" {\n    @return rgba(var(--#{$prefix}#{$identifier}-bg-rgb), var(--#{$prefix}#{$target}-opacity));\n  } @if $identifier == \"body\" and $target == \"text\" {\n    @return rgba(var(--#{$prefix}#{$identifier}-color-rgb), var(--#{$prefix}#{$target}-opacity));\n  } @else {\n    @return rgba(var(--#{$prefix}#{$identifier}-rgb), var(--#{$prefix}#{$target}-opacity));\n  }\n}\n\n@function map-loop($map, $func, $args...) {\n  $_map: ();\n\n  @each $key, $value in $map {\n    // allow to pass the $key and $value of the map as an function argument\n    $_args: ();\n    @each $arg in $args {\n      $_args: append($_args, if($arg == \"$key\", $key, if($arg == \"$value\", $value, $arg)));\n    }\n\n    $_map: map-merge($_map, ($key: call(get-function($func), $_args...)));\n  }\n\n  @return $_map;\n}\n// stylelint-enable scss/dollar-variable-pattern\n\n@function varify($list) {\n  $result: null;\n  @each $entry in $list {\n    $result: append($result, var(--#{$prefix}#{$entry}), space);\n  }\n  @return $result;\n}\n\n// Internal Bootstrap function to turn maps into its negative variant.\n// It prefixes the keys with `n` and makes the value negative.\n@function negativify-map($map) {\n  $result: ();\n  @each $key, $value in $map {\n    @if $key != 0 {\n      $result: map-merge($result, (\"n\" + $key: (-$value)));\n    }\n  }\n  @return $result;\n}\n\n// Get multiple keys from a sass map\n@function map-get-multiple($map, $values) {\n  $result: ();\n  @each $key, $value in $map {\n    @if (index($values, $key) != null) {\n      $result: map-merge($result, ($key: $value));\n    }\n  }\n  @return $result;\n}\n\n// Merge multiple maps\n@function map-merge-multiple($maps...) {\n  $merged-maps: ();\n\n  @each $map in $maps {\n    $merged-maps: map-merge($merged-maps, $map);\n  }\n  @return $merged-maps;\n}\n\n// Replace `$search` with `$replace` in `$string`\n// Used on our SVG icon backgrounds for custom forms.\n//\n// @author Kitty Giraudel\n// @param {String} $string - Initial string\n// @param {String} $search - Substring to replace\n// @param {String} $replace ('') - New value\n// @return {String} - Updated string\n@function str-replace($string, $search, $replace: \"\") {\n  $index: str-index($string, $search);\n\n  @if $index {\n    @return str-slice($string, 1, $index - 1) + $replace + str-replace(str-slice($string, $index + str-length($search)), $search, $replace);\n  }\n\n  @return $string;\n}\n\n// See https://codepen.io/kevinweber/pen/dXWoRw\n//\n// Requires the use of quotes around data URIs.\n\n@function escape-svg($string) {\n  @if str-index($string, \"data:image/svg+xml\") {\n    @each $char, $encoded in $escaped-characters {\n      // Do not escape the url brackets\n      @if str-index($string, \"url(\") == 1 {\n        $string: url(\"#{str-replace(str-slice($string, 6, -3), $char, $encoded)}\");\n      } @else {\n        $string: str-replace($string, $char, $encoded);\n      }\n    }\n  }\n\n  @return $string;\n}\n\n// Color contrast\n// See https://github.com/twbs/bootstrap/pull/30168\n\n// A list of pre-calculated numbers of pow(divide((divide($value, 255) + .055), 1.055), 2.4). (from 0 to 255)\n// stylelint-disable-next-line scss/dollar-variable-default, scss/dollar-variable-pattern\n$_luminance-list: .0008 .001 .0011 .0013 .0015 .0017 .002 .0022 .0025 .0027 .003 .0033 .0037 .004 .0044 .0048 .0052 .0056 .006 .0065 .007 .0075 .008 .0086 .0091 .0097 .0103 .011 .0116 .0123 .013 .0137 .0144 .0152 .016 .0168 .0176 .0185 .0194 .0203 .0212 .0222 .0232 .0242 .0252 .0262 .0273 .0284 .0296 .0307 .0319 .0331 .0343 .0356 .0369 .0382 .0395 .0409 .0423 .0437 .0452 .0467 .0482 .0497 .0513 .0529 .0545 .0561 .0578 .0595 .0612 .063 .0648 .0666 .0685 .0704 .0723 .0742 .0762 .0782 .0802 .0823 .0844 .0865 .0887 .0908 .0931 .0953 .0976 .0999 .1022 .1046 .107 .1095 .1119 .1144 .117 .1195 .1221 .1248 .1274 .1301 .1329 .1356 .1384 .1413 .1441 .147 .15 .1529 .1559 .159 .162 .1651 .1683 .1714 .1746 .1779 .1812 .1845 .1878 .1912 .1946 .1981 .2016 .2051 .2086 .2122 .2159 .2195 .2232 .227 .2307 .2346 .2384 .2423 .2462 .2502 .2542 .2582 .2623 .2664 .2705 .2747 .2789 .2831 .2874 .2918 .2961 .3005 .305 .3095 .314 .3185 .3231 .3278 .3325 .3372 .3419 .3467 .3515 .3564 .3613 .3663 .3712 .3763 .3813 .3864 .3916 .3968 .402 .4072 .4125 .4179 .4233 .4287 .4342 .4397 .4452 .4508 .4564 .4621 .4678 .4735 .4793 .4851 .491 .4969 .5029 .5089 .5149 .521 .5271 .5333 .5395 .5457 .552 .5583 .5647 .5711 .5776 .5841 .5906 .5972 .6038 .6105 .6172 .624 .6308 .6376 .6445 .6514 .6584 .6654 .6724 .6795 .6867 .6939 .7011 .7084 .7157 .7231 .7305 .7379 .7454 .7529 .7605 .7682 .7758 .7835 .7913 .7991 .807 .8148 .8228 .8308 .8388 .8469 .855 .8632 .8714 .8796 .8879 .8963 .9047 .9131 .9216 .9301 .9387 .9473 .956 .9647 .9734 .9823 .9911 1;\n\n@function color-contrast($background, $color-contrast-dark: $color-contrast-dark, $color-contrast-light: $color-contrast-light, $min-contrast-ratio: $min-contrast-ratio) {\n  $foregrounds: $color-contrast-light, $color-contrast-dark, $white, $black;\n  $max-ratio: 0;\n  $max-ratio-color: null;\n\n  @each $color in $foregrounds {\n    $contrast-ratio: contrast-ratio($background, $color);\n    @if $contrast-ratio > $min-contrast-ratio {\n      @return $color;\n    } @else if $contrast-ratio > $max-ratio {\n      $max-ratio: $contrast-ratio;\n      $max-ratio-color: $color;\n    }\n  }\n\n  @warn \"Found no color leading to #{$min-contrast-ratio}:1 contrast ratio against #{$background}...\";\n\n  @return $max-ratio-color;\n}\n\n@function contrast-ratio($background, $foreground: $color-contrast-light) {\n  $l1: luminance($background);\n  $l2: luminance(opaque($background, $foreground));\n\n  @return if($l1 > $l2, divide($l1 + .05, $l2 + .05), divide($l2 + .05, $l1 + .05));\n}\n\n// Return WCAG2.1 relative luminance\n// See https://www.w3.org/TR/WCAG/#dfn-relative-luminance\n// See https://www.w3.org/TR/WCAG/#dfn-contrast-ratio\n@function luminance($color) {\n  $rgb: (\n    \"r\": red($color),\n    \"g\": green($color),\n    \"b\": blue($color)\n  );\n\n  @each $name, $value in $rgb {\n    $value: if(divide($value, 255) < .04045, divide(divide($value, 255), 12.92), nth($_luminance-list, $value + 1));\n    $rgb: map-merge($rgb, ($name: $value));\n  }\n\n  @return (map-get($rgb, \"r\") * .2126) + (map-get($rgb, \"g\") * .7152) + (map-get($rgb, \"b\") * .0722);\n}\n\n// Return opaque color\n// opaque(#fff, rgba(0, 0, 0, .5)) => #808080\n@function opaque($background, $foreground) {\n  @return mix(rgba($foreground, 1), $background, opacity($foreground) * 100%);\n}\n\n// scss-docs-start color-functions\n// Tint a color: mix a color with white\n@function tint-color($color, $weight) {\n  @return mix(white, $color, $weight);\n}\n\n// Shade a color: mix a color with black\n@function shade-color($color, $weight) {\n  @return mix(black, $color, $weight);\n}\n\n// Shade the color if the weight is positive, else tint it\n@function shift-color($color, $weight) {\n  @return if($weight > 0, shade-color($color, $weight), tint-color($color, -$weight));\n}\n// scss-docs-end color-functions\n\n// Return valid calc\n@function add($value1, $value2, $return-calc: true) {\n  @if $value1 == null {\n    @return $value2;\n  }\n\n  @if $value2 == null {\n    @return $value1;\n  }\n\n  @if type-of($value1) == number and type-of($value2) == number and comparable($value1, $value2) {\n    @return $value1 + $value2;\n  }\n\n  @return if($return-calc == true, calc(#{$value1} + #{$value2}), $value1 + unquote(\" + \") + $value2);\n}\n\n@function subtract($value1, $value2, $return-calc: true) {\n  @if $value1 == null and $value2 == null {\n    @return null;\n  }\n\n  @if $value1 == null {\n    @return -$value2;\n  }\n\n  @if $value2 == null {\n    @return $value1;\n  }\n\n  @if type-of($value1) == number and type-of($value2) == number and comparable($value1, $value2) {\n    @return $value1 - $value2;\n  }\n\n  @if type-of($value2) != number {\n    $value2: unquote(\"(\") + $value2 + unquote(\")\");\n  }\n\n  @return if($return-calc == true, calc(#{$value1} - #{$value2}), $value1 + unquote(\" - \") + $value2);\n}\n\n@function divide($dividend, $divisor, $precision: 10) {\n  $sign: if($dividend > 0 and $divisor > 0 or $dividend < 0 and $divisor < 0, 1, -1);\n  $dividend: abs($dividend);\n  $divisor: abs($divisor);\n  @if $dividend == 0 {\n    @return 0;\n  }\n  @if $divisor == 0 {\n    @error \"Cannot divide by 0\";\n  }\n  $remainder: $dividend;\n  $result: 0;\n  $factor: 10;\n  @while ($remainder > 0 and $precision >= 0) {\n    $quotient: 0;\n    @while ($remainder >= $divisor) {\n      $remainder: $remainder - $divisor;\n      $quotient: $quotient + 1;\n    }\n    $result: $result * 10 + $quotient;\n    $factor: $factor * .1;\n    $remainder: $remainder * 10;\n    $precision: $precision - 1;\n    @if ($precision < 0 and $remainder >= $divisor * 5) {\n      $result: $result + 1;\n    }\n  }\n  $result: $result * $factor * $sign;\n  $dividend-unit: unit($dividend);\n  $divisor-unit: unit($divisor);\n  $unit-map: (\n    \"px\": 1px,\n    \"rem\": 1rem,\n    \"em\": 1em,\n    \"%\": 1%\n  );\n  @if ($dividend-unit != $divisor-unit and map-has-key($unit-map, $dividend-unit)) {\n    $result: $result * map-get($unit-map, $dividend-unit);\n  }\n  @return $result;\n}\n",
		"// color-contrast() was introduced in Bootstrap 5.\n// We include our own version for a few reasons:\n// 1. Easily turn off warnings options(bslib.color_contrast_warnings=F)\n// 2. Allow Bootstrap 3 & 4 to use color-contrast() in variable definitions\n// 3. Allow Bootstrap 3 & 4 to use bs_get_contrast()\n\n// Also note that color-contrast() lives in sass-utils since projects like Quarto\n// and flexdashboard currently assume it exists there....\n@import \"../sass-utils/color-contrast.scss\";\n\n\n@function is-css-variable($x) {\n  @if (type-of($x) != string) {\n    @return false;\n  } @else {\n    @return str-slice($x, 1, 6) == 'var(--';\n  }\n}\n",
		"/////////////////////////////////////////////////////////////////\n// Color contrasting (backported to BS4 from BS5)\n// See https://github.com/twbs/bootstrap/pull/30168\n/////////////////////////////////////////////////////////////////\n\n// A list of pre-calculated numbers of pow(divide((divide($value, 255) + .055), 1.055), 2.4). (from 0 to 255)\n// stylelint-disable-next-line scss/dollar-variable-default, scss/dollar-variable-pattern\n$_luminance-list: .0008 .001 .0011 .0013 .0015 .0017 .002 .0022 .0025 .0027 .003 .0033 .0037 .004 .0044 .0048 .0052 .0056 .006 .0065 .007 .0075 .008 .0086 .0091 .0097 .0103 .011 .0116 .0123 .013 .0137 .0144 .0152 .016 .0168 .0176 .0185 .0194 .0203 .0212 .0222 .0232 .0242 .0252 .0262 .0273 .0284 .0296 .0307 .0319 .0331 .0343 .0356 .0369 .0382 .0395 .0409 .0423 .0437 .0452 .0467 .0482 .0497 .0513 .0529 .0545 .0561 .0578 .0595 .0612 .063 .0648 .0666 .0685 .0704 .0723 .0742 .0762 .0782 .0802 .0823 .0844 .0865 .0887 .0908 .0931 .0953 .0976 .0999 .1022 .1046 .107 .1095 .1119 .1144 .117 .1195 .1221 .1248 .1274 .1301 .1329 .1356 .1384 .1413 .1441 .147 .15 .1529 .1559 .159 .162 .1651 .1683 .1714 .1746 .1779 .1812 .1845 .1878 .1912 .1946 .1981 .2016 .2051 .2086 .2122 .2159 .2195 .2232 .227 .2307 .2346 .2384 .2423 .2462 .2502 .2542 .2582 .2623 .2664 .2705 .2747 .2789 .2831 .2874 .2918 .2961 .3005 .305 .3095 .314 .3185 .3231 .3278 .3325 .3372 .3419 .3467 .3515 .3564 .3613 .3663 .3712 .3763 .3813 .3864 .3916 .3968 .402 .4072 .4125 .4179 .4233 .4287 .4342 .4397 .4452 .4508 .4564 .4621 .4678 .4735 .4793 .4851 .491 .4969 .5029 .5089 .5149 .521 .5271 .5333 .5395 .5457 .552 .5583 .5647 .5711 .5776 .5841 .5906 .5972 .6038 .6105 .6172 .624 .6308 .6376 .6445 .6514 .6584 .6654 .6724 .6795 .6867 .6939 .7011 .7084 .7157 .7231 .7305 .7379 .7454 .7529 .7605 .7682 .7758 .7835 .7913 .7991 .807 .8148 .8228 .8308 .8388 .8469 .855 .8632 .8714 .8796 .8879 .8963 .9047 .9131 .9216 .9301 .9387 .9473 .956 .9647 .9734 .9823 .9911 1;\n\n@function color-contrast($background, $foregrounds: null) {\n\n  // These variables should be defined in _variables.scss, but we also\n  // define them here so that 3rd party libs can use if they want\n  // without polluting the global namespace\n  $black: #000 !default;\n  $white: #fff !default;\n  $color-contrast-dark: $black !default;\n  $color-contrast-light: $white !default;\n  $min-contrast-ratio: 3 !default;\n\n  @if $foregrounds == null {\n    $foregrounds: $color-contrast-light, $color-contrast-dark, $white, $black;\n  } @else {\n    $foregrounds: $foregrounds, $color-contrast-light, $color-contrast-dark, $white, $black;\n  }\n\n  $max-ratio: 0;\n  $max-ratio-color: null;\n\n  @each $color in $foregrounds {\n    $contrast-ratio: contrast-ratio($background, $color);\n    @if $contrast-ratio > $min-contrast-ratio {\n      @return $color;\n    } @else if $contrast-ratio > $max-ratio {\n      $max-ratio: $contrast-ratio;\n      $max-ratio-color: $color;\n    }\n  }\n\n  $color-contrast-warnings: false !default;\n  @if $color-contrast-warnings {\n    @warn \"Found no color leading to #{$min-contrast-ratio}:1 contrast ratio against #{$background}...\";\n  }\n\n  @return $max-ratio-color;\n}\n\n@function contrast-ratio($background, $foreground: $color-contrast-light) {\n  $l1: luminance($background);\n  $l2: luminance(opaque($background, $foreground));\n\n  @return if($l1 > $l2, divide($l1 + .05, $l2 + .05), divide($l2 + .05, $l1 + .05));\n}\n\n// Return WCAG2.0 relative luminance\n// See https://www.w3.org/WAI/GL/wiki/Relative_luminance\n// See https://www.w3.org/TR/WCAG20-TECHS/G17.html#G17-tests\n@function luminance($color) {\n  $rgb: (\n    \"r\": red($color),\n    \"g\": green($color),\n    \"b\": blue($color)\n  );\n\n  @each $name, $value in $rgb {\n    $value: if(divide($value, 255) < .04045, divide(divide($value, 255), 12.92), nth($_luminance-list, $value + 1));\n    $rgb: map-merge($rgb, ($name: $value));\n  }\n\n  @return (map-get($rgb, \"r\") * .2126) + (map-get($rgb, \"g\") * .7152) + (map-get($rgb, \"b\") * .0722);\n}\n\n// Return opaque color\n// opaque(#fff, rgba(0, 0, 0, .5)) => #808080\n@function opaque($background, $foreground) {\n  @return mix(rgba($foreground, 1), $background, opacity($foreground) * 100%);\n}\n\n// Added in BS5 as an alternative to the \\ operator, which\n// throws warnings in Dart Sass\n// https://github.com/twbs/bootstrap/pull/34245\n@function divide($dividend, $divisor, $precision: 10) {\n  $sign: if($dividend > 0 and $divisor > 0 or $dividend < 0 and $divisor < 0, 1, -1);\n  $dividend: abs($dividend);\n  $divisor: abs($divisor);\n  @if $dividend == 0 {\n    @return 0;\n  }\n  @if $divisor == 0 {\n    @error \"Cannot divide by 0\";\n  }\n  $remainder: $dividend;\n  $result: 0;\n  $factor: 10;\n  @while ($remainder > 0 and $precision >= 0) {\n    $quotient: 0;\n    @while ($remainder >= $divisor) {\n      $remainder: $remainder - $divisor;\n      $quotient: $quotient + 1;\n    }\n    $result: $result * 10 + $quotient;\n    $factor: $factor * .1;\n    $remainder: $remainder * 10;\n    $precision: $precision - 1;\n    @if ($precision < 0 and $remainder >= $divisor * 5) {\n      $result: $result + 1;\n    }\n  }\n  $result: $result * $factor * $sign;\n  $dividend-unit: unit($dividend);\n  $divisor-unit: unit($divisor);\n  $unit-map: (\n    \"px\": 1px,\n    \"rem\": 1rem,\n    \"em\": 1em,\n    \"%\": 1%\n  );\n  @if ($dividend-unit != $divisor-unit and map-has-key($unit-map, $dividend-unit)) {\n    $result: $result * map-get($unit-map, $dividend-unit);\n  }\n  @return $result;\n}\n",
		"$blue: #007bc2 !default;\n$indigo: #4b00c1 !default;\n$purple: #74149c !default;\n$pink: #bf007f !default;\n$red: #c10000 !default;\n$orange: #f45100 !default;\n$yellow: #f9b928 !default;\n$green: #00891a !default;\n$teal: #00bf7f !default;\n$cyan: #03c7e8 !default;\n$white: #ffffff !default;\n\n$gray: #606060 !default;\n$gray-dark: #303030 !default;\n$gray-100: #f8f8f8 !default;\n$gray-200: #e9ecef !default;\n$gray-300: #dee2e6 !default;\n$gray-400: #cdd4da !default;\n$gray-500: #8D959E !default;\n$gray-600: #707782 !default;\n$gray-700: #48505F !default;\n$gray-800: #343A46 !default;\n$gray-900: #1D1F21 !default;\n\n$default: $gray-300 !default;\n$primary: $blue !default;\n$secondary: #404040 !default;\n$success: $green !default;\n$info: $cyan !default;\n$warning: $yellow !default;\n$danger: $red !default;\n$light: $gray-100 !default;\n$dark: #202020 !default;\n\n$default-rgb: 222, 226, 230 !default;\n$primary-rgb: 0, 123, 194 !default;\n$secondary-rgb: 64, 64, 64 !default;\n$success-rgb: 0, 137, 26 !default;\n$info-rgb: 3, 199, 232 !default;\n$warning-rgb: 249, 185, 40 !default;\n$danger-rgb: 193, 0, 0 !default;\n$light-rgb: 248, 248, 248 !default;\n$dark-rgb: 32, 32, 32 !default;\n$white-rgb: 255, 255, 255 !default;\n$black-rgb: 0, 0, 0 !default;\n$body-color-rgb: 52, 58, 70 !default;\n$body-bg-rgb: 255, 255, 255 !default;\n\n$gradient: linear-gradient(\n  180deg,\n  rgba(255, 255, 255, 0.15),\n  rgba(255, 255, 255, 0)\n) !default;\n\n$body-color: $gray-900 !default;\n$body-bg: $white !default;\n\n// Fonts\n$font-family-base: \"Open Sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, \"Helvetica Neue\", Arial, sans-serif !default;\n$font-family-monospace: \"Source Code Pro\", SFMono-Regular, Menlo, Monaco, Consolas, \"Liberation Mono\", \"Courier New\", monospace\t!default;\n\n$root-font-size: 18px !default;\n$body-font-size: 1rem !default;\n$h1-font-size: 2.1rem !default;\n\n$body-font-weight: 400 !default;\n$headings-font-weight: 400 !default;\n\n// Spacing\n$hr-margin-y: 2rem !default;\n$navbar-padding-x: 0.66rem !default;\n\n// Inputs\n$input-btn-font-size: 15px !default;\n\n// Buttons\n$btn-font-weight: 500 !default;\n$btn-padding-y: 0.75em !default;\n$btn-padding-x: 2em !default;\n\n// Form controls\n$form-check-input-width: 1.2em !default;\n$form-check-input-border-radius: 2px !default;\n$form-check-margin-bottom: 0.25rem !default;\n$form-text-color: $gray-600 !default;\n\n// Borders\n$input-border-color: $gray-500 !default;\n$border-radius: 3px !default;\n// Defaults to $gray700, of which we've set to a blueish-gray, which looks a bit weird...\n// We could go forward with the blue-ish gray, but if we do, we'll want to also make\n// $border-color-translucent-dark a bit more blueish\n$border-color-dark: #495057 !default;\n\n// Tables\n$table-striped-bg: rgba($primary, 0.06) !default;\n$table-hover-bg: rgba($primary, 0.1) !default;\n$table-striped-order: even !default;\n\n// Box Shadows\n// => These are shiny-preset-specific, hoping Bootstrap adds something like this\n$bslib-box-shadow-color-rgb: 29, 31, 33 !default;\n$bslib-box-shadow-color-rgb-dark: 0, 0, 0 !default;\n\n$box-shadow-sm:\n  0px 1px 2px RGBA(var(--bslib-box-shadow-color-rgb), .1),\n  0px 2px 3px RGBA(var(--bslib-box-shadow-color-rgb), 0.1),\n  0px 3px 8px RGBA(var(--bslib-box-shadow-color-rgb), 0.1) !default;\n\n$box-shadow:\n  0px 1px 2px RGBA(var(--bslib-box-shadow-color-rgb), .1),\n  0px 3px 7px RGBA(var(--bslib-box-shadow-color-rgb), .1),\n  0px 12px 30px RGBA(var(--bslib-box-shadow-color-rgb), .08) !default;\n\n$box-shadow-lg:\n  0px 16px 48px RGBA(var(--bslib-box-shadow-color-rgb), .1),\n  0px 2px 3px RGBA(var(--bslib-box-shadow-color-rgb), 0.1),\n  0px 16px 46px RGBA(var(--bslib-box-shadow-color-rgb), 0.1) !default;\n\n// Cards\n$card-border-radius: 8px !default;\n\n// bslib Dashboard Styles\n// \"Dashboard\" styles give you:\n// * softer borders\n// * white cards\n// * box shadow on cards\n// * white sidebars\n// * light gray background in the main container(s)\n// * white navbar and title panel\n\n$bslib-dashboard-design: true !default;\n$bslib-enable-shadows: $bslib-dashboard-design !default\n\n$border-color-translucent: if($bslib-dashboard-design, rgba(40, 70, 94, 0.1), null) !default;\n$border-color-translucent-dark: if($bslib-dashboard-design, rgba(255, 255, 255, 0.1), null) !default;\n\n// Modals\n$modal-dialog-margin-y-sm-up: 10% !default;\n$modal-header-border-width: none !default;\n$modal-header-padding: 1.5rem !default;\n$modal-backdrop-bg: #464646 !default;\n\n// Shiny: Base shiny.scss variables\n$notification-close-color: currentColor !default;\n",
		"// BS3 had .navbar { margin-bottom: 20px; }\n$navbar-margin-bottom: 20px !default;\n\n// BS5+ variable used for prefixing CSS vars\n$prefix: bs- !default;",
		"// Variables\n//\n// Variables should follow the `$component-state-property-size` formula for\n// consistent naming. Ex: $nav-link-disabled-color and $modal-content-box-shadow-xs.\n\n// Color system\n\n// scss-docs-start gray-color-variables\n$white:    #fff !default;\n$gray-100: #f8f9fa !default;\n$gray-200: #e9ecef !default;\n$gray-300: #dee2e6 !default;\n$gray-400: #ced4da !default;\n$gray-500: #adb5bd !default;\n$gray-600: #6c757d !default;\n$gray-700: #495057 !default;\n$gray-800: #343a40 !default;\n$gray-900: #212529 !default;\n$black:    #000 !default;\n// scss-docs-end gray-color-variables\n\n// fusv-disable\n// scss-docs-start gray-colors-map\n$grays: (\n  \"100\": $gray-100,\n  \"200\": $gray-200,\n  \"300\": $gray-300,\n  \"400\": $gray-400,\n  \"500\": $gray-500,\n  \"600\": $gray-600,\n  \"700\": $gray-700,\n  \"800\": $gray-800,\n  \"900\": $gray-900\n) !default;\n// scss-docs-end gray-colors-map\n// fusv-enable\n\n// scss-docs-start color-variables\n$blue:    #0d6efd !default;\n$indigo:  #6610f2 !default;\n$purple:  #6f42c1 !default;\n$pink:    #d63384 !default;\n$red:     #dc3545 !default;\n$orange:  #fd7e14 !default;\n$yellow:  #ffc107 !default;\n$green:   #198754 !default;\n$teal:    #20c997 !default;\n$cyan:    #0dcaf0 !default;\n// scss-docs-end color-variables\n\n// scss-docs-start colors-map\n$colors: (\n  \"blue\":       $blue,\n  \"indigo\":     $indigo,\n  \"purple\":     $purple,\n  \"pink\":       $pink,\n  \"red\":        $red,\n  \"orange\":     $orange,\n  \"yellow\":     $yellow,\n  \"green\":      $green,\n  \"teal\":       $teal,\n  \"cyan\":       $cyan,\n  \"black\":      $black,\n  \"white\":      $white,\n  \"gray\":       $gray-600,\n  \"gray-dark\":  $gray-800\n) !default;\n// scss-docs-end colors-map\n\n// The contrast ratio to reach against white, to determine if color changes from \"light\" to \"dark\". Acceptable values for WCAG 2.0 are 3, 4.5 and 7.\n// See https://www.w3.org/TR/WCAG20/#visual-audio-contrast-contrast\n$min-contrast-ratio:   4.5 !default;\n\n// Customize the light and dark text colors for use in our color contrast function.\n$color-contrast-dark:      $black !default;\n$color-contrast-light:     $white !default;\n\n// fusv-disable\n$blue-100: tint-color($blue, 80%) !default;\n$blue-200: tint-color($blue, 60%) !default;\n$blue-300: tint-color($blue, 40%) !default;\n$blue-400: tint-color($blue, 20%) !default;\n$blue-500: $blue !default;\n$blue-600: shade-color($blue, 20%) !default;\n$blue-700: shade-color($blue, 40%) !default;\n$blue-800: shade-color($blue, 60%) !default;\n$blue-900: shade-color($blue, 80%) !default;\n\n$indigo-100: tint-color($indigo, 80%) !default;\n$indigo-200: tint-color($indigo, 60%) !default;\n$indigo-300: tint-color($indigo, 40%) !default;\n$indigo-400: tint-color($indigo, 20%) !default;\n$indigo-500: $indigo !default;\n$indigo-600: shade-color($indigo, 20%) !default;\n$indigo-700: shade-color($indigo, 40%) !default;\n$indigo-800: shade-color($indigo, 60%) !default;\n$indigo-900: shade-color($indigo, 80%) !default;\n\n$purple-100: tint-color($purple, 80%) !default;\n$purple-200: tint-color($purple, 60%) !default;\n$purple-300: tint-color($purple, 40%) !default;\n$purple-400: tint-color($purple, 20%) !default;\n$purple-500: $purple !default;\n$purple-600: shade-color($purple, 20%) !default;\n$purple-700: shade-color($purple, 40%) !default;\n$purple-800: shade-color($purple, 60%) !default;\n$purple-900: shade-color($purple, 80%) !default;\n\n$pink-100: tint-color($pink, 80%) !default;\n$pink-200: tint-color($pink, 60%) !default;\n$pink-300: tint-color($pink, 40%) !default;\n$pink-400: tint-color($pink, 20%) !default;\n$pink-500: $pink !default;\n$pink-600: shade-color($pink, 20%) !default;\n$pink-700: shade-color($pink, 40%) !default;\n$pink-800: shade-color($pink, 60%) !default;\n$pink-900: shade-color($pink, 80%) !default;\n\n$red-100: tint-color($red, 80%) !default;\n$red-200: tint-color($red, 60%) !default;\n$red-300: tint-color($red, 40%) !default;\n$red-400: tint-color($red, 20%) !default;\n$red-500: $red !default;\n$red-600: shade-color($red, 20%) !default;\n$red-700: shade-color($red, 40%) !default;\n$red-800: shade-color($red, 60%) !default;\n$red-900: shade-color($red, 80%) !default;\n\n$orange-100: tint-color($orange, 80%) !default;\n$orange-200: tint-color($orange, 60%) !default;\n$orange-300: tint-color($orange, 40%) !default;\n$orange-400: tint-color($orange, 20%) !default;\n$orange-500: $orange !default;\n$orange-600: shade-color($orange, 20%) !default;\n$orange-700: shade-color($orange, 40%) !default;\n$orange-800: shade-color($orange, 60%) !default;\n$orange-900: shade-color($orange, 80%) !default;\n\n$yellow-100: tint-color($yellow, 80%) !default;\n$yellow-200: tint-color($yellow, 60%) !default;\n$yellow-300: tint-color($yellow, 40%) !default;\n$yellow-400: tint-color($yellow, 20%) !default;\n$yellow-500: $yellow !default;\n$yellow-600: shade-color($yellow, 20%) !default;\n$yellow-700: shade-color($yellow, 40%) !default;\n$yellow-800: shade-color($yellow, 60%) !default;\n$yellow-900: shade-color($yellow, 80%) !default;\n\n$green-100: tint-color($green, 80%) !default;\n$green-200: tint-color($green, 60%) !default;\n$green-300: tint-color($green, 40%) !default;\n$green-400: tint-color($green, 20%) !default;\n$green-500: $green !default;\n$green-600: shade-color($green, 20%) !default;\n$green-700: shade-color($green, 40%) !default;\n$green-800: shade-color($green, 60%) !default;\n$green-900: shade-color($green, 80%) !default;\n\n$teal-100: tint-color($teal, 80%) !default;\n$teal-200: tint-color($teal, 60%) !default;\n$teal-300: tint-color($teal, 40%) !default;\n$teal-400: tint-color($teal, 20%) !default;\n$teal-500: $teal !default;\n$teal-600: shade-color($teal, 20%) !default;\n$teal-700: shade-color($teal, 40%) !default;\n$teal-800: shade-color($teal, 60%) !default;\n$teal-900: shade-color($teal, 80%) !default;\n\n$cyan-100: tint-color($cyan, 80%) !default;\n$cyan-200: tint-color($cyan, 60%) !default;\n$cyan-300: tint-color($cyan, 40%) !default;\n$cyan-400: tint-color($cyan, 20%) !default;\n$cyan-500: $cyan !default;\n$cyan-600: shade-color($cyan, 20%) !default;\n$cyan-700: shade-color($cyan, 40%) !default;\n$cyan-800: shade-color($cyan, 60%) !default;\n$cyan-900: shade-color($cyan, 80%) !default;\n\n$blues: (\n  \"blue-100\": $blue-100,\n  \"blue-200\": $blue-200,\n  \"blue-300\": $blue-300,\n  \"blue-400\": $blue-400,\n  \"blue-500\": $blue-500,\n  \"blue-600\": $blue-600,\n  \"blue-700\": $blue-700,\n  \"blue-800\": $blue-800,\n  \"blue-900\": $blue-900\n) !default;\n\n$indigos: (\n  \"indigo-100\": $indigo-100,\n  \"indigo-200\": $indigo-200,\n  \"indigo-300\": $indigo-300,\n  \"indigo-400\": $indigo-400,\n  \"indigo-500\": $indigo-500,\n  \"indigo-600\": $indigo-600,\n  \"indigo-700\": $indigo-700,\n  \"indigo-800\": $indigo-800,\n  \"indigo-900\": $indigo-900\n) !default;\n\n$purples: (\n  \"purple-100\": $purple-100,\n  \"purple-200\": $purple-200,\n  \"purple-300\": $purple-300,\n  \"purple-400\": $purple-400,\n  \"purple-500\": $purple-500,\n  \"purple-600\": $purple-600,\n  \"purple-700\": $purple-700,\n  \"purple-800\": $purple-800,\n  \"purple-900\": $purple-900\n) !default;\n\n$pinks: (\n  \"pink-100\": $pink-100,\n  \"pink-200\": $pink-200,\n  \"pink-300\": $pink-300,\n  \"pink-400\": $pink-400,\n  \"pink-500\": $pink-500,\n  \"pink-600\": $pink-600,\n  \"pink-700\": $pink-700,\n  \"pink-800\": $pink-800,\n  \"pink-900\": $pink-900\n) !default;\n\n$reds: (\n  \"red-100\": $red-100,\n  \"red-200\": $red-200,\n  \"red-300\": $red-300,\n  \"red-400\": $red-400,\n  \"red-500\": $red-500,\n  \"red-600\": $red-600,\n  \"red-700\": $red-700,\n  \"red-800\": $red-800,\n  \"red-900\": $red-900\n) !default;\n\n$oranges: (\n  \"orange-100\": $orange-100,\n  \"orange-200\": $orange-200,\n  \"orange-300\": $orange-300,\n  \"orange-400\": $orange-400,\n  \"orange-500\": $orange-500,\n  \"orange-600\": $orange-600,\n  \"orange-700\": $orange-700,\n  \"orange-800\": $orange-800,\n  \"orange-900\": $orange-900\n) !default;\n\n$yellows: (\n  \"yellow-100\": $yellow-100,\n  \"yellow-200\": $yellow-200,\n  \"yellow-300\": $yellow-300,\n  \"yellow-400\": $yellow-400,\n  \"yellow-500\": $yellow-500,\n  \"yellow-600\": $yellow-600,\n  \"yellow-700\": $yellow-700,\n  \"yellow-800\": $yellow-800,\n  \"yellow-900\": $yellow-900\n) !default;\n\n$greens: (\n  \"green-100\": $green-100,\n  \"green-200\": $green-200,\n  \"green-300\": $green-300,\n  \"green-400\": $green-400,\n  \"green-500\": $green-500,\n  \"green-600\": $green-600,\n  \"green-700\": $green-700,\n  \"green-800\": $green-800,\n  \"green-900\": $green-900\n) !default;\n\n$teals: (\n  \"teal-100\": $teal-100,\n  \"teal-200\": $teal-200,\n  \"teal-300\": $teal-300,\n  \"teal-400\": $teal-400,\n  \"teal-500\": $teal-500,\n  \"teal-600\": $teal-600,\n  \"teal-700\": $teal-700,\n  \"teal-800\": $teal-800,\n  \"teal-900\": $teal-900\n) !default;\n\n$cyans: (\n  \"cyan-100\": $cyan-100,\n  \"cyan-200\": $cyan-200,\n  \"cyan-300\": $cyan-300,\n  \"cyan-400\": $cyan-400,\n  \"cyan-500\": $cyan-500,\n  \"cyan-600\": $cyan-600,\n  \"cyan-700\": $cyan-700,\n  \"cyan-800\": $cyan-800,\n  \"cyan-900\": $cyan-900\n) !default;\n// fusv-enable\n\n// Semantically, $secondary is closest to BS3's 'default' theme color;\n// so use that if specified. Otherwise, use a light instead of dark gray\n// default color for $default since that's closer to bootstrap 3's default\n$default: if(variable-exists(\"secondary\"), $secondary, $gray-300) !default;\n\n// scss-docs-start theme-color-variables\n$primary:       $blue !default;\n$secondary:     $gray-600 !default;\n$success:       $green !default;\n$info:          $cyan !default;\n$warning:       $yellow !default;\n$danger:        $red !default;\n$light:         $gray-100 !default;\n$dark:          $gray-900 !default;\n// scss-docs-end theme-color-variables\n\n// scss-docs-start theme-colors-map\n$theme-colors: (\n  // default needs to be 1st so that .btn-default comes before .btn-primary\n  // & therefore has lower priority.\n  \"default\":    $default,\n  \"primary\":    $primary,\n  \"secondary\":  $secondary,\n  \"success\":    $success,\n  \"info\":       $info,\n  \"warning\":    $warning,\n  \"danger\":     $danger,\n  \"light\":      $light,\n  \"dark\":       $dark\n) !default;\n// scss-docs-end theme-colors-map\n\n// scss-docs-start theme-text-variables\n$primary-text-emphasis:   shade-color($primary, 60%) !default;\n$secondary-text-emphasis: shade-color($secondary, 60%) !default;\n$success-text-emphasis:   shade-color($success, 60%) !default;\n$info-text-emphasis:      shade-color($info, 60%) !default;\n$warning-text-emphasis:   shade-color($warning, 60%) !default;\n$danger-text-emphasis:    shade-color($danger, 60%) !default;\n$light-text-emphasis:     $gray-700 !default;\n$dark-text-emphasis:      $gray-700 !default;\n// scss-docs-end theme-text-variables\n\n// scss-docs-start theme-bg-subtle-variables\n$primary-bg-subtle:       tint-color($primary, 80%) !default;\n$secondary-bg-subtle:     tint-color($secondary, 80%) !default;\n$success-bg-subtle:       tint-color($success, 80%) !default;\n$info-bg-subtle:          tint-color($info, 80%) !default;\n$warning-bg-subtle:       tint-color($warning, 80%) !default;\n$danger-bg-subtle:        tint-color($danger, 80%) !default;\n$light-bg-subtle:         mix($gray-100, $white) !default;\n$dark-bg-subtle:          $gray-400 !default;\n// scss-docs-end theme-bg-subtle-variables\n\n// scss-docs-start theme-border-subtle-variables\n$primary-border-subtle:   tint-color($primary, 60%) !default;\n$secondary-border-subtle: tint-color($secondary, 60%) !default;\n$success-border-subtle:   tint-color($success, 60%) !default;\n$info-border-subtle:      tint-color($info, 60%) !default;\n$warning-border-subtle:   tint-color($warning, 60%) !default;\n$danger-border-subtle:    tint-color($danger, 60%) !default;\n$light-border-subtle:     $gray-200 !default;\n$dark-border-subtle:      $gray-500 !default;\n// scss-docs-end theme-border-subtle-variables\n\n// Characters which are escaped by the escape-svg function\n$escaped-characters: (\n  (\"<\", \"%3c\"),\n  (\">\", \"%3e\"),\n  (\"#\", \"%23\"),\n  (\"(\", \"%28\"),\n  (\")\", \"%29\"),\n) !default;\n\n// Options\n//\n// Quickly modify global styling by enabling or disabling optional features.\n\n$enable-caret:                true !default;\n$enable-rounded:              true !default;\n$enable-shadows:              false !default;\n$enable-gradients:            false !default;\n$enable-transitions:          true !default;\n$enable-reduced-motion:       true !default;\n$enable-smooth-scroll:        true !default;\n$enable-grid-classes:         true !default;\n$enable-container-classes:    true !default;\n$enable-cssgrid:              false !default;\n$enable-button-pointers:      true !default;\n$enable-rfs:                  true !default;\n$enable-validation-icons:     true !default;\n$enable-negative-margins:     false !default;\n$enable-deprecation-messages: true !default;\n$enable-important-utilities:  true !default;\n\n$enable-dark-mode:            true !default;\n$color-mode-type:             data !default; // `data` or `media-query`\n\n// Prefix for :root CSS variables\n\n$variable-prefix:             bs- !default; // Deprecated in v5.2.0 for the shorter `$prefix`\n$prefix:                      $variable-prefix !default;\n\n// Gradient\n//\n// The gradient which is added to components if `$enable-gradients` is `true`\n// This gradient is also added to elements with `.bg-gradient`\n// scss-docs-start variable-gradient\n$gradient: linear-gradient(180deg, rgba($white, .15), rgba($white, 0)) !default;\n// scss-docs-end variable-gradient\n\n// Spacing\n//\n// Control the default styling of most Bootstrap elements by modifying these\n// variables. Mostly focused on spacing.\n// You can add more entries to the $spacers map, should you need more variation.\n\n// scss-docs-start spacer-variables-maps\n$spacer: 1rem !default;\n$spacers: (\n  0: 0,\n  1: $spacer * .25,\n  2: $spacer * .5,\n  3: $spacer,\n  4: $spacer * 1.5,\n  5: $spacer * 3,\n) !default;\n// scss-docs-end spacer-variables-maps\n\n// Position\n//\n// Define the edge positioning anchors of the position utilities.\n\n// scss-docs-start position-map\n$position-values: (\n  0: 0,\n  50: 50%,\n  100: 100%\n) !default;\n// scss-docs-end position-map\n\n// Body\n//\n// Settings for the `<body>` element.\n\n$body-text-align:           null !default;\n$body-color:                $gray-900 !default;\n$body-bg:                   $white !default;\n\n$body-secondary-color:      rgba($body-color, .75) !default;\n$body-secondary-bg:         $gray-200 !default;\n\n$body-tertiary-color:       rgba($body-color, .5) !default;\n$body-tertiary-bg:          $gray-100 !default;\n\n$body-emphasis-color:       $black !default;\n\n// Links\n//\n// Style anchor elements.\n\n$link-color:                              $primary !default;\n$link-decoration:                         underline !default;\n$link-shade-percentage:                   20% !default;\n$link-hover-color:                        shift-color($link-color, $link-shade-percentage) !default;\n$link-hover-decoration:                   null !default;\n\n$stretched-link-pseudo-element:           after !default;\n$stretched-link-z-index:                  1 !default;\n\n// Icon links\n// scss-docs-start icon-link-variables\n$icon-link-gap:               .375rem !default;\n$icon-link-underline-offset:  .25em !default;\n$icon-link-icon-size:         1em !default;\n$icon-link-icon-transition:   .2s ease-in-out transform !default;\n$icon-link-icon-transform:    translate3d(.25em, 0, 0) !default;\n// scss-docs-end icon-link-variables\n\n// Paragraphs\n//\n// Style p element.\n\n$paragraph-margin-bottom:   1rem !default;\n\n\n// Grid breakpoints\n//\n// Define the minimum dimensions at which your layout will change,\n// adapting to different screen sizes, for use in media queries.\n\n// scss-docs-start grid-breakpoints\n$grid-breakpoints: (\n  xs: 0,\n  sm: 576px,\n  md: 768px,\n  lg: 992px,\n  xl: 1200px,\n  xxl: 1400px\n) !default;\n// scss-docs-end grid-breakpoints\n\n@include _assert-ascending($grid-breakpoints, \"$grid-breakpoints\");\n@include _assert-starts-at-zero($grid-breakpoints, \"$grid-breakpoints\");\n\n\n// Grid containers\n//\n// Define the maximum width of `.container` for different screen sizes.\n\n// scss-docs-start container-max-widths\n$container-max-widths: (\n  sm: 540px,\n  md: 720px,\n  lg: 960px,\n  xl: 1140px,\n  xxl: 1320px\n) !default;\n// scss-docs-end container-max-widths\n\n@include _assert-ascending($container-max-widths, \"$container-max-widths\");\n\n\n// Grid columns\n//\n// Set the number of columns and specify the width of the gutters.\n\n$grid-columns:                12 !default;\n$grid-gutter-width:           1.5rem !default;\n$grid-row-columns:            6 !default;\n\n// Container padding\n\n$container-padding-x: $grid-gutter-width !default;\n\n\n// Components\n//\n// Define common padding and border radius sizes and more.\n\n// scss-docs-start border-variables\n$border-width:                1px !default;\n$border-widths: (\n  1: 1px,\n  2: 2px,\n  3: 3px,\n  4: 4px,\n  5: 5px\n) !default;\n$border-style:                solid !default;\n$border-color:                $gray-300 !default;\n$border-color-translucent:    rgba($black, .175) !default;\n// scss-docs-end border-variables\n\n// scss-docs-start border-radius-variables\n$border-radius:               .375rem !default;\n$border-radius-sm:            .25rem !default;\n$border-radius-lg:            .5rem !default;\n$border-radius-xl:            1rem !default;\n$border-radius-xxl:           2rem !default;\n$border-radius-pill:          50rem !default;\n// scss-docs-end border-radius-variables\n// fusv-disable\n$border-radius-2xl:           $border-radius-xxl !default; // Deprecated in v5.3.0\n// fusv-enable\n\n// scss-docs-start box-shadow-variables\n$box-shadow:                  0 .5rem 1rem rgba($black, .15) !default;\n$box-shadow-sm:               0 .125rem .25rem rgba($black, .075) !default;\n$box-shadow-lg:               0 1rem 3rem rgba($black, .175) !default;\n$box-shadow-inset:            inset 0 1px 2px rgba($black, .075) !default;\n// scss-docs-end box-shadow-variables\n\n$component-active-bg:         $primary !default;\n$component-active-color:      color-contrast($component-active-bg) !default;\n\n// scss-docs-start focus-ring-variables\n$focus-ring-width:      .25rem !default;\n$focus-ring-opacity:    .25 !default;\n$focus-ring-color:      rgba($primary, $focus-ring-opacity) !default;\n$focus-ring-blur:       0 !default;\n$focus-ring-box-shadow: 0 0 $focus-ring-blur $focus-ring-width $focus-ring-color !default;\n// scss-docs-end focus-ring-variables\n\n// scss-docs-start caret-variables\n$caret-width:                 .3em !default;\n$caret-vertical-align:        $caret-width * .85 !default;\n$caret-spacing:               $caret-width * .85 !default;\n// scss-docs-end caret-variables\n\n$transition-base:             all .2s ease-in-out !default;\n$transition-fade:             opacity .15s linear !default;\n// scss-docs-start collapse-transition\n$transition-collapse:         height .35s ease !default;\n$transition-collapse-width:   width .35s ease !default;\n// scss-docs-end collapse-transition\n\n// stylelint-disable function-disallowed-list\n// scss-docs-start aspect-ratios\n$aspect-ratios: (\n  \"1x1\": 100%,\n  \"4x3\": calc(3 / 4 * 100%),\n  \"16x9\": calc(9 / 16 * 100%),\n  \"21x9\": calc(9 / 21 * 100%)\n) !default;\n// scss-docs-end aspect-ratios\n// stylelint-enable function-disallowed-list\n\n// Typography\n//\n// Font, line-height, and color for body text, headings, and more.\n\n// scss-docs-start font-variables\n// stylelint-disable value-keyword-case\n$font-family-sans-serif:      system-ui, -apple-system, \"Segoe UI\", Roboto, \"Helvetica Neue\", \"Noto Sans\", \"Liberation Sans\", Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\", \"Noto Color Emoji\" !default;\n$font-family-monospace:       SFMono-Regular, Menlo, Monaco, Consolas, \"Liberation Mono\", \"Courier New\", monospace !default;\n// stylelint-enable value-keyword-case\n$font-family-base:            var(--#{$prefix}font-sans-serif) !default;\n$font-family-code:            var(--#{$prefix}font-monospace) !default;\n\n// $font-size-root affects the value of `rem`, which is used for as well font sizes, paddings, and margins\n// $font-size-base affects the font size of the body text\n$font-size-root:              null !default;\n$font-size-base:              1rem !default; // Assumes the browser default, typically `16px`\n$font-size-sm:                $font-size-base * .875 !default;\n$font-size-lg:                $font-size-base * 1.25 !default;\n\n$font-weight-lighter:         lighter !default;\n$font-weight-light:           300 !default;\n$font-weight-normal:          400 !default;\n$font-weight-medium:          500 !default;\n$font-weight-semibold:        600 !default;\n$font-weight-bold:            700 !default;\n$font-weight-bolder:          bolder !default;\n\n$font-weight-base:            $font-weight-normal !default;\n\n$line-height-base:            1.5 !default;\n$line-height-sm:              1.25 !default;\n$line-height-lg:              2 !default;\n\n$h1-font-size:                $font-size-base * 2.5 !default;\n$h2-font-size:                $font-size-base * 2 !default;\n$h3-font-size:                $font-size-base * 1.75 !default;\n$h4-font-size:                $font-size-base * 1.5 !default;\n$h5-font-size:                $font-size-base * 1.25 !default;\n$h6-font-size:                $font-size-base !default;\n// scss-docs-end font-variables\n\n// scss-docs-start font-sizes\n$font-sizes: (\n  1: $h1-font-size,\n  2: $h2-font-size,\n  3: $h3-font-size,\n  4: $h4-font-size,\n  5: $h5-font-size,\n  6: $h6-font-size\n) !default;\n// scss-docs-end font-sizes\n\n// scss-docs-start headings-variables\n$headings-margin-bottom:      $spacer * .5 !default;\n$headings-font-family:        null !default;\n$headings-font-style:         null !default;\n$headings-font-weight:        500 !default;\n$headings-line-height:        1.2 !default;\n$headings-color:              inherit !default;\n// scss-docs-end headings-variables\n\n// scss-docs-start display-headings\n$display-font-sizes: (\n  1: 5rem,\n  2: 4.5rem,\n  3: 4rem,\n  4: 3.5rem,\n  5: 3rem,\n  6: 2.5rem\n) !default;\n\n$display-font-family: null !default;\n$display-font-style:  null !default;\n$display-font-weight: 300 !default;\n$display-line-height: $headings-line-height !default;\n// scss-docs-end display-headings\n\n// scss-docs-start type-variables\n$lead-font-size:              $font-size-base * 1.25 !default;\n$lead-font-weight:            300 !default;\n\n$small-font-size:             .875em !default;\n\n$sub-sup-font-size:           .75em !default;\n\n// fusv-disable\n$text-muted:                  var(--#{$prefix}secondary-color) !default; // Deprecated in 5.3.0\n// fusv-enable\n\n$initialism-font-size:        $small-font-size !default;\n\n$blockquote-margin-y:         $spacer !default;\n$blockquote-font-size:        $font-size-base * 1.25 !default;\n$blockquote-footer-color:     $gray-600 !default;\n$blockquote-footer-font-size: $small-font-size !default;\n$blockquote-border-width:     $spacer / 4 !default;\n$blockquote-border-color:     $gray-200 !default;\n\n$hr-margin-y:                 $spacer !default;\n$hr-color:                    inherit !default;\n\n// fusv-disable\n$hr-bg-color:                 null !default; // Deprecated in v5.2.0\n$hr-height:                   null !default; // Deprecated in v5.2.0\n// fusv-enable\n\n$hr-border-color:             null !default; // Allows for inherited colors\n$hr-border-width:             var(--#{$prefix}border-width) !default;\n$hr-opacity:                  .25 !default;\n\n// scss-docs-start vr-variables\n$vr-border-width:             var(--#{$prefix}border-width) !default;\n// scss-docs-end vr-variables\n\n$legend-margin-bottom:        .5rem !default;\n$legend-font-size:            1.5rem !default;\n$legend-font-weight:          null !default;\n\n$dt-font-weight:              $font-weight-bold !default;\n\n$list-inline-padding:         .5rem !default;\n\n$mark-padding:                .1875em !default;\n$mark-bg:                     $yellow-100 !default;\n// scss-docs-end type-variables\n\n\n// Tables\n//\n// Customizes the `.table` component with basic values, each used across all table variations.\n\n// scss-docs-start table-variables\n$table-cell-padding-y:        .5rem !default;\n$table-cell-padding-x:        .5rem !default;\n$table-cell-padding-y-sm:     .25rem !default;\n$table-cell-padding-x-sm:     .25rem !default;\n\n$table-cell-vertical-align:   top !default;\n\n$table-color:                 var(--#{$prefix}body-color) !default;\n$table-bg:                    var(--#{$prefix}body-bg) !default;\n$table-accent-bg:             transparent !default;\n\n$table-th-font-weight:        null !default;\n\n$table-striped-color:         $table-color !default;\n$table-striped-bg-factor:     .05 !default;\n$table-striped-bg:            rgba($black, $table-striped-bg-factor) !default;\n\n$table-active-color:          $table-color !default;\n$table-active-bg-factor:      .1 !default;\n$table-active-bg:             rgba($black, $table-active-bg-factor) !default;\n\n$table-hover-color:           $table-color !default;\n$table-hover-bg-factor:       .075 !default;\n$table-hover-bg:              rgba($black, $table-hover-bg-factor) !default;\n\n$table-border-factor:         .1 !default;\n$table-border-width:          var(--#{$prefix}border-width) !default;\n$table-border-color:          var(--#{$prefix}border-color) !default;\n\n$table-striped-order:         odd !default;\n$table-striped-columns-order: even !default;\n\n$table-group-separator-color: currentcolor !default;\n\n$table-caption-color:         var(--#{$prefix}secondary-color) !default;\n\n$table-bg-scale:              -80% !default;\n// scss-docs-end table-variables\n\n// scss-docs-start table-loop\n$table-variants: (\n  \"primary\":    shift-color($primary, $table-bg-scale),\n  \"secondary\":  shift-color($secondary, $table-bg-scale),\n  \"success\":    shift-color($success, $table-bg-scale),\n  \"info\":       shift-color($info, $table-bg-scale),\n  \"warning\":    shift-color($warning, $table-bg-scale),\n  \"danger\":     shift-color($danger, $table-bg-scale),\n  \"light\":      $light,\n  \"dark\":       $dark,\n) !default;\n// scss-docs-end table-loop\n\n\n// Buttons + Forms\n//\n// Shared variables that are reassigned to `$input-` and `$btn-` specific variables.\n\n// scss-docs-start input-btn-variables\n$input-btn-padding-y:         .375rem !default;\n$input-btn-padding-x:         .75rem !default;\n$input-btn-font-family:       null !default;\n$input-btn-font-size:         $font-size-base !default;\n$input-btn-line-height:       $line-height-base !default;\n\n$input-btn-focus-width:         $focus-ring-width !default;\n$input-btn-focus-color-opacity: $focus-ring-opacity !default;\n$input-btn-focus-color:         $focus-ring-color !default;\n$input-btn-focus-blur:          $focus-ring-blur !default;\n$input-btn-focus-box-shadow:    $focus-ring-box-shadow !default;\n\n$input-btn-padding-y-sm:      .25rem !default;\n$input-btn-padding-x-sm:      .5rem !default;\n$input-btn-font-size-sm:      $font-size-sm !default;\n\n$input-btn-padding-y-lg:      .5rem !default;\n$input-btn-padding-x-lg:      1rem !default;\n$input-btn-font-size-lg:      $font-size-lg !default;\n\n$input-btn-border-width:      var(--#{$prefix}border-width) !default;\n// scss-docs-end input-btn-variables\n\n\n// Buttons\n//\n// For each of Bootstrap's buttons, define text, background, and border color.\n\n// scss-docs-start btn-variables\n$btn-color:                   var(--#{$prefix}body-color) !default;\n$btn-padding-y:               $input-btn-padding-y !default;\n$btn-padding-x:               $input-btn-padding-x !default;\n$btn-font-family:             $input-btn-font-family !default;\n$btn-font-size:               $input-btn-font-size !default;\n$btn-line-height:             $input-btn-line-height !default;\n$btn-white-space:             null !default; // Set to `nowrap` to prevent text wrapping\n\n$btn-padding-y-sm:            $input-btn-padding-y-sm !default;\n$btn-padding-x-sm:            $input-btn-padding-x-sm !default;\n$btn-font-size-sm:            $input-btn-font-size-sm !default;\n\n$btn-padding-y-lg:            $input-btn-padding-y-lg !default;\n$btn-padding-x-lg:            $input-btn-padding-x-lg !default;\n$btn-font-size-lg:            $input-btn-font-size-lg !default;\n\n$btn-border-width:            $input-btn-border-width !default;\n\n$btn-font-weight:             $font-weight-normal !default;\n$btn-box-shadow:              inset 0 1px 0 rgba($white, .15), 0 1px 1px rgba($black, .075) !default;\n$btn-focus-width:             $input-btn-focus-width !default;\n$btn-focus-box-shadow:        $input-btn-focus-box-shadow !default;\n$btn-disabled-opacity:        .65 !default;\n$btn-active-box-shadow:       inset 0 3px 5px rgba($black, .125) !default;\n\n$btn-link-color:              var(--#{$prefix}link-color) !default;\n$btn-link-hover-color:        var(--#{$prefix}link-hover-color) !default;\n$btn-link-disabled-color:     $gray-600 !default;\n\n// Allows for customizing button radius independently from global border radius\n$btn-border-radius:           var(--#{$prefix}border-radius) !default;\n$btn-border-radius-sm:        var(--#{$prefix}border-radius-sm) !default;\n$btn-border-radius-lg:        var(--#{$prefix}border-radius-lg) !default;\n\n$btn-transition:              color .15s ease-in-out, background-color .15s ease-in-out, border-color .15s ease-in-out, box-shadow .15s ease-in-out !default;\n\n$btn-hover-bg-shade-amount:       15% !default;\n$btn-hover-bg-tint-amount:        15% !default;\n$btn-hover-border-shade-amount:   20% !default;\n$btn-hover-border-tint-amount:    10% !default;\n$btn-active-bg-shade-amount:      20% !default;\n$btn-active-bg-tint-amount:       20% !default;\n$btn-active-border-shade-amount:  25% !default;\n$btn-active-border-tint-amount:   10% !default;\n// scss-docs-end btn-variables\n\n\n// Forms\n\n// scss-docs-start form-text-variables\n$form-text-margin-top:                  .25rem !default;\n$form-text-font-size:                   $small-font-size !default;\n$form-text-font-style:                  null !default;\n$form-text-font-weight:                 null !default;\n$form-text-color:                       var(--#{$prefix}secondary-color) !default;\n// scss-docs-end form-text-variables\n\n// scss-docs-start form-label-variables\n$form-label-margin-bottom:              .5rem !default;\n$form-label-font-size:                  null !default;\n$form-label-font-style:                 null !default;\n$form-label-font-weight:                null !default;\n$form-label-color:                      null !default;\n// scss-docs-end form-label-variables\n\n// scss-docs-start form-input-variables\n$input-padding-y:                       $input-btn-padding-y !default;\n$input-padding-x:                       $input-btn-padding-x !default;\n$input-font-family:                     $input-btn-font-family !default;\n$input-font-size:                       $input-btn-font-size !default;\n$input-font-weight:                     $font-weight-base !default;\n$input-line-height:                     $input-btn-line-height !default;\n\n$input-padding-y-sm:                    $input-btn-padding-y-sm !default;\n$input-padding-x-sm:                    $input-btn-padding-x-sm !default;\n$input-font-size-sm:                    $input-btn-font-size-sm !default;\n\n$input-padding-y-lg:                    $input-btn-padding-y-lg !default;\n$input-padding-x-lg:                    $input-btn-padding-x-lg !default;\n$input-font-size-lg:                    $input-btn-font-size-lg !default;\n\n$input-bg:                              var(--#{$prefix}body-bg) !default;\n$input-disabled-color:                  null !default;\n$input-disabled-bg:                     var(--#{$prefix}secondary-bg) !default;\n$input-disabled-border-color:           null !default;\n\n$input-color:                           var(--#{$prefix}body-color) !default;\n$input-border-color:                    var(--#{$prefix}border-color) !default;\n$input-border-width:                    $input-btn-border-width !default;\n$input-box-shadow:                      $box-shadow-inset !default;\n\n$input-border-radius:                   var(--#{$prefix}border-radius) !default;\n$input-border-radius-sm:                var(--#{$prefix}border-radius-sm) !default;\n$input-border-radius-lg:                var(--#{$prefix}border-radius-lg) !default;\n\n$input-focus-bg:                        $input-bg !default;\n$input-focus-border-color:              tint-color($component-active-bg, 50%) !default;\n$input-focus-color:                     $input-color !default;\n$input-focus-width:                     $input-btn-focus-width !default;\n$input-focus-box-shadow:                $input-btn-focus-box-shadow !default;\n\n$input-placeholder-color:               var(--#{$prefix}secondary-color) !default;\n$input-plaintext-color:                 var(--#{$prefix}body-color) !default;\n\n$input-height-border:                   calc(#{$input-border-width} * 2) !default; // stylelint-disable-line function-disallowed-list\n\n$input-height-inner:                    add($input-line-height * 1em, $input-padding-y * 2) !default;\n$input-height-inner-half:               add($input-line-height * .5em, $input-padding-y) !default;\n$input-height-inner-quarter:            add($input-line-height * .25em, $input-padding-y * .5) !default;\n\n$input-height:                          add($input-line-height * 1em, add($input-padding-y * 2, $input-height-border, false)) !default;\n$input-height-sm:                       add($input-line-height * 1em, add($input-padding-y-sm * 2, $input-height-border, false)) !default;\n$input-height-lg:                       add($input-line-height * 1em, add($input-padding-y-lg * 2, $input-height-border, false)) !default;\n\n$input-transition:                      border-color .15s ease-in-out, box-shadow .15s ease-in-out !default;\n\n$form-color-width:                      3rem !default;\n// scss-docs-end form-input-variables\n\n// scss-docs-start form-check-variables\n$form-check-input-width:                  1em !default;\n$form-check-min-height:                   $font-size-base * $line-height-base !default;\n$form-check-padding-start:                0 !default;\n$form-check-margin-bottom:                .125rem !default;\n$form-check-label-color:                  null !default;\n$form-check-label-cursor:                 pointer !default;\n$form-check-transition:                   null !default;\n\n$form-check-input-active-filter:          brightness(90%) !default;\n\n$form-check-input-bg:                     $input-bg !default;\n$form-check-input-border:                 var(--#{$prefix}border-width) solid var(--#{$prefix}border-color) !default;\n$form-check-input-border-radius:          .25em !default;\n$form-check-radio-border-radius:          50% !default;\n$form-check-input-focus-border:           $input-focus-border-color !default;\n$form-check-input-focus-box-shadow:       $focus-ring-box-shadow !default;\n\n$form-check-input-checked-color:          $component-active-color !default;\n$form-check-input-checked-bg-color:       $component-active-bg !default;\n$form-check-input-checked-border-color:   $form-check-input-checked-bg-color !default;\n$form-check-input-checked-bg-image:       url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'><path fill='none' stroke='#{$form-check-input-checked-color}' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='m6 10 3 3 6-6'/></svg>\") !default;\n$form-check-radio-checked-bg-image:       url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'><circle r='2' fill='#{$form-check-input-checked-color}'/></svg>\") !default;\n\n$form-check-input-indeterminate-color:          $component-active-color !default;\n$form-check-input-indeterminate-bg-color:       $component-active-bg !default;\n$form-check-input-indeterminate-border-color:   $form-check-input-indeterminate-bg-color !default;\n$form-check-input-indeterminate-bg-image:       url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'><path fill='none' stroke='#{$form-check-input-indeterminate-color}' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='M6 10h8'/></svg>\") !default;\n\n$form-check-input-disabled-opacity:        .5 !default;\n$form-check-label-disabled-opacity:        $form-check-input-disabled-opacity !default;\n$form-check-btn-check-disabled-opacity:    $btn-disabled-opacity !default;\n\n$form-check-inline-margin-end:    1rem !default;\n// scss-docs-end form-check-variables\n\n// scss-docs-start form-switch-variables\n$form-switch-color:               rgba($black, .25) !default;\n$form-switch-width:               2em !default;\n$form-switch-padding-start:       $form-switch-width + .5em !default;\n$form-switch-bg-image:            url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'><circle r='3' fill='#{$form-switch-color}'/></svg>\") !default;\n$form-switch-border-radius:       $form-switch-width !default;\n$form-switch-transition:          background-position .15s ease-in-out !default;\n\n$form-switch-focus-color:         $input-focus-border-color !default;\n$form-switch-focus-bg-image:      url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'><circle r='3' fill='#{$form-switch-focus-color}'/></svg>\") !default;\n\n$form-switch-checked-color:       $component-active-color !default;\n$form-switch-checked-bg-image:    url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'><circle r='3' fill='#{$form-switch-checked-color}'/></svg>\") !default;\n$form-switch-checked-bg-position: right center !default;\n// scss-docs-end form-switch-variables\n\n// scss-docs-start input-group-variables\n$input-group-addon-padding-y:           $input-padding-y !default;\n$input-group-addon-padding-x:           $input-padding-x !default;\n$input-group-addon-font-weight:         $input-font-weight !default;\n$input-group-addon-color:               $input-color !default;\n$input-group-addon-bg:                  var(--#{$prefix}tertiary-bg) !default;\n$input-group-addon-border-color:        $input-border-color !default;\n// scss-docs-end input-group-variables\n\n// scss-docs-start form-select-variables\n$form-select-padding-y:             $input-padding-y !default;\n$form-select-padding-x:             $input-padding-x !default;\n$form-select-font-family:           $input-font-family !default;\n$form-select-font-size:             $input-font-size !default;\n$form-select-indicator-padding:     $form-select-padding-x * 3 !default; // Extra padding for background-image\n$form-select-font-weight:           $input-font-weight !default;\n$form-select-line-height:           $input-line-height !default;\n$form-select-color:                 $input-color !default;\n$form-select-bg:                    $input-bg !default;\n$form-select-disabled-color:        null !default;\n$form-select-disabled-bg:           $input-disabled-bg !default;\n$form-select-disabled-border-color: $input-disabled-border-color !default;\n$form-select-bg-position:           right $form-select-padding-x center !default;\n$form-select-bg-size:               16px 12px !default; // In pixels because image dimensions\n$form-select-indicator-color:       $gray-800 !default;\n$form-select-indicator:             url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path fill='none' stroke='#{$form-select-indicator-color}' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/></svg>\") !default;\n\n$form-select-feedback-icon-padding-end: $form-select-padding-x * 2.5 + $form-select-indicator-padding !default;\n$form-select-feedback-icon-position:    center right $form-select-indicator-padding !default;\n$form-select-feedback-icon-size:        $input-height-inner-half $input-height-inner-half !default;\n\n$form-select-border-width:        $input-border-width !default;\n$form-select-border-color:        $input-border-color !default;\n$form-select-border-radius:       $input-border-radius !default;\n$form-select-box-shadow:          $box-shadow-inset !default;\n\n$form-select-focus-border-color:  $input-focus-border-color !default;\n$form-select-focus-width:         $input-focus-width !default;\n$form-select-focus-box-shadow:    0 0 0 $form-select-focus-width $input-btn-focus-color !default;\n\n$form-select-padding-y-sm:        $input-padding-y-sm !default;\n$form-select-padding-x-sm:        $input-padding-x-sm !default;\n$form-select-font-size-sm:        $input-font-size-sm !default;\n$form-select-border-radius-sm:    $input-border-radius-sm !default;\n\n$form-select-padding-y-lg:        $input-padding-y-lg !default;\n$form-select-padding-x-lg:        $input-padding-x-lg !default;\n$form-select-font-size-lg:        $input-font-size-lg !default;\n$form-select-border-radius-lg:    $input-border-radius-lg !default;\n\n$form-select-transition:          $input-transition !default;\n// scss-docs-end form-select-variables\n\n// scss-docs-start form-range-variables\n$form-range-track-width:          100% !default;\n$form-range-track-height:         .5rem !default;\n$form-range-track-cursor:         pointer !default;\n$form-range-track-bg:             var(--#{$prefix}tertiary-bg) !default;\n$form-range-track-border-radius:  1rem !default;\n$form-range-track-box-shadow:     $box-shadow-inset !default;\n\n$form-range-thumb-width:                   1rem !default;\n$form-range-thumb-height:                  $form-range-thumb-width !default;\n$form-range-thumb-bg:                      $component-active-bg !default;\n$form-range-thumb-border:                  0 !default;\n$form-range-thumb-border-radius:           1rem !default;\n$form-range-thumb-box-shadow:              0 .1rem .25rem rgba($black, .1) !default;\n$form-range-thumb-focus-box-shadow:        0 0 0 1px $body-bg, $input-focus-box-shadow !default;\n$form-range-thumb-focus-box-shadow-width:  $input-focus-width !default; // For focus box shadow issue in Edge\n$form-range-thumb-active-bg:               tint-color($component-active-bg, 70%) !default;\n$form-range-thumb-disabled-bg:             var(--#{$prefix}secondary-color) !default;\n$form-range-thumb-transition:              background-color .15s ease-in-out, border-color .15s ease-in-out, box-shadow .15s ease-in-out !default;\n// scss-docs-end form-range-variables\n\n// scss-docs-start form-file-variables\n$form-file-button-color:          $input-color !default;\n$form-file-button-bg:             var(--#{$prefix}tertiary-bg) !default;\n$form-file-button-hover-bg:       var(--#{$prefix}secondary-bg) !default;\n// scss-docs-end form-file-variables\n\n// scss-docs-start form-floating-variables\n$form-floating-height:                  add(3.5rem, $input-height-border) !default;\n$form-floating-line-height:             1.25 !default;\n$form-floating-padding-x:               $input-padding-x !default;\n$form-floating-padding-y:               1rem !default;\n$form-floating-input-padding-t:         1.625rem !default;\n$form-floating-input-padding-b:         .625rem !default;\n$form-floating-label-height:            1.5em !default;\n$form-floating-label-opacity:           .65 !default;\n$form-floating-label-transform:         scale(.85) translateY(-.5rem) translateX(.15rem) !default;\n$form-floating-label-disabled-color:    $gray-600 !default;\n$form-floating-transition:              opacity .1s ease-in-out, transform .1s ease-in-out !default;\n// scss-docs-end form-floating-variables\n\n// Form validation\n\n// scss-docs-start form-feedback-variables\n$form-feedback-margin-top:          $form-text-margin-top !default;\n$form-feedback-font-size:           $form-text-font-size !default;\n$form-feedback-font-style:          $form-text-font-style !default;\n$form-feedback-valid-color:         $success !default;\n$form-feedback-invalid-color:       $danger !default;\n\n$form-feedback-icon-valid-color:    $form-feedback-valid-color !default;\n$form-feedback-icon-valid:          url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'><path fill='#{$form-feedback-icon-valid-color}' d='M2.3 6.73.6 4.53c-.4-1.04.46-1.4 1.1-.8l1.1 1.4 3.4-3.8c.6-.63 1.6-.27 1.2.7l-4 4.6c-.43.5-.8.4-1.1.1z'/></svg>\") !default;\n$form-feedback-icon-invalid-color:  $form-feedback-invalid-color !default;\n$form-feedback-icon-invalid:        url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12' width='12' height='12' fill='none' stroke='#{$form-feedback-icon-invalid-color}'><circle cx='6' cy='6' r='4.5'/><path stroke-linejoin='round' d='M5.8 3.6h.4L6 6.5z'/><circle cx='6' cy='8.2' r='.6' fill='#{$form-feedback-icon-invalid-color}' stroke='none'/></svg>\") !default;\n// scss-docs-end form-feedback-variables\n\n// scss-docs-start form-validation-colors\n$form-valid-color:                  $form-feedback-valid-color !default;\n$form-valid-border-color:           $form-feedback-valid-color !default;\n$form-invalid-color:                $form-feedback-invalid-color !default;\n$form-invalid-border-color:         $form-feedback-invalid-color !default;\n// scss-docs-end form-validation-colors\n\n// scss-docs-start form-validation-states\n$form-validation-states: (\n  \"valid\": (\n    \"color\": var(--#{$prefix}form-valid-color),\n    \"icon\": $form-feedback-icon-valid,\n    \"tooltip-color\": #fff,\n    \"tooltip-bg-color\": var(--#{$prefix}success),\n    \"focus-box-shadow\": 0 0 $input-btn-focus-blur $input-focus-width rgba(var(--#{$prefix}success-rgb), $input-btn-focus-color-opacity),\n    \"border-color\": var(--#{$prefix}form-valid-border-color),\n  ),\n  \"invalid\": (\n    \"color\": var(--#{$prefix}form-invalid-color),\n    \"icon\": $form-feedback-icon-invalid,\n    \"tooltip-color\": #fff,\n    \"tooltip-bg-color\": var(--#{$prefix}danger),\n    \"focus-box-shadow\": 0 0 $input-btn-focus-blur $input-focus-width rgba(var(--#{$prefix}danger-rgb), $input-btn-focus-color-opacity),\n    \"border-color\": var(--#{$prefix}form-invalid-border-color),\n  )\n) !default;\n// scss-docs-end form-validation-states\n\n// Z-index master list\n//\n// Warning: Avoid customizing these values. They're used for a bird's eye view\n// of components dependent on the z-axis and are designed to all work together.\n\n// scss-docs-start zindex-stack\n$zindex-dropdown:                   1000 !default;\n$zindex-sticky:                     1020 !default;\n$zindex-fixed:                      1030 !default;\n$zindex-offcanvas-backdrop:         1040 !default;\n$zindex-offcanvas:                  1045 !default;\n$zindex-modal-backdrop:             1050 !default;\n$zindex-modal:                      1055 !default;\n$zindex-popover:                    1070 !default;\n$zindex-tooltip:                    1080 !default;\n$zindex-toast:                      1090 !default;\n// scss-docs-end zindex-stack\n\n// scss-docs-start zindex-levels-map\n$zindex-levels: (\n  n1: -1,\n  0: 0,\n  1: 1,\n  2: 2,\n  3: 3\n) !default;\n// scss-docs-end zindex-levels-map\n\n\n// Navs\n\n// scss-docs-start nav-variables\n$nav-link-padding-y:                .5rem !default;\n$nav-link-padding-x:                1rem !default;\n$nav-link-font-size:                null !default;\n$nav-link-font-weight:              null !default;\n$nav-link-color:                    var(--#{$prefix}link-color) !default;\n$nav-link-hover-color:              var(--#{$prefix}link-hover-color) !default;\n$nav-link-transition:               color .15s ease-in-out, background-color .15s ease-in-out, border-color .15s ease-in-out !default;\n$nav-link-disabled-color:           var(--#{$prefix}secondary-color) !default;\n$nav-link-focus-box-shadow:         $focus-ring-box-shadow !default;\n\n$nav-tabs-border-color:             var(--#{$prefix}border-color) !default;\n$nav-tabs-border-width:             var(--#{$prefix}border-width) !default;\n$nav-tabs-border-radius:            var(--#{$prefix}border-radius) !default;\n$nav-tabs-link-hover-border-color:  var(--#{$prefix}secondary-bg) var(--#{$prefix}secondary-bg) $nav-tabs-border-color !default;\n$nav-tabs-link-active-color:        var(--#{$prefix}emphasis-color) !default;\n$nav-tabs-link-active-bg:           var(--#{$prefix}body-bg) !default;\n$nav-tabs-link-active-border-color: var(--#{$prefix}border-color) var(--#{$prefix}border-color) $nav-tabs-link-active-bg !default;\n\n$nav-pills-border-radius:           var(--#{$prefix}border-radius) !default;\n$nav-pills-link-active-bg:          $component-active-bg !default;\n$nav-pills-link-active-color:       color-contrast($nav-pills-link-active-bg, $component-active-color) !default;\n\n$nav-underline-gap:                 1rem !default;\n$nav-underline-border-width:        .125rem !default;\n$nav-underline-link-active-color:   var(--#{$prefix}emphasis-color) !default;\n// scss-docs-end nav-variables\n\n\n// Navbar\n\n// scss-docs-start navbar-variables\n$navbar-padding-y:                  $spacer * .5 !default;\n$navbar-padding-x:                  null !default;\n\n$navbar-nav-link-padding-x:         .5rem !default;\n\n$navbar-brand-font-size:            $font-size-lg !default;\n// Compute the navbar-brand padding-y so the navbar-brand will have the same height as navbar-text and nav-link\n$nav-link-height:                   $font-size-base * $line-height-base + $nav-link-padding-y * 2 !default;\n$navbar-brand-height:               $navbar-brand-font-size * $line-height-base !default;\n$navbar-brand-padding-y:            ($nav-link-height - $navbar-brand-height) * .5 !default;\n$navbar-brand-margin-end:           1rem !default;\n\n$navbar-toggler-padding-y:          .25rem !default;\n$navbar-toggler-padding-x:          .75rem !default;\n$navbar-toggler-font-size:          $font-size-lg !default;\n$navbar-toggler-border-radius:      $btn-border-radius !default;\n$navbar-toggler-focus-width:        $btn-focus-width !default;\n$navbar-toggler-transition:         box-shadow .15s ease-in-out !default;\n\n$navbar-bg:       null !default; // Background color for any navbarPage()\n$navbar-light-bg: $navbar-bg !default; // Background color for navbarPage(inverse = FALSE)\n$navbar-dark-bg:  $navbar-bg !default; // Background color for navbarPage(inverse = TRUE)\n\n$navbar-light-contrast: if(\n  type-of($navbar-light-bg) == color,\n  color-contrast($navbar-light-bg),\n  var(--#{$prefix}emphasis-color-rgb)\n) !default; // Deepest contrasting color for navbarPage(inverse = FALSE).\n$navbar-dark-contrast: if(\n  type-of($navbar-dark-bg) == color,\n  color-contrast($navbar-dark-bg),\n  var(--#{$prefix}emphasis-color-rgb)\n) !default; // Deepest contrasting color for navbarPage(inverse = TRUE).\n\n$navbar-light-color:                rgba($navbar-light-contrast, .65) !default;\n$navbar-light-hover-color:          rgba($navbar-light-contrast, .8) !default;\n$navbar-light-active-color:         rgba($navbar-light-contrast, 1) !default;\n$navbar-light-disabled-color:       rgba($navbar-light-contrast, .3) !default;\n$navbar-light-icon-color:           rgba(if(type-of($navbar-light-contrast)==color, $navbar-light-contrast, $body-color), .75) !default;\n$navbar-light-toggler-icon-bg:      url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'><path stroke='#{$navbar-light-icon-color}' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/></svg>\") !default;\n$navbar-light-toggler-border-color: rgba($navbar-light-contrast, .15) !default;\n$navbar-light-brand-color:          $navbar-light-active-color !default;\n$navbar-light-brand-hover-color:    $navbar-light-active-color !default;\n// scss-docs-end navbar-variables\n\n// scss-docs-start navbar-dark-variables\n$navbar-dark-color:                 rgba($navbar-dark-contrast, .55) !default;\n$navbar-dark-hover-color:           rgba($navbar-dark-contrast, .75) !default;\n$navbar-dark-active-color:          rgba($navbar-dark-contrast, 1) !default;\n$navbar-dark-disabled-color:        rgba($navbar-dark-contrast, .25) !default;\n$navbar-dark-icon-color:            rgba(if(type-of($navbar-dark-contrast)==color, $navbar-dark-contrast, $white), .75) !default;\n$navbar-dark-toggler-icon-bg:       url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'><path stroke='#{$navbar-dark-icon-color}' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/></svg>\") !default;\n$navbar-dark-toggler-border-color:  rgba($navbar-dark-contrast, .1) !default;\n$navbar-dark-brand-color:           $navbar-dark-active-color !default;\n$navbar-dark-brand-hover-color:     $navbar-dark-active-color !default;\n// scss-docs-end navbar-dark-variables\n\n\n// Dropdowns\n//\n// Dropdown menu container and contents.\n\n// scss-docs-start dropdown-variables\n$dropdown-min-width:                10rem !default;\n$dropdown-padding-x:                0 !default;\n$dropdown-padding-y:                .5rem !default;\n$dropdown-spacer:                   .125rem !default;\n$dropdown-font-size:                $font-size-base !default;\n$dropdown-color:                    var(--#{$prefix}body-color) !default;\n$dropdown-bg:                       var(--#{$prefix}body-bg) !default;\n$dropdown-border-color:             var(--#{$prefix}border-color-translucent) !default;\n$dropdown-border-radius:            var(--#{$prefix}border-radius) !default;\n$dropdown-border-width:             var(--#{$prefix}border-width) !default;\n$dropdown-inner-border-radius:      calc(#{$dropdown-border-radius} - #{$dropdown-border-width}) !default; // stylelint-disable-line function-disallowed-list\n$dropdown-divider-bg:               $dropdown-border-color !default;\n$dropdown-divider-margin-y:         $spacer * .5 !default;\n$dropdown-box-shadow:               $box-shadow !default;\n\n$dropdown-link-color:               var(--#{$prefix}body-color) !default;\n$dropdown-link-hover-color:         $dropdown-link-color !default;\n$dropdown-link-hover-bg:            var(--#{$prefix}tertiary-bg) !default;\n\n$dropdown-link-active-bg:           $component-active-bg !default;\n$dropdown-link-active-color:        color-contrast($dropdown-link-active-bg, $component-active-color) !default;\n\n$dropdown-link-disabled-color:      var(--#{$prefix}tertiary-color) !default;\n\n$dropdown-item-padding-y:           $spacer * .25 !default;\n$dropdown-item-padding-x:           $spacer !default;\n\n$dropdown-header-color:             $gray-600 !default;\n$dropdown-header-padding-x:         $dropdown-item-padding-x !default;\n$dropdown-header-padding-y:         $dropdown-padding-y !default;\n// fusv-disable\n$dropdown-header-padding:           $dropdown-header-padding-y $dropdown-header-padding-x !default; // Deprecated in v5.2.0\n// fusv-enable\n// scss-docs-end dropdown-variables\n\n// scss-docs-start dropdown-dark-variables\n$dropdown-dark-color:               $gray-300 !default;\n$dropdown-dark-bg:                  $gray-800 !default;\n$dropdown-dark-border-color:        $dropdown-border-color !default;\n$dropdown-dark-divider-bg:          $dropdown-divider-bg !default;\n$dropdown-dark-box-shadow:          null !default;\n$dropdown-dark-link-color:          $dropdown-dark-color !default;\n$dropdown-dark-link-hover-color:    $white !default;\n$dropdown-dark-link-hover-bg:       rgba($white, .15) !default;\n$dropdown-dark-link-active-color:   $dropdown-link-active-color !default;\n$dropdown-dark-link-active-bg:      $dropdown-link-active-bg !default;\n$dropdown-dark-link-disabled-color: $gray-500 !default;\n$dropdown-dark-header-color:        $gray-500 !default;\n// scss-docs-end dropdown-dark-variables\n\n\n// Pagination\n\n// scss-docs-start pagination-variables\n$pagination-padding-y:              .375rem !default;\n$pagination-padding-x:              .75rem !default;\n$pagination-padding-y-sm:           .25rem !default;\n$pagination-padding-x-sm:           .5rem !default;\n$pagination-padding-y-lg:           .75rem !default;\n$pagination-padding-x-lg:           1.5rem !default;\n\n$pagination-font-size:              $font-size-base !default;\n\n$pagination-color:                  var(--#{$prefix}link-color) !default;\n$pagination-bg:                     var(--#{$prefix}body-bg) !default;\n$pagination-border-radius:          var(--#{$prefix}border-radius) !default;\n$pagination-border-width:           var(--#{$prefix}border-width) !default;\n$pagination-margin-start:           calc(#{$pagination-border-width} * -1) !default; // stylelint-disable-line function-disallowed-list\n$pagination-border-color:           var(--#{$prefix}border-color) !default;\n\n$pagination-focus-color:            var(--#{$prefix}link-hover-color) !default;\n$pagination-focus-bg:               var(--#{$prefix}secondary-bg) !default;\n$pagination-focus-box-shadow:       $focus-ring-box-shadow !default;\n$pagination-focus-outline:          0 !default;\n\n$pagination-hover-color:            var(--#{$prefix}link-hover-color) !default;\n$pagination-hover-bg:               var(--#{$prefix}tertiary-bg) !default;\n$pagination-hover-border-color:     var(--#{$prefix}border-color) !default; // Todo in v6: remove this?\n\n$pagination-active-color:           $component-active-color !default;\n$pagination-active-bg:              $component-active-bg !default;\n$pagination-active-border-color:    $component-active-bg !default;\n\n$pagination-disabled-color:         var(--#{$prefix}secondary-color) !default;\n$pagination-disabled-bg:            var(--#{$prefix}secondary-bg) !default;\n$pagination-disabled-border-color:  var(--#{$prefix}border-color) !default;\n\n$pagination-transition:              color .15s ease-in-out, background-color .15s ease-in-out, border-color .15s ease-in-out, box-shadow .15s ease-in-out !default;\n\n$pagination-border-radius-sm:       var(--#{$prefix}border-radius-sm) !default;\n$pagination-border-radius-lg:       var(--#{$prefix}border-radius-lg) !default;\n// scss-docs-end pagination-variables\n\n\n// Placeholders\n\n// scss-docs-start placeholders\n$placeholder-opacity-max:           .5 !default;\n$placeholder-opacity-min:           .2 !default;\n// scss-docs-end placeholders\n\n// Cards\n\n// scss-docs-start card-variables\n$card-spacer-y:                     $spacer !default;\n$card-spacer-x:                     $spacer !default;\n$card-title-spacer-y:               $spacer * .5 !default;\n$card-title-color:                  null !default;\n$card-subtitle-color:               null !default;\n$card-border-width:                 var(--#{$prefix}border-width) !default;\n$card-border-color:                 var(--#{$prefix}border-color-translucent) !default;\n$card-border-radius:                var(--#{$prefix}border-radius) !default;\n$card-box-shadow:                   null !default;\n$card-inner-border-radius:          subtract($card-border-radius, $card-border-width) !default;\n$card-cap-padding-y:                $card-spacer-y * .5 !default;\n$card-cap-padding-x:                $card-spacer-x !default;\n$card-cap-bg:                       rgba(var(--#{$prefix}body-color-rgb), .03) !default;\n$card-cap-color:                    null !default;\n$card-height:                       null !default;\n$card-color:                        null !default;\n$card-bg:                           var(--#{$prefix}body-bg) !default;\n$card-img-overlay-padding:          $spacer !default;\n$card-group-margin:                 $grid-gutter-width * .5 !default;\n// scss-docs-end card-variables\n\n// Accordion\n\n// scss-docs-start accordion-variables\n$accordion-padding-y:                     1rem !default;\n$accordion-padding-x:                     1.25rem !default;\n$accordion-color:                         var(--#{$prefix}body-color) !default;\n$accordion-bg:                            var(--#{$prefix}body-bg) !default;\n$accordion-border-width:                  var(--#{$prefix}border-width) !default;\n$accordion-border-color:                  var(--#{$prefix}border-color) !default;\n$accordion-border-radius:                 var(--#{$prefix}border-radius) !default;\n$accordion-inner-border-radius:           subtract($accordion-border-radius, $accordion-border-width) !default;\n\n$accordion-body-padding-y:                $accordion-padding-y !default;\n$accordion-body-padding-x:                $accordion-padding-x !default;\n\n$accordion-button-padding-y:              $accordion-padding-y !default;\n$accordion-button-padding-x:              $accordion-padding-x !default;\n$accordion-button-color:                  var(--#{$prefix}body-color) !default;\n$accordion-button-bg:                     var(--#{$prefix}accordion-bg) !default;\n$accordion-transition:                    $btn-transition, border-radius .15s ease !default;\n$accordion-button-active-bg:              var(--#{$prefix}primary-bg-subtle) !default;\n$accordion-button-active-color:           var(--#{$prefix}primary-text-emphasis) !default;\n\n$accordion-button-focus-border-color:     $input-focus-border-color !default;\n$accordion-button-focus-box-shadow:       $btn-focus-box-shadow !default;\n\n$accordion-icon-width:                    1.25rem !default;\n$accordion-icon-color:                    $body-color !default;\n$accordion-icon-active-color:             $primary-text-emphasis !default;\n$accordion-icon-transition:               transform .2s ease-in-out !default;\n$accordion-icon-transform:                rotate(-180deg) !default;\n\n$accordion-button-icon:         url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='#{$accordion-icon-color}'><path fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/></svg>\") !default;\n$accordion-button-active-icon:  url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='#{$accordion-icon-active-color}'><path fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/></svg>\") !default;\n// scss-docs-end accordion-variables\n\n// Tooltips\n\n// scss-docs-start tooltip-variables\n$tooltip-font-size:                 $font-size-sm !default;\n$tooltip-max-width:                 200px !default;\n$tooltip-color:                     var(--#{$prefix}body-bg) !default;\n$tooltip-bg:                        var(--#{$prefix}emphasis-color) !default;\n$tooltip-border-radius:             var(--#{$prefix}border-radius) !default;\n$tooltip-opacity:                   .9 !default;\n$tooltip-padding-y:                 $spacer * .25 !default;\n$tooltip-padding-x:                 $spacer * .5 !default;\n$tooltip-margin:                    null !default; // TODO: remove this in v6\n\n$tooltip-arrow-width:               .8rem !default;\n$tooltip-arrow-height:              .4rem !default;\n// fusv-disable\n$tooltip-arrow-color:               null !default; // Deprecated in Bootstrap 5.2.0 for CSS variables\n// fusv-enable\n// scss-docs-end tooltip-variables\n\n// Form tooltips must come after regular tooltips\n// scss-docs-start tooltip-feedback-variables\n$form-feedback-tooltip-padding-y:     $tooltip-padding-y !default;\n$form-feedback-tooltip-padding-x:     $tooltip-padding-x !default;\n$form-feedback-tooltip-font-size:     $tooltip-font-size !default;\n$form-feedback-tooltip-line-height:   null !default;\n$form-feedback-tooltip-opacity:       $tooltip-opacity !default;\n$form-feedback-tooltip-border-radius: $tooltip-border-radius !default;\n// scss-docs-end tooltip-feedback-variables\n\n\n// Popovers\n\n// scss-docs-start popover-variables\n$popover-font-size:                 $font-size-sm !default;\n$popover-bg:                        var(--#{$prefix}body-bg) !default;\n$popover-max-width:                 276px !default;\n$popover-border-width:              var(--#{$prefix}border-width) !default;\n$popover-border-color:              var(--#{$prefix}border-color-translucent) !default;\n$popover-border-radius:             var(--#{$prefix}border-radius-lg) !default;\n$popover-inner-border-radius:       calc(#{$popover-border-radius} - #{$popover-border-width}) !default; // stylelint-disable-line function-disallowed-list\n$popover-box-shadow:                $box-shadow !default;\n\n$popover-header-font-size:          $font-size-base !default;\n$popover-header-bg:                 var(--#{$prefix}secondary-bg) !default;\n$popover-header-color:              $headings-color !default;\n$popover-header-padding-y:          .5rem !default;\n$popover-header-padding-x:          $spacer !default;\n\n$popover-body-color:                var(--#{$prefix}body-color) !default;\n$popover-body-padding-y:            $spacer !default;\n$popover-body-padding-x:            $spacer !default;\n\n$popover-arrow-width:               1rem !default;\n$popover-arrow-height:              .5rem !default;\n// scss-docs-end popover-variables\n\n// fusv-disable\n// Deprecated in Bootstrap 5.2.0 for CSS variables\n$popover-arrow-color:               $popover-bg !default;\n$popover-arrow-outer-color:         var(--#{$prefix}border-color-translucent) !default;\n// fusv-enable\n\n\n// Toasts\n\n// scss-docs-start toast-variables\n$toast-max-width:                   350px !default;\n$toast-padding-x:                   .75rem !default;\n$toast-padding-y:                   .5rem !default;\n$toast-font-size:                   .875rem !default;\n$toast-color:                       null !default;\n$toast-background-color:            rgba(var(--#{$prefix}body-bg-rgb), .85) !default;\n$toast-border-width:                var(--#{$prefix}border-width) !default;\n$toast-border-color:                var(--#{$prefix}border-color-translucent) !default;\n$toast-border-radius:               var(--#{$prefix}border-radius) !default;\n$toast-box-shadow:                  var(--#{$prefix}box-shadow) !default;\n$toast-spacing:                     $container-padding-x !default;\n\n$toast-header-color:                var(--#{$prefix}secondary-color) !default;\n$toast-header-background-color:     rgba(var(--#{$prefix}body-bg-rgb), .85) !default;\n$toast-header-border-color:         $toast-border-color !default;\n// scss-docs-end toast-variables\n\n\n// Badges\n\n// scss-docs-start badge-variables\n$badge-font-size:                   .75em !default;\n$badge-font-weight:                 $font-weight-bold !default;\n$badge-color:                       $white !default;\n$badge-padding-y:                   .35em !default;\n$badge-padding-x:                   .65em !default;\n$badge-border-radius:               var(--#{$prefix}border-radius) !default;\n// scss-docs-end badge-variables\n\n\n// Modals\n\n// scss-docs-start modal-variables\n$modal-inner-padding:               $spacer !default;\n\n$modal-footer-margin-between:       .5rem !default;\n\n$modal-dialog-margin:               .5rem !default;\n$modal-dialog-margin-y-sm-up:       1.75rem !default;\n\n$modal-title-line-height:           $line-height-base !default;\n\n$modal-content-color:               null !default;\n$modal-content-bg:                  var(--#{$prefix}body-bg) !default;\n$modal-content-border-color:        var(--#{$prefix}border-color-translucent) !default;\n$modal-content-border-width:        var(--#{$prefix}border-width) !default;\n$modal-content-border-radius:       var(--#{$prefix}border-radius-lg) !default;\n$modal-content-inner-border-radius: subtract($modal-content-border-radius, $modal-content-border-width) !default;\n$modal-content-box-shadow-xs:       $box-shadow-sm !default;\n$modal-content-box-shadow-sm-up:    $box-shadow !default;\n\n$modal-backdrop-bg:                 $black !default;\n$modal-backdrop-opacity:            .5 !default;\n\n$modal-header-border-color:         var(--#{$prefix}border-color) !default;\n$modal-header-border-width:         $modal-content-border-width !default;\n$modal-header-padding-y:            $modal-inner-padding !default;\n$modal-header-padding-x:            $modal-inner-padding !default;\n$modal-header-padding:              $modal-header-padding-y $modal-header-padding-x !default; // Keep this for backwards compatibility\n\n$modal-footer-bg:                   null !default;\n$modal-footer-border-color:         $modal-header-border-color !default;\n$modal-footer-border-width:         $modal-header-border-width !default;\n\n$modal-sm:                          300px !default;\n$modal-md:                          500px !default;\n$modal-lg:                          800px !default;\n$modal-xl:                          1140px !default;\n\n$modal-fade-transform:              translate(0, -50px) !default;\n$modal-show-transform:              none !default;\n$modal-transition:                  transform .3s ease-out !default;\n$modal-scale-transform:             scale(1.02) !default;\n// scss-docs-end modal-variables\n\n\n// Alerts\n//\n// Define alert colors, border radius, and padding.\n\n// scss-docs-start alert-variables\n$alert-padding-y:               $spacer !default;\n$alert-padding-x:               $spacer !default;\n$alert-margin-bottom:           1rem !default;\n$alert-border-radius:           var(--#{$prefix}border-radius) !default;\n$alert-link-font-weight:        $font-weight-bold !default;\n$alert-border-width:            var(--#{$prefix}border-width) !default;\n$alert-dismissible-padding-r:   $alert-padding-x * 3 !default; // 3x covers width of x plus default padding on either side\n// scss-docs-end alert-variables\n\n// fusv-disable\n$alert-bg-scale:                -80% !default; // Deprecated in v5.2.0, to be removed in v6\n$alert-border-scale:            -70% !default; // Deprecated in v5.2.0, to be removed in v6\n$alert-color-scale:             40% !default; // Deprecated in v5.2.0, to be removed in v6\n// fusv-enable\n\n// Progress bars\n\n// scss-docs-start progress-variables\n$progress-height:                   1rem !default;\n$progress-font-size:                $font-size-base * .75 !default;\n$progress-bg:                       var(--#{$prefix}secondary-bg) !default;\n$progress-border-radius:            var(--#{$prefix}border-radius) !default;\n$progress-box-shadow:               var(--#{$prefix}box-shadow-inset) !default;\n$progress-bar-color:                $white !default;\n$progress-bar-bg:                   $primary !default;\n$progress-bar-animation-timing:     1s linear infinite !default;\n$progress-bar-transition:           width .6s ease !default;\n// scss-docs-end progress-variables\n\n\n// List group\n\n// scss-docs-start list-group-variables\n$list-group-color:                  var(--#{$prefix}body-color) !default;\n$list-group-bg:                     var(--#{$prefix}body-bg) !default;\n$list-group-border-color:           var(--#{$prefix}border-color) !default;\n$list-group-border-width:           var(--#{$prefix}border-width) !default;\n$list-group-border-radius:          var(--#{$prefix}border-radius) !default;\n\n$list-group-item-padding-y:         $spacer * .5 !default;\n$list-group-item-padding-x:         $spacer !default;\n// fusv-disable\n$list-group-item-bg-scale:          -80% !default; // Deprecated in v5.3.0\n$list-group-item-color-scale:       40% !default; // Deprecated in v5.3.0\n// fusv-enable\n\n$list-group-hover-bg:               var(--#{$prefix}tertiary-bg) !default;\n$list-group-active-bg:              $component-active-bg !default;\n$list-group-active-color:           color-contrast($list-group-active-bg, $component-active-color) !default;\n$list-group-active-border-color:    $list-group-active-bg !default;\n\n$list-group-disabled-color:         var(--#{$prefix}secondary-color) !default;\n$list-group-disabled-bg:            $list-group-bg !default;\n\n$list-group-action-color:           var(--#{$prefix}secondary-color) !default;\n$list-group-action-hover-color:     var(--#{$prefix}emphasis-color) !default;\n\n$list-group-action-active-color:    var(--#{$prefix}body-color) !default;\n$list-group-action-active-bg:       var(--#{$prefix}secondary-bg) !default;\n// scss-docs-end list-group-variables\n\n\n// Image thumbnails\n\n// scss-docs-start thumbnail-variables\n$thumbnail-padding:                 .25rem !default;\n$thumbnail-bg:                      var(--#{$prefix}body-bg) !default;\n$thumbnail-border-width:            var(--#{$prefix}border-width) !default;\n$thumbnail-border-color:            var(--#{$prefix}border-color) !default;\n$thumbnail-border-radius:           var(--#{$prefix}border-radius) !default;\n$thumbnail-box-shadow:              var(--#{$prefix}box-shadow-sm) !default;\n// scss-docs-end thumbnail-variables\n\n\n// Figures\n\n// scss-docs-start figure-variables\n$figure-caption-font-size:          $small-font-size !default;\n$figure-caption-color:              var(--#{$prefix}secondary-color) !default;\n// scss-docs-end figure-variables\n\n\n// Breadcrumbs\n\n// scss-docs-start breadcrumb-variables\n$breadcrumb-font-size:              null !default;\n$breadcrumb-padding-y:              0 !default;\n$breadcrumb-padding-x:              0 !default;\n$breadcrumb-item-padding-x:         .5rem !default;\n$breadcrumb-margin-bottom:          1rem !default;\n$breadcrumb-bg:                     null !default;\n$breadcrumb-divider-color:          var(--#{$prefix}secondary-color) !default;\n$breadcrumb-active-color:           var(--#{$prefix}secondary-color) !default;\n$breadcrumb-divider:                quote(\"/\") !default;\n$breadcrumb-divider-flipped:        $breadcrumb-divider !default;\n$breadcrumb-border-radius:          null !default;\n// scss-docs-end breadcrumb-variables\n\n// Carousel\n\n// scss-docs-start carousel-variables\n$carousel-control-color:             $white !default;\n$carousel-control-width:             15% !default;\n$carousel-control-opacity:           .5 !default;\n$carousel-control-hover-opacity:     .9 !default;\n$carousel-control-transition:        opacity .15s ease !default;\n\n$carousel-indicator-width:           30px !default;\n$carousel-indicator-height:          3px !default;\n$carousel-indicator-hit-area-height: 10px !default;\n$carousel-indicator-spacer:          3px !default;\n$carousel-indicator-opacity:         .5 !default;\n$carousel-indicator-active-bg:       $white !default;\n$carousel-indicator-active-opacity:  1 !default;\n$carousel-indicator-transition:      opacity .6s ease !default;\n\n$carousel-caption-width:             70% !default;\n$carousel-caption-color:             $white !default;\n$carousel-caption-padding-y:         1.25rem !default;\n$carousel-caption-spacer:            1.25rem !default;\n\n$carousel-control-icon-width:        2rem !default;\n\n$carousel-control-prev-icon-bg:      url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='#{$carousel-control-color}'><path d='M11.354 1.646a.5.5 0 0 1 0 .708L5.707 8l5.647 5.646a.5.5 0 0 1-.708.708l-6-6a.5.5 0 0 1 0-.708l6-6a.5.5 0 0 1 .708 0z'/></svg>\") !default;\n$carousel-control-next-icon-bg:      url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='#{$carousel-control-color}'><path d='M4.646 1.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708L10.293 8 4.646 2.354a.5.5 0 0 1 0-.708z'/></svg>\") !default;\n\n$carousel-transition-duration:       .6s !default;\n$carousel-transition:                transform $carousel-transition-duration ease-in-out !default; // Define transform transition first if using multiple transitions (e.g., `transform 2s ease, opacity .5s ease-out`)\n// scss-docs-end carousel-variables\n\n// scss-docs-start carousel-dark-variables\n$carousel-dark-indicator-active-bg:  $black !default;\n$carousel-dark-caption-color:        $black !default;\n$carousel-dark-control-icon-filter:  invert(1) grayscale(100) !default;\n// scss-docs-end carousel-dark-variables\n\n\n// Spinners\n\n// scss-docs-start spinner-variables\n$spinner-width:           2rem !default;\n$spinner-height:          $spinner-width !default;\n$spinner-vertical-align:  -.125em !default;\n$spinner-border-width:    .25em !default;\n$spinner-animation-speed: .75s !default;\n\n$spinner-width-sm:        1rem !default;\n$spinner-height-sm:       $spinner-width-sm !default;\n$spinner-border-width-sm: .2em !default;\n// scss-docs-end spinner-variables\n\n\n// Close\n\n// scss-docs-start close-variables\n$btn-close-width:            1em !default;\n$btn-close-height:           $btn-close-width !default;\n$btn-close-padding-x:        .25em !default;\n$btn-close-padding-y:        $btn-close-padding-x !default;\n$btn-close-color:            $black !default;\n$btn-close-bg:               url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='#{$btn-close-color}'><path d='M.293.293a1 1 0 0 1 1.414 0L8 6.586 14.293.293a1 1 0 1 1 1.414 1.414L9.414 8l6.293 6.293a1 1 0 0 1-1.414 1.414L8 9.414l-6.293 6.293a1 1 0 0 1-1.414-1.414L6.586 8 .293 1.707a1 1 0 0 1 0-1.414z'/></svg>\") !default;\n$btn-close-focus-shadow:     $focus-ring-box-shadow !default;\n$btn-close-opacity:          .5 !default;\n$btn-close-hover-opacity:    .75 !default;\n$btn-close-focus-opacity:    1 !default;\n$btn-close-disabled-opacity: .25 !default;\n$btn-close-white-filter:     invert(1) grayscale(100%) brightness(200%) !default;\n// scss-docs-end close-variables\n\n\n// Offcanvas\n\n// scss-docs-start offcanvas-variables\n$offcanvas-padding-y:               $modal-inner-padding !default;\n$offcanvas-padding-x:               $modal-inner-padding !default;\n$offcanvas-horizontal-width:        400px !default;\n$offcanvas-vertical-height:         30vh !default;\n$offcanvas-transition-duration:     .3s !default;\n$offcanvas-border-color:            $modal-content-border-color !default;\n$offcanvas-border-width:            $modal-content-border-width !default;\n$offcanvas-title-line-height:       $modal-title-line-height !default;\n$offcanvas-bg-color:                var(--#{$prefix}body-bg) !default;\n$offcanvas-color:                   var(--#{$prefix}body-color) !default;\n$offcanvas-box-shadow:              $modal-content-box-shadow-xs !default;\n$offcanvas-backdrop-bg:             $modal-backdrop-bg !default;\n$offcanvas-backdrop-opacity:        $modal-backdrop-opacity !default;\n// scss-docs-end offcanvas-variables\n\n// Code\n\n$code-font-size:                    $small-font-size !default;\n// Amount intentionally matches mixture amount of shiny::inputPanel()\n// https://github.com/rstudio/shiny/blob/4eeb4a1/inst/www/shared/shiny_scss/bootstrap.scss#L25\n$code-bg:                           RGBA(var(--#{$prefix}emphasis-color-rgb, 0,0,0), 0.04) !default;\n$code-color:                        RGB(var(--#{$prefix}emphasis-color-rgb, 0,0,0)) !default;\n$code-color-dark:                   RGB(var(--#{$prefix}emphasis-color-rgb, 0,0,0)) !default;\n\n$kbd-padding-y:                     .1875rem !default;\n$kbd-padding-x:                     .375rem !default;\n$kbd-font-size:                     $code-font-size !default;\n$kbd-color:                         var(--#{$prefix}body-bg) !default;\n$kbd-bg:                            var(--#{$prefix}body-color) !default;\n$nested-kbd-font-weight:            null !default; // Deprecated in v5.2.0, removing in v6\n\n$pre-bg:                            $code-bg  !default;\n$pre-color:                         $code-color !default;\n",
		"// Dark color mode variables\n//\n// Custom variables for the `[data-bs-theme=\"dark\"]` theme. Use this as a starting point for your own custom color modes by creating a new theme-specific file like `_variables-dark.scss` and adding the variables you need.\n\n//\n// Global colors\n//\n\n// scss-docs-start sass-dark-mode-vars\n// scss-docs-start theme-text-dark-variables\n$primary-text-emphasis-dark:        tint-color($primary, 40%) !default;\n$secondary-text-emphasis-dark:      tint-color($secondary, 40%) !default;\n$success-text-emphasis-dark:        tint-color($success, 40%) !default;\n$info-text-emphasis-dark:           tint-color($info, 40%) !default;\n$warning-text-emphasis-dark:        tint-color($warning, 40%) !default;\n$danger-text-emphasis-dark:         tint-color($danger, 40%) !default;\n$light-text-emphasis-dark:          $gray-100 !default;\n$dark-text-emphasis-dark:           $gray-300 !default;\n// scss-docs-end theme-text-dark-variables\n\n// scss-docs-start theme-bg-subtle-dark-variables\n$primary-bg-subtle-dark:            shade-color($primary, 80%) !default;\n$secondary-bg-subtle-dark:          shade-color($secondary, 80%) !default;\n$success-bg-subtle-dark:            shade-color($success, 80%) !default;\n$info-bg-subtle-dark:               shade-color($info, 80%) !default;\n$warning-bg-subtle-dark:            shade-color($warning, 80%) !default;\n$danger-bg-subtle-dark:             shade-color($danger, 80%) !default;\n$light-bg-subtle-dark:              $gray-800 !default;\n$dark-bg-subtle-dark:               mix($gray-800, $black) !default;\n// scss-docs-end theme-bg-subtle-dark-variables\n\n// scss-docs-start theme-border-subtle-dark-variables\n$primary-border-subtle-dark:        shade-color($primary, 40%) !default;\n$secondary-border-subtle-dark:      shade-color($secondary, 40%) !default;\n$success-border-subtle-dark:        shade-color($success, 40%) !default;\n$info-border-subtle-dark:           shade-color($info, 40%) !default;\n$warning-border-subtle-dark:        shade-color($warning, 40%) !default;\n$danger-border-subtle-dark:         shade-color($danger, 40%) !default;\n$light-border-subtle-dark:          $gray-700 !default;\n$dark-border-subtle-dark:           $gray-800 !default;\n// scss-docs-end theme-border-subtle-dark-variables\n\n$body-color-dark:                   $gray-300 !default;\n$body-bg-dark:                      $gray-900 !default;\n$body-secondary-color-dark:         rgba($body-color-dark, .75) !default;\n$body-secondary-bg-dark:            $gray-800 !default;\n$body-tertiary-color-dark:          rgba($body-color-dark, .5) !default;\n$body-tertiary-bg-dark:             mix($gray-800, $gray-900, 50%) !default;\n$body-emphasis-color-dark:          $white !default;\n$border-color-dark:                 $gray-700 !default;\n$border-color-translucent-dark:     rgba($white, .15) !default;\n$headings-color-dark:               inherit !default;\n$link-color-dark:                   tint-color($primary, 40%) !default;\n$link-hover-color-dark:             shift-color($link-color-dark, -$link-shade-percentage) !default;\n$code-color-dark:                   tint-color($code-color, 40%) !default;\n\n\n//\n// Forms\n//\n\n$form-select-indicator-color-dark:  $body-color-dark !default;\n$form-select-indicator-dark:        url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path fill='none' stroke='#{$form-select-indicator-color-dark}' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/></svg>\") !default;\n\n$form-switch-color-dark:            rgba($white, .25) !default;\n$form-switch-bg-image-dark:         url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'><circle r='3' fill='#{$form-switch-color-dark}'/></svg>\") !default;\n\n// scss-docs-start form-validation-colors-dark\n$form-valid-color-dark:             $green-300 !default;\n$form-valid-border-color-dark:      $green-300 !default;\n$form-invalid-color-dark:           $red-300 !default;\n$form-invalid-border-color-dark:    $red-300 !default;\n// scss-docs-end form-validation-colors-dark\n\n\n//\n// Accordion\n//\n\n$accordion-icon-color-dark:         $primary-text-emphasis-dark !default;\n$accordion-icon-active-color-dark:  $primary-text-emphasis-dark !default;\n\n$accordion-button-icon-dark:         url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='#{$accordion-icon-color-dark}'><path fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/></svg>\") !default;\n$accordion-button-active-icon-dark:  url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='#{$accordion-icon-active-color-dark}'><path fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/></svg>\") !default;\n// scss-docs-end sass-dark-mode-vars\n",
		"// Re-assigned maps\n//\n// Placed here so that others can override the default Sass maps and see automatic updates to utilities and more.\n\n// scss-docs-start theme-colors-rgb\n$theme-colors-rgb: map-loop($theme-colors, to-rgb, \"$value\") !default;\n// scss-docs-end theme-colors-rgb\n\n// scss-docs-start theme-text-map\n$theme-colors-text: (\n  \"primary\": $primary-text-emphasis,\n  \"secondary\": $secondary-text-emphasis,\n  \"success\": $success-text-emphasis,\n  \"info\": $info-text-emphasis,\n  \"warning\": $warning-text-emphasis,\n  \"danger\": $danger-text-emphasis,\n  \"light\": $light-text-emphasis,\n  \"dark\": $dark-text-emphasis,\n) !default;\n// scss-docs-end theme-text-map\n\n// scss-docs-start theme-bg-subtle-map\n$theme-colors-bg-subtle: (\n  \"primary\": $primary-bg-subtle,\n  \"secondary\": $secondary-bg-subtle,\n  \"success\": $success-bg-subtle,\n  \"info\": $info-bg-subtle,\n  \"warning\": $warning-bg-subtle,\n  \"danger\": $danger-bg-subtle,\n  \"light\": $light-bg-subtle,\n  \"dark\": $dark-bg-subtle,\n) !default;\n// scss-docs-end theme-bg-subtle-map\n\n// scss-docs-start theme-border-subtle-map\n$theme-colors-border-subtle: (\n  \"primary\": $primary-border-subtle,\n  \"secondary\": $secondary-border-subtle,\n  \"success\": $success-border-subtle,\n  \"info\": $info-border-subtle,\n  \"warning\": $warning-border-subtle,\n  \"danger\": $danger-border-subtle,\n  \"light\": $light-border-subtle,\n  \"dark\": $dark-border-subtle,\n) !default;\n// scss-docs-end theme-border-subtle-map\n\n$theme-colors-text-dark: null !default;\n$theme-colors-bg-subtle-dark: null !default;\n$theme-colors-border-subtle-dark: null !default;\n\n@if $enable-dark-mode {\n  // scss-docs-start theme-text-dark-map\n  $theme-colors-text-dark: (\n    \"primary\": $primary-text-emphasis-dark,\n    \"secondary\": $secondary-text-emphasis-dark,\n    \"success\": $success-text-emphasis-dark,\n    \"info\": $info-text-emphasis-dark,\n    \"warning\": $warning-text-emphasis-dark,\n    \"danger\": $danger-text-emphasis-dark,\n    \"light\": $light-text-emphasis-dark,\n    \"dark\": $dark-text-emphasis-dark,\n  ) !default;\n  // scss-docs-end theme-text-dark-map\n\n  // scss-docs-start theme-bg-subtle-dark-map\n  $theme-colors-bg-subtle-dark: (\n    \"primary\": $primary-bg-subtle-dark,\n    \"secondary\": $secondary-bg-subtle-dark,\n    \"success\": $success-bg-subtle-dark,\n    \"info\": $info-bg-subtle-dark,\n    \"warning\": $warning-bg-subtle-dark,\n    \"danger\": $danger-bg-subtle-dark,\n    \"light\": $light-bg-subtle-dark,\n    \"dark\": $dark-bg-subtle-dark,\n  ) !default;\n  // scss-docs-end theme-bg-subtle-dark-map\n\n  // scss-docs-start theme-border-subtle-dark-map\n  $theme-colors-border-subtle-dark: (\n    \"primary\": $primary-border-subtle-dark,\n    \"secondary\": $secondary-border-subtle-dark,\n    \"success\": $success-border-subtle-dark,\n    \"info\": $info-border-subtle-dark,\n    \"warning\": $warning-border-subtle-dark,\n    \"danger\": $danger-border-subtle-dark,\n    \"light\": $light-border-subtle-dark,\n    \"dark\": $dark-border-subtle-dark,\n  ) !default;\n  // scss-docs-end theme-border-subtle-dark-map\n}\n\n// Utilities maps\n//\n// Extends the default `$theme-colors` maps to help create our utilities.\n\n// Come v6, we'll de-dupe these variables. Until then, for backward compatibility, we keep them to reassign.\n// scss-docs-start utilities-colors\n$utilities-colors: $theme-colors-rgb !default;\n// scss-docs-end utilities-colors\n\n// scss-docs-start utilities-text-colors\n$utilities-text: map-merge(\n  $utilities-colors,\n  (\n    \"black\": to-rgb($black),\n    \"white\": to-rgb($white),\n    \"body\": to-rgb($body-color)\n  )\n) !default;\n$utilities-text-colors: map-loop($utilities-text, rgba-css-var, \"$key\", \"text\") !default;\n\n$utilities-text-emphasis-colors: (\n  \"primary-emphasis\": var(--#{$prefix}primary-text-emphasis),\n  \"secondary-emphasis\": var(--#{$prefix}secondary-text-emphasis),\n  \"success-emphasis\": var(--#{$prefix}success-text-emphasis),\n  \"info-emphasis\": var(--#{$prefix}info-text-emphasis),\n  \"warning-emphasis\": var(--#{$prefix}warning-text-emphasis),\n  \"danger-emphasis\": var(--#{$prefix}danger-text-emphasis),\n  \"light-emphasis\": var(--#{$prefix}light-text-emphasis),\n  \"dark-emphasis\": var(--#{$prefix}dark-text-emphasis)\n) !default;\n// scss-docs-end utilities-text-colors\n\n// scss-docs-start utilities-bg-colors\n$utilities-bg: map-merge(\n  $utilities-colors,\n  (\n    \"black\": to-rgb($black),\n    \"white\": to-rgb($white),\n    \"body\": to-rgb($body-bg)\n  )\n) !default;\n$utilities-bg-colors: map-loop($utilities-bg, rgba-css-var, \"$key\", \"bg\") !default;\n\n$utilities-bg-subtle: (\n  \"primary-subtle\": var(--#{$prefix}primary-bg-subtle),\n  \"secondary-subtle\": var(--#{$prefix}secondary-bg-subtle),\n  \"success-subtle\": var(--#{$prefix}success-bg-subtle),\n  \"info-subtle\": var(--#{$prefix}info-bg-subtle),\n  \"warning-subtle\": var(--#{$prefix}warning-bg-subtle),\n  \"danger-subtle\": var(--#{$prefix}danger-bg-subtle),\n  \"light-subtle\": var(--#{$prefix}light-bg-subtle),\n  \"dark-subtle\": var(--#{$prefix}dark-bg-subtle)\n) !default;\n// scss-docs-end utilities-bg-colors\n\n// scss-docs-start utilities-border-colors\n$utilities-border: map-merge(\n  $utilities-colors,\n  (\n    \"black\": to-rgb($black),\n    \"white\": to-rgb($white)\n  )\n) !default;\n$utilities-border-colors: map-loop($utilities-border, rgba-css-var, \"$key\", \"border\") !default;\n\n$utilities-border-subtle: (\n  \"primary-subtle\": var(--#{$prefix}primary-border-subtle),\n  \"secondary-subtle\": var(--#{$prefix}secondary-border-subtle),\n  \"success-subtle\": var(--#{$prefix}success-border-subtle),\n  \"info-subtle\": var(--#{$prefix}info-border-subtle),\n  \"warning-subtle\": var(--#{$prefix}warning-border-subtle),\n  \"danger-subtle\": var(--#{$prefix}danger-border-subtle),\n  \"light-subtle\": var(--#{$prefix}light-border-subtle),\n  \"dark-subtle\": var(--#{$prefix}dark-border-subtle)\n) !default;\n// scss-docs-end utilities-border-colors\n\n$utilities-links-underline: map-loop($utilities-colors, rgba-css-var, \"$key\", \"link-underline\") !default;\n\n$negative-spacers: if($enable-negative-margins, negativify-map($spacers), null) !default;\n\n$gutters: $spacers !default;\n",
		"// Toggles\n//\n// Used in conjunction with global variables to enable certain theme features.\n\n// Vendor\n@import \"vendor/rfs\";\n\n// Deprecate\n@import \"mixins/deprecate\";\n\n// Helpers\n@import \"mixins/breakpoints\";\n@import \"mixins/color-mode\";\n@import \"mixins/color-scheme\";\n@import \"mixins/image\";\n@import \"mixins/resize\";\n@import \"mixins/visually-hidden\";\n@import \"mixins/reset-text\";\n@import \"mixins/text-truncate\";\n\n// Utilities\n@import \"mixins/utilities\";\n\n// Components\n@import \"mixins/backdrop\";\n@import \"mixins/buttons\";\n@import \"mixins/caret\";\n@import \"mixins/pagination\";\n@import \"mixins/lists\";\n@import \"mixins/forms\";\n@import \"mixins/table-variants\";\n\n// Skins\n@import \"mixins/border-radius\";\n@import \"mixins/box-shadow\";\n@import \"mixins/gradients\";\n@import \"mixins/transition\";\n\n// Layout\n@import \"mixins/clearfix\";\n@import \"mixins/container\";\n@import \"mixins/grid\";\n",
		"// stylelint-disable scss/dimension-no-non-numeric-values\n\n// SCSS RFS mixin\n//\n// Automated responsive values for font sizes, paddings, margins and much more\n//\n// Licensed under MIT (https://github.com/twbs/rfs/blob/main/LICENSE)\n\n// Configuration\n\n// Base value\n$rfs-base-value: 1.25rem !default;\n$rfs-unit: rem !default;\n\n@if $rfs-unit != rem and $rfs-unit != px {\n  @error \"`#{$rfs-unit}` is not a valid unit for $rfs-unit. Use `px` or `rem`.\";\n}\n\n// Breakpoint at where values start decreasing if screen width is smaller\n$rfs-breakpoint: 1200px !default;\n$rfs-breakpoint-unit: px !default;\n\n@if $rfs-breakpoint-unit != px and $rfs-breakpoint-unit != em and $rfs-breakpoint-unit != rem {\n  @error \"`#{$rfs-breakpoint-unit}` is not a valid unit for $rfs-breakpoint-unit. Use `px`, `em` or `rem`.\";\n}\n\n// Resize values based on screen height and width\n$rfs-two-dimensional: false !default;\n\n// Factor of decrease\n$rfs-factor: 10 !default;\n\n@if type-of($rfs-factor) != number or $rfs-factor <= 1 {\n  @error \"`#{$rfs-factor}` is not a valid  $rfs-factor, it must be greater than 1.\";\n}\n\n// Mode. Possibilities: \"min-media-query\", \"max-media-query\"\n$rfs-mode: min-media-query !default;\n\n// Generate enable or disable classes. Possibilities: false, \"enable\" or \"disable\"\n$rfs-class: false !default;\n\n// 1 rem = $rfs-rem-value px\n$rfs-rem-value: 16 !default;\n\n// Safari iframe resize bug: https://github.com/twbs/rfs/issues/14\n$rfs-safari-iframe-resize-bug-fix: false !default;\n\n// Disable RFS by setting $enable-rfs to false\n$enable-rfs: true !default;\n\n// Cache $rfs-base-value unit\n$rfs-base-value-unit: unit($rfs-base-value);\n\n@function divide($dividend, $divisor, $precision: 10) {\n  $sign: if($dividend > 0 and $divisor > 0 or $dividend < 0 and $divisor < 0, 1, -1);\n  $dividend: abs($dividend);\n  $divisor: abs($divisor);\n  @if $dividend == 0 {\n    @return 0;\n  }\n  @if $divisor == 0 {\n    @error \"Cannot divide by 0\";\n  }\n  $remainder: $dividend;\n  $result: 0;\n  $factor: 10;\n  @while ($remainder > 0 and $precision >= 0) {\n    $quotient: 0;\n    @while ($remainder >= $divisor) {\n      $remainder: $remainder - $divisor;\n      $quotient: $quotient + 1;\n    }\n    $result: $result * 10 + $quotient;\n    $factor: $factor * .1;\n    $remainder: $remainder * 10;\n    $precision: $precision - 1;\n    @if ($precision < 0 and $remainder >= $divisor * 5) {\n      $result: $result + 1;\n    }\n  }\n  $result: $result * $factor * $sign;\n  $dividend-unit: unit($dividend);\n  $divisor-unit: unit($divisor);\n  $unit-map: (\n    \"px\": 1px,\n    \"rem\": 1rem,\n    \"em\": 1em,\n    \"%\": 1%\n  );\n  @if ($dividend-unit != $divisor-unit and map-has-key($unit-map, $dividend-unit)) {\n    $result: $result * map-get($unit-map, $dividend-unit);\n  }\n  @return $result;\n}\n\n// Remove px-unit from $rfs-base-value for calculations\n@if $rfs-base-value-unit == px {\n  $rfs-base-value: divide($rfs-base-value, $rfs-base-value * 0 + 1);\n}\n@else if $rfs-base-value-unit == rem {\n  $rfs-base-value: divide($rfs-base-value, divide($rfs-base-value * 0 + 1, $rfs-rem-value));\n}\n\n// Cache $rfs-breakpoint unit to prevent multiple calls\n$rfs-breakpoint-unit-cache: unit($rfs-breakpoint);\n\n// Remove unit from $rfs-breakpoint for calculations\n@if $rfs-breakpoint-unit-cache == px {\n  $rfs-breakpoint: divide($rfs-breakpoint, $rfs-breakpoint * 0 + 1);\n}\n@else if $rfs-breakpoint-unit-cache == rem or $rfs-breakpoint-unit-cache == \"em\" {\n  $rfs-breakpoint: divide($rfs-breakpoint, divide($rfs-breakpoint * 0 + 1, $rfs-rem-value));\n}\n\n// Calculate the media query value\n$rfs-mq-value: if($rfs-breakpoint-unit == px, #{$rfs-breakpoint}px, #{divide($rfs-breakpoint, $rfs-rem-value)}#{$rfs-breakpoint-unit});\n$rfs-mq-property-width: if($rfs-mode == max-media-query, max-width, min-width);\n$rfs-mq-property-height: if($rfs-mode == max-media-query, max-height, min-height);\n\n// Internal mixin used to determine which media query needs to be used\n@mixin _rfs-media-query {\n  @if $rfs-two-dimensional {\n    @if $rfs-mode == max-media-query {\n      @media (#{$rfs-mq-property-width}: #{$rfs-mq-value}), (#{$rfs-mq-property-height}: #{$rfs-mq-value}) {\n        @content;\n      }\n    }\n    @else {\n      @media (#{$rfs-mq-property-width}: #{$rfs-mq-value}) and (#{$rfs-mq-property-height}: #{$rfs-mq-value}) {\n        @content;\n      }\n    }\n  }\n  @else {\n    @media (#{$rfs-mq-property-width}: #{$rfs-mq-value}) {\n      @content;\n    }\n  }\n}\n\n// Internal mixin that adds disable classes to the selector if needed.\n@mixin _rfs-rule {\n  @if $rfs-class == disable and $rfs-mode == max-media-query {\n    // Adding an extra class increases specificity, which prevents the media query to override the property\n    &,\n    .disable-rfs &,\n    &.disable-rfs {\n      @content;\n    }\n  }\n  @else if $rfs-class == enable and $rfs-mode == min-media-query {\n    .enable-rfs &,\n    &.enable-rfs {\n      @content;\n    }\n  } @else {\n    @content;\n  }\n}\n\n// Internal mixin that adds enable classes to the selector if needed.\n@mixin _rfs-media-query-rule {\n\n  @if $rfs-class == enable {\n    @if $rfs-mode == min-media-query {\n      @content;\n    }\n\n    @include _rfs-media-query () {\n      .enable-rfs &,\n      &.enable-rfs {\n        @content;\n      }\n    }\n  }\n  @else {\n    @if $rfs-class == disable and $rfs-mode == min-media-query {\n      .disable-rfs &,\n      &.disable-rfs {\n        @content;\n      }\n    }\n    @include _rfs-media-query () {\n      @content;\n    }\n  }\n}\n\n// Helper function to get the formatted non-responsive value\n@function rfs-value($values) {\n  // Convert to list\n  $values: if(type-of($values) != list, ($values,), $values);\n\n  $val: \"\";\n\n  // Loop over each value and calculate value\n  @each $value in $values {\n    @if $value == 0 {\n      $val: $val + \" 0\";\n    }\n    @else {\n      // Cache $value unit\n      $unit: if(type-of($value) == \"number\", unit($value), false);\n\n      @if $unit == px {\n        // Convert to rem if needed\n        $val: $val + \" \" + if($rfs-unit == rem, #{divide($value, $value * 0 + $rfs-rem-value)}rem, $value);\n      }\n      @else if $unit == rem {\n        // Convert to px if needed\n        $val: $val + \" \" + if($rfs-unit == px, #{divide($value, $value * 0 + 1) * $rfs-rem-value}px, $value);\n      } @else {\n        // If $value isn't a number (like inherit) or $value has a unit (not px or rem, like 1.5em) or $ is 0, just print the value\n        $val: $val + \" \" + $value;\n      }\n    }\n  }\n\n  // Remove first space\n  @return unquote(str-slice($val, 2));\n}\n\n// Helper function to get the responsive value calculated by RFS\n@function rfs-fluid-value($values) {\n  // Convert to list\n  $values: if(type-of($values) != list, ($values,), $values);\n\n  $val: \"\";\n\n  // Loop over each value and calculate value\n  @each $value in $values {\n    @if $value == 0 {\n      $val: $val + \" 0\";\n    } @else {\n      // Cache $value unit\n      $unit: if(type-of($value) == \"number\", unit($value), false);\n\n      // If $value isn't a number (like inherit) or $value has a unit (not px or rem, like 1.5em) or $ is 0, just print the value\n      @if not $unit or $unit != px and $unit != rem {\n        $val: $val + \" \" + $value;\n      } @else {\n        // Remove unit from $value for calculations\n        $value: divide($value, $value * 0 + if($unit == px, 1, divide(1, $rfs-rem-value)));\n\n        // Only add the media query if the value is greater than the minimum value\n        @if abs($value) <= $rfs-base-value or not $enable-rfs {\n          $val: $val + \" \" + if($rfs-unit == rem, #{divide($value, $rfs-rem-value)}rem, #{$value}px);\n        }\n        @else {\n          // Calculate the minimum value\n          $value-min: $rfs-base-value + divide(abs($value) - $rfs-base-value, $rfs-factor);\n\n          // Calculate difference between $value and the minimum value\n          $value-diff: abs($value) - $value-min;\n\n          // Base value formatting\n          $min-width: if($rfs-unit == rem, #{divide($value-min, $rfs-rem-value)}rem, #{$value-min}px);\n\n          // Use negative value if needed\n          $min-width: if($value < 0, -$min-width, $min-width);\n\n          // Use `vmin` if two-dimensional is enabled\n          $variable-unit: if($rfs-two-dimensional, vmin, vw);\n\n          // Calculate the variable width between 0 and $rfs-breakpoint\n          $variable-width: #{divide($value-diff * 100, $rfs-breakpoint)}#{$variable-unit};\n\n          // Return the calculated value\n          $val: $val + \" calc(\" + $min-width + if($value < 0, \" - \", \" + \") + $variable-width + \")\";\n        }\n      }\n    }\n  }\n\n  // Remove first space\n  @return unquote(str-slice($val, 2));\n}\n\n// RFS mixin\n@mixin rfs($values, $property: font-size) {\n  @if $values != null {\n    $val: rfs-value($values);\n    $fluid-val: rfs-fluid-value($values);\n\n    // Do not print the media query if responsive & non-responsive values are the same\n    @if $val == $fluid-val {\n      #{$property}: $val;\n    }\n    @else {\n      @include _rfs-rule () {\n        #{$property}: if($rfs-mode == max-media-query, $val, $fluid-val);\n\n        // Include safari iframe resize fix if needed\n        min-width: if($rfs-safari-iframe-resize-bug-fix, (0 * 1vw), null);\n      }\n\n      @include _rfs-media-query-rule () {\n        #{$property}: if($rfs-mode == max-media-query, $fluid-val, $val);\n      }\n    }\n  }\n}\n\n// Shorthand helper mixins\n@mixin font-size($value) {\n  @include rfs($value);\n}\n\n@mixin padding($value) {\n  @include rfs($value, padding);\n}\n\n@mixin padding-top($value) {\n  @include rfs($value, padding-top);\n}\n\n@mixin padding-right($value) {\n  @include rfs($value, padding-right);\n}\n\n@mixin padding-bottom($value) {\n  @include rfs($value, padding-bottom);\n}\n\n@mixin padding-left($value) {\n  @include rfs($value, padding-left);\n}\n\n@mixin margin($value) {\n  @include rfs($value, margin);\n}\n\n@mixin margin-top($value) {\n  @include rfs($value, margin-top);\n}\n\n@mixin margin-right($value) {\n  @include rfs($value, margin-right);\n}\n\n@mixin margin-bottom($value) {\n  @include rfs($value, margin-bottom);\n}\n\n@mixin margin-left($value) {\n  @include rfs($value, margin-left);\n}\n",
		"// Deprecate mixin\n//\n// This mixin can be used to deprecate mixins or functions.\n// `$enable-deprecation-messages` is a global variable, `$ignore-warning` is a variable that can be passed to\n// some deprecated mixins to suppress the warning (for example if the mixin is still be used in the current version of Bootstrap)\n@mixin deprecate($name, $deprecate-version, $remove-version, $ignore-warning: false) {\n  @if ($enable-deprecation-messages != false and $ignore-warning != true) {\n    @warn \"#{$name} has been deprecated as of #{$deprecate-version}. It will be removed entirely in #{$remove-version}.\";\n  }\n}\n",
		"// Breakpoint viewport sizes and media queries.\n//\n// Breakpoints are defined as a map of (name: minimum width), order from small to large:\n//\n//    (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px, xxl: 1400px)\n//\n// The map defined in the `$grid-breakpoints` global variable is used as the `$breakpoints` argument by default.\n\n// Name of the next breakpoint, or null for the last breakpoint.\n//\n//    >> breakpoint-next(sm)\n//    md\n//    >> breakpoint-next(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px, xxl: 1400px))\n//    md\n//    >> breakpoint-next(sm, $breakpoint-names: (xs sm md lg xl xxl))\n//    md\n@function breakpoint-next($name, $breakpoints: $grid-breakpoints, $breakpoint-names: map-keys($breakpoints)) {\n  $n: index($breakpoint-names, $name);\n  @if not $n {\n    @error \"breakpoint `#{$name}` not found in `#{$breakpoints}`\";\n  }\n  @return if($n < length($breakpoint-names), nth($breakpoint-names, $n + 1), null);\n}\n\n// Minimum breakpoint width. Null for the smallest (first) breakpoint.\n//\n//    >> breakpoint-min(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px, xxl: 1400px))\n//    576px\n@function breakpoint-min($name, $breakpoints: $grid-breakpoints) {\n  $min: map-get($breakpoints, $name);\n  @return if($min != 0, $min, null);\n}\n\n// Maximum breakpoint width.\n// The maximum value is reduced by 0.02px to work around the limitations of\n// `min-` and `max-` prefixes and viewports with fractional widths.\n// See https://www.w3.org/TR/mediaqueries-4/#mq-min-max\n// Uses 0.02px rather than 0.01px to work around a current rounding bug in Safari.\n// See https://bugs.webkit.org/show_bug.cgi?id=178261\n//\n//    >> breakpoint-max(md, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px, xxl: 1400px))\n//    767.98px\n@function breakpoint-max($name, $breakpoints: $grid-breakpoints) {\n  $max: map-get($breakpoints, $name);\n  @return if($max and $max > 0, $max - .02, null);\n}\n\n// Returns a blank string if smallest breakpoint, otherwise returns the name with a dash in front.\n// Useful for making responsive utilities.\n//\n//    >> breakpoint-infix(xs, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px, xxl: 1400px))\n//    \"\"  (Returns a blank string)\n//    >> breakpoint-infix(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px, xxl: 1400px))\n//    \"-sm\"\n@function breakpoint-infix($name, $breakpoints: $grid-breakpoints) {\n  @return if(breakpoint-min($name, $breakpoints) == null, \"\", \"-#{$name}\");\n}\n\n// Media of at least the minimum breakpoint width. No query for the smallest breakpoint.\n// Makes the @content apply to the given breakpoint and wider.\n@mixin media-breakpoint-up($name, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($name, $breakpoints);\n  @if $min {\n    @media (min-width: $min) {\n      @content;\n    }\n  } @else {\n    @content;\n  }\n}\n\n// Media of at most the maximum breakpoint width. No query for the largest breakpoint.\n// Makes the @content apply to the given breakpoint and narrower.\n@mixin media-breakpoint-down($name, $breakpoints: $grid-breakpoints) {\n  $max: breakpoint-max($name, $breakpoints);\n  @if $max {\n    @media (max-width: $max) {\n      @content;\n    }\n  } @else {\n    @content;\n  }\n}\n\n// Media that spans multiple breakpoint widths.\n// Makes the @content apply between the min and max breakpoints\n@mixin media-breakpoint-between($lower, $upper, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($lower, $breakpoints);\n  $max: breakpoint-max($upper, $breakpoints);\n\n  @if $min != null and $max != null {\n    @media (min-width: $min) and (max-width: $max) {\n      @content;\n    }\n  } @else if $max == null {\n    @include media-breakpoint-up($lower, $breakpoints) {\n      @content;\n    }\n  } @else if $min == null {\n    @include media-breakpoint-down($upper, $breakpoints) {\n      @content;\n    }\n  }\n}\n\n// Media between the breakpoint's minimum and maximum widths.\n// No minimum for the smallest breakpoint, and no maximum for the largest one.\n// Makes the @content apply only to the given breakpoint, not viewports any wider or narrower.\n@mixin media-breakpoint-only($name, $breakpoints: $grid-breakpoints) {\n  $min:  breakpoint-min($name, $breakpoints);\n  $next: breakpoint-next($name, $breakpoints);\n  $max:  breakpoint-max($next, $breakpoints);\n\n  @if $min != null and $max != null {\n    @media (min-width: $min) and (max-width: $max) {\n      @content;\n    }\n  } @else if $max == null {\n    @include media-breakpoint-up($name, $breakpoints) {\n      @content;\n    }\n  } @else if $min == null {\n    @include media-breakpoint-down($next, $breakpoints) {\n      @content;\n    }\n  }\n}\n",
		"// scss-docs-start color-mode-mixin\n@mixin color-mode($mode: light, $root: false) {\n  @if $color-mode-type == \"media-query\" {\n    @if $root == true {\n      @media (prefers-color-scheme: $mode) {\n        :root {\n          @content;\n        }\n      }\n    } @else {\n      @media (prefers-color-scheme: $mode) {\n        @content;\n      }\n    }\n  } @else {\n    [data-bs-theme=\"#{$mode}\"] {\n      @content;\n    }\n  }\n}\n// scss-docs-end color-mode-mixin\n",
		"// scss-docs-start mixin-color-scheme\n@mixin color-scheme($name) {\n  @media (prefers-color-scheme: #{$name}) {\n    @content;\n  }\n}\n// scss-docs-end mixin-color-scheme\n",
		"// Image Mixins\n// - Responsive image\n// - Retina image\n\n\n// Responsive image\n//\n// Keep images from scaling beyond the width of their parents.\n\n@mixin img-fluid {\n  // Part 1: Set a maximum relative to the parent\n  max-width: 100%;\n  // Part 2: Override the height to auto, otherwise images will be stretched\n  // when setting a width and height attribute on the img element.\n  height: auto;\n}\n",
		"// Resize anything\n\n@mixin resizable($direction) {\n  overflow: auto; // Per CSS3 UI, `resize` only applies when `overflow` isn't `visible`\n  resize: $direction; // Options: horizontal, vertical, both\n}\n",
		"// stylelint-disable declaration-no-important\n\n// Hide content visually while keeping it accessible to assistive technologies\n//\n// See: https://www.a11yproject.com/posts/2013-01-11-how-to-hide-content/\n// See: https://kittygiraudel.com/2016/10/13/css-hide-and-seek/\n\n@mixin visually-hidden() {\n  width: 1px !important;\n  height: 1px !important;\n  padding: 0 !important;\n  margin: -1px !important; // Fix for https://github.com/twbs/bootstrap/issues/25686\n  overflow: hidden !important;\n  clip: rect(0, 0, 0, 0) !important;\n  white-space: nowrap !important;\n  border: 0 !important;\n\n  // Fix for positioned table caption that could become anonymous cells\n  &:not(caption) {\n    position: absolute !important;\n  }\n}\n\n// Use to only display content when it's focused, or one of its child elements is focused\n// (i.e. when focus is within the element/container that the class was applied to)\n//\n// Useful for \"Skip to main content\" links; see https://www.w3.org/TR/2013/NOTE-WCAG20-TECHS-20130905/G1\n\n@mixin visually-hidden-focusable() {\n  &:not(:focus):not(:focus-within) {\n    @include visually-hidden();\n  }\n}\n",
		"@mixin reset-text {\n  font-family: $font-family-base;\n  // We deliberately do NOT reset font-size or overflow-wrap / word-wrap.\n  font-style: normal;\n  font-weight: $font-weight-normal;\n  line-height: $line-height-base;\n  text-align: left; // Fallback for where `start` is not supported\n  text-align: start;\n  text-decoration: none;\n  text-shadow: none;\n  text-transform: none;\n  letter-spacing: normal;\n  word-break: normal;\n  white-space: normal;\n  word-spacing: normal;\n  line-break: auto;\n}\n",
		"// Text truncate\n// Requires inline-block or block for proper styling\n\n@mixin text-truncate() {\n  overflow: hidden;\n  text-overflow: ellipsis;\n  white-space: nowrap;\n}\n",
		"// Utility generator\n// Used to generate utilities & print utilities\n@mixin generate-utility($utility, $infix: \"\", $is-rfs-media-query: false) {\n  $values: map-get($utility, values);\n\n  // If the values are a list or string, convert it into a map\n  @if type-of($values) == \"string\" or type-of(nth($values, 1)) != \"list\" {\n    $values: zip($values, $values);\n  }\n\n  @each $key, $value in $values {\n    $properties: map-get($utility, property);\n\n    // Multiple properties are possible, for example with vertical or horizontal margins or paddings\n    @if type-of($properties) == \"string\" {\n      $properties: append((), $properties);\n    }\n\n    // Use custom class if present\n    $property-class: if(map-has-key($utility, class), map-get($utility, class), nth($properties, 1));\n    $property-class: if($property-class == null, \"\", $property-class);\n\n    // Use custom CSS variable name if present, otherwise default to `class`\n    $css-variable-name: if(map-has-key($utility, css-variable-name), map-get($utility, css-variable-name), map-get($utility, class));\n\n    // State params to generate pseudo-classes\n    $state: if(map-has-key($utility, state), map-get($utility, state), ());\n\n    $infix: if($property-class == \"\" and str-slice($infix, 1, 1) == \"-\", str-slice($infix, 2), $infix);\n\n    // Don't prefix if value key is null (e.g. with shadow class)\n    $property-class-modifier: if($key, if($property-class == \"\" and $infix == \"\", \"\", \"-\") + $key, \"\");\n\n    @if map-get($utility, rfs) {\n      // Inside the media query\n      @if $is-rfs-media-query {\n        $val: rfs-value($value);\n\n        // Do not render anything if fluid and non fluid values are the same\n        $value: if($val == rfs-fluid-value($value), null, $val);\n      }\n      @else {\n        $value: rfs-fluid-value($value);\n      }\n    }\n\n    $is-css-var: map-get($utility, css-var);\n    $is-local-vars: map-get($utility, local-vars);\n    $is-rtl: map-get($utility, rtl);\n\n    @if $value != null {\n      @if $is-rtl == false {\n        /* rtl:begin:remove */\n      }\n\n      @if $is-css-var {\n        .#{$property-class + $infix + $property-class-modifier} {\n          --#{$prefix}#{$css-variable-name}: #{$value};\n        }\n\n        @each $pseudo in $state {\n          .#{$property-class + $infix + $property-class-modifier}-#{$pseudo}:#{$pseudo} {\n            --#{$prefix}#{$css-variable-name}: #{$value};\n          }\n        }\n      } @else {\n        .#{$property-class + $infix + $property-class-modifier} {\n          @each $property in $properties {\n            @if $is-local-vars {\n              @each $local-var, $variable in $is-local-vars {\n                --#{$prefix}#{$local-var}: #{$variable};\n              }\n            }\n            #{$property}: $value if($enable-important-utilities, !important, null);\n          }\n        }\n\n        @each $pseudo in $state {\n          .#{$property-class + $infix + $property-class-modifier}-#{$pseudo}:#{$pseudo} {\n            @each $property in $properties {\n              @if $is-local-vars {\n                @each $local-var, $variable in $is-local-vars {\n                  --#{$prefix}#{$local-var}: #{$variable};\n                }\n              }\n              #{$property}: $value if($enable-important-utilities, !important, null);\n            }\n          }\n        }\n      }\n\n      @if $is-rtl == false {\n        /* rtl:end:remove */\n      }\n    }\n  }\n}\n",
		"// Shared between modals and offcanvases\n@mixin overlay-backdrop($zindex, $backdrop-bg, $backdrop-opacity) {\n  position: fixed;\n  top: 0;\n  left: 0;\n  z-index: $zindex;\n  width: 100vw;\n  height: 100vh;\n  background-color: $backdrop-bg;\n\n  // Fade for backdrop\n  &.fade { opacity: 0; }\n  &.show { opacity: $backdrop-opacity; }\n}\n",
		"// Button variants\n//\n// Easily pump out default styles, as well as :hover, :focus, :active,\n// and disabled options for all buttons\n\n// scss-docs-start btn-variant-mixin\n@mixin button-variant(\n  $background,\n  $border,\n  $color: color-contrast($background),\n  $hover-background: if($color == $color-contrast-light, shade-color($background, $btn-hover-bg-shade-amount), tint-color($background, $btn-hover-bg-tint-amount)),\n  $hover-border: if($color == $color-contrast-light, shade-color($border, $btn-hover-border-shade-amount), tint-color($border, $btn-hover-border-tint-amount)),\n  $hover-color: color-contrast($hover-background),\n  $active-background: if($color == $color-contrast-light, shade-color($background, $btn-active-bg-shade-amount), tint-color($background, $btn-active-bg-tint-amount)),\n  $active-border: if($color == $color-contrast-light, shade-color($border, $btn-active-border-shade-amount), tint-color($border, $btn-active-border-tint-amount)),\n  $active-color: color-contrast($active-background),\n  $disabled-background: $background,\n  $disabled-border: $border,\n  $disabled-color: color-contrast($disabled-background)\n) {\n  --#{$prefix}btn-color: #{$color};\n  --#{$prefix}btn-bg: #{$background};\n  --#{$prefix}btn-border-color: #{$border};\n  --#{$prefix}btn-hover-color: #{$hover-color};\n  --#{$prefix}btn-hover-bg: #{$hover-background};\n  --#{$prefix}btn-hover-border-color: #{$hover-border};\n  --#{$prefix}btn-focus-shadow-rgb: #{to-rgb(mix($color, $border, 15%))};\n  --#{$prefix}btn-active-color: #{$active-color};\n  --#{$prefix}btn-active-bg: #{$active-background};\n  --#{$prefix}btn-active-border-color: #{$active-border};\n  --#{$prefix}btn-active-shadow: #{$btn-active-box-shadow};\n  --#{$prefix}btn-disabled-color: #{$disabled-color};\n  --#{$prefix}btn-disabled-bg: #{$disabled-background};\n  --#{$prefix}btn-disabled-border-color: #{$disabled-border};\n}\n// scss-docs-end btn-variant-mixin\n\n// scss-docs-start btn-outline-variant-mixin\n@mixin button-outline-variant(\n  $color,\n  $color-hover: color-contrast($color),\n  $active-background: $color,\n  $active-border: $color,\n  $active-color: color-contrast($active-background)\n) {\n  --#{$prefix}btn-color: #{$color};\n  --#{$prefix}btn-border-color: #{$color};\n  --#{$prefix}btn-hover-color: #{$color-hover};\n  --#{$prefix}btn-hover-bg: #{$active-background};\n  --#{$prefix}btn-hover-border-color: #{$active-border};\n  --#{$prefix}btn-focus-shadow-rgb: #{to-rgb($color)};\n  --#{$prefix}btn-active-color: #{$active-color};\n  --#{$prefix}btn-active-bg: #{$active-background};\n  --#{$prefix}btn-active-border-color: #{$active-border};\n  --#{$prefix}btn-active-shadow: #{$btn-active-box-shadow};\n  --#{$prefix}btn-disabled-color: #{$color};\n  --#{$prefix}btn-disabled-bg: transparent;\n  --#{$prefix}btn-disabled-border-color: #{$color};\n  --#{$prefix}btn-bg: transparent;\n  --#{$prefix}gradient: none;\n}\n// scss-docs-end btn-outline-variant-mixin\n\n// scss-docs-start btn-size-mixin\n@mixin button-size($padding-y, $padding-x, $font-size, $border-radius) {\n  --#{$prefix}btn-padding-y: #{$padding-y};\n  --#{$prefix}btn-padding-x: #{$padding-x};\n  @include rfs($font-size, --#{$prefix}btn-font-size);\n  --#{$prefix}btn-border-radius: #{$border-radius};\n}\n// scss-docs-end btn-size-mixin\n",
		"// scss-docs-start caret-mixins\n@mixin caret-down($width: $caret-width) {\n  border-top: $width solid;\n  border-right: $width solid transparent;\n  border-bottom: 0;\n  border-left: $width solid transparent;\n}\n\n@mixin caret-up($width: $caret-width) {\n  border-top: 0;\n  border-right: $width solid transparent;\n  border-bottom: $width solid;\n  border-left: $width solid transparent;\n}\n\n@mixin caret-end($width: $caret-width) {\n  border-top: $width solid transparent;\n  border-right: 0;\n  border-bottom: $width solid transparent;\n  border-left: $width solid;\n}\n\n@mixin caret-start($width: $caret-width) {\n  border-top: $width solid transparent;\n  border-right: $width solid;\n  border-bottom: $width solid transparent;\n}\n\n@mixin caret(\n  $direction: down,\n  $width: $caret-width,\n  $spacing: $caret-spacing,\n  $vertical-align: $caret-vertical-align\n) {\n  @if $enable-caret {\n    &::after {\n      display: inline-block;\n      margin-left: $spacing;\n      vertical-align: $vertical-align;\n      content: \"\";\n      @if $direction == down {\n        @include caret-down($width);\n      } @else if $direction == up {\n        @include caret-up($width);\n      } @else if $direction == end {\n        @include caret-end($width);\n      }\n    }\n\n    @if $direction == start {\n      &::after {\n        display: none;\n      }\n\n      &::before {\n        display: inline-block;\n        margin-right: $spacing;\n        vertical-align: $vertical-align;\n        content: \"\";\n        @include caret-start($width);\n      }\n    }\n\n    &:empty::after {\n      margin-left: 0;\n    }\n  }\n}\n// scss-docs-end caret-mixins\n",
		"// Pagination\n\n// scss-docs-start pagination-mixin\n@mixin pagination-size($padding-y, $padding-x, $font-size, $border-radius) {\n  --#{$prefix}pagination-padding-x: #{$padding-x};\n  --#{$prefix}pagination-padding-y: #{$padding-y};\n  @include rfs($font-size, --#{$prefix}pagination-font-size);\n  --#{$prefix}pagination-border-radius: #{$border-radius};\n}\n// scss-docs-end pagination-mixin\n",
		"// Lists\n\n// Unstyled keeps list items block level, just removes default browser padding and list-style\n@mixin list-unstyled {\n  padding-left: 0;\n  list-style: none;\n}\n",
		"// This mixin uses an `if()` technique to be compatible with Dart Sass\n// See https://github.com/sass/sass/issues/1873#issuecomment-152293725 for more details\n\n// scss-docs-start form-validation-mixins\n@mixin form-validation-state-selector($state) {\n  @if ($state == \"valid\" or $state == \"invalid\") {\n    .was-validated #{if(&, \"&\", \"\")}:#{$state},\n    #{if(&, \"&\", \"\")}.is-#{$state} {\n      @content;\n    }\n  } @else {\n    #{if(&, \"&\", \"\")}.is-#{$state} {\n      @content;\n    }\n  }\n}\n\n@mixin form-validation-state(\n  $state,\n  $color,\n  $icon,\n  $tooltip-color: color-contrast($color),\n  $tooltip-bg-color: rgba($color, $form-feedback-tooltip-opacity),\n  $focus-box-shadow: 0 0 $input-btn-focus-blur $input-focus-width rgba($color, $input-btn-focus-color-opacity),\n  $border-color: $color\n) {\n  .#{$state}-feedback {\n    display: none;\n    width: 100%;\n    margin-top: $form-feedback-margin-top;\n    @include font-size($form-feedback-font-size);\n    font-style: $form-feedback-font-style;\n    color: $color;\n  }\n\n  .#{$state}-tooltip {\n    position: absolute;\n    top: 100%;\n    z-index: 5;\n    display: none;\n    max-width: 100%; // Contain to parent when possible\n    padding: $form-feedback-tooltip-padding-y $form-feedback-tooltip-padding-x;\n    margin-top: .1rem;\n    @include font-size($form-feedback-tooltip-font-size);\n    line-height: $form-feedback-tooltip-line-height;\n    color: $tooltip-color;\n    background-color: $tooltip-bg-color;\n    @include border-radius($form-feedback-tooltip-border-radius);\n  }\n\n  @include form-validation-state-selector($state) {\n    ~ .#{$state}-feedback,\n    ~ .#{$state}-tooltip {\n      display: block;\n    }\n  }\n\n  .form-control {\n    @include form-validation-state-selector($state) {\n      border-color: $border-color;\n\n      @if $enable-validation-icons {\n        padding-right: $input-height-inner;\n        background-image: escape-svg($icon);\n        background-repeat: no-repeat;\n        background-position: right $input-height-inner-quarter center;\n        background-size: $input-height-inner-half $input-height-inner-half;\n      }\n\n      &:focus {\n        border-color: $border-color;\n        box-shadow: $focus-box-shadow;\n      }\n    }\n  }\n\n  // stylelint-disable-next-line selector-no-qualifying-type\n  textarea.form-control {\n    @include form-validation-state-selector($state) {\n      @if $enable-validation-icons {\n        padding-right: $input-height-inner;\n        background-position: top $input-height-inner-quarter right $input-height-inner-quarter;\n      }\n    }\n  }\n\n  .form-select {\n    @include form-validation-state-selector($state) {\n      border-color: $border-color;\n\n      @if $enable-validation-icons {\n        &:not([multiple]):not([size]),\n        &:not([multiple])[size=\"1\"] {\n          --#{$prefix}form-select-bg-icon: #{escape-svg($icon)};\n          padding-right: $form-select-feedback-icon-padding-end;\n          background-position: $form-select-bg-position, $form-select-feedback-icon-position;\n          background-size: $form-select-bg-size, $form-select-feedback-icon-size;\n        }\n      }\n\n      &:focus {\n        border-color: $border-color;\n        box-shadow: $focus-box-shadow;\n      }\n    }\n  }\n\n  .form-control-color {\n    @include form-validation-state-selector($state) {\n      @if $enable-validation-icons {\n        width: add($form-color-width, $input-height-inner);\n      }\n    }\n  }\n\n  .form-check-input {\n    @include form-validation-state-selector($state) {\n      border-color: $border-color;\n\n      &:checked {\n        background-color: $color;\n      }\n\n      &:focus {\n        box-shadow: $focus-box-shadow;\n      }\n\n      ~ .form-check-label {\n        color: $color;\n      }\n    }\n  }\n  .form-check-inline .form-check-input {\n    ~ .#{$state}-feedback {\n      margin-left: .5em;\n    }\n  }\n\n  .input-group {\n    > .form-control:not(:focus),\n    > .form-select:not(:focus),\n    > .form-floating:not(:focus-within) {\n      @include form-validation-state-selector($state) {\n        @if $state == \"valid\" {\n          z-index: 3;\n        } @else if $state == \"invalid\" {\n          z-index: 4;\n        }\n      }\n    }\n  }\n}\n// scss-docs-end form-validation-mixins\n",
		"// scss-docs-start table-variant\n@mixin table-variant($state, $background) {\n  .table-#{$state} {\n    $color: color-contrast(opaque($body-bg, $background));\n    $hover-bg: mix($color, $background, percentage($table-hover-bg-factor));\n    $striped-bg: mix($color, $background, percentage($table-striped-bg-factor));\n    $active-bg: mix($color, $background, percentage($table-active-bg-factor));\n    $table-border-color: mix($color, $background, percentage($table-border-factor));\n\n    --#{$prefix}table-color: #{$color};\n    --#{$prefix}table-bg: #{$background};\n    --#{$prefix}table-border-color: #{$table-border-color};\n    --#{$prefix}table-striped-bg: #{$striped-bg};\n    --#{$prefix}table-striped-color: #{color-contrast($striped-bg)};\n    --#{$prefix}table-active-bg: #{$active-bg};\n    --#{$prefix}table-active-color: #{color-contrast($active-bg)};\n    --#{$prefix}table-hover-bg: #{$hover-bg};\n    --#{$prefix}table-hover-color: #{color-contrast($hover-bg)};\n\n    color: var(--#{$prefix}table-color);\n    border-color: var(--#{$prefix}table-border-color);\n  }\n}\n// scss-docs-end table-variant\n",
		"// stylelint-disable property-disallowed-list\n// Single side border-radius\n\n// Helper function to replace negative values with 0\n@function valid-radius($radius) {\n  $return: ();\n  @each $value in $radius {\n    @if type-of($value) == number {\n      $return: append($return, max($value, 0));\n    } @else {\n      $return: append($return, $value);\n    }\n  }\n  @return $return;\n}\n\n// scss-docs-start border-radius-mixins\n@mixin border-radius($radius: $border-radius, $fallback-border-radius: false) {\n  @if $enable-rounded {\n    border-radius: valid-radius($radius);\n  }\n  @else if $fallback-border-radius != false {\n    border-radius: $fallback-border-radius;\n  }\n}\n\n@mixin border-top-radius($radius: $border-radius) {\n  @if $enable-rounded {\n    border-top-left-radius: valid-radius($radius);\n    border-top-right-radius: valid-radius($radius);\n  }\n}\n\n@mixin border-end-radius($radius: $border-radius) {\n  @if $enable-rounded {\n    border-top-right-radius: valid-radius($radius);\n    border-bottom-right-radius: valid-radius($radius);\n  }\n}\n\n@mixin border-bottom-radius($radius: $border-radius) {\n  @if $enable-rounded {\n    border-bottom-right-radius: valid-radius($radius);\n    border-bottom-left-radius: valid-radius($radius);\n  }\n}\n\n@mixin border-start-radius($radius: $border-radius) {\n  @if $enable-rounded {\n    border-top-left-radius: valid-radius($radius);\n    border-bottom-left-radius: valid-radius($radius);\n  }\n}\n\n@mixin border-top-start-radius($radius: $border-radius) {\n  @if $enable-rounded {\n    border-top-left-radius: valid-radius($radius);\n  }\n}\n\n@mixin border-top-end-radius($radius: $border-radius) {\n  @if $enable-rounded {\n    border-top-right-radius: valid-radius($radius);\n  }\n}\n\n@mixin border-bottom-end-radius($radius: $border-radius) {\n  @if $enable-rounded {\n    border-bottom-right-radius: valid-radius($radius);\n  }\n}\n\n@mixin border-bottom-start-radius($radius: $border-radius) {\n  @if $enable-rounded {\n    border-bottom-left-radius: valid-radius($radius);\n  }\n}\n// scss-docs-end border-radius-mixins\n",
		"@mixin box-shadow($shadow...) {\n  @if $enable-shadows {\n    $result: ();\n\n    @each $value in $shadow {\n      @if $value != null {\n        $result: append($result, $value, \"comma\");\n      }\n      @if $value == none and length($shadow) > 1 {\n        @warn \"The keyword 'none' must be used as a single argument.\";\n      }\n    }\n\n    @if (length($result) > 0) {\n      box-shadow: $result;\n    }\n  }\n}\n",
		"// Gradients\n\n// scss-docs-start gradient-bg-mixin\n@mixin gradient-bg($color: null) {\n  background-color: $color;\n\n  @if $enable-gradients {\n    background-image: var(--#{$prefix}gradient);\n  }\n}\n// scss-docs-end gradient-bg-mixin\n\n// scss-docs-start gradient-mixins\n// Horizontal gradient, from left to right\n//\n// Creates two color stops, start and end, by specifying a color and position for each color stop.\n@mixin gradient-x($start-color: $gray-700, $end-color: $gray-800, $start-percent: 0%, $end-percent: 100%) {\n  background-image: linear-gradient(to right, $start-color $start-percent, $end-color $end-percent);\n}\n\n// Vertical gradient, from top to bottom\n//\n// Creates two color stops, start and end, by specifying a color and position for each color stop.\n@mixin gradient-y($start-color: $gray-700, $end-color: $gray-800, $start-percent: null, $end-percent: null) {\n  background-image: linear-gradient(to bottom, $start-color $start-percent, $end-color $end-percent);\n}\n\n@mixin gradient-directional($start-color: $gray-700, $end-color: $gray-800, $deg: 45deg) {\n  background-image: linear-gradient($deg, $start-color, $end-color);\n}\n\n@mixin gradient-x-three-colors($start-color: $blue, $mid-color: $purple, $color-stop: 50%, $end-color: $red) {\n  background-image: linear-gradient(to right, $start-color, $mid-color $color-stop, $end-color);\n}\n\n@mixin gradient-y-three-colors($start-color: $blue, $mid-color: $purple, $color-stop: 50%, $end-color: $red) {\n  background-image: linear-gradient($start-color, $mid-color $color-stop, $end-color);\n}\n\n@mixin gradient-radial($inner-color: $gray-700, $outer-color: $gray-800) {\n  background-image: radial-gradient(circle, $inner-color, $outer-color);\n}\n\n@mixin gradient-striped($color: rgba($white, .15), $angle: 45deg) {\n  background-image: linear-gradient($angle, $color 25%, transparent 25%, transparent 50%, $color 50%, $color 75%, transparent 75%, transparent);\n}\n// scss-docs-end gradient-mixins\n",
		"// stylelint-disable property-disallowed-list\n@mixin transition($transition...) {\n  @if length($transition) == 0 {\n    $transition: $transition-base;\n  }\n\n  @if length($transition) > 1 {\n    @each $value in $transition {\n      @if $value == null or $value == none {\n        @warn \"The keyword 'none' or 'null' must be used as a single argument.\";\n      }\n    }\n  }\n\n  @if $enable-transitions {\n    @if nth($transition, 1) != null {\n      transition: $transition;\n    }\n\n    @if $enable-reduced-motion and nth($transition, 1) != null and nth($transition, 1) != none {\n      @media (prefers-reduced-motion: reduce) {\n        transition: none;\n      }\n    }\n  }\n}\n",
		"// scss-docs-start clearfix\n@mixin clearfix() {\n  &::after {\n    display: block;\n    clear: both;\n    content: \"\";\n  }\n}\n// scss-docs-end clearfix\n",
		"// Container mixins\n\n@mixin make-container($gutter: $container-padding-x) {\n  --#{$prefix}gutter-x: #{$gutter};\n  --#{$prefix}gutter-y: 0;\n  width: 100%;\n  padding-right: calc(var(--#{$prefix}gutter-x) * .5); // stylelint-disable-line function-disallowed-list\n  padding-left: calc(var(--#{$prefix}gutter-x) * .5); // stylelint-disable-line function-disallowed-list\n  margin-right: auto;\n  margin-left: auto;\n}\n",
		"// Grid system\n//\n// Generate semantic grid columns with these mixins.\n\n@mixin make-row($gutter: $grid-gutter-width) {\n  --#{$prefix}gutter-x: #{$gutter};\n  --#{$prefix}gutter-y: 0;\n  display: flex;\n  display: -webkit-flex;\n  flex-wrap: wrap;\n  -webkit-flex-wrap: wrap;\n  // TODO: Revisit calc order after https://github.com/react-bootstrap/react-bootstrap/issues/6039 is fixed\n  margin-top: calc(-1 * var(--#{$prefix}gutter-y)); // stylelint-disable-line function-disallowed-list\n  margin-right: calc(-.5 * var(--#{$prefix}gutter-x)); // stylelint-disable-line function-disallowed-list\n  margin-left: calc(-.5 * var(--#{$prefix}gutter-x)); // stylelint-disable-line function-disallowed-list\n}\n\n@mixin make-col-ready() {\n  // Add box sizing if only the grid is loaded\n  box-sizing: if(variable-exists(include-column-box-sizing) and $include-column-box-sizing, border-box, null);\n  // Prevent columns from becoming too narrow when at smaller grid tiers by\n  // always setting `width: 100%;`. This works because we set the width\n  // later on to override this initial width.\n  flex-shrink: 0;\n  -webkit-flex-shrink: 0;\n  width: 100%;\n  max-width: 100%; // Prevent `.col-auto`, `.col` (& responsive variants) from breaking out the grid\n  padding-right: calc(var(--#{$prefix}gutter-x) * .5); // stylelint-disable-line function-disallowed-list\n  padding-left: calc(var(--#{$prefix}gutter-x) * .5); // stylelint-disable-line function-disallowed-list\n  margin-top: var(--#{$prefix}gutter-y);\n}\n\n@mixin make-col($size: false, $columns: $grid-columns) {\n  @if $size {\n    flex: 0 0 auto;\n    -webkit-flex: 0 0 auto;\n    width: percentage(divide($size, $columns));\n\n  } @else {\n    flex: 1 1 0;\n    -webkit-flex: 1 1 0;\n    max-width: 100%;\n  }\n}\n\n@mixin make-col-auto() {\n  flex: 0 0 auto;\n  -webkit-flex: 0 0 auto;\n  width: auto;\n}\n\n@mixin make-col-offset($size, $columns: $grid-columns) {\n  $num: divide($size, $columns);\n  margin-left: if($num == 0, 0, percentage($num));\n}\n\n// Row columns\n//\n// Specify on a parent element(e.g., .row) to force immediate children into NN\n// number of columns. Supports wrapping to new lines, but does not do a Masonry\n// style grid.\n@mixin row-cols($count) {\n  > * {\n    flex: 0 0 auto;\n    -webkit-flex: 0 0 auto;\n    width: divide(100%, $count);\n  }\n}\n\n// Framework grid generation\n//\n// Used only by Bootstrap to generate the correct number of grid classes given\n// any value of `$grid-columns`.\n\n@mixin make-grid-columns($columns: $grid-columns, $gutter: $grid-gutter-width, $breakpoints: $grid-breakpoints) {\n  @each $breakpoint in map-keys($breakpoints) {\n    $infix: breakpoint-infix($breakpoint, $breakpoints);\n\n    @include media-breakpoint-up($breakpoint, $breakpoints) {\n      // Provide basic `.col-{bp}` classes for equal-width flexbox columns\n      .col#{$infix} {\n        flex: 1 0 0%; // Flexbugs #4: https://github.com/philipwalton/flexbugs#flexbug-4\n        -webkit-flex: 1 0 0%; // Flexbugs #4: https://github.com/philipwalton/flexbugs#flexbug-4\n      }\n\n      .row-cols#{$infix}-auto > * {\n        @include make-col-auto();\n      }\n\n      @if $grid-row-columns > 0 {\n        @for $i from 1 through $grid-row-columns {\n          .row-cols#{$infix}-#{$i} {\n            @include row-cols($i);\n          }\n        }\n      }\n\n      .col#{$infix}-auto {\n        @include make-col-auto();\n      }\n\n      @if $columns > 0 {\n        @for $i from 1 through $columns {\n          .col#{$infix}-#{$i} {\n            @include make-col($i, $columns);\n          }\n        }\n\n        // `$columns - 1` because offsetting by the width of an entire row isn't possible\n        @for $i from 0 through ($columns - 1) {\n          @if not ($infix == \"\" and $i == 0) { // Avoid emitting useless .offset-0\n            .offset#{$infix}-#{$i} {\n              @include make-col-offset($i, $columns);\n            }\n          }\n        }\n      }\n\n      // Gutters\n      //\n      // Make use of `.g-*`, `.gx-*` or `.gy-*` utilities to change spacing between the columns.\n      @each $key, $value in $gutters {\n        .g#{$infix}-#{$key},\n        .gx#{$infix}-#{$key} {\n          --#{$prefix}gutter-x: #{$value};\n        }\n\n        .g#{$infix}-#{$key},\n        .gy#{$infix}-#{$key} {\n          --#{$prefix}gutter-y: #{$value};\n        }\n      }\n    }\n  }\n}\n\n@mixin make-cssgrid($columns: $grid-columns, $breakpoints: $grid-breakpoints) {\n  @each $breakpoint in map-keys($breakpoints) {\n    $infix: breakpoint-infix($breakpoint, $breakpoints);\n\n    @include media-breakpoint-up($breakpoint, $breakpoints) {\n      @if $columns > 0 {\n        @for $i from 1 through $columns {\n          .g-col#{$infix}-#{$i} {\n            grid-column: auto / span $i;\n          }\n        }\n\n        // Start with `1` because `0` is and invalid value.\n        // Ends with `$columns - 1` because offsetting by the width of an entire row isn't possible.\n        @for $i from 1 through ($columns - 1) {\n          .g-start#{$infix}-#{$i} {\n            grid-column-start: $i;\n          }\n        }\n      }\n    }\n  }\n}\n",
		"// BS5+ dark color mode foreground color\n$emphasis-color-rgb: var(--#{$prefix}emphasis-color-rgb, 0,0,0) !default;\n\n// Cards are white by default, but we want a smarter default for .well\n// that it appears gray by default\n$well-bg: if($bootstrap-version>=5, RGBA($emphasis-color-rgb, .03), rgba($black, .03)) !default;\n$well-color: if($bootstrap-version>=5, RGB($emphasis-color-rgb), $body-color) !default;\n\n// Bootstrap 5.3.1 + selectize.js v0.12.4 (i.e., shiny v1.7.5) shim\n//\n// Starting with 5.3.x, Bootstrap started having Sass variables default to CSS\n// variables (e.g., $input-color: var(--bs-body-color)), which is problematic for\n// compuation that happens in Sass (e.g., `mix($color1, $color2)`). This bundle\n// fixes this problem for shiny::selectizeInput()'s Sass code (future versions of\n// selectizeInput() should hopefully address this problem, making this temporary\n// stopgap solution no longer required).\n$selectize-color-text: if(is-css-variable($input-color), $body-color, $input-color) !default;\n$selectize-color-item: rgba($selectize-color-text, 0.1) !default;\n$selectize-color-item-border: if(is-css-variable($input-border-color), $border-color, $input-border-color) !default;\n$selectize-color-dropdown: if(is-css-variable($dropdown-bg), $body-bg, $dropdown-bg) !default;\n$selectize-color-dropdown-border-top: rgba($input-border-color, 0.2) !default;\n$selectize-color-dropdown-item-create-text: rgba($selectize-color-text, 0.5) !default;\n@if variable-exists(\"input-btn-font-size\") {\n  $selectize-font-size: $input-btn-font-size !default;\n} @else if variable-exists(\"font-size-base\") {\n  $selectize-font-size: $font-size-base !default;\n}\n$selectize-font-family: if($input-btn-font-family, $input-btn-font-family, inherit) !default;\n",
		"// Accordions\n// These definitions can't go in _defaults.scss with a !default flag (because !default doesn't respect null)\n$accordion-button-active-bg: null;\n$accordion-button-active-color: null;\n$accordion-icon-active-color: null;\n\n// Shiny: selectInput() and selectizeInput()\n$selectize-color-dropdown-item-active: $component-active-bg !default;\n$selectize-color-dropdown-item-active-text: $component-active-color !default;\n\n// Component Variables\n@import \"ionrangeslider/_variables.scss\";\n",
		"// https://github.com/rstudio/shiny/blob/main/inst/www/shared/ionrangeslider/scss/shiny.scss\n\n$emphasis-color-rgb: var(--bs-emphasis-color-rgb, 0, 0, 0) !default;\n\n$minmax_bg_color: RGBA($emphasis-color-rgb, 0.1) !default;\n\n$top: 32px !default;\n\n$line_height: 1px !default;\n$line_bg: none !default;\n$line_bg_color: RGBA($emphasis-color-rgb, 0.65) !default;\n$line_border: none !default;\n\n$handle_color: $component-active-bg !default;\n$handle_color_hover: tint-color($handle_color, 15%) !default;\n$handle_border: none !default;\n$handle_box_shadow: none !default;\n$handle_radius: $top - 10px !default;\n$handle_height: 19px !default;\n$handle_width: $handle_height !default;\n\n$bar_color: $component-active-bg !default;\n\n$grid_major_color: RGBA($emphasis-color-rgb, 0.65) !default;\n$grid_minor_color: transparent !default;\n$grid_text_color: RGBA($emphasis-color-rgb, 0.85) !default;\n",
		"@mixin bsBanner($file) {\n  /*!\n   * Bootstrap #{$file} v5.3.1 (https://getbootstrap.com/)\n   * Copyright 2011-2023 The Bootstrap Authors\n   * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\n   */\n}\n",
		"// Utilities\n\n$utilities: () !default;\n// stylelint-disable-next-line scss/dollar-variable-default\n$utilities: map-merge(\n  (\n    // scss-docs-start utils-vertical-align\n    \"align\": (\n      property: vertical-align,\n      class: align,\n      values: baseline top middle bottom text-bottom text-top\n    ),\n    // scss-docs-end utils-vertical-align\n    // scss-docs-start utils-float\n    \"float\": (\n      responsive: true,\n      property: float,\n      values: (\n        start: left,\n        end: right,\n        none: none,\n      )\n    ),\n    // scss-docs-end utils-float\n    // Object Fit utilities\n    // scss-docs-start utils-object-fit\n    \"object-fit\": (\n      responsive: true,\n      property: object-fit,\n      values: (\n        contain: contain,\n        cover: cover,\n        fill: fill,\n        scale: scale-down,\n        none: none,\n      )\n    ),\n    // scss-docs-end utils-object-fit\n    // Opacity utilities\n    // scss-docs-start utils-opacity\n    \"opacity\": (\n      property: opacity,\n      values: (\n        0: 0,\n        25: .25,\n        50: .5,\n        75: .75,\n        100: 1,\n      )\n    ),\n    // scss-docs-end utils-opacity\n    // scss-docs-start utils-overflow\n    \"overflow\": (\n      property: overflow,\n      values: auto hidden visible scroll,\n    ),\n    \"overflow-x\": (\n      property: overflow-x,\n      values: auto hidden visible scroll,\n    ),\n    \"overflow-y\": (\n      property: overflow-y,\n      values: auto hidden visible scroll,\n    ),\n    // scss-docs-end utils-overflow\n    // scss-docs-start utils-display\n    \"display\": (\n      responsive: true,\n      print: true,\n      property: display,\n      class: d,\n      values: inline inline-block block grid inline-grid table table-row table-cell flex inline-flex none\n    ),\n    // scss-docs-end utils-display\n    // scss-docs-start utils-shadow\n    \"shadow\": (\n      property: box-shadow,\n      class: shadow,\n      values: (\n        null: $box-shadow,\n        sm: $box-shadow-sm,\n        lg: $box-shadow-lg,\n        none: none,\n      )\n    ),\n    // scss-docs-end utils-shadow\n    // scss-docs-start utils-focus-ring\n    \"focus-ring\": (\n      css-var: true,\n      css-variable-name: focus-ring-color,\n      class: focus-ring,\n      values: map-loop($theme-colors-rgb, rgba-css-var, \"$key\", \"focus-ring\")\n    ),\n    // scss-docs-end utils-focus-ring\n    // scss-docs-start utils-position\n    \"position\": (\n      property: position,\n      values: static relative absolute fixed sticky\n    ),\n    \"top\": (\n      property: top,\n      values: $position-values\n    ),\n    \"bottom\": (\n      property: bottom,\n      values: $position-values\n    ),\n    \"start\": (\n      property: left,\n      class: start,\n      values: $position-values\n    ),\n    \"end\": (\n      property: right,\n      class: end,\n      values: $position-values\n    ),\n    \"translate-middle\": (\n      property: transform,\n      class: translate-middle,\n      values: (\n        null: translate(-50%, -50%),\n        x: translateX(-50%),\n        y: translateY(-50%),\n      )\n    ),\n    // scss-docs-end utils-position\n    // scss-docs-start utils-borders\n    \"border\": (\n      property: border,\n      values: (\n        null: var(--#{$prefix}border-width) var(--#{$prefix}border-style) var(--#{$prefix}border-color),\n        0: 0,\n      )\n    ),\n    \"border-top\": (\n      property: border-top,\n      values: (\n        null: var(--#{$prefix}border-width) var(--#{$prefix}border-style) var(--#{$prefix}border-color),\n        0: 0,\n      )\n    ),\n    \"border-end\": (\n      property: border-right,\n      class: border-end,\n      values: (\n        null: var(--#{$prefix}border-width) var(--#{$prefix}border-style) var(--#{$prefix}border-color),\n        0: 0,\n      )\n    ),\n    \"border-bottom\": (\n      property: border-bottom,\n      values: (\n        null: var(--#{$prefix}border-width) var(--#{$prefix}border-style) var(--#{$prefix}border-color),\n        0: 0,\n      )\n    ),\n    \"border-start\": (\n      property: border-left,\n      class: border-start,\n      values: (\n        null: var(--#{$prefix}border-width) var(--#{$prefix}border-style) var(--#{$prefix}border-color),\n        0: 0,\n      )\n    ),\n    \"border-color\": (\n      property: border-color,\n      class: border,\n      local-vars: (\n        \"border-opacity\": 1\n      ),\n      values: $utilities-border-colors\n    ),\n    \"subtle-border-color\": (\n      property: border-color,\n      class: border,\n      values: $utilities-border-subtle\n    ),\n    \"border-width\": (\n      property: border-width,\n      class: border,\n      values: $border-widths\n    ),\n    \"border-opacity\": (\n      css-var: true,\n      class: border-opacity,\n      values: (\n        10: .1,\n        25: .25,\n        50: .5,\n        75: .75,\n        100: 1\n      )\n    ),\n    // scss-docs-end utils-borders\n    // Sizing utilities\n    // scss-docs-start utils-sizing\n    \"width\": (\n      property: width,\n      class: w,\n      values: (\n        25: 25%,\n        50: 50%,\n        75: 75%,\n        100: 100%,\n        auto: auto\n      )\n    ),\n    \"max-width\": (\n      property: max-width,\n      class: mw,\n      values: (100: 100%)\n    ),\n    \"viewport-width\": (\n      property: width,\n      class: vw,\n      values: (100: 100vw)\n    ),\n    \"min-viewport-width\": (\n      property: min-width,\n      class: min-vw,\n      values: (100: 100vw)\n    ),\n    \"height\": (\n      property: height,\n      class: h,\n      values: (\n        25: 25%,\n        50: 50%,\n        75: 75%,\n        100: 100%,\n        auto: auto\n      )\n    ),\n    \"max-height\": (\n      property: max-height,\n      class: mh,\n      values: (100: 100%)\n    ),\n    \"viewport-height\": (\n      property: height,\n      class: vh,\n      values: (100: 100vh)\n    ),\n    \"min-viewport-height\": (\n      property: min-height,\n      class: min-vh,\n      values: (100: 100vh)\n    ),\n    // scss-docs-end utils-sizing\n    // Flex utilities\n    // scss-docs-start utils-flex\n    \"flex\": (\n      responsive: true,\n      property: flex,\n      values: (fill: 1 1 auto)\n    ),\n    \"flex-direction\": (\n      responsive: true,\n      property: flex-direction,\n      class: flex,\n      values: row column row-reverse column-reverse\n    ),\n    \"flex-grow\": (\n      responsive: true,\n      property: flex-grow,\n      class: flex,\n      values: (\n        grow-0: 0,\n        grow-1: 1,\n      )\n    ),\n    \"flex-shrink\": (\n      responsive: true,\n      property: flex-shrink,\n      class: flex,\n      values: (\n        shrink-0: 0,\n        shrink-1: 1,\n      )\n    ),\n    \"flex-wrap\": (\n      responsive: true,\n      property: flex-wrap,\n      class: flex,\n      values: wrap nowrap wrap-reverse\n    ),\n    \"justify-content\": (\n      responsive: true,\n      property: justify-content,\n      values: (\n        start: flex-start,\n        end: flex-end,\n        center: center,\n        between: space-between,\n        around: space-around,\n        evenly: space-evenly,\n      )\n    ),\n    \"align-items\": (\n      responsive: true,\n      property: align-items,\n      values: (\n        start: flex-start,\n        end: flex-end,\n        center: center,\n        baseline: baseline,\n        stretch: stretch,\n      )\n    ),\n    \"align-content\": (\n      responsive: true,\n      property: align-content,\n      values: (\n        start: flex-start,\n        end: flex-end,\n        center: center,\n        between: space-between,\n        around: space-around,\n        stretch: stretch,\n      )\n    ),\n    \"align-self\": (\n      responsive: true,\n      property: align-self,\n      values: (\n        auto: auto,\n        start: flex-start,\n        end: flex-end,\n        center: center,\n        baseline: baseline,\n        stretch: stretch,\n      )\n    ),\n    \"order\": (\n      responsive: true,\n      property: order,\n      values: (\n        first: -1,\n        0: 0,\n        1: 1,\n        2: 2,\n        3: 3,\n        4: 4,\n        5: 5,\n        last: 6,\n      ),\n    ),\n    // scss-docs-end utils-flex\n    // Margin utilities\n    // scss-docs-start utils-spacing\n    \"margin\": (\n      responsive: true,\n      property: margin,\n      class: m,\n      values: map-merge($spacers, (auto: auto))\n    ),\n    \"margin-x\": (\n      responsive: true,\n      property: margin-right margin-left,\n      class: mx,\n      values: map-merge($spacers, (auto: auto))\n    ),\n    \"margin-y\": (\n      responsive: true,\n      property: margin-top margin-bottom,\n      class: my,\n      values: map-merge($spacers, (auto: auto))\n    ),\n    \"margin-top\": (\n      responsive: true,\n      property: margin-top,\n      class: mt,\n      values: map-merge($spacers, (auto: auto))\n    ),\n    \"margin-end\": (\n      responsive: true,\n      property: margin-right,\n      class: me,\n      values: map-merge($spacers, (auto: auto))\n    ),\n    \"margin-bottom\": (\n      responsive: true,\n      property: margin-bottom,\n      class: mb,\n      values: map-merge($spacers, (auto: auto))\n    ),\n    \"margin-start\": (\n      responsive: true,\n      property: margin-left,\n      class: ms,\n      values: map-merge($spacers, (auto: auto))\n    ),\n    // Negative margin utilities\n    \"negative-margin\": (\n      responsive: true,\n      property: margin,\n      class: m,\n      values: $negative-spacers\n    ),\n    \"negative-margin-x\": (\n      responsive: true,\n      property: margin-right margin-left,\n      class: mx,\n      values: $negative-spacers\n    ),\n    \"negative-margin-y\": (\n      responsive: true,\n      property: margin-top margin-bottom,\n      class: my,\n      values: $negative-spacers\n    ),\n    \"negative-margin-top\": (\n      responsive: true,\n      property: margin-top,\n      class: mt,\n      values: $negative-spacers\n    ),\n    \"negative-margin-end\": (\n      responsive: true,\n      property: margin-right,\n      class: me,\n      values: $negative-spacers\n    ),\n    \"negative-margin-bottom\": (\n      responsive: true,\n      property: margin-bottom,\n      class: mb,\n      values: $negative-spacers\n    ),\n    \"negative-margin-start\": (\n      responsive: true,\n      property: margin-left,\n      class: ms,\n      values: $negative-spacers\n    ),\n    // Padding utilities\n    \"padding\": (\n      responsive: true,\n      property: padding,\n      class: p,\n      values: $spacers\n    ),\n    \"padding-x\": (\n      responsive: true,\n      property: padding-right padding-left,\n      class: px,\n      values: $spacers\n    ),\n    \"padding-y\": (\n      responsive: true,\n      property: padding-top padding-bottom,\n      class: py,\n      values: $spacers\n    ),\n    \"padding-top\": (\n      responsive: true,\n      property: padding-top,\n      class: pt,\n      values: $spacers\n    ),\n    \"padding-end\": (\n      responsive: true,\n      property: padding-right,\n      class: pe,\n      values: $spacers\n    ),\n    \"padding-bottom\": (\n      responsive: true,\n      property: padding-bottom,\n      class: pb,\n      values: $spacers\n    ),\n    \"padding-start\": (\n      responsive: true,\n      property: padding-left,\n      class: ps,\n      values: $spacers\n    ),\n    // Gap utility\n    \"gap\": (\n      responsive: true,\n      property: gap,\n      class: gap,\n      values: $spacers\n    ),\n    \"row-gap\": (\n      responsive: true,\n      property: row-gap,\n      class: row-gap,\n      values: $spacers\n    ),\n    \"column-gap\": (\n      responsive: true,\n      property: column-gap,\n      class: column-gap,\n      values: $spacers\n    ),\n    // scss-docs-end utils-spacing\n    // Text\n    // scss-docs-start utils-text\n    \"font-family\": (\n      property: font-family,\n      class: font,\n      values: (monospace: var(--#{$prefix}font-monospace))\n    ),\n    \"font-size\": (\n      rfs: true,\n      property: font-size,\n      class: fs,\n      values: $font-sizes\n    ),\n    \"font-style\": (\n      property: font-style,\n      class: fst,\n      values: italic normal\n    ),\n    \"font-weight\": (\n      property: font-weight,\n      class: fw,\n      values: (\n        lighter: $font-weight-lighter,\n        light: $font-weight-light,\n        normal: $font-weight-normal,\n        medium: $font-weight-medium,\n        semibold: $font-weight-semibold,\n        bold: $font-weight-bold,\n        bolder: $font-weight-bolder\n      )\n    ),\n    \"line-height\": (\n      property: line-height,\n      class: lh,\n      values: (\n        1: 1,\n        sm: $line-height-sm,\n        base: $line-height-base,\n        lg: $line-height-lg,\n      )\n    ),\n    \"text-align\": (\n      responsive: true,\n      property: text-align,\n      class: text,\n      values: (\n        start: left,\n        end: right,\n        center: center,\n      )\n    ),\n    \"text-decoration\": (\n      property: text-decoration,\n      values: none underline line-through\n    ),\n    \"text-transform\": (\n      property: text-transform,\n      class: text,\n      values: lowercase uppercase capitalize\n    ),\n    \"white-space\": (\n      property: white-space,\n      class: text,\n      values: (\n        wrap: normal,\n        nowrap: nowrap,\n      )\n    ),\n    \"word-wrap\": (\n      property: word-wrap word-break,\n      class: text,\n      values: (break: break-word),\n      rtl: false\n    ),\n    // scss-docs-end utils-text\n    // scss-docs-start utils-color\n    \"color\": (\n      property: color,\n      class: text,\n      local-vars: (\n        \"text-opacity\": 1\n      ),\n      values: map-merge(\n        $utilities-text-colors,\n        (\n          \"muted\": var(--#{$prefix}secondary-color), // deprecated\n          \"black-50\": rgba($black, .5), // deprecated\n          \"white-50\": rgba($white, .5), // deprecated\n          \"body-secondary\": var(--#{$prefix}secondary-color),\n          \"body-tertiary\": var(--#{$prefix}tertiary-color),\n          \"body-emphasis\": var(--#{$prefix}emphasis-color),\n          \"reset\": inherit,\n        )\n      )\n    ),\n    \"text-opacity\": (\n      css-var: true,\n      class: text-opacity,\n      values: (\n        25: .25,\n        50: .5,\n        75: .75,\n        100: 1\n      )\n    ),\n    \"text-color\": (\n      property: color,\n      class: text,\n      values: $utilities-text-emphasis-colors\n    ),\n    // scss-docs-end utils-color\n    // scss-docs-start utils-links\n    \"link-opacity\": (\n      css-var: true,\n      class: link-opacity,\n      state: hover,\n      values: (\n        10: .1,\n        25: .25,\n        50: .5,\n        75: .75,\n        100: 1\n      )\n    ),\n    \"link-offset\": (\n      property: text-underline-offset,\n      class: link-offset,\n      state: hover,\n      values: (\n        1: .125em,\n        2: .25em,\n        3: .375em,\n      )\n    ),\n    \"link-underline\": (\n      property: text-decoration-color,\n      class: link-underline,\n      local-vars: (\n        \"link-underline-opacity\": 1\n      ),\n      values: map-merge(\n        $utilities-links-underline,\n        (\n          null: rgba(var(--#{$prefix}link-color-rgb), var(--#{$prefix}link-underline-opacity, 1)),\n        )\n      )\n    ),\n    \"link-underline-opacity\": (\n      css-var: true,\n      class: link-underline-opacity,\n      state: hover,\n      values: (\n        0: 0,\n        10: .1,\n        25: .25,\n        50: .5,\n        75: .75,\n        100: 1\n      ),\n    ),\n    // scss-docs-end utils-links\n    // scss-docs-start utils-bg-color\n    \"background-color\": (\n      property: background-color,\n      class: bg,\n      local-vars: (\n        \"bg-opacity\": 1\n      ),\n      values: map-merge(\n        $utilities-bg-colors,\n        (\n          \"transparent\": transparent,\n          \"body-secondary\": rgba(var(--#{$prefix}secondary-bg-rgb), var(--#{$prefix}bg-opacity)),\n          \"body-tertiary\": rgba(var(--#{$prefix}tertiary-bg-rgb), var(--#{$prefix}bg-opacity)),\n        )\n      )\n    ),\n    \"bg-opacity\": (\n      css-var: true,\n      class: bg-opacity,\n      values: (\n        10: .1,\n        25: .25,\n        50: .5,\n        75: .75,\n        100: 1\n      )\n    ),\n    \"subtle-background-color\": (\n      property: background-color,\n      class: bg,\n      values: $utilities-bg-subtle\n    ),\n    // scss-docs-end utils-bg-color\n    \"gradient\": (\n      property: background-image,\n      class: bg,\n      values: (gradient: var(--#{$prefix}gradient))\n    ),\n    // scss-docs-start utils-interaction\n    \"user-select\": (\n      property: user-select,\n      values: all auto none\n    ),\n    \"pointer-events\": (\n      property: pointer-events,\n      class: pe,\n      values: none auto,\n    ),\n    // scss-docs-end utils-interaction\n    // scss-docs-start utils-border-radius\n    \"rounded\": (\n      property: border-radius,\n      class: rounded,\n      values: (\n        null: var(--#{$prefix}border-radius),\n        0: 0,\n        1: var(--#{$prefix}border-radius-sm),\n        2: var(--#{$prefix}border-radius),\n        3: var(--#{$prefix}border-radius-lg),\n        4: var(--#{$prefix}border-radius-xl),\n        5: var(--#{$prefix}border-radius-xxl),\n        circle: 50%,\n        pill: var(--#{$prefix}border-radius-pill)\n      )\n    ),\n    \"rounded-top\": (\n      property: border-top-left-radius border-top-right-radius,\n      class: rounded-top,\n      values: (\n        null: var(--#{$prefix}border-radius),\n        0: 0,\n        1: var(--#{$prefix}border-radius-sm),\n        2: var(--#{$prefix}border-radius),\n        3: var(--#{$prefix}border-radius-lg),\n        4: var(--#{$prefix}border-radius-xl),\n        5: var(--#{$prefix}border-radius-xxl),\n        circle: 50%,\n        pill: var(--#{$prefix}border-radius-pill)\n      )\n    ),\n    \"rounded-end\": (\n      property: border-top-right-radius border-bottom-right-radius,\n      class: rounded-end,\n      values: (\n        null: var(--#{$prefix}border-radius),\n        0: 0,\n        1: var(--#{$prefix}border-radius-sm),\n        2: var(--#{$prefix}border-radius),\n        3: var(--#{$prefix}border-radius-lg),\n        4: var(--#{$prefix}border-radius-xl),\n        5: var(--#{$prefix}border-radius-xxl),\n        circle: 50%,\n        pill: var(--#{$prefix}border-radius-pill)\n      )\n    ),\n    \"rounded-bottom\": (\n      property: border-bottom-right-radius border-bottom-left-radius,\n      class: rounded-bottom,\n      values: (\n        null: var(--#{$prefix}border-radius),\n        0: 0,\n        1: var(--#{$prefix}border-radius-sm),\n        2: var(--#{$prefix}border-radius),\n        3: var(--#{$prefix}border-radius-lg),\n        4: var(--#{$prefix}border-radius-xl),\n        5: var(--#{$prefix}border-radius-xxl),\n        circle: 50%,\n        pill: var(--#{$prefix}border-radius-pill)\n      )\n    ),\n    \"rounded-start\": (\n      property: border-bottom-left-radius border-top-left-radius,\n      class: rounded-start,\n      values: (\n        null: var(--#{$prefix}border-radius),\n        0: 0,\n        1: var(--#{$prefix}border-radius-sm),\n        2: var(--#{$prefix}border-radius),\n        3: var(--#{$prefix}border-radius-lg),\n        4: var(--#{$prefix}border-radius-xl),\n        5: var(--#{$prefix}border-radius-xxl),\n        circle: 50%,\n        pill: var(--#{$prefix}border-radius-pill)\n      )\n    ),\n    // scss-docs-end utils-border-radius\n    // scss-docs-start utils-visibility\n    \"visibility\": (\n      property: visibility,\n      class: null,\n      values: (\n        visible: visible,\n        invisible: hidden,\n      )\n    ),\n    // scss-docs-end utils-visibility\n    // scss-docs-start utils-zindex\n    \"z-index\": (\n      property: z-index,\n      class: z,\n      values: $zindex-levels,\n    )\n    // scss-docs-end utils-zindex\n  ),\n  $utilities\n);\n",
		":root,\n[data-bs-theme=\"light\"] {\n  // Note: Custom variable values only support SassScript inside `#{}`.\n\n  // Colors\n  //\n  // Generate palettes for full colors, grays, and theme colors.\n\n  @each $color, $value in $colors {\n    --#{$prefix}#{$color}: #{$value};\n  }\n\n  @each $color, $value in $grays {\n    --#{$prefix}gray-#{$color}: #{$value};\n  }\n\n  @each $color, $value in $theme-colors {\n    --#{$prefix}#{$color}: #{$value};\n  }\n\n  @each $color, $value in $theme-colors-rgb {\n    --#{$prefix}#{$color}-rgb: #{$value};\n  }\n\n  @each $color, $value in $theme-colors-text {\n    --#{$prefix}#{$color}-text-emphasis: #{$value};\n  }\n\n  @each $color, $value in $theme-colors-bg-subtle {\n    --#{$prefix}#{$color}-bg-subtle: #{$value};\n  }\n\n  @each $color, $value in $theme-colors-border-subtle {\n    --#{$prefix}#{$color}-border-subtle: #{$value};\n  }\n\n  --#{$prefix}white-rgb: #{to-rgb($white)};\n  --#{$prefix}black-rgb: #{to-rgb($black)};\n\n  // Fonts\n\n  // Note: Use `inspect` for lists so that quoted items keep the quotes.\n  // See https://github.com/sass/sass/issues/2383#issuecomment-336349172\n  --#{$prefix}font-sans-serif: #{inspect($font-family-sans-serif)};\n  --#{$prefix}font-monospace: #{inspect($font-family-monospace)};\n  --#{$prefix}gradient: #{$gradient};\n\n  // Root and body\n  // scss-docs-start root-body-variables\n  @if $font-size-root != null {\n    --#{$prefix}root-font-size: #{$font-size-root};\n  }\n  --#{$prefix}body-font-family: #{inspect($font-family-base)};\n  @include rfs($font-size-base, --#{$prefix}body-font-size);\n  --#{$prefix}body-font-weight: #{$font-weight-base};\n  --#{$prefix}body-line-height: #{$line-height-base};\n  @if $body-text-align != null {\n    --#{$prefix}body-text-align: #{$body-text-align};\n  }\n\n  --#{$prefix}body-color: #{$body-color};\n  --#{$prefix}body-color-rgb: #{to-rgb($body-color)};\n  --#{$prefix}body-bg: #{$body-bg};\n  --#{$prefix}body-bg-rgb: #{to-rgb($body-bg)};\n\n  --#{$prefix}emphasis-color: #{$body-emphasis-color};\n  --#{$prefix}emphasis-color-rgb: #{to-rgb($body-emphasis-color)};\n\n  --#{$prefix}secondary-color: #{$body-secondary-color};\n  --#{$prefix}secondary-color-rgb: #{to-rgb($body-secondary-color)};\n  --#{$prefix}secondary-bg: #{$body-secondary-bg};\n  --#{$prefix}secondary-bg-rgb: #{to-rgb($body-secondary-bg)};\n\n  --#{$prefix}tertiary-color: #{$body-tertiary-color};\n  --#{$prefix}tertiary-color-rgb: #{to-rgb($body-tertiary-color)};\n  --#{$prefix}tertiary-bg: #{$body-tertiary-bg};\n  --#{$prefix}tertiary-bg-rgb: #{to-rgb($body-tertiary-bg)};\n  // scss-docs-end root-body-variables\n\n  --#{$prefix}heading-color: #{$headings-color};\n\n  --#{$prefix}link-color: #{$link-color};\n  --#{$prefix}link-color-rgb: #{to-rgb($link-color)};\n  --#{$prefix}link-decoration: #{$link-decoration};\n\n  --#{$prefix}link-hover-color: #{$link-hover-color};\n  --#{$prefix}link-hover-color-rgb: #{to-rgb($link-hover-color)};\n\n  @if $link-hover-decoration != null {\n    --#{$prefix}link-hover-decoration: #{$link-hover-decoration};\n  }\n\n  --#{$prefix}code-color: #{$code-color};\n  --#{$prefix}highlight-bg: #{$mark-bg};\n\n  // scss-docs-start root-border-var\n  --#{$prefix}border-width: #{$border-width};\n  --#{$prefix}border-style: #{$border-style};\n  --#{$prefix}border-color: #{$border-color};\n  --#{$prefix}border-color-translucent: #{$border-color-translucent};\n\n  --#{$prefix}border-radius: #{$border-radius};\n  --#{$prefix}border-radius-sm: #{$border-radius-sm};\n  --#{$prefix}border-radius-lg: #{$border-radius-lg};\n  --#{$prefix}border-radius-xl: #{$border-radius-xl};\n  --#{$prefix}border-radius-xxl: #{$border-radius-xxl};\n  --#{$prefix}border-radius-2xl: var(--#{$prefix}border-radius-xxl); // Deprecated in v5.3.0 for consistency\n  --#{$prefix}border-radius-pill: #{$border-radius-pill};\n  // scss-docs-end root-border-var\n\n  --#{$prefix}box-shadow: #{$box-shadow};\n  --#{$prefix}box-shadow-sm: #{$box-shadow-sm};\n  --#{$prefix}box-shadow-lg: #{$box-shadow-lg};\n  --#{$prefix}box-shadow-inset: #{$box-shadow-inset};\n\n  // Focus styles\n  // scss-docs-start root-focus-variables\n  --#{$prefix}focus-ring-width: #{$focus-ring-width};\n  --#{$prefix}focus-ring-opacity: #{$focus-ring-opacity};\n  --#{$prefix}focus-ring-color: #{$focus-ring-color};\n  // scss-docs-end root-focus-variables\n\n  // scss-docs-start root-form-validation-variables\n  --#{$prefix}form-valid-color: #{$form-valid-color};\n  --#{$prefix}form-valid-border-color: #{$form-valid-border-color};\n  --#{$prefix}form-invalid-color: #{$form-invalid-color};\n  --#{$prefix}form-invalid-border-color: #{$form-invalid-border-color};\n  // scss-docs-end root-form-validation-variables\n}\n\n@if $enable-dark-mode {\n  @include color-mode(dark, true) {\n    color-scheme: dark;\n\n    // scss-docs-start root-dark-mode-vars\n    --#{$prefix}body-color: #{$body-color-dark};\n    --#{$prefix}body-color-rgb: #{to-rgb($body-color-dark)};\n    --#{$prefix}body-bg: #{$body-bg-dark};\n    --#{$prefix}body-bg-rgb: #{to-rgb($body-bg-dark)};\n\n    --#{$prefix}emphasis-color: #{$body-emphasis-color-dark};\n    --#{$prefix}emphasis-color-rgb: #{to-rgb($body-emphasis-color-dark)};\n\n    --#{$prefix}secondary-color: #{$body-secondary-color-dark};\n    --#{$prefix}secondary-color-rgb: #{to-rgb($body-secondary-color-dark)};\n    --#{$prefix}secondary-bg: #{$body-secondary-bg-dark};\n    --#{$prefix}secondary-bg-rgb: #{to-rgb($body-secondary-bg-dark)};\n\n    --#{$prefix}tertiary-color: #{$body-tertiary-color-dark};\n    --#{$prefix}tertiary-color-rgb: #{to-rgb($body-tertiary-color-dark)};\n    --#{$prefix}tertiary-bg: #{$body-tertiary-bg-dark};\n    --#{$prefix}tertiary-bg-rgb: #{to-rgb($body-tertiary-bg-dark)};\n\n    @each $color, $value in $theme-colors-text-dark {\n      --#{$prefix}#{$color}-text-emphasis: #{$value};\n    }\n\n    @each $color, $value in $theme-colors-bg-subtle-dark {\n      --#{$prefix}#{$color}-bg-subtle: #{$value};\n    }\n\n    @each $color, $value in $theme-colors-border-subtle-dark {\n      --#{$prefix}#{$color}-border-subtle: #{$value};\n    }\n\n    --#{$prefix}heading-color: #{$headings-color-dark};\n\n    --#{$prefix}link-color: #{$link-color-dark};\n    --#{$prefix}link-hover-color: #{$link-hover-color-dark};\n    --#{$prefix}link-color-rgb: #{to-rgb($link-color-dark)};\n    --#{$prefix}link-hover-color-rgb: #{to-rgb($link-hover-color-dark)};\n\n    --#{$prefix}code-color: #{$code-color-dark};\n\n    --#{$prefix}border-color: #{$border-color-dark};\n    --#{$prefix}border-color-translucent: #{$border-color-translucent-dark};\n\n    --#{$prefix}form-valid-color: #{$form-valid-color-dark};\n    --#{$prefix}form-valid-border-color: #{$form-valid-border-color-dark};\n    --#{$prefix}form-invalid-color: #{$form-invalid-color-dark};\n    --#{$prefix}form-invalid-border-color: #{$form-invalid-border-color-dark};\n    // scss-docs-end root-dark-mode-vars\n  }\n}\n",
		"// stylelint-disable declaration-no-important, selector-no-qualifying-type, property-no-vendor-prefix\n\n\n// Reboot\n//\n// Normalization of HTML elements, manually forked from Normalize.css to remove\n// styles targeting irrelevant browsers while applying new styles.\n//\n// Normalize is licensed MIT. https://github.com/necolas/normalize.css\n\n\n// Document\n//\n// Change from `box-sizing: content-box` so that `width` is not affected by `padding` or `border`.\n\n*,\n*::before,\n*::after {\n  box-sizing: border-box;\n}\n\n\n// Root\n//\n// Ability to the value of the root font sizes, affecting the value of `rem`.\n// null by default, thus nothing is generated.\n\n:root {\n  @if $font-size-root != null {\n    @include font-size(var(--#{$prefix}root-font-size));\n  }\n\n  @if $enable-smooth-scroll {\n    @media (prefers-reduced-motion: no-preference) {\n      scroll-behavior: smooth;\n    }\n  }\n}\n\n\n// Body\n//\n// 1. Remove the margin in all browsers.\n// 2. As a best practice, apply a default `background-color`.\n// 3. Prevent adjustments of font size after orientation changes in iOS.\n// 4. Change the default tap highlight to be completely transparent in iOS.\n\n// scss-docs-start reboot-body-rules\nbody {\n  margin: 0; // 1\n  font-family: var(--#{$prefix}body-font-family);\n  @include font-size(var(--#{$prefix}body-font-size));\n  font-weight: var(--#{$prefix}body-font-weight);\n  line-height: var(--#{$prefix}body-line-height);\n  color: var(--#{$prefix}body-color);\n  text-align: var(--#{$prefix}body-text-align);\n  background-color: var(--#{$prefix}body-bg); // 2\n  -webkit-text-size-adjust: 100%; // 3\n  -webkit-tap-highlight-color: rgba($black, 0); // 4\n}\n// scss-docs-end reboot-body-rules\n\n\n// Content grouping\n//\n// 1. Reset Firefox's gray color\n\nhr {\n  margin: $hr-margin-y 0;\n  color: $hr-color; // 1\n  border: 0;\n  border-top: $hr-border-width solid $hr-border-color;\n  opacity: $hr-opacity;\n}\n\n\n// Typography\n//\n// 1. Remove top margins from headings\n//    By default, `<h1>`-`<h6>` all receive top and bottom margins. We nuke the top\n//    margin for easier control within type scales as it avoids margin collapsing.\n\n%heading {\n  margin-top: 0; // 1\n  margin-bottom: $headings-margin-bottom;\n  font-family: $headings-font-family;\n  font-style: $headings-font-style;\n  font-weight: $headings-font-weight;\n  line-height: $headings-line-height;\n  color: var(--#{$prefix}heading-color);\n}\n\nh1 {\n  @extend %heading;\n  @include font-size($h1-font-size);\n}\n\nh2 {\n  @extend %heading;\n  @include font-size($h2-font-size);\n}\n\nh3 {\n  @extend %heading;\n  @include font-size($h3-font-size);\n}\n\nh4 {\n  @extend %heading;\n  @include font-size($h4-font-size);\n}\n\nh5 {\n  @extend %heading;\n  @include font-size($h5-font-size);\n}\n\nh6 {\n  @extend %heading;\n  @include font-size($h6-font-size);\n}\n\n\n// Reset margins on paragraphs\n//\n// Similarly, the top margin on `<p>`s get reset. However, we also reset the\n// bottom margin to use `rem` units instead of `em`.\n\np {\n  margin-top: 0;\n  margin-bottom: $paragraph-margin-bottom;\n}\n\n\n// Abbreviations\n//\n// 1. Add the correct text decoration in Chrome, Edge, Opera, and Safari.\n// 2. Add explicit cursor to indicate changed behavior.\n// 3. Prevent the text-decoration to be skipped.\n\nabbr[title] {\n  text-decoration: underline dotted; // 1\n  -webkit-text-decoration: underline dotted; // 1\n  -moz-text-decoration: underline dotted; // 1\n  -ms-text-decoration: underline dotted; // 1\n  -o-text-decoration: underline dotted; // 1\n  cursor: help; // 2\n  text-decoration-skip-ink: none; // 3\n}\n\n\n// Address\n\naddress {\n  margin-bottom: 1rem;\n  font-style: normal;\n  line-height: inherit;\n}\n\n\n// Lists\n\nol,\nul {\n  padding-left: 2rem;\n}\n\nol,\nul,\ndl {\n  margin-top: 0;\n  margin-bottom: 1rem;\n}\n\nol ol,\nul ul,\nol ul,\nul ol {\n  margin-bottom: 0;\n}\n\ndt {\n  font-weight: $dt-font-weight;\n}\n\n// 1. Undo browser default\n\ndd {\n  margin-bottom: .5rem;\n  margin-left: 0; // 1\n}\n\n\n// Blockquote\n\nblockquote {\n  margin: 0 0 1rem;\n  padding: ($blockquote-font-size / 2) $blockquote-font-size;\n  border-left: $blockquote-border-width solid $blockquote-border-color;\n  p, ul, ol {\n    &:last-child {\n      margin-bottom: 0;\n    }\n  }\n}\n\n\n// Strong\n//\n// Add the correct font weight in Chrome, Edge, and Safari\n\nb,\nstrong {\n  font-weight: $font-weight-bolder;\n}\n\n\n// Small\n//\n// Add the correct font size in all browsers\n\nsmall {\n  @include font-size($small-font-size);\n}\n\n\n// Mark\n\nmark {\n  padding: $mark-padding;\n  background-color: var(--#{$prefix}highlight-bg);\n}\n\n\n// Sub and Sup\n//\n// Prevent `sub` and `sup` elements from affecting the line height in\n// all browsers.\n\nsub,\nsup {\n  position: relative;\n  @include font-size($sub-sup-font-size);\n  line-height: 0;\n  vertical-align: baseline;\n}\n\nsub { bottom: -.25em; }\nsup { top: -.5em; }\n\n\n// Links\n\na {\n  color: rgba(var(--#{$prefix}link-color-rgb), var(--#{$prefix}link-opacity, 1));\n  text-decoration: $link-decoration;\n  -webkit-text-decoration: $link-decoration;\n  -moz-text-decoration: $link-decoration;\n  -ms-text-decoration: $link-decoration;\n  -o-text-decoration: $link-decoration;\n\n  &:hover {\n    --#{$prefix}link-color-rgb: var(--#{$prefix}link-hover-color-rgb);\n    text-decoration: $link-hover-decoration;\n    -webkit-text-decoration: $link-hover-decoration;\n    -moz-text-decoration: $link-hover-decoration;\n    -ms-text-decoration: $link-hover-decoration;\n    -o-text-decoration: $link-hover-decoration;\n  }\n}\n\n// And undo these styles for placeholder links/named anchors (without href).\n// It would be more straightforward to just use a[href] in previous block, but that\n// causes specificity issues in many other styles that are too complex to fix.\n// See https://github.com/twbs/bootstrap/issues/19402\n\na:not([href]):not([class]) {\n  &,\n  &:hover {\n    color: inherit;\n    text-decoration: none;\n  }\n}\n\n\n// Code\n\npre,\ncode,\nkbd,\nsamp {\n  font-family: $font-family-code;\n  @include font-size(1em); // Correct the odd `em` font sizing in all browsers.\n}\n\n// 1. Remove browser default top margin\n// 2. Reset browser default of `1em` to use `rem`s\n// 3. Don't allow content to break outside\n\npre {\n  display: block;\n  margin-top: 0; // 1\n  margin-bottom: 1rem; // 2\n  overflow: auto; // 3\n  @include font-size($code-font-size);\n  color: $pre-color;\n  background-color: $pre-bg;\n  padding: $spacer / 2;\n  border: $border-width solid var(--#{$prefix}border-color, $border-color);\n  @include border-radius($border-radius);\n\n  // Account for some code outputs that place code tags in pre tags\n  code {\n    background-color: transparent;\n    @include font-size(inherit);\n    color: inherit;\n    word-break: normal;\n  }\n}\n\ncode {\n  @include font-size($code-font-size);\n  color: var(--#{$prefix}code-color);\n  background-color: $code-bg;\n  @include border-radius($border-radius);\n  padding: $spacer/8 $spacer/4;\n  word-wrap: break-word;\n\n  // Streamline the style when inside anchors to avoid broken underline and more\n  a > & {\n    color: inherit;\n  }\n}\n\nkbd {\n  padding: $kbd-padding-y $kbd-padding-x;\n  @include font-size($kbd-font-size);\n  color: $kbd-color;\n  background-color: $kbd-bg;\n  @include border-radius($border-radius-sm);\n\n  kbd {\n    padding: 0;\n    @include font-size(1em);\n    font-weight: $nested-kbd-font-weight;\n  }\n}\n\n\n// Figures\n//\n// Apply a consistent margin strategy (matches our type styles).\n\nfigure {\n  margin: 0 0 1rem;\n}\n\n\n// Images and content\n\nimg,\nsvg {\n  vertical-align: middle;\n}\n\n\n// Tables\n//\n// Prevent double borders\n\ntable {\n  caption-side: bottom;\n  border-collapse: collapse;\n}\n\ncaption {\n  padding-top: $table-cell-padding-y;\n  padding-bottom: $table-cell-padding-y;\n  color: $table-caption-color;\n  text-align: left;\n}\n\n// 1. Removes font-weight bold by inheriting\n// 2. Matches default `<td>` alignment by inheriting `text-align`.\n// 3. Fix alignment for Safari\n\nth {\n  font-weight: $table-th-font-weight; // 1\n  text-align: inherit; // 2\n  text-align: -webkit-match-parent; // 3\n}\n\nthead,\ntbody,\ntfoot,\ntr,\ntd,\nth {\n  border-color: inherit;\n  border-style: solid;\n  border-width: 0;\n}\n\n\n// Forms\n//\n// 1. Allow labels to use `margin` for spacing.\n\nlabel {\n  display: inline-block; // 1\n}\n\n// Remove the default `border-radius` that macOS Chrome adds.\n// See https://github.com/twbs/bootstrap/issues/24093\n\nbutton {\n  // stylelint-disable-next-line property-disallowed-list\n  border-radius: 0;\n}\n\n// Explicitly remove focus outline in Chromium when it shouldn't be\n// visible (e.g. as result of mouse click or touch tap). It already\n// should be doing this automatically, but seems to currently be\n// confused and applies its very visible two-tone outline anyway.\n\nbutton:focus:not(:focus-visible) {\n  outline: 0;\n}\n\n// 1. Remove the margin in Firefox and Safari\n\ninput,\nbutton,\nselect,\noptgroup,\ntextarea {\n  margin: 0; // 1\n  font-family: inherit;\n  @include font-size(inherit);\n  line-height: inherit;\n}\n\n// Remove the inheritance of text transform in Firefox\nbutton,\nselect {\n  text-transform: none;\n}\n// Set the cursor for non-`<button>` buttons\n//\n// Details at https://github.com/twbs/bootstrap/pull/30562\n[role=\"button\"] {\n  cursor: pointer;\n}\n\nselect {\n  // Remove the inheritance of word-wrap in Safari.\n  // See https://github.com/twbs/bootstrap/issues/24990\n  word-wrap: normal;\n\n  // Undo the opacity change from Chrome\n  &:disabled {\n    opacity: 1;\n  }\n}\n\n// Remove the dropdown arrow only from text type inputs built with datalists in Chrome.\n// See https://stackoverflow.com/a/54997118\n\n[list]:not([type=\"date\"]):not([type=\"datetime-local\"]):not([type=\"month\"]):not([type=\"week\"]):not([type=\"time\"])::-webkit-calendar-picker-indicator {\n  display: none !important;\n}\n\n// 1. Prevent a WebKit bug where (2) destroys native `audio` and `video`\n//    controls in Android 4.\n// 2. Correct the inability to style clickable types in iOS and Safari.\n// 3. Opinionated: add \"hand\" cursor to non-disabled button elements.\n\nbutton,\n[type=\"button\"], // 1\n[type=\"reset\"],\n[type=\"submit\"] {\n  -webkit-appearance: button; // 2\n\n  @if $enable-button-pointers {\n    &:not(:disabled) {\n      cursor: pointer; // 3\n    }\n  }\n}\n\n// Remove inner border and padding from Firefox, but don't restore the outline like Normalize.\n\n::-moz-focus-inner {\n  padding: 0;\n  border-style: none;\n}\n\n// 1. Textareas should really only resize vertically so they don't break their (horizontal) containers.\n\ntextarea {\n  resize: vertical; // 1\n}\n\n// 1. Browsers set a default `min-width: min-content;` on fieldsets,\n//    unlike e.g. `<div>`s, which have `min-width: 0;` by default.\n//    So we reset that to ensure fieldsets behave more like a standard block element.\n//    See https://github.com/twbs/bootstrap/issues/12359\n//    and https://html.spec.whatwg.org/multipage/#the-fieldset-and-legend-elements\n// 2. Reset the default outline behavior of fieldsets so they don't affect page layout.\n\nfieldset {\n  min-width: 0; // 1\n  padding: 0; // 2\n  margin: 0; // 2\n  border: 0; // 2\n}\n\n// 1. By using `float: left`, the legend will behave like a block element.\n//    This way the border of a fieldset wraps around the legend if present.\n// 2. Fix wrapping bug.\n//    See https://github.com/twbs/bootstrap/issues/29712\n\nlegend {\n  float: left; // 1\n  width: 100%;\n  padding: 0;\n  margin-bottom: $legend-margin-bottom;\n  @include font-size($legend-font-size);\n  font-weight: $legend-font-weight;\n  line-height: inherit;\n\n  + * {\n    clear: left; // 2\n  }\n}\n\n// Fix height of inputs with a type of datetime-local, date, month, week, or time\n// See https://github.com/twbs/bootstrap/issues/18842\n\n::-webkit-datetime-edit-fields-wrapper,\n::-webkit-datetime-edit-text,\n::-webkit-datetime-edit-minute,\n::-webkit-datetime-edit-hour-field,\n::-webkit-datetime-edit-day-field,\n::-webkit-datetime-edit-month-field,\n::-webkit-datetime-edit-year-field {\n  padding: 0;\n}\n\n::-webkit-inner-spin-button {\n  height: auto;\n}\n\n// 1. This overrides the extra rounded corners on search inputs in iOS so that our\n//    `.form-control` class can properly style them. Note that this cannot simply\n//    be added to `.form-control` as it's not specific enough. For details, see\n//    https://github.com/twbs/bootstrap/issues/11586.\n// 2. Correct the outline style in Safari.\n\n[type=\"search\"] {\n  -webkit-appearance: textfield; // 1\n  outline-offset: -2px; // 2\n}\n\n// 1. A few input types should stay LTR\n// See https://rtlstyling.com/posts/rtl-styling#form-inputs\n// 2. RTL only output\n// See https://rtlcss.com/learn/usage-guide/control-directives/#raw\n\n/* rtl:raw:\n[type=\"tel\"],\n[type=\"url\"],\n[type=\"email\"],\n[type=\"number\"] {\n  direction: ltr;\n}\n*/\n\n// Remove the inner padding in Chrome and Safari on macOS.\n\n::-webkit-search-decoration {\n  -webkit-appearance: none;\n}\n\n// Remove padding around color pickers in webkit browsers\n\n::-webkit-color-swatch-wrapper {\n  padding: 0;\n}\n\n\n// 1. Inherit font family and line height for file input buttons\n// 2. Correct the inability to style clickable types in iOS and Safari.\n\n::file-selector-button {\n  font: inherit; // 1\n  -webkit-appearance: button; // 2\n}\n\n// Correct element displays\n\noutput {\n  display: inline-block;\n}\n\n// Remove border from iframe\n\niframe {\n  border: 0;\n}\n\n// Summary\n//\n// 1. Add the correct display in all browsers\n\nsummary {\n  display: list-item; // 1\n  cursor: pointer;\n}\n\n\n// Progress\n//\n// Add the correct vertical alignment in Chrome, Firefox, and Opera.\n\nprogress {\n  vertical-align: baseline;\n}\n\n\n// Hidden attribute\n//\n// Always hide an element with the `hidden` HTML attribute.\n\n[hidden] {\n  display: none !important;\n}\n",
		"//\n// Headings\n//\n.h1 {\n  @extend h1;\n}\n\n.h2 {\n  @extend h2;\n}\n\n.h3 {\n  @extend h3;\n}\n\n.h4 {\n  @extend h4;\n}\n\n.h5 {\n  @extend h5;\n}\n\n.h6 {\n  @extend h6;\n}\n\n\n.lead {\n  @include font-size($lead-font-size);\n  font-weight: $lead-font-weight;\n}\n\n// Type display classes\n@each $display, $font-size in $display-font-sizes {\n  .display-#{$display} {\n    @include font-size($font-size);\n    font-family: $display-font-family;\n    font-style: $display-font-style;\n    font-weight: $display-font-weight;\n    line-height: $display-line-height;\n  }\n}\n\n//\n// Emphasis\n//\n.small {\n  @extend small;\n}\n\n.mark {\n  @extend mark;\n}\n\n//\n// Lists\n//\n\n.list-unstyled {\n  @include list-unstyled();\n}\n\n// Inline turns list items into inline-block\n.list-inline {\n  @include list-unstyled();\n}\n.list-inline-item {\n  display: inline-block;\n\n  &:not(:last-child) {\n    margin-right: $list-inline-padding;\n  }\n}\n\n\n//\n// Misc\n//\n\n// Builds on `abbr`\n.initialism {\n  @include font-size($initialism-font-size);\n  text-transform: uppercase;\n}\n\n// Blockquotes\n.blockquote {\n  margin-bottom: $blockquote-margin-y;\n  @include font-size($blockquote-font-size);\n\n  > :last-child {\n    margin-bottom: 0;\n  }\n}\n\n.blockquote-footer {\n  margin-top: -$blockquote-margin-y;\n  margin-bottom: $blockquote-margin-y;\n  @include font-size($blockquote-footer-font-size);\n  color: $blockquote-footer-color;\n\n  &::before {\n    content: \"\\2014\\00A0\"; // em dash, nbsp\n  }\n}\n",
		"// Responsive images (ensure images don't scale beyond their parents)\n//\n// This is purposefully opt-in via an explicit class rather than being the default for all `<img>`s.\n// We previously tried the \"images are responsive by default\" approach in Bootstrap v2,\n// and abandoned it in Bootstrap v3 because it breaks lots of third-party widgets (including Google Maps)\n// which weren't expecting the images within themselves to be involuntarily resized.\n// See also https://github.com/twbs/bootstrap/issues/18178\n.img-fluid {\n  @include img-fluid();\n}\n\n\n// Image thumbnails\n.img-thumbnail {\n  padding: $thumbnail-padding;\n  background-color: $thumbnail-bg;\n  border: $thumbnail-border-width solid $thumbnail-border-color;\n  @include border-radius($thumbnail-border-radius);\n  @include box-shadow($thumbnail-box-shadow);\n\n  // Keep them at most 100% wide\n  @include img-fluid();\n}\n\n//\n// Figures\n//\n\n.figure {\n  // Ensures the caption's text aligns with the image.\n  display: inline-block;\n}\n\n.figure-img {\n  margin-bottom: $spacer * .5;\n  line-height: 1;\n}\n\n.figure-caption {\n  @include font-size($figure-caption-font-size);\n  color: $figure-caption-color;\n}\n",
		"// Container widths\n//\n// Set the container width, and override it for fixed navbars in media queries.\n\n@if $enable-container-classes {\n  // Single container class with breakpoint max-widths\n  .container,\n  // 100% wide container at all breakpoints\n  .container-fluid {\n    @include make-container();\n  }\n\n  // Responsive containers that are 100% wide until a breakpoint\n  @each $breakpoint, $container-max-width in $container-max-widths {\n    .container-#{$breakpoint} {\n      @extend .container-fluid;\n    }\n\n    @include media-breakpoint-up($breakpoint, $grid-breakpoints) {\n      %responsive-container-#{$breakpoint} {\n        max-width: $container-max-width;\n      }\n\n      // Extend each breakpoint which is smaller or equal to the current breakpoint\n      $extend-breakpoint: true;\n\n      @each $name, $width in $grid-breakpoints {\n        @if ($extend-breakpoint) {\n          .container#{breakpoint-infix($name, $grid-breakpoints)} {\n            @extend %responsive-container-#{$breakpoint};\n          }\n\n          // Once the current breakpoint is reached, stop extending\n          @if ($breakpoint == $name) {\n            $extend-breakpoint: false;\n          }\n        }\n      }\n    }\n  }\n}\n",
		"// Row\n//\n// Rows contain your columns.\n\n:root {\n  @each $name, $value in $grid-breakpoints {\n    --#{$prefix}breakpoint-#{$name}: #{$value};\n  }\n}\n\n@if $enable-grid-classes {\n  .row {\n    @include make-row();\n\n    > * {\n      @include make-col-ready();\n    }\n  }\n}\n\n@if $enable-cssgrid {\n  .grid {\n    display: grid;\n    grid-template-rows: repeat(var(--#{$prefix}rows, 1), 1fr);\n    grid-template-columns: repeat(var(--#{$prefix}columns, #{$grid-columns}), 1fr);\n    gap: var(--#{$prefix}gap, #{$grid-gutter-width});\n\n    @include make-cssgrid();\n  }\n}\n\n\n// Columns\n//\n// Common styles for small and large grid columns\n\n@if $enable-grid-classes {\n  @include make-grid-columns();\n}\n",
		"//\n// Basic Bootstrap table\n//\n\n.table {\n  // Reset needed for nesting tables\n  --#{$prefix}table-color-type: initial;\n  --#{$prefix}table-bg-type: initial;\n  --#{$prefix}table-color-state: initial;\n  --#{$prefix}table-bg-state: initial;\n  // End of reset\n  --#{$prefix}table-color: #{$table-color};\n  --#{$prefix}table-bg: #{$table-bg};\n  --#{$prefix}table-border-color: #{$table-border-color};\n  --#{$prefix}table-accent-bg: #{$table-accent-bg};\n  --#{$prefix}table-striped-color: #{$table-striped-color};\n  --#{$prefix}table-striped-bg: #{$table-striped-bg};\n  --#{$prefix}table-active-color: #{$table-active-color};\n  --#{$prefix}table-active-bg: #{$table-active-bg};\n  --#{$prefix}table-hover-color: #{$table-hover-color};\n  --#{$prefix}table-hover-bg: #{$table-hover-bg};\n\n  width: 100%;\n  margin-bottom: $spacer;\n  vertical-align: $table-cell-vertical-align;\n  border-color: var(--#{$prefix}table-border-color);\n\n  // Target th & td\n  // We need the child combinator to prevent styles leaking to nested tables which doesn't have a `.table` class.\n  // We use the universal selectors here to simplify the selector (else we would need 6 different selectors).\n  // Another advantage is that this generates less code and makes the selector less specific making it easier to override.\n  // stylelint-disable-next-line selector-max-universal\n  > :not(caption) > * > * {\n    padding: $table-cell-padding-y $table-cell-padding-x;\n    // Following the precept of cascades: https://codepen.io/miriamsuzanne/full/vYNgodb\n    color: var(--#{$prefix}table-color-state, var(--#{$prefix}table-color-type, var(--#{$prefix}table-color)));\n    background-color: var(--#{$prefix}table-bg);\n    border-bottom-width: $table-border-width;\n    box-shadow: inset 0 0 0 9999px var(--#{$prefix}table-bg-state, var(--#{$prefix}table-bg-type, var(--#{$prefix}table-accent-bg)));\n  }\n\n  > tbody {\n    vertical-align: inherit;\n  }\n\n  > thead {\n    vertical-align: bottom;\n  }\n}\n\n.table-group-divider {\n  border-top: calc(#{$table-border-width} * 2) solid $table-group-separator-color; // stylelint-disable-line function-disallowed-list\n}\n\n//\n// Change placement of captions with a class\n//\n\n.caption-top {\n  caption-side: top;\n}\n\n\n//\n// Condensed table w/ half padding\n//\n\n.table-sm {\n  // stylelint-disable-next-line selector-max-universal\n  > :not(caption) > * > * {\n    padding: $table-cell-padding-y-sm $table-cell-padding-x-sm;\n  }\n}\n\n\n// Border versions\n//\n// Add or remove borders all around the table and between all the columns.\n//\n// When borders are added on all sides of the cells, the corners can render odd when\n// these borders do not have the same color or if they are semi-transparent.\n// Therefor we add top and border bottoms to the `tr`s and left and right borders\n// to the `td`s or `th`s\n\n.table-bordered {\n  > :not(caption) > * {\n    border-width: $table-border-width 0;\n\n    // stylelint-disable-next-line selector-max-universal\n    > * {\n      border-width: 0 $table-border-width;\n    }\n  }\n}\n\n.table-borderless {\n  // stylelint-disable-next-line selector-max-universal\n  > :not(caption) > * > * {\n    border-bottom-width: 0;\n  }\n\n  > :not(:first-child) {\n    border-top-width: 0;\n  }\n}\n\n// Zebra-striping\n//\n// Default zebra-stripe styles (alternating gray and transparent backgrounds)\n\n// For rows\n.table-striped {\n  > tbody > tr:nth-of-type(#{$table-striped-order}) > * {\n    --#{$prefix}table-color-type: var(--#{$prefix}table-striped-color);\n    --#{$prefix}table-bg-type: var(--#{$prefix}table-striped-bg);\n  }\n}\n\n// For columns\n.table-striped-columns {\n  > :not(caption) > tr > :nth-child(#{$table-striped-columns-order}) {\n    --#{$prefix}table-color-type: var(--#{$prefix}table-striped-color);\n    --#{$prefix}table-bg-type: var(--#{$prefix}table-striped-bg);\n  }\n}\n\n// Active table\n//\n// The `.table-active` class can be added to highlight rows or cells\n\n.table-active {\n  --#{$prefix}table-color-state: var(--#{$prefix}table-active-color);\n  --#{$prefix}table-bg-state: var(--#{$prefix}table-active-bg);\n}\n\n// Hover effect\n//\n// Placed here since it has to come after the potential zebra striping\n\n.table-hover {\n  > tbody > tr:hover > * {\n    --#{$prefix}table-color-state: var(--#{$prefix}table-hover-color);\n    --#{$prefix}table-bg-state: var(--#{$prefix}table-hover-bg);\n  }\n}\n\n\n// Table variants\n//\n// Table variants set the table cell backgrounds, border colors\n// and the colors of the striped, hovered & active tables\n\n@each $color, $value in $table-variants {\n  @include table-variant($color, $value);\n}\n\n// Responsive tables\n//\n// Generate series of `.table-responsive-*` classes for configuring the screen\n// size of where your table will overflow.\n\n@each $breakpoint in map-keys($grid-breakpoints) {\n  $infix: breakpoint-infix($breakpoint, $grid-breakpoints);\n\n  @include media-breakpoint-down($breakpoint) {\n    .table-responsive#{$infix} {\n      overflow-x: auto;\n      -webkit-overflow-scrolling: touch;\n    }\n  }\n}\n",
		"$shiny-check: \".shiny-input-container .checkbox\";\n$shiny-check-inline: $shiny-check + \"-inline\";\n$shiny-radio: \".shiny-input-container .radio\";\n$shiny-radio-inline: $shiny-radio + \"-inline\";\n$form-check-input-selector: \".form-check-input, \" +\n  $shiny-check + \" input, \" + $shiny-check-inline + \" input, \" +\n  $shiny-radio + \" input, \" + $shiny-radio-inline + \" input, \";\n$form-check-label-selector: \".form-check-label, \" +\n  $shiny-check + \" label, \" + $shiny-check-inline + \" label, \" +\n  $shiny-radio + \" label, \" + $shiny-radio-inline + \" label, \";\n\n@import \"forms/labels\";\n@import \"forms/form-text\";\n@import \"forms/form-control\";\n@import \"forms/form-select\";\n@import \"forms/form-check\";\n@import \"forms/form-range\";\n@import \"forms/floating-labels\";\n@import \"forms/input-group\";\n@import \"forms/validation\";\n",
		"//\n// Labels\n//\n\n.form-label, .shiny-input-container .control-label {\n  margin-bottom: $form-label-margin-bottom;\n  @include font-size($form-label-font-size);\n  font-style: $form-label-font-style;\n  font-weight: $form-label-font-weight;\n  color: $form-label-color;\n}\n\n// For use with horizontal and inline forms, when you need the label (or legend)\n// text to align with the form controls.\n.col-form-label {\n  padding-top: add($input-padding-y, $input-border-width);\n  padding-bottom: add($input-padding-y, $input-border-width);\n  margin-bottom: 0; // Override the `<legend>` default\n  @include font-size(inherit); // Override the `<legend>` default\n  font-style: $form-label-font-style;\n  font-weight: $form-label-font-weight;\n  line-height: $input-line-height;\n  color: $form-label-color;\n}\n\n.col-form-label-lg {\n  padding-top: add($input-padding-y-lg, $input-border-width);\n  padding-bottom: add($input-padding-y-lg, $input-border-width);\n  @include font-size($input-font-size-lg);\n}\n\n.col-form-label-sm {\n  padding-top: add($input-padding-y-sm, $input-border-width);\n  padding-bottom: add($input-padding-y-sm, $input-border-width);\n  @include font-size($input-font-size-sm);\n}\n",
		"//\n// Form text\n//\n\n.form-text {\n  margin-top: $form-text-margin-top;\n  @include font-size($form-text-font-size);\n  font-style: $form-text-font-style;\n  font-weight: $form-text-font-weight;\n  color: $form-text-color;\n}\n",
		"//\n// General form controls (plus a few specific high-level interventions)\n//\n\n.form-control {\n  display: block;\n  width: 100%;\n  padding: $input-padding-y $input-padding-x;\n  font-family: $input-font-family;\n  @include font-size($input-font-size);\n  font-weight: $input-font-weight;\n  line-height: $input-line-height;\n  color: $input-color;\n  appearance: none; // Fix appearance for date inputs in Safari\n  -webkit-appearance: none; // Fix appearance for date inputs in Safari\n  -moz-appearance: none; // Fix appearance for date inputs in Safari\n  -ms-appearance: none; // Fix appearance for date inputs in Safari\n  -o-appearance: none; // Fix appearance for date inputs in Safari\n  background-color: $input-bg;\n  background-clip: padding-box;\n  border: $input-border-width solid $input-border-color;\n\n  // Note: This has no effect on <select>s in some browsers, due to the limited stylability of `<select>`s in CSS.\n  @include border-radius($input-border-radius, 0);\n\n  @include box-shadow($input-box-shadow);\n  @include transition($input-transition);\n\n  &[type=\"file\"] {\n    overflow: hidden; // prevent pseudo element button overlap\n\n    &:not(:disabled):not([readonly]) {\n      cursor: pointer;\n    }\n  }\n\n  // Customize the `:focus` state to imitate native WebKit styles.\n  &:focus {\n    color: $input-focus-color;\n    background-color: $input-focus-bg;\n    border-color: $input-focus-border-color;\n    outline: 0;\n    @if $enable-shadows {\n      @include box-shadow($input-box-shadow, $input-focus-box-shadow);\n    } @else {\n      // Avoid using mixin so we can pass custom focus shadow properly\n      box-shadow: $input-focus-box-shadow;\n    }\n  }\n\n  &::-webkit-date-and-time-value {\n    // On Android Chrome, form-control's \"width: 100%\" makes the input width too small\n    // Tested under Android 11 / Chrome 89, Android 12 / Chrome 100, Android 13 / Chrome 109\n    //\n    // On iOS Safari, form-control's \"appearance: none\" + \"width: 100%\" makes the input width too small\n    // Tested under iOS 16.2 / Safari 16.2\n    min-width: 85px; // Seems to be a good minimum safe width\n\n    // Add some height to date inputs on iOS\n    // https://github.com/twbs/bootstrap/issues/23307\n    // TODO: we can remove this workaround once https://bugs.webkit.org/show_bug.cgi?id=198959 is resolved\n    // Multiply line-height by 1em if it has no unit\n    height: if(unit($input-line-height) == \"\", $input-line-height * 1em, $input-line-height);\n\n    // Android Chrome type=\"date\" is taller than the other inputs\n    // because of \"margin: 1px 24px 1px 4px\" inside the shadow DOM\n    // Tested under Android 11 / Chrome 89, Android 12 / Chrome 100, Android 13 / Chrome 109\n    margin: 0;\n  }\n\n  // Prevent excessive date input height in Webkit\n  // https://github.com/twbs/bootstrap/issues/34433\n  &::-webkit-datetime-edit {\n    display: block;\n    padding: 0;\n  }\n\n  // Placeholder\n  &::placeholder {\n    color: $input-placeholder-color;\n    // Override Firefox's unusual default opacity; see https://github.com/twbs/bootstrap/pull/11526.\n    opacity: 1;\n  }\n\n  // Disabled inputs\n  //\n  // HTML5 says that controls under a fieldset > legend:first-child won't be\n  // disabled if the fieldset is disabled. Due to implementation difficulty, we\n  // don't honor that edge case; we style them as disabled anyway.\n  &:disabled {\n    color: $input-disabled-color;\n    background-color: $input-disabled-bg;\n    border-color: $input-disabled-border-color;\n    // iOS fix for unreadable disabled content; see https://github.com/twbs/bootstrap/issues/11655.\n    opacity: 1;\n  }\n\n  // File input buttons theming\n  &::file-selector-button {\n    padding: $input-padding-y $input-padding-x;\n    margin: (-$input-padding-y) (-$input-padding-x);\n    margin-inline-end: $input-padding-x;\n    color: $form-file-button-color;\n    @include gradient-bg($form-file-button-bg);\n    pointer-events: none;\n    border-color: inherit;\n    border-style: solid;\n    border-width: 0;\n    border-inline-end-width: $input-border-width;\n    border-radius: 0; // stylelint-disable-line property-disallowed-list\n    @include transition($btn-transition);\n  }\n\n  &:hover:not(:disabled):not([readonly])::file-selector-button {\n    background-color: $form-file-button-hover-bg;\n  }\n}\n\n// Readonly controls as plain text\n//\n// Apply class to a readonly input to make it appear like regular plain\n// text (without any border, background color, focus indicator)\n\n.form-control-plaintext {\n  display: block;\n  width: 100%;\n  padding: $input-padding-y 0;\n  margin-bottom: 0; // match inputs if this class comes on inputs with default margins\n  line-height: $input-line-height;\n  color: $input-plaintext-color;\n  background-color: transparent;\n  border: solid transparent;\n  border-width: $input-border-width 0;\n\n  &:focus {\n    outline: 0;\n  }\n\n  &.form-control-sm,\n  &.form-control-lg {\n    padding-right: 0;\n    padding-left: 0;\n  }\n}\n\n// Form control sizing\n//\n// Build on `.form-control` with modifier classes to decrease or increase the\n// height and font-size of form controls.\n//\n// Repeated in `_input_group.scss` to avoid Sass extend issues.\n\n.form-control-sm {\n  min-height: $input-height-sm;\n  padding: $input-padding-y-sm $input-padding-x-sm;\n  @include font-size($input-font-size-sm);\n  @include border-radius($input-border-radius-sm);\n\n  &::file-selector-button {\n    padding: $input-padding-y-sm $input-padding-x-sm;\n    margin: (-$input-padding-y-sm) (-$input-padding-x-sm);\n    margin-inline-end: $input-padding-x-sm;\n  }\n}\n\n.form-control-lg {\n  min-height: $input-height-lg;\n  padding: $input-padding-y-lg $input-padding-x-lg;\n  @include font-size($input-font-size-lg);\n  @include border-radius($input-border-radius-lg);\n\n  &::file-selector-button {\n    padding: $input-padding-y-lg $input-padding-x-lg;\n    margin: (-$input-padding-y-lg) (-$input-padding-x-lg);\n    margin-inline-end: $input-padding-x-lg;\n  }\n}\n\n// Make sure textareas don't shrink too much when resized\n// https://github.com/twbs/bootstrap/pull/29124\n// stylelint-disable selector-no-qualifying-type\ntextarea {\n  &.form-control {\n    min-height: $input-height;\n  }\n\n  &.form-control-sm {\n    min-height: $input-height-sm;\n  }\n\n  &.form-control-lg {\n    min-height: $input-height-lg;\n  }\n}\n// stylelint-enable selector-no-qualifying-type\n\n.form-control-color {\n  width: $form-color-width;\n  height: $input-height;\n  padding: $input-padding-y;\n\n  &:not(:disabled):not([readonly]) {\n    cursor: pointer;\n  }\n\n  &::-moz-color-swatch {\n    border: 0 !important; // stylelint-disable-line declaration-no-important\n    @include border-radius($input-border-radius);\n  }\n\n  &::-webkit-color-swatch {\n    border: 0 !important; // stylelint-disable-line declaration-no-important\n    @include border-radius($input-border-radius);\n  }\n\n  &.form-control-sm { height: $input-height-sm; }\n  &.form-control-lg { height: $input-height-lg; }\n}\n",
		"// Select\n//\n// Replaces the browser default select with a custom one, mostly pulled from\n// https://primer.github.io/.\n\n.form-select {\n  --#{$prefix}form-select-bg-img: #{escape-svg($form-select-indicator)};\n\n  display: block;\n  width: 100%;\n  padding: $form-select-padding-y $form-select-indicator-padding $form-select-padding-y $form-select-padding-x;\n  font-family: $form-select-font-family;\n  @include font-size($form-select-font-size);\n  font-weight: $form-select-font-weight;\n  line-height: $form-select-line-height;\n  color: $form-select-color;\n  appearance: none;\n  -webkit-appearance: none;\n  -moz-appearance: none;\n  -ms-appearance: none;\n  -o-appearance: none;\n  background-color: $form-select-bg;\n  background-image: var(--#{$prefix}form-select-bg-img), var(--#{$prefix}form-select-bg-icon, none);\n  background-repeat: no-repeat;\n  background-position: $form-select-bg-position;\n  background-size: $form-select-bg-size;\n  border: $form-select-border-width solid $form-select-border-color;\n  @include border-radius($form-select-border-radius, 0);\n  @include box-shadow($form-select-box-shadow);\n  @include transition($form-select-transition);\n\n  &:focus {\n    border-color: $form-select-focus-border-color;\n    outline: 0;\n    @if $enable-shadows {\n      @include box-shadow($form-select-box-shadow, $form-select-focus-box-shadow);\n    } @else {\n      // Avoid using mixin so we can pass custom focus shadow properly\n      box-shadow: $form-select-focus-box-shadow;\n    }\n  }\n\n  &[multiple],\n  &[size]:not([size=\"1\"]) {\n    padding-right: $form-select-padding-x;\n    background-image: none;\n  }\n\n  &:disabled {\n    color: $form-select-disabled-color;\n    background-color: $form-select-disabled-bg;\n    border-color: $form-select-disabled-border-color;\n  }\n\n  // Remove outline from select box in FF\n  &:-moz-focusring {\n    color: transparent;\n    text-shadow: 0 0 0 $form-select-color;\n  }\n}\n\n.form-select-sm {\n  padding-top: $form-select-padding-y-sm;\n  padding-bottom: $form-select-padding-y-sm;\n  padding-left: $form-select-padding-x-sm;\n  @include font-size($form-select-font-size-sm);\n  @include border-radius($form-select-border-radius-sm);\n}\n\n.form-select-lg {\n  padding-top: $form-select-padding-y-lg;\n  padding-bottom: $form-select-padding-y-lg;\n  padding-left: $form-select-padding-x-lg;\n  @include font-size($form-select-font-size-lg);\n  @include border-radius($form-select-border-radius-lg);\n}\n\n@if $enable-dark-mode {\n  @include color-mode(dark) {\n    .form-select {\n      --#{$prefix}form-select-bg-img: #{escape-svg($form-select-indicator-dark)};\n    }\n  }\n}\n",
		"//\n// Check/radio\n//\n\n.form-check, #{$shiny-check}, #{$shiny-radio} {\n  display: block;\n  min-height: $form-check-min-height;\n  padding-left: $form-check-padding-start;\n  margin-bottom: $form-check-margin-bottom;\n\n  .form-check-input, #{$shiny-check} input, #{$shiny-radio} input {\n    float: left;\n    margin-left: $form-check-padding-start * -1;\n  }\n}\n\n.form-check-reverse {\n  padding-right: $form-check-padding-start;\n  padding-left: 0;\n  text-align: right;\n\n  .form-check-input {\n    float: right;\n    margin-right: $form-check-padding-start * -1;\n    margin-left: 0;\n  }\n}\n\n#{$form-check-input-selector} {\n  --#{$prefix}form-check-bg: #{$form-check-input-bg};\n\n  width: $form-check-input-width;\n  height: $form-check-input-width;\n  margin-top: ($line-height-base - $form-check-input-width) * .5; // line-height minus check height\n  vertical-align: top;\n  appearance: none;\n  -webkit-appearance: none;\n  -moz-appearance: none;\n  -ms-appearance: none;\n  -o-appearance: none;\n  background-color: var(--#{$prefix}form-check-bg);\n  background-image: var(--#{$prefix}form-check-bg-image);\n  background-repeat: no-repeat;\n  background-position: center;\n  background-size: contain;\n  border: $form-check-input-border;\n  print-color-adjust: exact; // Keep themed appearance for print\n  @include transition($form-check-transition);\n\n  &[type=\"checkbox\"] {\n    @include border-radius($form-check-input-border-radius);\n  }\n\n  &[type=\"radio\"] {\n    // stylelint-disable-next-line property-disallowed-list\n    border-radius: $form-check-radio-border-radius;\n  }\n\n  &:active {\n    filter: $form-check-input-active-filter;\n  }\n\n  &:focus {\n    border-color: $form-check-input-focus-border;\n    outline: 0;\n    box-shadow: $form-check-input-focus-box-shadow;\n  }\n\n  &:checked {\n    background-color: $form-check-input-checked-bg-color;\n    border-color: $form-check-input-checked-border-color;\n\n    &[type=\"checkbox\"] {\n      @if $enable-gradients {\n        --#{$prefix}form-check-bg-image: #{escape-svg($form-check-input-checked-bg-image)}, var(--#{$prefix}gradient);\n      } @else {\n        --#{$prefix}form-check-bg-image: #{escape-svg($form-check-input-checked-bg-image)};\n      }\n    }\n\n    &[type=\"radio\"] {\n      @if $enable-gradients {\n        --#{$prefix}form-check-bg-image: #{escape-svg($form-check-radio-checked-bg-image)}, var(--#{$prefix}gradient);\n      } @else {\n        --#{$prefix}form-check-bg-image: #{escape-svg($form-check-radio-checked-bg-image)};\n      }\n    }\n  }\n\n  &[type=\"checkbox\"]:indeterminate {\n    background-color: $form-check-input-indeterminate-bg-color;\n    border-color: $form-check-input-indeterminate-border-color;\n\n    @if $enable-gradients {\n      --#{$prefix}form-check-bg-image: #{escape-svg($form-check-input-indeterminate-bg-image)}, var(--#{$prefix}gradient);\n    } @else {\n      --#{$prefix}form-check-bg-image: #{escape-svg($form-check-input-indeterminate-bg-image)};\n    }\n  }\n\n  &:disabled {\n    pointer-events: none;\n    filter: none;\n    opacity: $form-check-input-disabled-opacity;\n  }\n\n  // Use disabled attribute in addition of :disabled pseudo-class\n  // See: https://github.com/twbs/bootstrap/issues/28247\n  &[disabled],\n  &:disabled {\n    ~ .form-check-label, ~ span {\n      cursor: default;\n      opacity: $form-check-label-disabled-opacity;\n    }\n  }\n}\n\n#{$form-check-label-selector} {\n  color: $form-check-label-color;\n  cursor: $form-check-label-cursor;\n}\n\n//\n// Switch\n//\n\n.form-switch {\n  padding-left: $form-switch-padding-start;\n\n  .form-check-input {\n    --#{$prefix}form-switch-bg: #{escape-svg($form-switch-bg-image)};\n\n    width: $form-switch-width;\n    margin-left: $form-switch-padding-start * -1;\n    background-image: var(--#{$prefix}form-switch-bg);\n    background-position: left center;\n    @include border-radius($form-switch-border-radius);\n    @include transition($form-switch-transition);\n\n    &:focus {\n      --#{$prefix}form-switch-bg: #{escape-svg($form-switch-focus-bg-image)};\n    }\n\n    &:checked {\n      background-position: $form-switch-checked-bg-position;\n\n      @if $enable-gradients {\n        --#{$prefix}form-switch-bg: #{escape-svg($form-switch-checked-bg-image)}, var(--#{$prefix}gradient);\n      } @else {\n        --#{$prefix}form-switch-bg: #{escape-svg($form-switch-checked-bg-image)};\n      }\n    }\n  }\n\n  &.form-check-reverse {\n    padding-right: $form-switch-padding-start;\n    padding-left: 0;\n\n    .form-check-input {\n      margin-right: $form-switch-padding-start * -1;\n      margin-left: 0;\n    }\n  }\n}\n\n.form-check-inline {\n  display: inline-block;\n  margin-right: $form-check-inline-margin-end;\n}\n\n.btn-check {\n  position: absolute;\n  clip: rect(0, 0, 0, 0);\n  pointer-events: none;\n\n  &[disabled],\n  &:disabled {\n    + .btn {\n      pointer-events: none;\n      filter: none;\n      opacity: $form-check-btn-check-disabled-opacity;\n    }\n  }\n}\n\n@if $enable-dark-mode {\n  @include color-mode(dark) {\n    .form-switch .form-check-input:not(:checked):not(:focus) {\n      --#{$prefix}form-switch-bg: #{escape-svg($form-switch-bg-image-dark)};\n    }\n  }\n}\n",
		"// Range\n//\n// Style range inputs the same across browsers. Vendor-specific rules for pseudo\n// elements cannot be mixed. As such, there are no shared styles for focus or\n// active states on prefixed selectors.\n\n.form-range {\n  width: 100%;\n  height: add($form-range-thumb-height, $form-range-thumb-focus-box-shadow-width * 2);\n  padding: 0; // Need to reset padding\n  appearance: none;\n  -webkit-appearance: none;\n  -moz-appearance: none;\n  -ms-appearance: none;\n  -o-appearance: none;\n  background-color: transparent;\n\n  &:focus {\n    outline: 0;\n\n    // Pseudo-elements must be split across multiple rulesets to have an effect.\n    // No box-shadow() mixin for focus accessibility.\n    &::-webkit-slider-thumb { box-shadow: $form-range-thumb-focus-box-shadow; }\n    &::-moz-range-thumb     { box-shadow: $form-range-thumb-focus-box-shadow; }\n  }\n\n  &::-moz-focus-outer {\n    border: 0;\n  }\n\n  &::-webkit-slider-thumb {\n    width: $form-range-thumb-width;\n    height: $form-range-thumb-height;\n    margin-top: ($form-range-track-height - $form-range-thumb-height) * .5; // Webkit specific\n    appearance: none;\n    -webkit-appearance: none;\n    -moz-appearance: none;\n    -ms-appearance: none;\n    -o-appearance: none;\n    @include gradient-bg($form-range-thumb-bg);\n    border: $form-range-thumb-border;\n    @include border-radius($form-range-thumb-border-radius);\n    @include box-shadow($form-range-thumb-box-shadow);\n    @include transition($form-range-thumb-transition);\n\n    &:active {\n      @include gradient-bg($form-range-thumb-active-bg);\n    }\n  }\n\n  &::-webkit-slider-runnable-track {\n    width: $form-range-track-width;\n    height: $form-range-track-height;\n    color: transparent; // Why?\n    cursor: $form-range-track-cursor;\n    background-color: $form-range-track-bg;\n    border-color: transparent;\n    @include border-radius($form-range-track-border-radius);\n    @include box-shadow($form-range-track-box-shadow);\n  }\n\n  &::-moz-range-thumb {\n    width: $form-range-thumb-width;\n    height: $form-range-thumb-height;\n    appearance: none;\n    -webkit-appearance: none;\n    -moz-appearance: none;\n    -ms-appearance: none;\n    -o-appearance: none;\n    @include gradient-bg($form-range-thumb-bg);\n    border: $form-range-thumb-border;\n    @include border-radius($form-range-thumb-border-radius);\n    @include box-shadow($form-range-thumb-box-shadow);\n    @include transition($form-range-thumb-transition);\n\n    &:active {\n      @include gradient-bg($form-range-thumb-active-bg);\n    }\n  }\n\n  &::-moz-range-track {\n    width: $form-range-track-width;\n    height: $form-range-track-height;\n    color: transparent;\n    cursor: $form-range-track-cursor;\n    background-color: $form-range-track-bg;\n    border-color: transparent; // Firefox specific?\n    @include border-radius($form-range-track-border-radius);\n    @include box-shadow($form-range-track-box-shadow);\n  }\n\n  &:disabled {\n    pointer-events: none;\n\n    &::-webkit-slider-thumb {\n      background-color: $form-range-thumb-disabled-bg;\n    }\n\n    &::-moz-range-thumb {\n      background-color: $form-range-thumb-disabled-bg;\n    }\n  }\n}\n",
		".form-floating {\n  position: relative;\n\n  > .form-control,\n  > .form-control-plaintext,\n  > .form-select {\n    height: $form-floating-height;\n    min-height: $form-floating-height;\n    line-height: $form-floating-line-height;\n  }\n\n  > label {\n    position: absolute;\n    top: 0;\n    left: 0;\n    z-index: 2;\n    height: 100%; // allow textareas\n    padding: $form-floating-padding-y $form-floating-padding-x;\n    overflow: hidden;\n    text-align: start;\n    text-overflow: ellipsis;\n    white-space: nowrap;\n    pointer-events: none;\n    border: $input-border-width solid transparent; // Required for aligning label's text with the input as it affects inner box model\n    transform-origin: 0 0;\n    @include transition($form-floating-transition);\n  }\n\n  > .form-control,\n  > .form-control-plaintext {\n    padding: $form-floating-padding-y $form-floating-padding-x;\n\n    &::placeholder {\n      color: transparent;\n    }\n\n    &:focus,\n    &:not(:placeholder-shown) {\n      padding-top: $form-floating-input-padding-t;\n      padding-bottom: $form-floating-input-padding-b;\n    }\n    // Duplicated because `:-webkit-autofill` invalidates other selectors when grouped\n    &:-webkit-autofill {\n      padding-top: $form-floating-input-padding-t;\n      padding-bottom: $form-floating-input-padding-b;\n    }\n  }\n\n  > .form-select {\n    padding-top: $form-floating-input-padding-t;\n    padding-bottom: $form-floating-input-padding-b;\n  }\n\n  > .form-control:focus,\n  > .form-control:not(:placeholder-shown),\n  > .form-control-plaintext,\n  > .form-select {\n    ~ label {\n      color: rgba(var(--#{$prefix}body-color-rgb), #{$form-floating-label-opacity});\n      transform: $form-floating-label-transform;\n\n      &::after {\n        position: absolute;\n        inset: $form-floating-padding-y ($form-floating-padding-x * .5);\n        z-index: -1;\n        height: $form-floating-label-height;\n        content: \"\";\n        background-color: $input-bg;\n        @include border-radius($input-border-radius);\n      }\n    }\n  }\n  // Duplicated because `:-webkit-autofill` invalidates other selectors when grouped\n  > .form-control:-webkit-autofill {\n    ~ label {\n      color: rgba(var(--#{$prefix}body-color-rgb), #{$form-floating-label-opacity});\n      transform: $form-floating-label-transform;\n    }\n  }\n\n  > .form-control-plaintext {\n    ~ label {\n      border-width: $input-border-width 0; // Required to properly position label text - as explained above\n    }\n  }\n\n  > :disabled ~ label,\n  > .form-control:disabled ~ label { // Required for `.form-control`s because of specificity\n    color: $form-floating-label-disabled-color;\n\n    &::after {\n      background-color: $input-disabled-bg;\n    }\n  }\n}\n",
		"//\n// Base styles\n//\n\n.input-group {\n  position: relative;\n  display: flex;\n  display: -webkit-flex;\n  flex-wrap: wrap; // For form validation feedback\n  -webkit-flex-wrap: wrap; // For form validation feedback\n  align-items: stretch;\n  -webkit-align-items: stretch;\n  width: 100%;\n\n  > .form-control,\n  > .form-select,\n  > .form-floating {\n    position: relative; // For focus state's z-index\n    flex: 1 1 auto;\n    -webkit-flex: 1 1 auto;\n    width: 1%;\n    min-width: 0; // https://stackoverflow.com/questions/36247140/why-dont-flex-items-shrink-past-content-size\n  }\n\n  // Bring the \"active\" form control to the top of surrounding elements\n  > .form-control:focus,\n  > .form-select:focus,\n  > .form-floating:focus-within {\n    z-index: 5;\n  }\n\n  // Ensure buttons are always above inputs for more visually pleasing borders.\n  // This isn't needed for `.input-group-text` since it shares the same border-color\n  // as our inputs.\n  .btn {\n    position: relative;\n    z-index: 2;\n\n    &:focus {\n      z-index: 5;\n    }\n  }\n}\n\n\n// Textual addons\n//\n// Serves as a catch-all element for any text or radio/checkbox input you wish\n// to prepend or append to an input.\n\n.input-group-text {\n  display: flex;\n  display: -webkit-flex;\n  align-items: center;\n  -webkit-align-items: center;\n  padding: $input-group-addon-padding-y $input-group-addon-padding-x;\n  @include font-size($input-font-size); // Match inputs\n  font-weight: $input-group-addon-font-weight;\n  line-height: $input-line-height;\n  color: $input-group-addon-color;\n  text-align: center;\n  white-space: nowrap;\n  background-color: $input-group-addon-bg;\n  border: $input-border-width solid $input-group-addon-border-color;\n  @include border-radius($input-border-radius);\n}\n\n\n// Sizing\n//\n// Remix the default form control sizing classes into new ones for easier\n// manipulation.\n\n.input-group-lg > .form-control,\n.input-group-lg > .form-select,\n.input-group-lg > .input-group-text,\n.input-group-lg > .btn {\n  padding: $input-padding-y-lg $input-padding-x-lg;\n  @include font-size($input-font-size-lg);\n  @include border-radius($input-border-radius-lg);\n}\n\n.input-group-sm > .form-control,\n.input-group-sm > .form-select,\n.input-group-sm > .input-group-text,\n.input-group-sm > .btn {\n  padding: $input-padding-y-sm $input-padding-x-sm;\n  @include font-size($input-font-size-sm);\n  @include border-radius($input-border-radius-sm);\n}\n\n.input-group-lg > .form-select,\n.input-group-sm > .form-select {\n  padding-right: $form-select-padding-x + $form-select-indicator-padding;\n}\n\n\n// Rounded corners\n//\n// These rulesets must come after the sizing ones to properly override sm and lg\n// border-radius values when extending. They're more specific than we'd like\n// with the `.input-group >` part, but without it, we cannot override the sizing.\n\n// stylelint-disable-next-line no-duplicate-selectors\n.input-group {\n  &:not(.has-validation) {\n    > :not(:last-child):not(.dropdown-toggle):not(.dropdown-menu):not(.form-floating),\n    > .dropdown-toggle:nth-last-child(n + 3),\n    > .form-floating:not(:last-child) > .form-control,\n    > .form-floating:not(:last-child) > .form-select {\n      @include border-end-radius(0);\n    }\n  }\n\n  &.has-validation {\n    > :nth-last-child(n + 3):not(.dropdown-toggle):not(.dropdown-menu):not(.form-floating),\n    > .dropdown-toggle:nth-last-child(n + 4),\n    > .form-floating:nth-last-child(n + 3) > .form-control,\n    > .form-floating:nth-last-child(n + 3) > .form-select {\n      @include border-end-radius(0);\n    }\n  }\n\n  $validation-messages: \"\";\n  @each $state in map-keys($form-validation-states) {\n    $validation-messages: $validation-messages + \":not(.\" + unquote($state) + \"-tooltip)\" + \":not(.\" + unquote($state) + \"-feedback)\";\n  }\n\n  > :not(:first-child):not(.dropdown-menu)#{$validation-messages} {\n    margin-left: calc(#{$input-border-width} * -1); // stylelint-disable-line function-disallowed-list\n    @include border-start-radius(0);\n  }\n\n  > .form-floating:not(:first-child) > .form-control,\n  > .form-floating:not(:first-child) > .form-select {\n    @include border-start-radius(0);\n  }\n}\n",
		"// Form validation\n//\n// Provide feedback to users when form field values are valid or invalid. Works\n// primarily for client-side validation via scoped `:invalid` and `:valid`\n// pseudo-classes but also includes `.is-invalid` and `.is-valid` classes for\n// server-side validation.\n\n// scss-docs-start form-validation-states-loop\n@each $state, $data in $form-validation-states {\n  @include form-validation-state($state, $data...);\n}\n// scss-docs-end form-validation-states-loop\n",
		"//\n// Base styles\n//\n\n.btn {\n  // scss-docs-start btn-css-vars\n  --#{$prefix}btn-padding-x: #{$btn-padding-x};\n  --#{$prefix}btn-padding-y: #{$btn-padding-y};\n  --#{$prefix}btn-font-family: #{$btn-font-family};\n  @include rfs($btn-font-size, --#{$prefix}btn-font-size);\n  --#{$prefix}btn-font-weight: #{$btn-font-weight};\n  --#{$prefix}btn-line-height: #{$btn-line-height};\n  --#{$prefix}btn-color: #{$btn-color};\n  --#{$prefix}btn-bg: transparent;\n  --#{$prefix}btn-border-width: #{$btn-border-width};\n  --#{$prefix}btn-border-color: transparent;\n  --#{$prefix}btn-border-radius: #{$btn-border-radius};\n  --#{$prefix}btn-hover-border-color: transparent;\n  --#{$prefix}btn-box-shadow: #{$btn-box-shadow};\n  --#{$prefix}btn-disabled-opacity: #{$btn-disabled-opacity};\n  --#{$prefix}btn-focus-box-shadow: 0 0 0 #{$btn-focus-width} rgba(var(--#{$prefix}btn-focus-shadow-rgb), .5);\n  // scss-docs-end btn-css-vars\n\n  display: inline-block;\n  padding: var(--#{$prefix}btn-padding-y) var(--#{$prefix}btn-padding-x);\n  font-family: var(--#{$prefix}btn-font-family);\n  @include font-size(var(--#{$prefix}btn-font-size));\n  font-weight: var(--#{$prefix}btn-font-weight);\n  line-height: var(--#{$prefix}btn-line-height);\n  color: var(--#{$prefix}btn-color);\n  text-align: center;\n  text-decoration: if($link-decoration == none, null, none);\n  -webkit-text-decoration: if($link-decoration == none, null, none);\n  -moz-text-decoration: if($link-decoration == none, null, none);\n  -ms-text-decoration: if($link-decoration == none, null, none);\n  -o-text-decoration: if($link-decoration == none, null, none);\n  white-space: $btn-white-space;\n  vertical-align: middle;\n  cursor: if($enable-button-pointers, pointer, null);\n  user-select: none;\n  -webkit-user-select: none;\n  -moz-user-select: none;\n  -ms-user-select: none;\n  -o-user-select: none;\n  border: var(--#{$prefix}btn-border-width) solid var(--#{$prefix}btn-border-color);\n  @include border-radius(var(--#{$prefix}btn-border-radius));\n  @include gradient-bg(var(--#{$prefix}btn-bg));\n  @include box-shadow(var(--#{$prefix}btn-box-shadow));\n  @include transition($btn-transition);\n\n  &:hover {\n    color: var(--#{$prefix}btn-hover-color);\n    text-decoration: if($link-hover-decoration == underline, none, null);\n    -webkit-text-decoration: if($link-hover-decoration == underline, none, null);\n    -moz-text-decoration: if($link-hover-decoration == underline, none, null);\n    -ms-text-decoration: if($link-hover-decoration == underline, none, null);\n    -o-text-decoration: if($link-hover-decoration == underline, none, null);\n    background-color: var(--#{$prefix}btn-hover-bg);\n    border-color: var(--#{$prefix}btn-hover-border-color);\n  }\n\n  .btn-check + &:hover {\n    // override for the checkbox/radio buttons\n    color: var(--#{$prefix}btn-color);\n    background-color: var(--#{$prefix}btn-bg);\n    border-color: var(--#{$prefix}btn-border-color);\n  }\n\n  &:focus-visible {\n    color: var(--#{$prefix}btn-hover-color);\n    @include gradient-bg(var(--#{$prefix}btn-hover-bg));\n    border-color: var(--#{$prefix}btn-hover-border-color);\n    outline: 0;\n    // Avoid using mixin so we can pass custom focus shadow properly\n    @if $enable-shadows {\n      box-shadow: var(--#{$prefix}btn-box-shadow), var(--#{$prefix}btn-focus-box-shadow);\n    } @else {\n      box-shadow: var(--#{$prefix}btn-focus-box-shadow);\n    }\n  }\n\n  .btn-check:focus-visible + & {\n    border-color: var(--#{$prefix}btn-hover-border-color);\n    outline: 0;\n    // Avoid using mixin so we can pass custom focus shadow properly\n    @if $enable-shadows {\n      box-shadow: var(--#{$prefix}btn-box-shadow), var(--#{$prefix}btn-focus-box-shadow);\n    } @else {\n      box-shadow: var(--#{$prefix}btn-focus-box-shadow);\n    }\n  }\n\n  .btn-check:checked + &,\n  :not(.btn-check) + &:active,\n  &:first-child:active,\n  &.active,\n  &.show {\n    color: var(--#{$prefix}btn-active-color);\n    background-color: var(--#{$prefix}btn-active-bg);\n    // Remove CSS gradients if they're enabled\n    background-image: if($enable-gradients, none, null);\n    border-color: var(--#{$prefix}btn-active-border-color);\n    @include box-shadow(var(--#{$prefix}btn-active-shadow));\n\n    &:focus-visible {\n      // Avoid using mixin so we can pass custom focus shadow properly\n      @if $enable-shadows {\n        box-shadow: var(--#{$prefix}btn-active-shadow), var(--#{$prefix}btn-focus-box-shadow);\n      } @else {\n        box-shadow: var(--#{$prefix}btn-focus-box-shadow);\n      }\n    }\n  }\n\n  &:disabled,\n  &.disabled,\n  fieldset:disabled & {\n    color: var(--#{$prefix}btn-disabled-color);\n    pointer-events: none;\n    background-color: var(--#{$prefix}btn-disabled-bg);\n    background-image: if($enable-gradients, none, null);\n    border-color: var(--#{$prefix}btn-disabled-border-color);\n    opacity: var(--#{$prefix}btn-disabled-opacity);\n    @include box-shadow(none);\n  }\n}\n\n\n//\n// Alternate buttons\n//\n\n// scss-docs-start btn-variant-loops\n@each $color, $value in $theme-colors {\n  .btn-#{$color} {\n    @if $color == \"light\" {\n      @include button-variant(\n        $value,\n        $value,\n        $hover-background: shade-color($value, $btn-hover-bg-shade-amount),\n        $hover-border: shade-color($value, $btn-hover-border-shade-amount),\n        $active-background: shade-color($value, $btn-active-bg-shade-amount),\n        $active-border: shade-color($value, $btn-active-border-shade-amount)\n      );\n    } @else if $color == \"dark\" {\n      @include button-variant(\n        $value,\n        $value,\n        $hover-background: tint-color($value, $btn-hover-bg-tint-amount),\n        $hover-border: tint-color($value, $btn-hover-border-tint-amount),\n        $active-background: tint-color($value, $btn-active-bg-tint-amount),\n        $active-border: tint-color($value, $btn-active-border-tint-amount)\n      );\n    } @else {\n      @include button-variant($value, $value);\n    }\n  }\n}\n\n@each $color, $value in $theme-colors {\n  .btn-outline-#{$color} {\n    @include button-outline-variant($value);\n  }\n}\n// scss-docs-end btn-variant-loops\n\n\n//\n// Link buttons\n//\n\n// Make a button look and behave like a link\n.btn-link {\n  --#{$prefix}btn-font-weight: #{$font-weight-normal};\n  --#{$prefix}btn-color: #{$btn-link-color};\n  --#{$prefix}btn-bg: transparent;\n  --#{$prefix}btn-border-color: transparent;\n  --#{$prefix}btn-hover-color: #{$btn-link-hover-color};\n  --#{$prefix}btn-hover-border-color: transparent;\n  --#{$prefix}btn-active-color: #{$btn-link-hover-color};\n  --#{$prefix}btn-active-border-color: transparent;\n  --#{$prefix}btn-disabled-color: #{$btn-link-disabled-color};\n  --#{$prefix}btn-disabled-border-color: transparent;\n  --#{$prefix}btn-box-shadow: 0 0 0 #000; // Can't use `none` as keyword negates all values when used with multiple shadows\n  --#{$prefix}btn-focus-shadow-rgb: #{to-rgb(mix(color-contrast($link-color), $link-color, 15%))};\n\n  text-decoration: $link-decoration;\n  -webkit-text-decoration: $link-decoration;\n  -moz-text-decoration: $link-decoration;\n  -ms-text-decoration: $link-decoration;\n  -o-text-decoration: $link-decoration;\n  @if $enable-gradients {\n    background-image: none;\n  }\n\n  &:hover,\n  &:focus-visible {\n    text-decoration: $link-hover-decoration;\n    -webkit-text-decoration: $link-hover-decoration;\n    -moz-text-decoration: $link-hover-decoration;\n    -ms-text-decoration: $link-hover-decoration;\n    -o-text-decoration: $link-hover-decoration;\n  }\n\n  &:focus-visible {\n    color: var(--#{$prefix}btn-color);\n  }\n\n  &:hover {\n    color: var(--#{$prefix}btn-hover-color);\n  }\n\n  // No need for an active state here\n}\n\n\n//\n// Button Sizes\n//\n\n.btn-lg {\n  @include button-size($btn-padding-y-lg, $btn-padding-x-lg, $btn-font-size-lg, $btn-border-radius-lg);\n}\n\n.btn-sm {\n  @include button-size($btn-padding-y-sm, $btn-padding-x-sm, $btn-font-size-sm, $btn-border-radius-sm);\n}\n",
		".fade {\n  @include transition($transition-fade);\n\n  &:not(.show) {\n    opacity: 0;\n  }\n}\n\n// scss-docs-start collapse-classes\n.collapse {\n  &:not(.show) {\n    display: none;\n  }\n}\n\n.collapsing {\n  height: 0;\n  overflow: hidden;\n  @include transition($transition-collapse);\n\n  &.collapse-horizontal {\n    width: 0;\n    height: auto;\n    @include transition($transition-collapse-width);\n  }\n}\n// scss-docs-end collapse-classes\n",
		"// The dropdown wrapper (`<div>`)\n.dropup,\n.dropend,\n.dropdown,\n.dropstart,\n.dropup-center,\n.dropdown-center {\n  position: relative;\n}\n\n.dropdown-toggle {\n  white-space: nowrap;\n\n  // Generate the caret automatically\n  @include caret();\n}\n\n// The dropdown menu\n.dropdown-menu {\n  // scss-docs-start dropdown-css-vars\n  --#{$prefix}dropdown-zindex: #{$zindex-dropdown};\n  --#{$prefix}dropdown-min-width: #{$dropdown-min-width};\n  --#{$prefix}dropdown-padding-x: #{$dropdown-padding-x};\n  --#{$prefix}dropdown-padding-y: #{$dropdown-padding-y};\n  --#{$prefix}dropdown-spacer: #{$dropdown-spacer};\n  @include rfs($dropdown-font-size, --#{$prefix}dropdown-font-size);\n  --#{$prefix}dropdown-color: #{$dropdown-color};\n  --#{$prefix}dropdown-bg: #{$dropdown-bg};\n  --#{$prefix}dropdown-border-color: #{$dropdown-border-color};\n  --#{$prefix}dropdown-border-radius: #{$dropdown-border-radius};\n  --#{$prefix}dropdown-border-width: #{$dropdown-border-width};\n  --#{$prefix}dropdown-inner-border-radius: #{$dropdown-inner-border-radius};\n  --#{$prefix}dropdown-divider-bg: #{$dropdown-divider-bg};\n  --#{$prefix}dropdown-divider-margin-y: #{$dropdown-divider-margin-y};\n  --#{$prefix}dropdown-box-shadow: #{$dropdown-box-shadow};\n  --#{$prefix}dropdown-link-color: #{$dropdown-link-color};\n  --#{$prefix}dropdown-link-hover-color: #{$dropdown-link-hover-color};\n  --#{$prefix}dropdown-link-hover-bg: #{$dropdown-link-hover-bg};\n  --#{$prefix}dropdown-link-active-color: #{$dropdown-link-active-color};\n  --#{$prefix}dropdown-link-active-bg: #{$dropdown-link-active-bg};\n  --#{$prefix}dropdown-link-disabled-color: #{$dropdown-link-disabled-color};\n  --#{$prefix}dropdown-item-padding-x: #{$dropdown-item-padding-x};\n  --#{$prefix}dropdown-item-padding-y: #{$dropdown-item-padding-y};\n  --#{$prefix}dropdown-header-color: #{$dropdown-header-color};\n  --#{$prefix}dropdown-header-padding-x: #{$dropdown-header-padding-x};\n  --#{$prefix}dropdown-header-padding-y: #{$dropdown-header-padding-y};\n  // scss-docs-end dropdown-css-vars\n\n  position: absolute;\n  z-index: var(--#{$prefix}dropdown-zindex);\n  display: none; // none by default, but block on \"open\" of the menu\n  min-width: var(--#{$prefix}dropdown-min-width);\n  padding: var(--#{$prefix}dropdown-padding-y) var(--#{$prefix}dropdown-padding-x);\n  margin: 0; // Override default margin of ul\n  @include font-size(var(--#{$prefix}dropdown-font-size));\n  color: var(--#{$prefix}dropdown-color);\n  text-align: left; // Ensures proper alignment if parent has it changed (e.g., modal footer)\n  list-style: none;\n  background-color: var(--#{$prefix}dropdown-bg);\n  background-clip: padding-box;\n  border: var(--#{$prefix}dropdown-border-width) solid var(--#{$prefix}dropdown-border-color);\n  @include border-radius(var(--#{$prefix}dropdown-border-radius));\n  @include box-shadow(var(--#{$prefix}dropdown-box-shadow));\n\n  &[data-bs-popper] {\n    top: 100%;\n    left: 0;\n    margin-top: var(--#{$prefix}dropdown-spacer);\n  }\n\n  @if $dropdown-padding-y == 0 {\n    > .dropdown-item:first-child,\n    > li:first-child .dropdown-item {\n      @include border-top-radius(var(--#{$prefix}dropdown-inner-border-radius));\n    }\n    > .dropdown-item:last-child,\n    > li:last-child .dropdown-item {\n      @include border-bottom-radius(var(--#{$prefix}dropdown-inner-border-radius));\n    }\n\n  }\n}\n\n// scss-docs-start responsive-breakpoints\n// We deliberately hardcode the `bs-` prefix because we check\n// this custom property in JS to determine Popper's positioning\n\n@each $breakpoint in map-keys($grid-breakpoints) {\n  @include media-breakpoint-up($breakpoint) {\n    $infix: breakpoint-infix($breakpoint, $grid-breakpoints);\n\n    .dropdown-menu#{$infix}-start {\n      --bs-position: start;\n\n      &[data-bs-popper] {\n        right: auto;\n        left: 0;\n      }\n    }\n\n    .dropdown-menu#{$infix}-end {\n      --bs-position: end;\n\n      &[data-bs-popper] {\n        right: 0;\n        left: auto;\n      }\n    }\n  }\n}\n// scss-docs-end responsive-breakpoints\n\n// Allow for dropdowns to go bottom up (aka, dropup-menu)\n// Just add .dropup after the standard .dropdown class and you're set.\n.dropup {\n  .dropdown-menu[data-bs-popper] {\n    top: auto;\n    bottom: 100%;\n    margin-top: 0;\n    margin-bottom: var(--#{$prefix}dropdown-spacer);\n  }\n\n  .dropdown-toggle {\n    @include caret(up);\n  }\n}\n\n.dropend {\n  .dropdown-menu[data-bs-popper] {\n    top: 0;\n    right: auto;\n    left: 100%;\n    margin-top: 0;\n    margin-left: var(--#{$prefix}dropdown-spacer);\n  }\n\n  .dropdown-toggle {\n    @include caret(end);\n    &::after {\n      vertical-align: 0;\n    }\n  }\n}\n\n.dropstart {\n  .dropdown-menu[data-bs-popper] {\n    top: 0;\n    right: 100%;\n    left: auto;\n    margin-top: 0;\n    margin-right: var(--#{$prefix}dropdown-spacer);\n  }\n\n  .dropdown-toggle {\n    @include caret(start);\n    &::before {\n      vertical-align: 0;\n    }\n  }\n}\n\n\n// Dividers (basically an `<hr>`) within the dropdown\n.dropdown-divider {\n  height: 0;\n  margin: var(--#{$prefix}dropdown-divider-margin-y) 0;\n  overflow: hidden;\n  border-top: 1px solid var(--#{$prefix}dropdown-divider-bg);\n  opacity: 1; // Revisit in v6 to de-dupe styles that conflict with <hr> element\n}\n\n// Links, buttons, and more within the dropdown menu\n//\n// `<button>`-specific styles are denoted with `// For <button>s`\n.dropdown-item {\n  display: block;\n  width: 100%; // For `<button>`s\n  padding: var(--#{$prefix}dropdown-item-padding-y) var(--#{$prefix}dropdown-item-padding-x);\n  clear: both;\n  font-weight: $font-weight-normal;\n  color: var(--#{$prefix}dropdown-link-color);\n  text-align: inherit; // For `<button>`s\n  text-decoration: if($link-decoration == none, null, none);\n  -webkit-text-decoration: if($link-decoration == none, null, none);\n  -moz-text-decoration: if($link-decoration == none, null, none);\n  -ms-text-decoration: if($link-decoration == none, null, none);\n  -o-text-decoration: if($link-decoration == none, null, none);\n  white-space: nowrap; // prevent links from randomly breaking onto new lines\n  background-color: transparent; // For `<button>`s\n  border: 0; // For `<button>`s\n  @include border-radius(var(--#{$prefix}dropdown-item-border-radius, 0));\n\n  &:hover,\n  &:focus {\n    color: var(--#{$prefix}dropdown-link-hover-color);\n    text-decoration: if($link-hover-decoration == underline, none, null);\n    -webkit-text-decoration: if($link-hover-decoration == underline, none, null);\n    -moz-text-decoration: if($link-hover-decoration == underline, none, null);\n    -ms-text-decoration: if($link-hover-decoration == underline, none, null);\n    -o-text-decoration: if($link-hover-decoration == underline, none, null);\n    @include gradient-bg(var(--#{$prefix}dropdown-link-hover-bg));\n  }\n\n  &.active,\n  &:active {\n    color: var(--#{$prefix}dropdown-link-active-color);\n    text-decoration: none;\n    @include gradient-bg(var(--#{$prefix}dropdown-link-active-bg));\n  }\n\n  &.disabled,\n  &:disabled {\n    color: var(--#{$prefix}dropdown-link-disabled-color);\n    pointer-events: none;\n    background-color: transparent;\n    // Remove CSS gradients if they're enabled\n    background-image: if($enable-gradients, none, null);\n  }\n}\n\n.dropdown-menu.show {\n  display: block;\n}\n\n// Dropdown section headers\n.dropdown-header {\n  display: block;\n  padding: var(--#{$prefix}dropdown-header-padding-y) var(--#{$prefix}dropdown-header-padding-x);\n  margin-bottom: 0; // for use with heading elements\n  @include font-size($font-size-sm);\n  color: var(--#{$prefix}dropdown-header-color);\n  white-space: nowrap; // as with > li > a\n}\n\n// Dropdown text\n.dropdown-item-text {\n  display: block;\n  padding: var(--#{$prefix}dropdown-item-padding-y) var(--#{$prefix}dropdown-item-padding-x);\n  color: var(--#{$prefix}dropdown-link-color);\n}\n\n// Dark dropdowns\n.dropdown-menu-dark {\n  // scss-docs-start dropdown-dark-css-vars\n  --#{$prefix}dropdown-color: #{$dropdown-dark-color};\n  --#{$prefix}dropdown-bg: #{$dropdown-dark-bg};\n  --#{$prefix}dropdown-border-color: #{$dropdown-dark-border-color};\n  --#{$prefix}dropdown-box-shadow: #{$dropdown-dark-box-shadow};\n  --#{$prefix}dropdown-link-color: #{$dropdown-dark-link-color};\n  --#{$prefix}dropdown-link-hover-color: #{$dropdown-dark-link-hover-color};\n  --#{$prefix}dropdown-divider-bg: #{$dropdown-dark-divider-bg};\n  --#{$prefix}dropdown-link-hover-bg: #{$dropdown-dark-link-hover-bg};\n  --#{$prefix}dropdown-link-active-color: #{$dropdown-dark-link-active-color};\n  --#{$prefix}dropdown-link-active-bg: #{$dropdown-dark-link-active-bg};\n  --#{$prefix}dropdown-link-disabled-color: #{$dropdown-dark-link-disabled-color};\n  --#{$prefix}dropdown-header-color: #{$dropdown-dark-header-color};\n  // scss-docs-end dropdown-dark-css-vars\n}\n",
		"// Make the div behave like a button\n.btn-group,\n.btn-group-vertical {\n  position: relative;\n  display: inline-flex;\n  vertical-align: middle; // match .btn alignment given font-size hack above\n\n  > .btn {\n    position: relative;\n    flex: 1 1 auto;\n    -webkit-flex: 1 1 auto;\n  }\n\n  // Bring the hover, focused, and \"active\" buttons to the front to overlay\n  // the borders properly\n  > .btn-check:checked + .btn,\n  > .btn-check:focus + .btn,\n  > .btn:hover,\n  > .btn:focus,\n  > .btn:active,\n  > .btn.active {\n    z-index: 1;\n  }\n}\n\n// Optional: Group multiple button groups together for a toolbar\n.btn-toolbar {\n  display: flex;\n  display: -webkit-flex;\n  flex-wrap: wrap;\n  -webkit-flex-wrap: wrap;\n  justify-content: flex-start;\n  -webkit-justify-content: flex-start;\n\n  .input-group {\n    width: auto;\n  }\n}\n\n.btn-group {\n  @include border-radius($btn-border-radius);\n\n  // Prevent double borders when buttons are next to each other\n  > :not(.btn-check:first-child) + .btn,\n  > .btn-group:not(:first-child) {\n    margin-left: calc(#{$btn-border-width} * -1); // stylelint-disable-line function-disallowed-list\n  }\n\n  // Reset rounded corners\n  > .btn:not(:last-child):not(.dropdown-toggle),\n  > .btn.dropdown-toggle-split:first-child,\n  > .btn-group:not(:last-child) > .btn {\n    @include border-end-radius(0);\n  }\n\n  // The left radius should be 0 if the button is:\n  // - the \"third or more\" child\n  // - the second child and the previous element isn't `.btn-check` (making it the first child visually)\n  // - part of a btn-group which isn't the first child\n  > .btn:nth-child(n + 3),\n  > :not(.btn-check) + .btn,\n  > .btn-group:not(:first-child) > .btn {\n    @include border-start-radius(0);\n  }\n}\n\n// Sizing\n//\n// Remix the default button sizing classes into new ones for easier manipulation.\n\n.btn-group-sm > .btn { @extend .btn-sm; }\n.btn-group-lg > .btn { @extend .btn-lg; }\n\n\n//\n// Split button dropdowns\n//\n\n.dropdown-toggle-split {\n  padding-right: $btn-padding-x * .75;\n  padding-left: $btn-padding-x * .75;\n\n  &::after,\n  .dropup &::after,\n  .dropend &::after {\n    margin-left: 0;\n  }\n\n  .dropstart &::before {\n    margin-right: 0;\n  }\n}\n\n.btn-sm + .dropdown-toggle-split {\n  padding-right: $btn-padding-x-sm * .75;\n  padding-left: $btn-padding-x-sm * .75;\n}\n\n.btn-lg + .dropdown-toggle-split {\n  padding-right: $btn-padding-x-lg * .75;\n  padding-left: $btn-padding-x-lg * .75;\n}\n\n\n// The clickable button for toggling the menu\n// Set the same inset shadow as the :active state\n.btn-group.show .dropdown-toggle {\n  @include box-shadow($btn-active-box-shadow);\n\n  // Show no shadow for `.btn-link` since it has no other button styles.\n  &.btn-link {\n    @include box-shadow(none);\n  }\n}\n\n\n//\n// Vertical button groups\n//\n\n.btn-group-vertical {\n  flex-direction: column;\n  -webkit-flex-direction: column;\n  align-items: flex-start;\n  -webkit-align-items: flex-start;\n  justify-content: center;\n  -webkit-justify-content: center;\n\n  > .btn,\n  > .btn-group {\n    width: 100%;\n  }\n\n  > .btn:not(:first-child),\n  > .btn-group:not(:first-child) {\n    margin-top: calc(#{$btn-border-width} * -1); // stylelint-disable-line function-disallowed-list\n  }\n\n  // Reset rounded corners\n  > .btn:not(:last-child):not(.dropdown-toggle),\n  > .btn-group:not(:last-child) > .btn {\n    @include border-bottom-radius(0);\n  }\n\n  > .btn ~ .btn,\n  > .btn-group:not(:first-child) > .btn {\n    @include border-top-radius(0);\n  }\n}\n",
		"// Base class\n//\n// Kickstart any navigation component with a set of style resets. Works with\n// `<nav>`s, `<ul>`s or `<ol>`s.\n\n.nav {\n  // scss-docs-start nav-css-vars\n  --#{$prefix}nav-link-padding-x: #{$nav-link-padding-x};\n  --#{$prefix}nav-link-padding-y: #{$nav-link-padding-y};\n  @include rfs($nav-link-font-size, --#{$prefix}nav-link-font-size);\n  --#{$prefix}nav-link-font-weight: #{$nav-link-font-weight};\n  --#{$prefix}nav-link-color: #{$nav-link-color};\n  --#{$prefix}nav-link-hover-color: #{$nav-link-hover-color};\n  --#{$prefix}nav-link-disabled-color: #{$nav-link-disabled-color};\n  // scss-docs-end nav-css-vars\n\n  display: flex;\n  display: -webkit-flex;\n  flex-wrap: wrap;\n  -webkit-flex-wrap: wrap;\n  padding-left: 0;\n  margin-bottom: 0;\n  list-style: none;\n}\n\n.nav-link {\n  display: block;\n  padding: var(--#{$prefix}nav-link-padding-y) var(--#{$prefix}nav-link-padding-x);\n  @include font-size(var(--#{$prefix}nav-link-font-size));\n  font-weight: var(--#{$prefix}nav-link-font-weight);\n  color: var(--#{$prefix}nav-link-color);\n  text-decoration: if($link-decoration == none, null, none);\n  -webkit-text-decoration: if($link-decoration == none, null, none);\n  -moz-text-decoration: if($link-decoration == none, null, none);\n  -ms-text-decoration: if($link-decoration == none, null, none);\n  -o-text-decoration: if($link-decoration == none, null, none);\n  background: none;\n  border: 0;\n  @include transition($nav-link-transition);\n\n  &:hover,\n  &:focus {\n    color: var(--#{$prefix}nav-link-hover-color);\n    text-decoration: if($link-hover-decoration == underline, none, null);\n    -webkit-text-decoration: if($link-hover-decoration == underline, none, null);\n    -moz-text-decoration: if($link-hover-decoration == underline, none, null);\n    -ms-text-decoration: if($link-hover-decoration == underline, none, null);\n    -o-text-decoration: if($link-hover-decoration == underline, none, null);\n  }\n\n  &:focus-visible {\n    outline: 0;\n    box-shadow: $nav-link-focus-box-shadow;\n  }\n\n  // Disabled state lightens text\n  &.disabled,\n  &:disabled {\n    color: var(--#{$prefix}nav-link-disabled-color);\n    pointer-events: none;\n    cursor: default;\n  }\n}\n\n//\n// Tabs\n//\n\n.nav-tabs {\n  // scss-docs-start nav-tabs-css-vars\n  --#{$prefix}nav-tabs-border-width: #{$nav-tabs-border-width};\n  --#{$prefix}nav-tabs-border-color: #{$nav-tabs-border-color};\n  --#{$prefix}nav-tabs-border-radius: #{$nav-tabs-border-radius};\n  --#{$prefix}nav-tabs-link-hover-border-color: #{$nav-tabs-link-hover-border-color};\n  --#{$prefix}nav-tabs-link-active-color: #{$nav-tabs-link-active-color};\n  --#{$prefix}nav-tabs-link-active-bg: #{$nav-tabs-link-active-bg};\n  --#{$prefix}nav-tabs-link-active-border-color: #{$nav-tabs-link-active-border-color};\n  // scss-docs-end nav-tabs-css-vars\n\n  border-bottom: var(--#{$prefix}nav-tabs-border-width) solid var(--#{$prefix}nav-tabs-border-color);\n\n  .nav-link {\n    margin-bottom: calc(-1 * var(--#{$prefix}nav-tabs-border-width)); // stylelint-disable-line function-disallowed-list\n    border: var(--#{$prefix}nav-tabs-border-width) solid transparent;\n    @include border-top-radius(var(--#{$prefix}nav-tabs-border-radius));\n\n    &:hover,\n    &:focus {\n      // Prevents active .nav-link tab overlapping focus outline of previous/next .nav-link\n      isolation: isolate;\n      border-color: var(--#{$prefix}nav-tabs-link-hover-border-color);\n    }\n  }\n\n  .nav-link.active,\n  .nav-item.show .nav-link {\n    color: var(--#{$prefix}nav-tabs-link-active-color);\n    background-color: var(--#{$prefix}nav-tabs-link-active-bg);\n    border-color: var(--#{$prefix}nav-tabs-link-active-border-color);\n  }\n\n  .dropdown-menu {\n    // Make dropdown border overlap tab border\n    margin-top: calc(-1 * var(--#{$prefix}nav-tabs-border-width)); // stylelint-disable-line function-disallowed-list\n    // Remove the top rounded corners here since there is a hard edge above the menu\n    @include border-top-radius(0);\n  }\n}\n\n\n//\n// Pills\n//\n\n.nav-pills {\n  // scss-docs-start nav-pills-css-vars\n  --#{$prefix}nav-pills-border-radius: #{$nav-pills-border-radius};\n  --#{$prefix}nav-pills-link-active-color: #{$nav-pills-link-active-color};\n  --#{$prefix}nav-pills-link-active-bg: #{$nav-pills-link-active-bg};\n  // scss-docs-end nav-pills-css-vars\n\n  .nav-link {\n    @include border-radius(var(--#{$prefix}nav-pills-border-radius));\n  }\n\n  .nav-link.active,\n  .show > .nav-link {\n    color: var(--#{$prefix}nav-pills-link-active-color);\n    @include gradient-bg(var(--#{$prefix}nav-pills-link-active-bg));\n  }\n}\n\n\n//\n// Underline\n//\n\n.nav-underline {\n  // scss-docs-start nav-underline-css-vars\n  --#{$prefix}nav-underline-gap: #{$nav-underline-gap};\n  --#{$prefix}nav-underline-border-width: #{$nav-underline-border-width};\n  --#{$prefix}nav-underline-link-active-color: #{$nav-underline-link-active-color};\n  // scss-docs-end nav-underline-css-vars\n\n  gap: var(--#{$prefix}nav-underline-gap);\n\n  .nav-link {\n    padding-right: 0;\n    padding-left: 0;\n    border-bottom: var(--#{$prefix}nav-underline-border-width) solid transparent;\n\n    &:hover,\n    &:focus {\n      border-bottom-color: currentcolor;\n    }\n  }\n\n  .nav-link.active,\n  .show > .nav-link {\n    font-weight: $font-weight-bold;\n    color: var(--#{$prefix}nav-underline-link-active-color);\n    border-bottom-color: currentcolor;\n  }\n}\n\n\n//\n// Justified variants\n//\n\n.nav-fill {\n  > .nav-link,\n  .nav-item {\n    flex: 1 1 auto;\n    -webkit-flex: 1 1 auto;\n    text-align: center;\n  }\n}\n\n.nav-justified {\n  > .nav-link,\n  .nav-item {\n    flex-basis: 0;\n    -webkit-flex-basis: 0;\n    flex-grow: 1;\n    -webkit-flex-grow: 1;\n    text-align: center;\n  }\n}\n\n.nav-fill,\n.nav-justified {\n  .nav-item .nav-link {\n    width: 100%; // Make sure button will grow\n  }\n}\n\n\n// Tabbable tabs\n//\n// Hide tabbable panes to start, show them when `.active`\n\n.tab-content {\n  > .tab-pane {\n    display: none;\n  }\n  > .active {\n    display: block;\n  }\n}\n",
		"// Navbar\n//\n// Provide a static navbar from which we expand to create full-width, fixed, and\n// other navbar variations.\n\n.navbar {\n  // scss-docs-start navbar-css-vars\n  --#{$prefix}navbar-padding-x: #{if($navbar-padding-x == null, 0, $navbar-padding-x)};\n  --#{$prefix}navbar-padding-y: #{$navbar-padding-y};\n  --#{$prefix}navbar-color: #{$navbar-light-color};\n  --#{$prefix}navbar-hover-color: #{$navbar-light-hover-color};\n  --#{$prefix}navbar-disabled-color: #{$navbar-light-disabled-color};\n  --#{$prefix}navbar-active-color: #{$navbar-light-active-color};\n  --#{$prefix}navbar-brand-padding-y: #{$navbar-brand-padding-y};\n  --#{$prefix}navbar-brand-margin-end: #{$navbar-brand-margin-end};\n  --#{$prefix}navbar-brand-font-size: #{$navbar-brand-font-size};\n  --#{$prefix}navbar-brand-color: #{$navbar-light-brand-color};\n  --#{$prefix}navbar-brand-hover-color: #{$navbar-light-brand-hover-color};\n  --#{$prefix}navbar-nav-link-padding-x: #{$navbar-nav-link-padding-x};\n  --#{$prefix}navbar-toggler-padding-y: #{$navbar-toggler-padding-y};\n  --#{$prefix}navbar-toggler-padding-x: #{$navbar-toggler-padding-x};\n  --#{$prefix}navbar-toggler-font-size: #{$navbar-toggler-font-size};\n  --#{$prefix}navbar-toggler-icon-bg: #{escape-svg($navbar-light-toggler-icon-bg)};\n  --#{$prefix}navbar-toggler-border-color: #{$navbar-light-toggler-border-color};\n  --#{$prefix}navbar-toggler-border-radius: #{$navbar-toggler-border-radius};\n  --#{$prefix}navbar-toggler-focus-width: #{$navbar-toggler-focus-width};\n  --#{$prefix}navbar-toggler-transition: #{$navbar-toggler-transition};\n  // scss-docs-end navbar-css-vars\n\n  position: relative;\n  display: flex;\n  display: -webkit-flex;\n  flex-wrap: wrap; // allow us to do the line break for collapsing content\n  -webkit-flex-wrap: wrap; // allow us to do the line break for collapsing content\n  align-items: center;\n  -webkit-align-items: center;\n  justify-content: space-between; // space out brand from logo\n  -webkit-justify-content: space-between; // space out brand from logo\n  padding: var(--#{$prefix}navbar-padding-y) var(--#{$prefix}navbar-padding-x);\n  @include gradient-bg();\n\n  // Because flex properties aren't inherited, we need to redeclare these first\n  // few properties so that content nested within behave properly.\n  // The `flex-wrap` property is inherited to simplify the expanded navbars\n  %container-flex-properties {\n    display: flex;\n    display: -webkit-flex;\n    flex-wrap: inherit;\n    -webkit-flex-wrap: inherit;\n    align-items: center;\n    -webkit-align-items: center;\n    justify-content: space-between;\n    -webkit-justify-content: space-between;\n  }\n\n  > .container,\n  > .container-fluid {\n    @extend %container-flex-properties;\n  }\n\n  @each $breakpoint, $container-max-width in $container-max-widths {\n    > .container#{breakpoint-infix($breakpoint, $container-max-widths)} {\n      @extend %container-flex-properties;\n    }\n  }\n}\n\n\n// Navbar brand\n//\n// Used for brand, project, or site names.\n\n.navbar-brand {\n  padding-top: var(--#{$prefix}navbar-brand-padding-y);\n  padding-bottom: var(--#{$prefix}navbar-brand-padding-y);\n  margin-right: var(--#{$prefix}navbar-brand-margin-end);\n  @include font-size(var(--#{$prefix}navbar-brand-font-size));\n  color: var(--#{$prefix}navbar-brand-color);\n  text-decoration: if($link-decoration == none, null, none);\n  -webkit-text-decoration: if($link-decoration == none, null, none);\n  -moz-text-decoration: if($link-decoration == none, null, none);\n  -ms-text-decoration: if($link-decoration == none, null, none);\n  -o-text-decoration: if($link-decoration == none, null, none);\n  white-space: nowrap;\n\n  &:hover,\n  &:focus {\n    color: var(--#{$prefix}navbar-brand-hover-color);\n    text-decoration: if($link-hover-decoration == underline, none, null);\n    -webkit-text-decoration: if($link-hover-decoration == underline, none, null);\n    -moz-text-decoration: if($link-hover-decoration == underline, none, null);\n    -ms-text-decoration: if($link-hover-decoration == underline, none, null);\n    -o-text-decoration: if($link-hover-decoration == underline, none, null);\n  }\n}\n\n\n// Navbar nav\n//\n// Custom navbar navigation (doesn't require `.nav`, but does make use of `.nav-link`).\n\n.navbar-nav {\n  // scss-docs-start navbar-nav-css-vars\n  --#{$prefix}nav-link-padding-x: 0;\n  --#{$prefix}nav-link-padding-y: #{$nav-link-padding-y};\n  @include rfs($nav-link-font-size, --#{$prefix}nav-link-font-size);\n  --#{$prefix}nav-link-font-weight: #{$nav-link-font-weight};\n  --#{$prefix}nav-link-color: var(--#{$prefix}navbar-color);\n  --#{$prefix}nav-link-hover-color: var(--#{$prefix}navbar-hover-color);\n  --#{$prefix}nav-link-disabled-color: var(--#{$prefix}navbar-disabled-color);\n  // scss-docs-end navbar-nav-css-vars\n\n  display: flex;\n  display: -webkit-flex;\n  flex-direction: column; // cannot use `inherit` to get the `.navbar`s value\n  -webkit-flex-direction: column; // cannot use `inherit` to get the `.navbar`s value\n  padding-left: 0;\n  margin-bottom: 0;\n  list-style: none;\n\n  .nav-link {\n    &.active,\n    &.show {\n      color: var(--#{$prefix}navbar-active-color);\n    }\n  }\n\n  .dropdown-menu {\n    position: static;\n  }\n}\n\n\n// Navbar text\n//\n//\n\n.navbar-text {\n  padding-top: $nav-link-padding-y;\n  padding-bottom: $nav-link-padding-y;\n  color: var(--#{$prefix}navbar-color);\n\n  a,\n  a:hover,\n  a:focus  {\n    color: var(--#{$prefix}navbar-active-color);\n  }\n}\n\n\n// Responsive navbar\n//\n// Custom styles for responsive collapsing and toggling of navbar contents.\n// Powered by the collapse Bootstrap JavaScript plugin.\n\n// When collapsed, prevent the toggleable navbar contents from appearing in\n// the default flexbox row orientation. Requires the use of `flex-wrap: wrap`\n// on the `.navbar` parent.\n.navbar-collapse {\n  flex-basis: 100%;\n  -webkit-flex-basis: 100%;\n  flex-grow: 1;\n  -webkit-flex-grow: 1;\n  // For always expanded or extra full navbars, ensure content aligns itself\n  // properly vertically. Can be easily overridden with flex utilities.\n  align-items: center;\n  -webkit-align-items: center;\n}\n\n// Button for toggling the navbar when in its collapsed state\n.navbar-toggler {\n  padding: var(--#{$prefix}navbar-toggler-padding-y) var(--#{$prefix}navbar-toggler-padding-x);\n  @include font-size(var(--#{$prefix}navbar-toggler-font-size));\n  line-height: 1;\n  color: var(--#{$prefix}navbar-color);\n  background-color: transparent; // remove default button style\n  border: var(--#{$prefix}border-width) solid var(--#{$prefix}navbar-toggler-border-color); // remove default button style\n  @include border-radius(var(--#{$prefix}navbar-toggler-border-radius));\n  @include transition(var(--#{$prefix}navbar-toggler-transition));\n\n  &:hover {\n    text-decoration: none;\n  }\n\n  &:focus {\n    text-decoration: none;\n    outline: 0;\n    box-shadow: 0 0 0 var(--#{$prefix}navbar-toggler-focus-width);\n  }\n}\n\n// Keep as a separate element so folks can easily override it with another icon\n// or image file as needed.\n.navbar-toggler-icon {\n  display: inline-block;\n  width: 1.5em;\n  height: 1.5em;\n  vertical-align: middle;\n  background-image: var(--#{$prefix}navbar-toggler-icon-bg);\n  background-repeat: no-repeat;\n  background-position: center;\n  background-size: 100%;\n}\n\n.navbar-nav-scroll {\n  max-height: var(--#{$prefix}scroll-height, 75vh);\n  overflow-y: auto;\n}\n\n// scss-docs-start navbar-expand-loop\n// Generate series of `.navbar-expand-*` responsive classes for configuring\n// where your navbar collapses.\n.navbar-expand {\n  @each $breakpoint in map-keys($grid-breakpoints) {\n    $next: breakpoint-next($breakpoint, $grid-breakpoints);\n    $infix: breakpoint-infix($next, $grid-breakpoints);\n\n    // stylelint-disable-next-line scss/selector-no-union-class-name\n    &#{$infix} {\n      @include media-breakpoint-up($next) {\n        flex-wrap: nowrap;\n        -webkit-flex-wrap: nowrap;\n        justify-content: flex-start;\n        -webkit-justify-content: flex-start;\n\n        .navbar-nav {\n          flex-direction: row;\n          -webkit-flex-direction: row;\n\n          .dropdown-menu {\n            position: absolute;\n          }\n\n          .nav-link {\n            padding-right: var(--#{$prefix}navbar-nav-link-padding-x);\n            padding-left: var(--#{$prefix}navbar-nav-link-padding-x);\n          }\n        }\n\n        .navbar-nav-scroll {\n          overflow: visible;\n        }\n\n        .navbar-collapse {\n          display: flex !important; // stylelint-disable-line declaration-no-important\n          display: -webkit-flex !important; // stylelint-disable-line declaration-no-important\n          flex-basis: auto;\n          -webkit-flex-basis: auto;\n        }\n\n        .navbar-toggler {\n          display: none;\n        }\n\n        .offcanvas {\n          // stylelint-disable declaration-no-important\n          position: static;\n          z-index: auto;\n          flex-grow: 1;\n          -webkit-flex-grow: 1;\n          width: auto !important;\n          height: auto !important;\n          visibility: visible !important;\n          background-color: transparent !important;\n          border: 0 !important;\n          transform: none !important;\n          @include box-shadow(none);\n          @include transition(none);\n          // stylelint-enable declaration-no-important\n\n          .offcanvas-header {\n            display: none;\n          }\n\n          .offcanvas-body {\n            display: flex;\n            display: -webkit-flex;\n            flex-grow: 0;\n            -webkit-flex-grow: 0;\n            padding: 0;\n            overflow-y: visible;\n          }\n        }\n      }\n    }\n  }\n}\n// scss-docs-end navbar-expand-loop\n\n// Navbar themes\n//\n// Styles for switching between navbars with light or dark background.\n\n.navbar-light {\n  @include deprecate(\"`.navbar-light`\", \"v5.2.0\", \"v6.0.0\", true);\n}\n\n.navbar-dark,\n.navbar[data-bs-theme=\"dark\"] {\n  // scss-docs-start navbar-dark-css-vars\n  --#{$prefix}navbar-color: #{$navbar-dark-color};\n  --#{$prefix}navbar-hover-color: #{$navbar-dark-hover-color};\n  --#{$prefix}navbar-disabled-color: #{$navbar-dark-disabled-color};\n  --#{$prefix}navbar-active-color: #{$navbar-dark-active-color};\n  --#{$prefix}navbar-brand-color: #{$navbar-dark-brand-color};\n  --#{$prefix}navbar-brand-hover-color: #{$navbar-dark-brand-hover-color};\n  --#{$prefix}navbar-toggler-border-color: #{$navbar-dark-toggler-border-color};\n  --#{$prefix}navbar-toggler-icon-bg: #{escape-svg($navbar-dark-toggler-icon-bg)};\n  // scss-docs-end navbar-dark-css-vars\n}\n\n@if $enable-dark-mode {\n  @include color-mode(dark) {\n    .navbar-toggler-icon {\n      --#{$prefix}navbar-toggler-icon-bg: #{escape-svg($navbar-dark-toggler-icon-bg)};\n    }\n  }\n}\n",
		"//\n// Base styles\n//\n\n.card {\n  // scss-docs-start card-css-vars\n  --#{$prefix}card-spacer-y: #{$card-spacer-y};\n  --#{$prefix}card-spacer-x: #{$card-spacer-x};\n  --#{$prefix}card-title-spacer-y: #{$card-title-spacer-y};\n  --#{$prefix}card-title-color: #{$card-title-color};\n  --#{$prefix}card-subtitle-color: #{$card-subtitle-color};\n  --#{$prefix}card-border-width: #{$card-border-width};\n  --#{$prefix}card-border-color: #{$card-border-color};\n  --#{$prefix}card-border-radius: #{$card-border-radius};\n  --#{$prefix}card-box-shadow: #{$card-box-shadow};\n  --#{$prefix}card-inner-border-radius: #{$card-inner-border-radius};\n  --#{$prefix}card-cap-padding-y: #{$card-cap-padding-y};\n  --#{$prefix}card-cap-padding-x: #{$card-cap-padding-x};\n  --#{$prefix}card-cap-bg: #{$card-cap-bg};\n  --#{$prefix}card-cap-color: #{$card-cap-color};\n  --#{$prefix}card-height: #{$card-height};\n  --#{$prefix}card-color: #{$card-color};\n  --#{$prefix}card-bg: #{$card-bg};\n  --#{$prefix}card-img-overlay-padding: #{$card-img-overlay-padding};\n  --#{$prefix}card-group-margin: #{$card-group-margin};\n  // scss-docs-end card-css-vars\n\n  position: relative;\n  display: flex;\n  display: -webkit-flex;\n  flex-direction: column;\n  -webkit-flex-direction: column;\n  min-width: 0; // See https://github.com/twbs/bootstrap/pull/22740#issuecomment-305868106\n  height: var(--#{$prefix}card-height);\n  color: var(--#{$prefix}body-color);\n  word-wrap: break-word;\n  background-color: var(--#{$prefix}card-bg);\n  background-clip: border-box;\n  border: var(--#{$prefix}card-border-width) solid var(--#{$prefix}card-border-color);\n  @include border-radius(var(--#{$prefix}card-border-radius));\n  @include box-shadow(var(--#{$prefix}card-box-shadow));\n\n  > hr {\n    margin-right: 0;\n    margin-left: 0;\n  }\n\n  > .list-group {\n    border-top: inherit;\n    border-bottom: inherit;\n\n    &:first-child {\n      border-top-width: 0;\n      @include border-top-radius(var(--#{$prefix}card-inner-border-radius));\n    }\n\n    &:last-child  {\n      border-bottom-width: 0;\n      @include border-bottom-radius(var(--#{$prefix}card-inner-border-radius));\n    }\n  }\n\n  // Due to specificity of the above selector (`.card > .list-group`), we must\n  // use a child selector here to prevent double borders.\n  > .card-header + .list-group,\n  > .list-group + .card-footer {\n    border-top: 0;\n  }\n}\n\n.card-body {\n  // Enable `flex-grow: 1` for decks and groups so that card blocks take up\n  // as much space as possible, ensuring footers are aligned to the bottom.\n  flex: 1 1 auto;\n  -webkit-flex: 1 1 auto;\n  padding: var(--#{$prefix}card-spacer-y) var(--#{$prefix}card-spacer-x);\n  color: var(--#{$prefix}card-color);\n}\n\n.card-title {\n  margin-bottom: var(--#{$prefix}card-title-spacer-y);\n  color: var(--#{$prefix}card-title-color);\n}\n\n.card-subtitle {\n  margin-top: calc(-.5 * var(--#{$prefix}card-title-spacer-y)); // stylelint-disable-line function-disallowed-list\n  margin-bottom: 0;\n  color: var(--#{$prefix}card-subtitle-color);\n}\n\n.card-text:last-child {\n  margin-bottom: 0;\n}\n\n.card-link {\n  &:hover {\n    text-decoration: if($link-hover-decoration == underline, none, null);\n    -webkit-text-decoration: if($link-hover-decoration == underline, none, null);\n    -moz-text-decoration: if($link-hover-decoration == underline, none, null);\n    -ms-text-decoration: if($link-hover-decoration == underline, none, null);\n    -o-text-decoration: if($link-hover-decoration == underline, none, null);\n  }\n\n  + .card-link {\n    margin-left: var(--#{$prefix}card-spacer-x);\n  }\n}\n\n//\n// Optional textual caps\n//\n\n.card-header {\n  padding: var(--#{$prefix}card-cap-padding-y) var(--#{$prefix}card-cap-padding-x);\n  margin-bottom: 0; // Removes the default margin-bottom of <hN>\n  color: var(--#{$prefix}card-cap-color);\n  background-color: var(--#{$prefix}card-cap-bg);\n  border-bottom: var(--#{$prefix}card-border-width) solid var(--#{$prefix}card-border-color);\n\n  &:first-child {\n    @include border-radius(var(--#{$prefix}card-inner-border-radius) var(--#{$prefix}card-inner-border-radius) 0 0);\n  }\n}\n\n.card-footer {\n  padding: var(--#{$prefix}card-cap-padding-y) var(--#{$prefix}card-cap-padding-x);\n  color: var(--#{$prefix}card-cap-color);\n  background-color: var(--#{$prefix}card-cap-bg);\n  border-top: var(--#{$prefix}card-border-width) solid var(--#{$prefix}card-border-color);\n\n  &:last-child {\n    @include border-radius(0 0 var(--#{$prefix}card-inner-border-radius) var(--#{$prefix}card-inner-border-radius));\n  }\n}\n\n\n//\n// Header navs\n//\n\n.card-header-tabs {\n  margin-right: calc(-.5 * var(--#{$prefix}card-cap-padding-x)); // stylelint-disable-line function-disallowed-list\n  margin-bottom: calc(-1 * var(--#{$prefix}card-cap-padding-y)); // stylelint-disable-line function-disallowed-list\n  margin-left: calc(-.5 * var(--#{$prefix}card-cap-padding-x)); // stylelint-disable-line function-disallowed-list\n  border-bottom: 0;\n\n  .nav-link.active {\n    background-color: var(--#{$prefix}card-bg);\n    border-bottom-color: var(--#{$prefix}card-bg);\n  }\n}\n\n.card-header-pills {\n  margin-right: calc(-.5 * var(--#{$prefix}card-cap-padding-x)); // stylelint-disable-line function-disallowed-list\n  margin-left: calc(-.5 * var(--#{$prefix}card-cap-padding-x)); // stylelint-disable-line function-disallowed-list\n}\n\n// Card image\n.card-img-overlay {\n  position: absolute;\n  top: 0;\n  right: 0;\n  bottom: 0;\n  left: 0;\n  padding: var(--#{$prefix}card-img-overlay-padding);\n  @include border-radius(var(--#{$prefix}card-inner-border-radius));\n}\n\n.card-img,\n.card-img-top,\n.card-img-bottom {\n  width: 100%; // Required because we use flexbox and this inherently applies align-self: stretch\n}\n\n.card-img,\n.card-img-top {\n  @include border-top-radius(var(--#{$prefix}card-inner-border-radius));\n}\n\n.card-img,\n.card-img-bottom {\n  @include border-bottom-radius(var(--#{$prefix}card-inner-border-radius));\n}\n\n\n//\n// Card groups\n//\n\n.card-group {\n  // The child selector allows nested `.card` within `.card-group`\n  // to display properly.\n  > .card {\n    margin-bottom: var(--#{$prefix}card-group-margin);\n  }\n\n  @include media-breakpoint-up(sm) {\n    display: flex;\n    display: -webkit-flex;\n    flex-flow: row wrap;\n    -webkit-flex-flow: row wrap;\n    // The child selector allows nested `.card` within `.card-group`\n    // to display properly.\n    > .card {\n      // Flexbugs #4: https://github.com/philipwalton/flexbugs#flexbug-4\n      flex: 1 0 0%;\n      -webkit-flex: 1 0 0%;\n      margin-bottom: 0;\n\n      + .card {\n        margin-left: 0;\n        border-left: 0;\n      }\n\n      // Handle rounded corners\n      @if $enable-rounded {\n        &:not(:last-child) {\n          @include border-end-radius(0);\n\n          .card-img-top,\n          .card-header {\n            // stylelint-disable-next-line property-disallowed-list\n            border-top-right-radius: 0;\n          }\n          .card-img-bottom,\n          .card-footer {\n            // stylelint-disable-next-line property-disallowed-list\n            border-bottom-right-radius: 0;\n          }\n        }\n\n        &:not(:first-child) {\n          @include border-start-radius(0);\n\n          .card-img-top,\n          .card-header {\n            // stylelint-disable-next-line property-disallowed-list\n            border-top-left-radius: 0;\n          }\n          .card-img-bottom,\n          .card-footer {\n            // stylelint-disable-next-line property-disallowed-list\n            border-bottom-left-radius: 0;\n          }\n        }\n      }\n    }\n  }\n}\n",
		"//\n// Base styles\n//\n\n.accordion {\n  // scss-docs-start accordion-css-vars\n  --#{$prefix}accordion-color: #{$accordion-color};\n  --#{$prefix}accordion-bg: #{$accordion-bg};\n  --#{$prefix}accordion-transition: #{$accordion-transition};\n  --#{$prefix}accordion-border-color: #{$accordion-border-color};\n  --#{$prefix}accordion-border-width: #{$accordion-border-width};\n  --#{$prefix}accordion-border-radius: #{$accordion-border-radius};\n  --#{$prefix}accordion-inner-border-radius: #{$accordion-inner-border-radius};\n  --#{$prefix}accordion-btn-padding-x: #{$accordion-button-padding-x};\n  --#{$prefix}accordion-btn-padding-y: #{$accordion-button-padding-y};\n  --#{$prefix}accordion-btn-color: #{$accordion-button-color};\n  --#{$prefix}accordion-btn-bg: #{$accordion-button-bg};\n  --#{$prefix}accordion-btn-icon: #{escape-svg($accordion-button-icon)};\n  --#{$prefix}accordion-btn-icon-width: #{$accordion-icon-width};\n  --#{$prefix}accordion-btn-icon-transform: #{$accordion-icon-transform};\n  --#{$prefix}accordion-btn-icon-transition: #{$accordion-icon-transition};\n  --#{$prefix}accordion-btn-active-icon: #{escape-svg($accordion-button-active-icon)};\n  --#{$prefix}accordion-btn-focus-border-color: #{$accordion-button-focus-border-color};\n  --#{$prefix}accordion-btn-focus-box-shadow: #{$accordion-button-focus-box-shadow};\n  --#{$prefix}accordion-body-padding-x: #{$accordion-body-padding-x};\n  --#{$prefix}accordion-body-padding-y: #{$accordion-body-padding-y};\n  --#{$prefix}accordion-active-color: #{$accordion-button-active-color};\n  --#{$prefix}accordion-active-bg: #{$accordion-button-active-bg};\n  // scss-docs-end accordion-css-vars\n}\n\n.accordion-button {\n  position: relative;\n  display: flex;\n  display: -webkit-flex;\n  align-items: center;\n  -webkit-align-items: center;\n  width: 100%;\n  padding: var(--#{$prefix}accordion-btn-padding-y) var(--#{$prefix}accordion-btn-padding-x);\n  @include font-size($font-size-base);\n  color: var(--#{$prefix}accordion-btn-color);\n  text-align: left; // Reset button style\n  background-color: var(--#{$prefix}accordion-btn-bg);\n  border: 0;\n  @include border-radius(0);\n  overflow-anchor: none;\n  @include transition(var(--#{$prefix}accordion-transition));\n\n  &:not(.collapsed) {\n    color: var(--#{$prefix}accordion-active-color);\n    background-color: var(--#{$prefix}accordion-active-bg);\n    box-shadow: inset 0 calc(-1 * var(--#{$prefix}accordion-border-width)) 0 var(--#{$prefix}accordion-border-color); // stylelint-disable-line function-disallowed-list\n\n    &::after {\n      background-image: var(--#{$prefix}accordion-btn-active-icon);\n      transform: var(--#{$prefix}accordion-btn-icon-transform);\n    }\n  }\n\n  // Accordion icon\n  &::after {\n    flex-shrink: 0;\n    -webkit-flex-shrink: 0;\n    width: var(--#{$prefix}accordion-btn-icon-width);\n    height: var(--#{$prefix}accordion-btn-icon-width);\n    margin-left: auto;\n    content: \"\";\n    background-image: var(--#{$prefix}accordion-btn-icon);\n    background-repeat: no-repeat;\n    background-size: var(--#{$prefix}accordion-btn-icon-width);\n    @include transition(var(--#{$prefix}accordion-btn-icon-transition));\n  }\n\n  &:hover {\n    z-index: 2;\n  }\n\n  &:focus {\n    z-index: 3;\n    border-color: var(--#{$prefix}accordion-btn-focus-border-color);\n    outline: 0;\n    box-shadow: var(--#{$prefix}accordion-btn-focus-box-shadow);\n  }\n}\n\n.accordion-header {\n  margin-bottom: 0;\n}\n\n.accordion-item {\n  color: var(--#{$prefix}accordion-color);\n  background-color: var(--#{$prefix}accordion-bg);\n  border: var(--#{$prefix}accordion-border-width) solid var(--#{$prefix}accordion-border-color);\n\n  &:first-of-type {\n    @include border-top-radius(var(--#{$prefix}accordion-border-radius));\n\n    .accordion-button {\n      @include border-top-radius(var(--#{$prefix}accordion-inner-border-radius));\n    }\n  }\n\n  &:not(:first-of-type) {\n    border-top: 0;\n  }\n\n  // Only set a border-radius on the last item if the accordion is collapsed\n  &:last-of-type {\n    @include border-bottom-radius(var(--#{$prefix}accordion-border-radius));\n\n    .accordion-button {\n      &.collapsed {\n        @include border-bottom-radius(var(--#{$prefix}accordion-inner-border-radius));\n      }\n    }\n\n    .accordion-collapse {\n      @include border-bottom-radius(var(--#{$prefix}accordion-border-radius));\n    }\n  }\n}\n\n.accordion-body {\n  padding: var(--#{$prefix}accordion-body-padding-y) var(--#{$prefix}accordion-body-padding-x);\n}\n\n\n// Flush accordion items\n//\n// Remove borders and border-radius to keep accordion items edge-to-edge.\n\n.accordion-flush {\n  .accordion-collapse {\n    border-width: 0;\n  }\n\n  .accordion-item {\n    border-right: 0;\n    border-left: 0;\n    @include border-radius(0);\n\n    &:first-child { border-top: 0; }\n    &:last-child { border-bottom: 0; }\n\n    .accordion-button {\n      &,\n      &.collapsed {\n        @include border-radius(0);\n      }\n    }\n  }\n}\n\n@if $enable-dark-mode {\n  @include color-mode(dark) {\n    .accordion-button::after {\n      --#{$prefix}accordion-btn-icon: #{escape-svg($accordion-button-icon-dark)};\n      --#{$prefix}accordion-btn-active-icon: #{escape-svg($accordion-button-active-icon-dark)};\n    }\n  }\n}\n",
		".breadcrumb {\n  // scss-docs-start breadcrumb-css-vars\n  --#{$prefix}breadcrumb-padding-x: #{$breadcrumb-padding-x};\n  --#{$prefix}breadcrumb-padding-y: #{$breadcrumb-padding-y};\n  --#{$prefix}breadcrumb-margin-bottom: #{$breadcrumb-margin-bottom};\n  @include rfs($breadcrumb-font-size, --#{$prefix}breadcrumb-font-size);\n  --#{$prefix}breadcrumb-bg: #{$breadcrumb-bg};\n  --#{$prefix}breadcrumb-border-radius: #{$breadcrumb-border-radius};\n  --#{$prefix}breadcrumb-divider-color: #{$breadcrumb-divider-color};\n  --#{$prefix}breadcrumb-item-padding-x: #{$breadcrumb-item-padding-x};\n  --#{$prefix}breadcrumb-item-active-color: #{$breadcrumb-active-color};\n  // scss-docs-end breadcrumb-css-vars\n\n  display: flex;\n  display: -webkit-flex;\n  flex-wrap: wrap;\n  -webkit-flex-wrap: wrap;\n  padding: var(--#{$prefix}breadcrumb-padding-y) var(--#{$prefix}breadcrumb-padding-x);\n  margin-bottom: var(--#{$prefix}breadcrumb-margin-bottom);\n  @include font-size(var(--#{$prefix}breadcrumb-font-size));\n  list-style: none;\n  background-color: var(--#{$prefix}breadcrumb-bg);\n  @include border-radius(var(--#{$prefix}breadcrumb-border-radius));\n}\n\n.breadcrumb-item {\n  // The separator between breadcrumbs (by default, a forward-slash: \"/\")\n  + .breadcrumb-item {\n    padding-left: var(--#{$prefix}breadcrumb-item-padding-x);\n\n    &::before {\n      float: left; // Suppress inline spacings and underlining of the separator\n      padding-right: var(--#{$prefix}breadcrumb-item-padding-x);\n      color: var(--#{$prefix}breadcrumb-divider-color);\n      content: var(--#{$prefix}breadcrumb-divider, escape-svg($breadcrumb-divider)) #{\"/* rtl:\"} var(--#{$prefix}breadcrumb-divider, escape-svg($breadcrumb-divider-flipped)) #{\"*/\"};\n    }\n  }\n\n  &.active {\n    color: var(--#{$prefix}breadcrumb-item-active-color);\n  }\n}\n",
		".pagination {\n  // scss-docs-start pagination-css-vars\n  --#{$prefix}pagination-padding-x: #{$pagination-padding-x};\n  --#{$prefix}pagination-padding-y: #{$pagination-padding-y};\n  @include rfs($pagination-font-size, --#{$prefix}pagination-font-size);\n  --#{$prefix}pagination-color: #{$pagination-color};\n  --#{$prefix}pagination-bg: #{$pagination-bg};\n  --#{$prefix}pagination-border-width: #{$pagination-border-width};\n  --#{$prefix}pagination-border-color: #{$pagination-border-color};\n  --#{$prefix}pagination-border-radius: #{$pagination-border-radius};\n  --#{$prefix}pagination-hover-color: #{$pagination-hover-color};\n  --#{$prefix}pagination-hover-bg: #{$pagination-hover-bg};\n  --#{$prefix}pagination-hover-border-color: #{$pagination-hover-border-color};\n  --#{$prefix}pagination-focus-color: #{$pagination-focus-color};\n  --#{$prefix}pagination-focus-bg: #{$pagination-focus-bg};\n  --#{$prefix}pagination-focus-box-shadow: #{$pagination-focus-box-shadow};\n  --#{$prefix}pagination-active-color: #{$pagination-active-color};\n  --#{$prefix}pagination-active-bg: #{$pagination-active-bg};\n  --#{$prefix}pagination-active-border-color: #{$pagination-active-border-color};\n  --#{$prefix}pagination-disabled-color: #{$pagination-disabled-color};\n  --#{$prefix}pagination-disabled-bg: #{$pagination-disabled-bg};\n  --#{$prefix}pagination-disabled-border-color: #{$pagination-disabled-border-color};\n  // scss-docs-end pagination-css-vars\n\n  display: flex;\n  display: -webkit-flex;\n  @include list-unstyled();\n}\n\n.page-link {\n  position: relative;\n  display: block;\n  padding: var(--#{$prefix}pagination-padding-y) var(--#{$prefix}pagination-padding-x);\n  @include font-size(var(--#{$prefix}pagination-font-size));\n  color: var(--#{$prefix}pagination-color);\n  text-decoration: if($link-decoration == none, null, none);\n  -webkit-text-decoration: if($link-decoration == none, null, none);\n  -moz-text-decoration: if($link-decoration == none, null, none);\n  -ms-text-decoration: if($link-decoration == none, null, none);\n  -o-text-decoration: if($link-decoration == none, null, none);\n  background-color: var(--#{$prefix}pagination-bg);\n  border: var(--#{$prefix}pagination-border-width) solid var(--#{$prefix}pagination-border-color);\n  @include transition($pagination-transition);\n\n  &:hover {\n    z-index: 2;\n    color: var(--#{$prefix}pagination-hover-color);\n    text-decoration: if($link-hover-decoration == underline, none, null);\n    -webkit-text-decoration: if($link-hover-decoration == underline, none, null);\n    -moz-text-decoration: if($link-hover-decoration == underline, none, null);\n    -ms-text-decoration: if($link-hover-decoration == underline, none, null);\n    -o-text-decoration: if($link-hover-decoration == underline, none, null);\n    background-color: var(--#{$prefix}pagination-hover-bg);\n    border-color: var(--#{$prefix}pagination-hover-border-color);\n  }\n\n  &:focus {\n    z-index: 3;\n    color: var(--#{$prefix}pagination-focus-color);\n    background-color: var(--#{$prefix}pagination-focus-bg);\n    outline: $pagination-focus-outline;\n    box-shadow: var(--#{$prefix}pagination-focus-box-shadow);\n  }\n\n  &.active,\n  .active > & {\n    z-index: 3;\n    color: var(--#{$prefix}pagination-active-color);\n    @include gradient-bg(var(--#{$prefix}pagination-active-bg));\n    border-color: var(--#{$prefix}pagination-active-border-color);\n  }\n\n  &.disabled,\n  .disabled > & {\n    color: var(--#{$prefix}pagination-disabled-color);\n    pointer-events: none;\n    background-color: var(--#{$prefix}pagination-disabled-bg);\n    border-color: var(--#{$prefix}pagination-disabled-border-color);\n  }\n}\n\n.page-item {\n  &:not(:first-child) .page-link {\n    margin-left: $pagination-margin-start;\n  }\n\n  @if $pagination-margin-start == calc(#{$pagination-border-width} * -1) {\n    &:first-child {\n      .page-link {\n        @include border-start-radius(var(--#{$prefix}pagination-border-radius));\n      }\n    }\n\n    &:last-child {\n      .page-link {\n        @include border-end-radius(var(--#{$prefix}pagination-border-radius));\n      }\n    }\n  } @else {\n    // Add border-radius to all pageLinks in case they have left margin\n    .page-link {\n      @include border-radius(var(--#{$prefix}pagination-border-radius));\n    }\n  }\n}\n\n\n//\n// Sizing\n//\n\n.pagination-lg {\n  @include pagination-size($pagination-padding-y-lg, $pagination-padding-x-lg, $font-size-lg, $pagination-border-radius-lg);\n}\n\n.pagination-sm {\n  @include pagination-size($pagination-padding-y-sm, $pagination-padding-x-sm, $font-size-sm, $pagination-border-radius-sm);\n}\n",
		"// Base class\n//\n// Requires one of the contextual, color modifier classes for `color` and\n// `background-color`.\n\n.badge {\n  // scss-docs-start badge-css-vars\n  --#{$prefix}badge-padding-x: #{$badge-padding-x};\n  --#{$prefix}badge-padding-y: #{$badge-padding-y};\n  @include rfs($badge-font-size, --#{$prefix}badge-font-size);\n  --#{$prefix}badge-font-weight: #{$badge-font-weight};\n  --#{$prefix}badge-color: #{$badge-color};\n  --#{$prefix}badge-border-radius: #{$badge-border-radius};\n  // scss-docs-end badge-css-vars\n\n  display: inline-block;\n  padding: var(--#{$prefix}badge-padding-y) var(--#{$prefix}badge-padding-x);\n  @include font-size(var(--#{$prefix}badge-font-size));\n  font-weight: var(--#{$prefix}badge-font-weight);\n  line-height: 1;\n  color: var(--#{$prefix}badge-color);\n  text-align: center;\n  white-space: nowrap;\n  vertical-align: baseline;\n  @include border-radius(var(--#{$prefix}badge-border-radius));\n  @include gradient-bg();\n\n  // Empty badges collapse automatically\n  &:empty {\n    display: none;\n  }\n}\n\n// Quick fix for badges in buttons\n.btn .badge {\n  position: relative;\n  top: -1px;\n}\n",
		"//\n// Base styles\n//\n\n.alert {\n  // scss-docs-start alert-css-vars\n  --#{$prefix}alert-bg: transparent;\n  --#{$prefix}alert-padding-x: #{$alert-padding-x};\n  --#{$prefix}alert-padding-y: #{$alert-padding-y};\n  --#{$prefix}alert-margin-bottom: #{$alert-margin-bottom};\n  --#{$prefix}alert-color: inherit;\n  --#{$prefix}alert-border-color: transparent;\n  --#{$prefix}alert-border: #{$alert-border-width} solid var(--#{$prefix}alert-border-color);\n  --#{$prefix}alert-border-radius: #{$alert-border-radius};\n  --#{$prefix}alert-link-color: inherit;\n  // scss-docs-end alert-css-vars\n\n  position: relative;\n  padding: var(--#{$prefix}alert-padding-y) var(--#{$prefix}alert-padding-x);\n  margin-bottom: var(--#{$prefix}alert-margin-bottom);\n  color: var(--#{$prefix}alert-color);\n  background-color: var(--#{$prefix}alert-bg);\n  border: var(--#{$prefix}alert-border);\n  @include border-radius(var(--#{$prefix}alert-border-radius));\n}\n\n// Headings for larger alerts\n.alert-heading {\n  // Specified to prevent conflicts of changing $headings-color\n  color: inherit;\n}\n\n// Provide class for links that match alerts\n.alert-link {\n  font-weight: $alert-link-font-weight;\n  color: var(--#{$prefix}alert-link-color);\n}\n\n\n// Dismissible alerts\n//\n// Expand the right padding and account for the close button's positioning.\n\n.alert-dismissible {\n  padding-right: $alert-dismissible-padding-r;\n\n  // Adjust close link position\n  .btn-close {\n    position: absolute;\n    top: 0;\n    right: 0;\n    z-index: $stretched-link-z-index + 1;\n    padding: $alert-padding-y * 1.25 $alert-padding-x;\n  }\n}\n\n\n// scss-docs-start alert-modifiers\n// Generate contextual modifier classes for colorizing the alert\n@each $state in map-keys($theme-colors) {\n  .alert-#{$state} {\n    --#{$prefix}alert-color: var(--#{$prefix}#{$state}-text-emphasis);\n    --#{$prefix}alert-bg: var(--#{$prefix}#{$state}-bg-subtle);\n    --#{$prefix}alert-border-color: var(--#{$prefix}#{$state}-border-subtle);\n    --#{$prefix}alert-link-color: var(--#{$prefix}#{$state}-text-emphasis);\n  }\n}\n// scss-docs-end alert-modifiers\n",
		"// Disable animation if transitions are disabled\n\n// scss-docs-start progress-keyframes\n@if $enable-transitions {\n  @keyframes progress-bar-stripes {\n    0% { background-position-x: $progress-height; }\n  }\n}\n// scss-docs-end progress-keyframes\n\n.progress,\n.progress-stacked {\n  // scss-docs-start progress-css-vars\n  --#{$prefix}progress-height: #{$progress-height};\n  @include rfs($progress-font-size, --#{$prefix}progress-font-size);\n  --#{$prefix}progress-bg: #{$progress-bg};\n  --#{$prefix}progress-border-radius: #{$progress-border-radius};\n  --#{$prefix}progress-box-shadow: #{$progress-box-shadow};\n  --#{$prefix}progress-bar-color: #{$progress-bar-color};\n  --#{$prefix}progress-bar-bg: #{$progress-bar-bg};\n  --#{$prefix}progress-bar-transition: #{$progress-bar-transition};\n  // scss-docs-end progress-css-vars\n\n  display: flex;\n  display: -webkit-flex;\n  height: var(--#{$prefix}progress-height);\n  overflow: hidden; // force rounded corners by cropping it\n  @include font-size(var(--#{$prefix}progress-font-size));\n  background-color: var(--#{$prefix}progress-bg);\n  @include border-radius(var(--#{$prefix}progress-border-radius));\n  @include box-shadow(var(--#{$prefix}progress-box-shadow));\n}\n\n.progress-bar {\n  display: flex;\n  display: -webkit-flex;\n  flex-direction: column;\n  -webkit-flex-direction: column;\n  justify-content: center;\n  -webkit-justify-content: center;\n  overflow: hidden;\n  color: var(--#{$prefix}progress-bar-color);\n  text-align: center;\n  white-space: nowrap;\n  background-color: var(--#{$prefix}progress-bar-bg);\n  @include transition(var(--#{$prefix}progress-bar-transition));\n}\n\n.progress-bar-striped {\n  @include gradient-striped();\n  background-size: var(--#{$prefix}progress-height) var(--#{$prefix}progress-height);\n}\n\n.progress-stacked > .progress {\n  overflow: visible;\n}\n\n.progress-stacked > .progress > .progress-bar {\n  width: 100%;\n}\n\n@if $enable-transitions {\n  .progress-bar-animated {\n    animation: $progress-bar-animation-timing progress-bar-stripes;\n\n    @if $enable-reduced-motion {\n      @media (prefers-reduced-motion: reduce) {\n        animation: none;\n      }\n    }\n  }\n}\n",
		"// Base class\n//\n// Easily usable on <ul>, <ol>, or <div>.\n\n.list-group {\n  // scss-docs-start list-group-css-vars\n  --#{$prefix}list-group-color: #{$list-group-color};\n  --#{$prefix}list-group-bg: #{$list-group-bg};\n  --#{$prefix}list-group-border-color: #{$list-group-border-color};\n  --#{$prefix}list-group-border-width: #{$list-group-border-width};\n  --#{$prefix}list-group-border-radius: #{$list-group-border-radius};\n  --#{$prefix}list-group-item-padding-x: #{$list-group-item-padding-x};\n  --#{$prefix}list-group-item-padding-y: #{$list-group-item-padding-y};\n  --#{$prefix}list-group-action-color: #{$list-group-action-color};\n  --#{$prefix}list-group-action-hover-color: #{$list-group-action-hover-color};\n  --#{$prefix}list-group-action-hover-bg: #{$list-group-hover-bg};\n  --#{$prefix}list-group-action-active-color: #{$list-group-action-active-color};\n  --#{$prefix}list-group-action-active-bg: #{$list-group-action-active-bg};\n  --#{$prefix}list-group-disabled-color: #{$list-group-disabled-color};\n  --#{$prefix}list-group-disabled-bg: #{$list-group-disabled-bg};\n  --#{$prefix}list-group-active-color: #{$list-group-active-color};\n  --#{$prefix}list-group-active-bg: #{$list-group-active-bg};\n  --#{$prefix}list-group-active-border-color: #{$list-group-active-border-color};\n  // scss-docs-end list-group-css-vars\n\n  display: flex;\n  display: -webkit-flex;\n  flex-direction: column;\n  -webkit-flex-direction: column;\n\n  // No need to set list-style: none; since .list-group-item is block level\n  padding-left: 0; // reset padding because ul and ol\n  margin-bottom: 0;\n  @include border-radius(var(--#{$prefix}list-group-border-radius));\n}\n\n.list-group-numbered {\n  list-style-type: none;\n  counter-reset: section;\n\n  > .list-group-item::before {\n    // Increments only this instance of the section counter\n    content: counters(section, \".\") \". \";\n    counter-increment: section;\n  }\n}\n\n// Interactive list items\n//\n// Use anchor or button elements instead of `li`s or `div`s to create interactive\n// list items. Includes an extra `.active` modifier class for selected items.\n\n.list-group-item-action {\n  width: 100%; // For `<button>`s (anchors become 100% by default though)\n  color: var(--#{$prefix}list-group-action-color);\n  text-align: inherit; // For `<button>`s (anchors inherit)\n\n  // Hover state\n  &:hover,\n  &:focus {\n    z-index: 1; // Place hover/focus items above their siblings for proper border styling\n    color: var(--#{$prefix}list-group-action-hover-color);\n    text-decoration: none;\n    background-color: var(--#{$prefix}list-group-action-hover-bg);\n  }\n\n  &:active {\n    color: var(--#{$prefix}list-group-action-active-color);\n    background-color: var(--#{$prefix}list-group-action-active-bg);\n  }\n}\n\n// Individual list items\n//\n// Use on `li`s or `div`s within the `.list-group` parent.\n\n.list-group-item {\n  position: relative;\n  display: block;\n  padding: var(--#{$prefix}list-group-item-padding-y) var(--#{$prefix}list-group-item-padding-x);\n  color: var(--#{$prefix}list-group-color);\n  text-decoration: if($link-decoration == none, null, none);\n  -webkit-text-decoration: if($link-decoration == none, null, none);\n  -moz-text-decoration: if($link-decoration == none, null, none);\n  -ms-text-decoration: if($link-decoration == none, null, none);\n  -o-text-decoration: if($link-decoration == none, null, none);\n  background-color: var(--#{$prefix}list-group-bg);\n  border: var(--#{$prefix}list-group-border-width) solid var(--#{$prefix}list-group-border-color);\n\n  &:first-child {\n    @include border-top-radius(inherit);\n  }\n\n  &:last-child {\n    @include border-bottom-radius(inherit);\n  }\n\n  &.disabled,\n  &:disabled {\n    color: var(--#{$prefix}list-group-disabled-color);\n    pointer-events: none;\n    background-color: var(--#{$prefix}list-group-disabled-bg);\n  }\n\n  // Include both here for `<a>`s and `<button>`s\n  &.active {\n    z-index: 2; // Place active items above their siblings for proper border styling\n    color: var(--#{$prefix}list-group-active-color);\n    background-color: var(--#{$prefix}list-group-active-bg);\n    border-color: var(--#{$prefix}list-group-active-border-color);\n  }\n\n  // stylelint-disable-next-line scss/selector-no-redundant-nesting-selector\n  & + .list-group-item {\n    border-top-width: 0;\n\n    &.active {\n      margin-top: calc(-1 * var(--#{$prefix}list-group-border-width)); // stylelint-disable-line function-disallowed-list\n      border-top-width: var(--#{$prefix}list-group-border-width);\n    }\n  }\n}\n\n// Horizontal\n//\n// Change the layout of list group items from vertical (default) to horizontal.\n\n@each $breakpoint in map-keys($grid-breakpoints) {\n  @include media-breakpoint-up($breakpoint) {\n    $infix: breakpoint-infix($breakpoint, $grid-breakpoints);\n\n    .list-group-horizontal#{$infix} {\n      flex-direction: row;\n      -webkit-flex-direction: row;\n\n      > .list-group-item {\n        &:first-child:not(:last-child) {\n          @include border-bottom-start-radius(var(--#{$prefix}list-group-border-radius));\n          @include border-top-end-radius(0);\n        }\n\n        &:last-child:not(:first-child) {\n          @include border-top-end-radius(var(--#{$prefix}list-group-border-radius));\n          @include border-bottom-start-radius(0);\n        }\n\n        &.active {\n          margin-top: 0;\n        }\n\n        + .list-group-item {\n          border-top-width: var(--#{$prefix}list-group-border-width);\n          border-left-width: 0;\n\n          &.active {\n            margin-left: calc(-1 * var(--#{$prefix}list-group-border-width)); // stylelint-disable-line function-disallowed-list\n            border-left-width: var(--#{$prefix}list-group-border-width);\n          }\n        }\n      }\n    }\n  }\n}\n\n\n// Flush list items\n//\n// Remove borders and border-radius to keep list group items edge-to-edge. Most\n// useful within other components (e.g., cards).\n\n.list-group-flush {\n  @include border-radius(0);\n\n  > .list-group-item {\n    border-width: 0 0 var(--#{$prefix}list-group-border-width);\n\n    &:last-child {\n      border-bottom-width: 0;\n    }\n  }\n}\n\n\n// scss-docs-start list-group-modifiers\n// List group contextual variants\n//\n// Add modifier classes to change text and background color on individual items.\n// Organizationally, this must come after the `:hover` states.\n\n@each $state in map-keys($theme-colors) {\n  .list-group-item-#{$state} {\n    --#{$prefix}list-group-color: var(--#{$prefix}#{$state}-text-emphasis);\n    --#{$prefix}list-group-bg: var(--#{$prefix}#{$state}-bg-subtle);\n    --#{$prefix}list-group-border-color: var(--#{$prefix}#{$state}-border-subtle);\n    --#{$prefix}list-group-action-hover-color: var(--#{$prefix}emphasis-color);\n    --#{$prefix}list-group-action-hover-bg: var(--#{$prefix}#{$state}-border-subtle);\n    --#{$prefix}list-group-action-active-color: var(--#{$prefix}emphasis-color);\n    --#{$prefix}list-group-action-active-bg: var(--#{$prefix}#{$state}-border-subtle);\n    --#{$prefix}list-group-active-color: var(--#{$prefix}#{$state}-bg-subtle);\n    --#{$prefix}list-group-active-bg: var(--#{$prefix}#{$state}-text-emphasis);\n    --#{$prefix}list-group-active-border-color: var(--#{$prefix}#{$state}-text-emphasis);\n  }\n}\n// scss-docs-end list-group-modifiers\n",
		"// Transparent background and border properties included for button version.\n// iOS requires the button element instead of an anchor tag.\n// If you want the anchor version, it requires `href=\"#\"`.\n// See https://developer.mozilla.org/en-US/docs/Web/Events/click#Safari_Mobile\n\n.btn-close {\n  // scss-docs-start close-css-vars\n  --#{$prefix}btn-close-color: #{$btn-close-color};\n  --#{$prefix}btn-close-bg: #{ escape-svg($btn-close-bg) };\n  --#{$prefix}btn-close-opacity: #{$btn-close-opacity};\n  --#{$prefix}btn-close-hover-opacity: #{$btn-close-hover-opacity};\n  --#{$prefix}btn-close-focus-shadow: #{$btn-close-focus-shadow};\n  --#{$prefix}btn-close-focus-opacity: #{$btn-close-focus-opacity};\n  --#{$prefix}btn-close-disabled-opacity: #{$btn-close-disabled-opacity};\n  --#{$prefix}btn-close-white-filter: #{$btn-close-white-filter};\n  // scss-docs-end close-css-vars\n\n  box-sizing: content-box;\n  width: $btn-close-width;\n  height: $btn-close-height;\n  padding: $btn-close-padding-y $btn-close-padding-x;\n  color: var(--#{$prefix}btn-close-color);\n  background: transparent var(--#{$prefix}btn-close-bg) center / $btn-close-width auto no-repeat; // include transparent for button elements\n  border: 0; // for button elements\n  @include border-radius();\n  opacity: var(--#{$prefix}btn-close-opacity);\n\n  // Override <a>'s hover style\n  &:hover {\n    color: var(--#{$prefix}btn-close-color);\n    text-decoration: none;\n    opacity: var(--#{$prefix}btn-close-hover-opacity);\n  }\n\n  &:focus {\n    outline: 0;\n    box-shadow: var(--#{$prefix}btn-close-focus-shadow);\n    opacity: var(--#{$prefix}btn-close-focus-opacity);\n  }\n\n  &:disabled,\n  &.disabled {\n    pointer-events: none;\n    user-select: none;\n    -webkit-user-select: none;\n    -moz-user-select: none;\n    -ms-user-select: none;\n    -o-user-select: none;\n    opacity: var(--#{$prefix}btn-close-disabled-opacity);\n  }\n}\n\n@mixin btn-close-white() {\n  filter: var(--#{$prefix}btn-close-white-filter);\n}\n\n.btn-close-white {\n  @include btn-close-white();\n}\n\n@if $enable-dark-mode {\n  @include color-mode(dark) {\n    .btn-close {\n      @include btn-close-white();\n    }\n  }\n}\n",
		".toast {\n  // scss-docs-start toast-css-vars\n  --#{$prefix}toast-zindex: #{$zindex-toast};\n  --#{$prefix}toast-padding-x: #{$toast-padding-x};\n  --#{$prefix}toast-padding-y: #{$toast-padding-y};\n  --#{$prefix}toast-spacing: #{$toast-spacing};\n  --#{$prefix}toast-max-width: #{$toast-max-width};\n  @include rfs($toast-font-size, --#{$prefix}toast-font-size);\n  --#{$prefix}toast-color: #{$toast-color};\n  --#{$prefix}toast-bg: #{$toast-background-color};\n  --#{$prefix}toast-border-width: #{$toast-border-width};\n  --#{$prefix}toast-border-color: #{$toast-border-color};\n  --#{$prefix}toast-border-radius: #{$toast-border-radius};\n  --#{$prefix}toast-box-shadow: #{$toast-box-shadow};\n  --#{$prefix}toast-header-color: #{$toast-header-color};\n  --#{$prefix}toast-header-bg: #{$toast-header-background-color};\n  --#{$prefix}toast-header-border-color: #{$toast-header-border-color};\n  // scss-docs-end toast-css-vars\n\n  width: var(--#{$prefix}toast-max-width);\n  max-width: 100%;\n  @include font-size(var(--#{$prefix}toast-font-size));\n  color: var(--#{$prefix}toast-color);\n  pointer-events: auto;\n  background-color: var(--#{$prefix}toast-bg);\n  background-clip: padding-box;\n  border: var(--#{$prefix}toast-border-width) solid var(--#{$prefix}toast-border-color);\n  box-shadow: var(--#{$prefix}toast-box-shadow);\n  @include border-radius(var(--#{$prefix}toast-border-radius));\n\n  &.showing {\n    opacity: 0;\n  }\n\n  &:not(.show) {\n    display: none;\n  }\n}\n\n.toast-container {\n  --#{$prefix}toast-zindex: #{$zindex-toast};\n\n  position: absolute;\n  z-index: var(--#{$prefix}toast-zindex);\n  width: max-content;\n  width: -webkit-max-content;\n  width: -moz-max-content;\n  width: -ms-max-content;\n  width: -o-max-content;\n  max-width: 100%;\n  pointer-events: none;\n\n  > :not(:last-child) {\n    margin-bottom: var(--#{$prefix}toast-spacing);\n  }\n}\n\n.toast-header {\n  display: flex;\n  display: -webkit-flex;\n  align-items: center;\n  -webkit-align-items: center;\n  padding: var(--#{$prefix}toast-padding-y) var(--#{$prefix}toast-padding-x);\n  color: var(--#{$prefix}toast-header-color);\n  background-color: var(--#{$prefix}toast-header-bg);\n  background-clip: padding-box;\n  border-bottom: var(--#{$prefix}toast-border-width) solid var(--#{$prefix}toast-header-border-color);\n  @include border-top-radius(calc(var(--#{$prefix}toast-border-radius) - var(--#{$prefix}toast-border-width)));\n\n  .btn-close {\n    margin-right: calc(-.5 * var(--#{$prefix}toast-padding-x)); // stylelint-disable-line function-disallowed-list\n    margin-left: var(--#{$prefix}toast-padding-x);\n  }\n}\n\n.toast-body {\n  padding: var(--#{$prefix}toast-padding-x);\n  word-wrap: break-word;\n}\n",
		"// stylelint-disable function-disallowed-list\n\n// .modal-open      - body class for killing the scroll\n// .modal           - container to scroll within\n// .modal-dialog    - positioning shell for the actual modal\n// .modal-content   - actual modal w/ bg and corners and stuff\n\n\n// Container that the modal scrolls within\n.modal {\n  // scss-docs-start modal-css-vars\n  --#{$prefix}modal-zindex: #{$zindex-modal};\n  --#{$prefix}modal-width: #{$modal-md};\n  --#{$prefix}modal-padding: #{$modal-inner-padding};\n  --#{$prefix}modal-margin: #{$modal-dialog-margin};\n  --#{$prefix}modal-color: #{$modal-content-color};\n  --#{$prefix}modal-bg: #{$modal-content-bg};\n  --#{$prefix}modal-border-color: #{$modal-content-border-color};\n  --#{$prefix}modal-border-width: #{$modal-content-border-width};\n  --#{$prefix}modal-border-radius: #{$modal-content-border-radius};\n  --#{$prefix}modal-box-shadow: #{$modal-content-box-shadow-xs};\n  --#{$prefix}modal-inner-border-radius: #{$modal-content-inner-border-radius};\n  --#{$prefix}modal-header-padding-x: #{$modal-header-padding-x};\n  --#{$prefix}modal-header-padding-y: #{$modal-header-padding-y};\n  --#{$prefix}modal-header-padding: #{$modal-header-padding}; // Todo in v6: Split this padding into x and y\n  --#{$prefix}modal-header-border-color: #{$modal-header-border-color};\n  --#{$prefix}modal-header-border-width: #{$modal-header-border-width};\n  --#{$prefix}modal-title-line-height: #{$modal-title-line-height};\n  --#{$prefix}modal-footer-gap: #{$modal-footer-margin-between};\n  --#{$prefix}modal-footer-bg: #{$modal-footer-bg};\n  --#{$prefix}modal-footer-border-color: #{$modal-footer-border-color};\n  --#{$prefix}modal-footer-border-width: #{$modal-footer-border-width};\n  // scss-docs-end modal-css-vars\n\n  position: fixed;\n  top: 0;\n  left: 0;\n  z-index: var(--#{$prefix}modal-zindex);\n  display: none;\n  width: 100%;\n  height: 100%;\n  overflow-x: hidden;\n  overflow-y: auto;\n  // Prevent Chrome on Windows from adding a focus outline. For details, see\n  // https://github.com/twbs/bootstrap/pull/10951.\n  outline: 0;\n  // We deliberately don't use `-webkit-overflow-scrolling: touch;` due to a\n  // gnarly iOS Safari bug: https://bugs.webkit.org/show_bug.cgi?id=158342\n  // See also https://github.com/twbs/bootstrap/issues/17695\n}\n\n// Shell div to position the modal with bottom padding\n.modal-dialog {\n  position: relative;\n  width: auto;\n  margin: var(--#{$prefix}modal-margin);\n  // allow clicks to pass through for custom click handling to close modal\n  pointer-events: none;\n\n  // When fading in the modal, animate it to slide down\n  .modal.fade & {\n    @include transition($modal-transition);\n    transform: $modal-fade-transform;\n  }\n  .modal.show & {\n    transform: $modal-show-transform;\n  }\n\n  // When trying to close, animate focus to scale\n  .modal.modal-static & {\n    transform: $modal-scale-transform;\n  }\n}\n\n.modal-dialog-scrollable {\n  height: calc(100% - var(--#{$prefix}modal-margin) * 2);\n\n  .modal-content {\n    max-height: 100%;\n    overflow: hidden;\n  }\n\n  .modal-body {\n    overflow-y: auto;\n  }\n}\n\n.modal-dialog-centered {\n  display: flex;\n  display: -webkit-flex;\n  align-items: center;\n  -webkit-align-items: center;\n  min-height: calc(100% - var(--#{$prefix}modal-margin) * 2);\n}\n\n// Actual modal\n.modal-content {\n  position: relative;\n  display: flex;\n  display: -webkit-flex;\n  flex-direction: column;\n  -webkit-flex-direction: column;\n  width: 100%; // Ensure `.modal-content` extends the full width of the parent `.modal-dialog`\n  // counteract the pointer-events: none; in the .modal-dialog\n  color: var(--#{$prefix}modal-color);\n  pointer-events: auto;\n  background-color: var(--#{$prefix}modal-bg);\n  background-clip: padding-box;\n  border: var(--#{$prefix}modal-border-width) solid var(--#{$prefix}modal-border-color);\n  @include border-radius(var(--#{$prefix}modal-border-radius));\n  @include box-shadow(var(--#{$prefix}modal-box-shadow));\n  // Remove focus outline from opened modal\n  outline: 0;\n}\n\n// Modal background\n.modal-backdrop {\n  // scss-docs-start modal-backdrop-css-vars\n  --#{$prefix}backdrop-zindex: #{$zindex-modal-backdrop};\n  --#{$prefix}backdrop-bg: #{$modal-backdrop-bg};\n  --#{$prefix}backdrop-opacity: #{$modal-backdrop-opacity};\n  // scss-docs-end modal-backdrop-css-vars\n\n  @include overlay-backdrop(var(--#{$prefix}backdrop-zindex), var(--#{$prefix}backdrop-bg), var(--#{$prefix}backdrop-opacity));\n}\n\n// Modal header\n// Top section of the modal w/ title and dismiss\n.modal-header {\n  display: flex;\n  display: -webkit-flex;\n  flex-shrink: 0;\n  -webkit-flex-shrink: 0;\n  align-items: center;\n  -webkit-align-items: center;\n  justify-content: space-between; // Put modal header elements (title and dismiss) on opposite ends\n  -webkit-justify-content: space-between; // Put modal header elements (title and dismiss) on opposite ends\n  padding: var(--#{$prefix}modal-header-padding);\n  border-bottom: var(--#{$prefix}modal-header-border-width) solid var(--#{$prefix}modal-header-border-color);\n  @include border-top-radius(var(--#{$prefix}modal-inner-border-radius));\n\n  .btn-close {\n    padding: calc(var(--#{$prefix}modal-header-padding-y) * .5) calc(var(--#{$prefix}modal-header-padding-x) * .5);\n    margin: calc(-.5 * var(--#{$prefix}modal-header-padding-y)) calc(-.5 * var(--#{$prefix}modal-header-padding-x)) calc(-.5 * var(--#{$prefix}modal-header-padding-y)) auto;\n  }\n}\n\n// Title text within header\n.modal-title {\n  margin-bottom: 0;\n  line-height: var(--#{$prefix}modal-title-line-height);\n}\n\n// Modal body\n// Where all modal content resides (sibling of .modal-header and .modal-footer)\n.modal-body {\n  position: relative;\n  // Enable `flex-grow: 1` so that the body take up as much space as possible\n  // when there should be a fixed height on `.modal-dialog`.\n  flex: 1 1 auto;\n  -webkit-flex: 1 1 auto;\n  padding: var(--#{$prefix}modal-padding);\n}\n\n// Footer (for actions)\n.modal-footer {\n  display: flex;\n  display: -webkit-flex;\n  flex-shrink: 0;\n  -webkit-flex-shrink: 0;\n  flex-wrap: wrap;\n  -webkit-flex-wrap: wrap;\n  align-items: center; // vertically center\n  -webkit-align-items: center; // vertically center\n  justify-content: flex-end; // Right align buttons with flex property because text-align doesn't work on flex items\n  -webkit-justify-content: flex-end; // Right align buttons with flex property because text-align doesn't work on flex items\n  padding: calc(var(--#{$prefix}modal-padding) - var(--#{$prefix}modal-footer-gap) * .5);\n  background-color: var(--#{$prefix}modal-footer-bg);\n  border-top: var(--#{$prefix}modal-footer-border-width) solid var(--#{$prefix}modal-footer-border-color);\n  @include border-bottom-radius(var(--#{$prefix}modal-inner-border-radius));\n\n  // Place margin between footer elements\n  // This solution is far from ideal because of the universal selector usage,\n  // but is needed to fix https://github.com/twbs/bootstrap/issues/24800\n  > * {\n    margin: calc(var(--#{$prefix}modal-footer-gap) * .5); // Todo in v6: replace with gap on parent class\n  }\n}\n\n// Scale up the modal\n@include media-breakpoint-up(sm) {\n  .modal {\n    --#{$prefix}modal-margin: #{$modal-dialog-margin-y-sm-up};\n    --#{$prefix}modal-box-shadow: #{$modal-content-box-shadow-sm-up};\n  }\n\n  // Automatically set modal's width for larger viewports\n  .modal-dialog {\n    max-width: var(--#{$prefix}modal-width);\n    margin-right: auto;\n    margin-left: auto;\n  }\n\n  .modal-sm {\n    --#{$prefix}modal-width: #{$modal-sm};\n  }\n}\n\n@include media-breakpoint-up(lg) {\n  .modal-lg,\n  .modal-xl {\n    --#{$prefix}modal-width: #{$modal-lg};\n  }\n}\n\n@include media-breakpoint-up(xl) {\n  .modal-xl {\n    --#{$prefix}modal-width: #{$modal-xl};\n  }\n}\n\n// scss-docs-start modal-fullscreen-loop\n@each $breakpoint in map-keys($grid-breakpoints) {\n  $infix: breakpoint-infix($breakpoint, $grid-breakpoints);\n  $postfix: if($infix != \"\", $infix + \"-down\", \"\");\n\n  @include media-breakpoint-down($breakpoint) {\n    .modal-fullscreen#{$postfix} {\n      width: 100vw;\n      max-width: none;\n      height: 100%;\n      margin: 0;\n\n      .modal-content {\n        height: 100%;\n        border: 0;\n        @include border-radius(0);\n      }\n\n      .modal-header,\n      .modal-footer {\n        @include border-radius(0);\n      }\n\n      .modal-body {\n        overflow-y: auto;\n      }\n    }\n  }\n}\n// scss-docs-end modal-fullscreen-loop\n",
		"// Base class\n.tooltip {\n  // scss-docs-start tooltip-css-vars\n  --#{$prefix}tooltip-zindex: #{$zindex-tooltip};\n  --#{$prefix}tooltip-max-width: #{$tooltip-max-width};\n  --#{$prefix}tooltip-padding-x: #{$tooltip-padding-x};\n  --#{$prefix}tooltip-padding-y: #{$tooltip-padding-y};\n  --#{$prefix}tooltip-margin: #{$tooltip-margin};\n  @include rfs($tooltip-font-size, --#{$prefix}tooltip-font-size);\n  --#{$prefix}tooltip-color: #{$tooltip-color};\n  --#{$prefix}tooltip-bg: #{$tooltip-bg};\n  --#{$prefix}tooltip-border-radius: #{$tooltip-border-radius};\n  --#{$prefix}tooltip-opacity: #{$tooltip-opacity};\n  --#{$prefix}tooltip-arrow-width: #{$tooltip-arrow-width};\n  --#{$prefix}tooltip-arrow-height: #{$tooltip-arrow-height};\n  // scss-docs-end tooltip-css-vars\n\n  z-index: var(--#{$prefix}tooltip-zindex);\n  display: block;\n  margin: var(--#{$prefix}tooltip-margin);\n  @include deprecate(\"`$tooltip-margin`\", \"v5\", \"v5.x\", true);\n  // Our parent element can be arbitrary since tooltips are by default inserted as a sibling of their target element.\n  // So reset our font and text properties to avoid inheriting weird values.\n  @include reset-text();\n  @include font-size(var(--#{$prefix}tooltip-font-size));\n  // Allow breaking very long words so they don't overflow the tooltip's bounds\n  word-wrap: break-word;\n  opacity: 0;\n\n  &.show { opacity: var(--#{$prefix}tooltip-opacity); }\n\n  .tooltip-arrow {\n    display: block;\n    width: var(--#{$prefix}tooltip-arrow-width);\n    height: var(--#{$prefix}tooltip-arrow-height);\n\n    &::before {\n      position: absolute;\n      content: \"\";\n      border-color: transparent;\n      border-style: solid;\n    }\n  }\n}\n\n.bs-tooltip-top .tooltip-arrow {\n  bottom: calc(-1 * var(--#{$prefix}tooltip-arrow-height)); // stylelint-disable-line function-disallowed-list\n\n  &::before {\n    top: -1px;\n    border-width: var(--#{$prefix}tooltip-arrow-height) calc(var(--#{$prefix}tooltip-arrow-width) * .5) 0; // stylelint-disable-line function-disallowed-list\n    border-top-color: var(--#{$prefix}tooltip-bg);\n  }\n}\n\n/* rtl:begin:ignore */\n.bs-tooltip-end .tooltip-arrow {\n  left: calc(-1 * var(--#{$prefix}tooltip-arrow-height)); // stylelint-disable-line function-disallowed-list\n  width: var(--#{$prefix}tooltip-arrow-height);\n  height: var(--#{$prefix}tooltip-arrow-width);\n\n  &::before {\n    right: -1px;\n    border-width: calc(var(--#{$prefix}tooltip-arrow-width) * .5) var(--#{$prefix}tooltip-arrow-height) calc(var(--#{$prefix}tooltip-arrow-width) * .5) 0; // stylelint-disable-line function-disallowed-list\n    border-right-color: var(--#{$prefix}tooltip-bg);\n  }\n}\n\n/* rtl:end:ignore */\n\n.bs-tooltip-bottom .tooltip-arrow {\n  top: calc(-1 * var(--#{$prefix}tooltip-arrow-height)); // stylelint-disable-line function-disallowed-list\n\n  &::before {\n    bottom: -1px;\n    border-width: 0 calc(var(--#{$prefix}tooltip-arrow-width) * .5) var(--#{$prefix}tooltip-arrow-height); // stylelint-disable-line function-disallowed-list\n    border-bottom-color: var(--#{$prefix}tooltip-bg);\n  }\n}\n\n/* rtl:begin:ignore */\n.bs-tooltip-start .tooltip-arrow {\n  right: calc(-1 * var(--#{$prefix}tooltip-arrow-height)); // stylelint-disable-line function-disallowed-list\n  width: var(--#{$prefix}tooltip-arrow-height);\n  height: var(--#{$prefix}tooltip-arrow-width);\n\n  &::before {\n    left: -1px;\n    border-width: calc(var(--#{$prefix}tooltip-arrow-width) * .5) 0 calc(var(--#{$prefix}tooltip-arrow-width) * .5) var(--#{$prefix}tooltip-arrow-height); // stylelint-disable-line function-disallowed-list\n    border-left-color: var(--#{$prefix}tooltip-bg);\n  }\n}\n\n/* rtl:end:ignore */\n\n.bs-tooltip-auto {\n  &[data-popper-placement^=\"top\"] {\n    @extend .bs-tooltip-top;\n  }\n  &[data-popper-placement^=\"right\"] {\n    @extend .bs-tooltip-end;\n  }\n  &[data-popper-placement^=\"bottom\"] {\n    @extend .bs-tooltip-bottom;\n  }\n  &[data-popper-placement^=\"left\"] {\n    @extend .bs-tooltip-start;\n  }\n}\n\n// Wrapper for the tooltip content\n.tooltip-inner {\n  max-width: var(--#{$prefix}tooltip-max-width);\n  padding: var(--#{$prefix}tooltip-padding-y) var(--#{$prefix}tooltip-padding-x);\n  color: var(--#{$prefix}tooltip-color);\n  text-align: center;\n  background-color: var(--#{$prefix}tooltip-bg);\n  @include border-radius(var(--#{$prefix}tooltip-border-radius));\n}\n",
		".popover {\n  // scss-docs-start popover-css-vars\n  --#{$prefix}popover-zindex: #{$zindex-popover};\n  --#{$prefix}popover-max-width: #{$popover-max-width};\n  @include rfs($popover-font-size, --#{$prefix}popover-font-size);\n  --#{$prefix}popover-bg: #{$popover-bg};\n  --#{$prefix}popover-border-width: #{$popover-border-width};\n  --#{$prefix}popover-border-color: #{$popover-border-color};\n  --#{$prefix}popover-border-radius: #{$popover-border-radius};\n  --#{$prefix}popover-inner-border-radius: #{$popover-inner-border-radius};\n  --#{$prefix}popover-box-shadow: #{$popover-box-shadow};\n  --#{$prefix}popover-header-padding-x: #{$popover-header-padding-x};\n  --#{$prefix}popover-header-padding-y: #{$popover-header-padding-y};\n  @include rfs($popover-header-font-size, --#{$prefix}popover-header-font-size);\n  --#{$prefix}popover-header-color: #{$popover-header-color};\n  --#{$prefix}popover-header-bg: #{$popover-header-bg};\n  --#{$prefix}popover-body-padding-x: #{$popover-body-padding-x};\n  --#{$prefix}popover-body-padding-y: #{$popover-body-padding-y};\n  --#{$prefix}popover-body-color: #{$popover-body-color};\n  --#{$prefix}popover-arrow-width: #{$popover-arrow-width};\n  --#{$prefix}popover-arrow-height: #{$popover-arrow-height};\n  --#{$prefix}popover-arrow-border: var(--#{$prefix}popover-border-color);\n  // scss-docs-end popover-css-vars\n\n  z-index: var(--#{$prefix}popover-zindex);\n  display: block;\n  max-width: var(--#{$prefix}popover-max-width);\n  // Our parent element can be arbitrary since tooltips are by default inserted as a sibling of their target element.\n  // So reset our font and text properties to avoid inheriting weird values.\n  @include reset-text();\n  @include font-size(var(--#{$prefix}popover-font-size));\n  // Allow breaking very long words so they don't overflow the popover's bounds\n  word-wrap: break-word;\n  background-color: var(--#{$prefix}popover-bg);\n  background-clip: padding-box;\n  border: var(--#{$prefix}popover-border-width) solid var(--#{$prefix}popover-border-color);\n  @include border-radius(var(--#{$prefix}popover-border-radius));\n  @include box-shadow(var(--#{$prefix}popover-box-shadow));\n\n  .popover-arrow {\n    display: block;\n    width: var(--#{$prefix}popover-arrow-width);\n    height: var(--#{$prefix}popover-arrow-height);\n\n    &::before,\n    &::after {\n      position: absolute;\n      display: block;\n      content: \"\";\n      border-color: transparent;\n      border-style: solid;\n      border-width: 0;\n    }\n  }\n}\n\n.bs-popover-top {\n  > .popover-arrow {\n    bottom: calc(-1 * (var(--#{$prefix}popover-arrow-height)) - var(--#{$prefix}popover-border-width)); // stylelint-disable-line function-disallowed-list\n\n    &::before,\n    &::after {\n      border-width: var(--#{$prefix}popover-arrow-height) calc(var(--#{$prefix}popover-arrow-width) * .5) 0; // stylelint-disable-line function-disallowed-list\n    }\n\n    &::before {\n      bottom: 0;\n      border-top-color: var(--#{$prefix}popover-arrow-border);\n    }\n\n    &::after {\n      bottom: var(--#{$prefix}popover-border-width);\n      border-top-color: var(--#{$prefix}popover-bg);\n    }\n  }\n}\n\n/* rtl:begin:ignore */\n.bs-popover-end {\n  > .popover-arrow {\n    left: calc(-1 * (var(--#{$prefix}popover-arrow-height)) - var(--#{$prefix}popover-border-width)); // stylelint-disable-line function-disallowed-list\n    width: var(--#{$prefix}popover-arrow-height);\n    height: var(--#{$prefix}popover-arrow-width);\n\n    &::before,\n    &::after {\n      border-width: calc(var(--#{$prefix}popover-arrow-width) * .5) var(--#{$prefix}popover-arrow-height) calc(var(--#{$prefix}popover-arrow-width) * .5) 0; // stylelint-disable-line function-disallowed-list\n    }\n\n    &::before {\n      left: 0;\n      border-right-color: var(--#{$prefix}popover-arrow-border);\n    }\n\n    &::after {\n      left: var(--#{$prefix}popover-border-width);\n      border-right-color: var(--#{$prefix}popover-bg);\n    }\n  }\n}\n\n/* rtl:end:ignore */\n\n.bs-popover-bottom {\n  > .popover-arrow {\n    top: calc(-1 * (var(--#{$prefix}popover-arrow-height)) - var(--#{$prefix}popover-border-width)); // stylelint-disable-line function-disallowed-list\n\n    &::before,\n    &::after {\n      border-width: 0 calc(var(--#{$prefix}popover-arrow-width) * .5) var(--#{$prefix}popover-arrow-height); // stylelint-disable-line function-disallowed-list\n    }\n\n    &::before {\n      top: 0;\n      border-bottom-color: var(--#{$prefix}popover-arrow-border);\n    }\n\n    &::after {\n      top: var(--#{$prefix}popover-border-width);\n      border-bottom-color: var(--#{$prefix}popover-bg);\n    }\n  }\n\n  // This will remove the popover-header's border just below the arrow\n  .popover-header::before {\n    position: absolute;\n    top: 0;\n    left: 50%;\n    display: block;\n    width: var(--#{$prefix}popover-arrow-width);\n    margin-left: calc(-.5 * var(--#{$prefix}popover-arrow-width)); // stylelint-disable-line function-disallowed-list\n    content: \"\";\n    border-bottom: var(--#{$prefix}popover-border-width) solid var(--#{$prefix}popover-header-bg);\n  }\n}\n\n/* rtl:begin:ignore */\n.bs-popover-start {\n  > .popover-arrow {\n    right: calc(-1 * (var(--#{$prefix}popover-arrow-height)) - var(--#{$prefix}popover-border-width)); // stylelint-disable-line function-disallowed-list\n    width: var(--#{$prefix}popover-arrow-height);\n    height: var(--#{$prefix}popover-arrow-width);\n\n    &::before,\n    &::after {\n      border-width: calc(var(--#{$prefix}popover-arrow-width) * .5) 0 calc(var(--#{$prefix}popover-arrow-width) * .5) var(--#{$prefix}popover-arrow-height); // stylelint-disable-line function-disallowed-list\n    }\n\n    &::before {\n      right: 0;\n      border-left-color: var(--#{$prefix}popover-arrow-border);\n    }\n\n    &::after {\n      right: var(--#{$prefix}popover-border-width);\n      border-left-color: var(--#{$prefix}popover-bg);\n    }\n  }\n}\n\n/* rtl:end:ignore */\n\n.bs-popover-auto {\n  &[data-popper-placement^=\"top\"] {\n    @extend .bs-popover-top;\n  }\n  &[data-popper-placement^=\"right\"] {\n    @extend .bs-popover-end;\n  }\n  &[data-popper-placement^=\"bottom\"] {\n    @extend .bs-popover-bottom;\n  }\n  &[data-popper-placement^=\"left\"] {\n    @extend .bs-popover-start;\n  }\n}\n\n// Offset the popover to account for the popover arrow\n.popover-header {\n  padding: var(--#{$prefix}popover-header-padding-y) var(--#{$prefix}popover-header-padding-x);\n  margin-bottom: 0; // Reset the default from Reboot\n  @include font-size(var(--#{$prefix}popover-header-font-size));\n  color: var(--#{$prefix}popover-header-color);\n  background-color: var(--#{$prefix}popover-header-bg);\n  border-bottom: var(--#{$prefix}popover-border-width) solid var(--#{$prefix}popover-border-color);\n  @include border-top-radius(var(--#{$prefix}popover-inner-border-radius));\n\n  &:empty {\n    display: none;\n  }\n}\n\n.popover-body {\n  padding: var(--#{$prefix}popover-body-padding-y) var(--#{$prefix}popover-body-padding-x);\n  color: var(--#{$prefix}popover-body-color);\n}\n",
		"// Notes on the classes:\n//\n// 1. .carousel.pointer-event should ideally be pan-y (to allow for users to scroll vertically)\n//    even when their scroll action started on a carousel, but for compatibility (with Firefox)\n//    we're preventing all actions instead\n// 2. The .carousel-item-start and .carousel-item-end is used to indicate where\n//    the active slide is heading.\n// 3. .active.carousel-item is the current slide.\n// 4. .active.carousel-item-start and .active.carousel-item-end is the current\n//    slide in its in-transition state. Only one of these occurs at a time.\n// 5. .carousel-item-next.carousel-item-start and .carousel-item-prev.carousel-item-end\n//    is the upcoming slide in transition.\n\n.carousel {\n  position: relative;\n}\n\n.carousel.pointer-event {\n  touch-action: pan-y;\n  -webkit-touch-action: pan-y;\n  -moz-touch-action: pan-y;\n  -ms-touch-action: pan-y;\n  -o-touch-action: pan-y;\n}\n\n.carousel-inner {\n  position: relative;\n  width: 100%;\n  overflow: hidden;\n  @include clearfix();\n}\n\n.carousel-item {\n  position: relative;\n  display: none;\n  float: left;\n  width: 100%;\n  margin-right: -100%;\n  backface-visibility: hidden;\n  -webkit-backface-visibility: hidden;\n  -moz-backface-visibility: hidden;\n  -ms-backface-visibility: hidden;\n  -o-backface-visibility: hidden;\n  @include transition($carousel-transition);\n}\n\n.carousel-item.active,\n.carousel-item-next,\n.carousel-item-prev {\n  display: block;\n}\n\n.carousel-item-next:not(.carousel-item-start),\n.active.carousel-item-end {\n  transform: translateX(100%);\n}\n\n.carousel-item-prev:not(.carousel-item-end),\n.active.carousel-item-start {\n  transform: translateX(-100%);\n}\n\n\n//\n// Alternate transitions\n//\n\n.carousel-fade {\n  .carousel-item {\n    opacity: 0;\n    transition-property: opacity;\n    transform: none;\n  }\n\n  .carousel-item.active,\n  .carousel-item-next.carousel-item-start,\n  .carousel-item-prev.carousel-item-end {\n    z-index: 1;\n    opacity: 1;\n  }\n\n  .active.carousel-item-start,\n  .active.carousel-item-end {\n    z-index: 0;\n    opacity: 0;\n    @include transition(opacity 0s $carousel-transition-duration);\n  }\n}\n\n\n//\n// Left/right controls for nav\n//\n\n.carousel-control-prev,\n.carousel-control-next {\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  z-index: 1;\n  // Use flex for alignment (1-3)\n  display: flex; // 1. allow flex styles\n  display: -webkit-flex; // 1. allow flex styles\n  align-items: center; // 2. vertically center contents\n  -webkit-align-items: center; // 2. vertically center contents\n  justify-content: center; // 3. horizontally center contents\n  -webkit-justify-content: center; // 3. horizontally center contents\n  width: $carousel-control-width;\n  padding: 0;\n  color: $carousel-control-color;\n  text-align: center;\n  background: none;\n  border: 0;\n  opacity: $carousel-control-opacity;\n  @include transition($carousel-control-transition);\n\n  // Hover/focus state\n  &:hover,\n  &:focus {\n    color: $carousel-control-color;\n    text-decoration: none;\n    outline: 0;\n    opacity: $carousel-control-hover-opacity;\n  }\n}\n.carousel-control-prev {\n  left: 0;\n  background-image: if($enable-gradients, linear-gradient(90deg, rgba($black, .25), rgba($black, .001)), null);\n}\n.carousel-control-next {\n  right: 0;\n  background-image: if($enable-gradients, linear-gradient(270deg, rgba($black, .25), rgba($black, .001)), null);\n}\n\n// Icons for within\n.carousel-control-prev-icon,\n.carousel-control-next-icon {\n  display: inline-block;\n  width: $carousel-control-icon-width;\n  height: $carousel-control-icon-width;\n  background-repeat: no-repeat;\n  background-position: 50%;\n  background-size: 100% 100%;\n}\n\n/* rtl:options: {\n  \"autoRename\": true,\n  \"stringMap\":[ {\n    \"name\"    : \"prev-next\",\n    \"search\"  : \"prev\",\n    \"replace\" : \"next\"\n  } ]\n} */\n.carousel-control-prev-icon {\n  background-image: escape-svg($carousel-control-prev-icon-bg);\n}\n.carousel-control-next-icon {\n  background-image: escape-svg($carousel-control-next-icon-bg);\n}\n\n// Optional indicator pips/controls\n//\n// Add a container (such as a list) with the following class and add an item (ideally a focusable control,\n// like a button) with data-bs-target for each slide your carousel holds.\n\n.carousel-indicators {\n  position: absolute;\n  right: 0;\n  bottom: 0;\n  left: 0;\n  z-index: 2;\n  display: flex;\n  display: -webkit-flex;\n  justify-content: center;\n  -webkit-justify-content: center;\n  padding: 0;\n  // Use the .carousel-control's width as margin so we don't overlay those\n  margin-right: $carousel-control-width;\n  margin-bottom: 1rem;\n  margin-left: $carousel-control-width;\n\n  [data-bs-target] {\n    box-sizing: content-box;\n    flex: 0 1 auto;\n    -webkit-flex: 0 1 auto;\n    width: $carousel-indicator-width;\n    height: $carousel-indicator-height;\n    padding: 0;\n    margin-right: $carousel-indicator-spacer;\n    margin-left: $carousel-indicator-spacer;\n    text-indent: -999px;\n    cursor: pointer;\n    background-color: $carousel-indicator-active-bg;\n    background-clip: padding-box;\n    border: 0;\n    // Use transparent borders to increase the hit area by 10px on top and bottom.\n    border-top: $carousel-indicator-hit-area-height solid transparent;\n    border-bottom: $carousel-indicator-hit-area-height solid transparent;\n    opacity: $carousel-indicator-opacity;\n    @include transition($carousel-indicator-transition);\n  }\n\n  .active {\n    opacity: $carousel-indicator-active-opacity;\n  }\n}\n\n\n// Optional captions\n//\n//\n\n.carousel-caption {\n  position: absolute;\n  right: (100% - $carousel-caption-width) * .5;\n  bottom: $carousel-caption-spacer;\n  left: (100% - $carousel-caption-width) * .5;\n  padding-top: $carousel-caption-padding-y;\n  padding-bottom: $carousel-caption-padding-y;\n  color: $carousel-caption-color;\n  text-align: center;\n}\n\n// Dark mode carousel\n\n@mixin carousel-dark() {\n  .carousel-control-prev-icon,\n  .carousel-control-next-icon {\n    filter: $carousel-dark-control-icon-filter;\n  }\n\n  .carousel-indicators [data-bs-target] {\n    background-color: $carousel-dark-indicator-active-bg;\n  }\n\n  .carousel-caption {\n    color: $carousel-dark-caption-color;\n  }\n}\n\n.carousel-dark {\n  @include carousel-dark();\n}\n\n@if $enable-dark-mode {\n  @include color-mode(dark) {\n    @if $color-mode-type == \"media-query\" {\n      .carousel {\n        @include carousel-dark();\n      }\n    } @else {\n      .carousel,\n      &.carousel {\n        @include carousel-dark();\n      }\n    }\n  }\n}\n",
		"//\n// Rotating border\n//\n\n.spinner-grow,\n.spinner-border {\n  display: inline-block;\n  width: var(--#{$prefix}spinner-width);\n  height: var(--#{$prefix}spinner-height);\n  vertical-align: var(--#{$prefix}spinner-vertical-align);\n  // stylelint-disable-next-line property-disallowed-list\n  border-radius: 50%;\n  animation: var(--#{$prefix}spinner-animation-speed) linear infinite var(--#{$prefix}spinner-animation-name);\n}\n\n// scss-docs-start spinner-border-keyframes\n@keyframes spinner-border {\n  to { transform: rotate(360deg) #{\"/* rtl:ignore */\"}; }\n}\n// scss-docs-end spinner-border-keyframes\n\n.spinner-border {\n  // scss-docs-start spinner-border-css-vars\n  --#{$prefix}spinner-width: #{$spinner-width};\n  --#{$prefix}spinner-height: #{$spinner-height};\n  --#{$prefix}spinner-vertical-align: #{$spinner-vertical-align};\n  --#{$prefix}spinner-border-width: #{$spinner-border-width};\n  --#{$prefix}spinner-animation-speed: #{$spinner-animation-speed};\n  --#{$prefix}spinner-animation-name: spinner-border;\n  // scss-docs-end spinner-border-css-vars\n\n  border: var(--#{$prefix}spinner-border-width) solid currentcolor;\n  border-right-color: transparent;\n}\n\n.spinner-border-sm {\n  // scss-docs-start spinner-border-sm-css-vars\n  --#{$prefix}spinner-width: #{$spinner-width-sm};\n  --#{$prefix}spinner-height: #{$spinner-height-sm};\n  --#{$prefix}spinner-border-width: #{$spinner-border-width-sm};\n  // scss-docs-end spinner-border-sm-css-vars\n}\n\n//\n// Growing circle\n//\n\n// scss-docs-start spinner-grow-keyframes\n@keyframes spinner-grow {\n  0% {\n    transform: scale(0);\n  }\n  50% {\n    opacity: 1;\n    transform: none;\n  }\n}\n// scss-docs-end spinner-grow-keyframes\n\n.spinner-grow {\n  // scss-docs-start spinner-grow-css-vars\n  --#{$prefix}spinner-width: #{$spinner-width};\n  --#{$prefix}spinner-height: #{$spinner-height};\n  --#{$prefix}spinner-vertical-align: #{$spinner-vertical-align};\n  --#{$prefix}spinner-animation-speed: #{$spinner-animation-speed};\n  --#{$prefix}spinner-animation-name: spinner-grow;\n  // scss-docs-end spinner-grow-css-vars\n\n  background-color: currentcolor;\n  opacity: 0;\n}\n\n.spinner-grow-sm {\n  --#{$prefix}spinner-width: #{$spinner-width-sm};\n  --#{$prefix}spinner-height: #{$spinner-height-sm};\n}\n\n@if $enable-reduced-motion {\n  @media (prefers-reduced-motion: reduce) {\n    .spinner-border,\n    .spinner-grow {\n      --#{$prefix}spinner-animation-speed: #{$spinner-animation-speed * 2};\n    }\n  }\n}\n",
		"// stylelint-disable function-disallowed-list\n\n%offcanvas-css-vars {\n  // scss-docs-start offcanvas-css-vars\n  --#{$prefix}offcanvas-zindex: #{$zindex-offcanvas};\n  --#{$prefix}offcanvas-width: #{$offcanvas-horizontal-width};\n  --#{$prefix}offcanvas-height: #{$offcanvas-vertical-height};\n  --#{$prefix}offcanvas-padding-x: #{$offcanvas-padding-x};\n  --#{$prefix}offcanvas-padding-y: #{$offcanvas-padding-y};\n  --#{$prefix}offcanvas-color: #{$offcanvas-color};\n  --#{$prefix}offcanvas-bg: #{$offcanvas-bg-color};\n  --#{$prefix}offcanvas-border-width: #{$offcanvas-border-width};\n  --#{$prefix}offcanvas-border-color: #{$offcanvas-border-color};\n  --#{$prefix}offcanvas-box-shadow: #{$offcanvas-box-shadow};\n  --#{$prefix}offcanvas-transition: #{transform $offcanvas-transition-duration ease-in-out};\n  --#{$prefix}offcanvas-title-line-height: #{$offcanvas-title-line-height};\n  // scss-docs-end offcanvas-css-vars\n}\n\n@each $breakpoint in map-keys($grid-breakpoints) {\n  $next: breakpoint-next($breakpoint, $grid-breakpoints);\n  $infix: breakpoint-infix($next, $grid-breakpoints);\n\n  .offcanvas#{$infix} {\n    @extend %offcanvas-css-vars;\n  }\n}\n\n@each $breakpoint in map-keys($grid-breakpoints) {\n  $next: breakpoint-next($breakpoint, $grid-breakpoints);\n  $infix: breakpoint-infix($next, $grid-breakpoints);\n\n  .offcanvas#{$infix} {\n    @include media-breakpoint-down($next) {\n      position: fixed;\n      bottom: 0;\n      z-index: var(--#{$prefix}offcanvas-zindex);\n      display: flex;\n      display: -webkit-flex;\n      flex-direction: column;\n      -webkit-flex-direction: column;\n      max-width: 100%;\n      color: var(--#{$prefix}offcanvas-color);\n      visibility: hidden;\n      background-color: var(--#{$prefix}offcanvas-bg);\n      background-clip: padding-box;\n      outline: 0;\n      @include box-shadow(var(--#{$prefix}offcanvas-box-shadow));\n      @include transition(var(--#{$prefix}offcanvas-transition));\n\n      &.offcanvas-start {\n        top: 0;\n        left: 0;\n        width: var(--#{$prefix}offcanvas-width);\n        border-right: var(--#{$prefix}offcanvas-border-width) solid var(--#{$prefix}offcanvas-border-color);\n        transform: translateX(-100%);\n      }\n\n      &.offcanvas-end {\n        top: 0;\n        right: 0;\n        width: var(--#{$prefix}offcanvas-width);\n        border-left: var(--#{$prefix}offcanvas-border-width) solid var(--#{$prefix}offcanvas-border-color);\n        transform: translateX(100%);\n      }\n\n      &.offcanvas-top {\n        top: 0;\n        right: 0;\n        left: 0;\n        height: var(--#{$prefix}offcanvas-height);\n        max-height: 100%;\n        border-bottom: var(--#{$prefix}offcanvas-border-width) solid var(--#{$prefix}offcanvas-border-color);\n        transform: translateY(-100%);\n      }\n\n      &.offcanvas-bottom {\n        right: 0;\n        left: 0;\n        height: var(--#{$prefix}offcanvas-height);\n        max-height: 100%;\n        border-top: var(--#{$prefix}offcanvas-border-width) solid var(--#{$prefix}offcanvas-border-color);\n        transform: translateY(100%);\n      }\n\n      &.showing,\n      &.show:not(.hiding) {\n        transform: none;\n      }\n\n      &.showing,\n      &.hiding,\n      &.show {\n        visibility: visible;\n      }\n    }\n\n    @if not ($infix == \"\") {\n      @include media-breakpoint-up($next) {\n        --#{$prefix}offcanvas-height: auto;\n        --#{$prefix}offcanvas-border-width: 0;\n        background-color: transparent !important; // stylelint-disable-line declaration-no-important\n\n        .offcanvas-header {\n          display: none;\n        }\n\n        .offcanvas-body {\n          display: flex;\n          display: -webkit-flex;\n          flex-grow: 0;\n          -webkit-flex-grow: 0;\n          padding: 0;\n          overflow-y: visible;\n          // Reset `background-color` in case `.bg-*` classes are used in offcanvas\n          background-color: transparent !important; // stylelint-disable-line declaration-no-important\n        }\n      }\n    }\n  }\n}\n\n.offcanvas-backdrop {\n  @include overlay-backdrop($zindex-offcanvas-backdrop, $offcanvas-backdrop-bg, $offcanvas-backdrop-opacity);\n}\n\n.offcanvas-header {\n  display: flex;\n  display: -webkit-flex;\n  align-items: center;\n  -webkit-align-items: center;\n  justify-content: space-between;\n  -webkit-justify-content: space-between;\n  padding: var(--#{$prefix}offcanvas-padding-y) var(--#{$prefix}offcanvas-padding-x);\n\n  .btn-close {\n    padding: calc(var(--#{$prefix}offcanvas-padding-y) * .5) calc(var(--#{$prefix}offcanvas-padding-x) * .5);\n    margin-top: calc(-.5 * var(--#{$prefix}offcanvas-padding-y));\n    margin-right: calc(-.5 * var(--#{$prefix}offcanvas-padding-x));\n    margin-bottom: calc(-.5 * var(--#{$prefix}offcanvas-padding-y));\n  }\n}\n\n.offcanvas-title {\n  margin-bottom: 0;\n  line-height: var(--#{$prefix}offcanvas-title-line-height);\n}\n\n.offcanvas-body {\n  flex-grow: 1;\n  -webkit-flex-grow: 1;\n  padding: var(--#{$prefix}offcanvas-padding-y) var(--#{$prefix}offcanvas-padding-x);\n  overflow-y: auto;\n}\n",
		".placeholder {\n  display: inline-block;\n  min-height: 1em;\n  vertical-align: middle;\n  cursor: wait;\n  background-color: currentcolor;\n  opacity: $placeholder-opacity-max;\n\n  &.btn::before {\n    display: inline-block;\n    content: \"\";\n  }\n}\n\n// Sizing\n.placeholder-xs {\n  min-height: .6em;\n}\n\n.placeholder-sm {\n  min-height: .8em;\n}\n\n.placeholder-lg {\n  min-height: 1.2em;\n}\n\n// Animation\n.placeholder-glow {\n  .placeholder {\n    animation: placeholder-glow 2s ease-in-out infinite;\n  }\n}\n\n@keyframes placeholder-glow {\n  50% {\n    opacity: $placeholder-opacity-min;\n  }\n}\n\n.placeholder-wave {\n  mask-image: linear-gradient(130deg, $black 55%, rgba(0, 0, 0, (1 - $placeholder-opacity-min)) 75%, $black 95%);\n  -webkit-mask-image: linear-gradient(130deg, $black 55%, rgba(0, 0, 0, (1 - $placeholder-opacity-min)) 75%, $black 95%);\n  mask-size: 200% 100%;\n  -webkit-mask-size: 200% 100%;\n  animation: placeholder-wave 2s linear infinite;\n}\n\n@keyframes placeholder-wave {\n  100% {\n    mask-position: -200% 0%;\n    -webkit-mask-position: -200% 0%;\n  }\n}\n",
		"@import \"helpers/clearfix\";\n@import \"helpers/color-bg\";\n@import \"helpers/colored-links\";\n@import \"helpers/focus-ring\";\n@import \"helpers/icon-link\";\n@import \"helpers/ratio\";\n@import \"helpers/position\";\n@import \"helpers/stacks\";\n@import \"helpers/visually-hidden\";\n@import \"helpers/stretched-link\";\n@import \"helpers/text-truncation\";\n@import \"helpers/vr\";\n",
		".clearfix {\n  @include clearfix();\n}\n",
		"// All-caps `RGBA()` function used because of this Sass bug: https://github.com/sass/node-sass/issues/2251\n@each $color, $value in $theme-colors {\n  .text-bg-#{$color} {\n    color: color-contrast($value) if($enable-important-utilities, !important, null);\n    background-color: RGBA(var(--#{$prefix}#{$color}-rgb), var(--#{$prefix}bg-opacity, 1)) if($enable-important-utilities, !important, null);\n  }\n}\n",
		"// All-caps `RGBA()` function used because of this Sass bug: https://github.com/sass/node-sass/issues/2251\n@each $color, $value in $theme-colors {\n  .link-#{$color} {\n    color: RGBA(var(--#{$prefix}#{$color}-rgb), var(--#{$prefix}link-opacity, 1)) if($enable-important-utilities, !important, null);\n    text-decoration-color: RGBA(var(--#{$prefix}#{$color}-rgb), var(--#{$prefix}link-underline-opacity, 1)) if($enable-important-utilities, !important, null);\n\n    @if $link-shade-percentage != 0 {\n      &:hover,\n      &:focus {\n        $hover-color: if(color-contrast($value) == $color-contrast-light, shade-color($value, $link-shade-percentage), tint-color($value, $link-shade-percentage));\n        color: RGBA(#{to-rgb($hover-color)}, var(--#{$prefix}link-opacity, 1)) if($enable-important-utilities, !important, null);\n        text-decoration-color: RGBA(to-rgb($hover-color), var(--#{$prefix}link-underline-opacity, 1)) if($enable-important-utilities, !important, null);\n      }\n    }\n  }\n}\n\n// One-off special link helper as a bridge until v6\n.link-body-emphasis {\n  color: RGBA(var(--#{$prefix}emphasis-color-rgb), var(--#{$prefix}link-opacity, 1)) if($enable-important-utilities, !important, null);\n  text-decoration-color: RGBA(var(--#{$prefix}emphasis-color-rgb), var(--#{$prefix}link-underline-opacity, 1)) if($enable-important-utilities, !important, null);\n\n  @if $link-shade-percentage != 0 {\n    &:hover,\n    &:focus {\n      color: RGBA(var(--#{$prefix}emphasis-color-rgb), var(--#{$prefix}link-opacity, .75)) if($enable-important-utilities, !important, null);\n      text-decoration-color: RGBA(var(--#{$prefix}emphasis-color-rgb), var(--#{$prefix}link-underline-opacity, .75)) if($enable-important-utilities, !important, null);\n    }\n  }\n}\n",
		".focus-ring:focus {\n  outline: 0;\n  // By default, there is no `--bs-focus-ring-x`, `--bs-focus-ring-y`, or `--bs-focus-ring-blur`, but we provide CSS variables with fallbacks to initial `0` values\n  box-shadow: var(--#{$prefix}focus-ring-x, 0) var(--#{$prefix}focus-ring-y, 0) var(--#{$prefix}focus-ring-blur, 0) var(--#{$prefix}focus-ring-width) var(--#{$prefix}focus-ring-color);\n}\n",
		".icon-link {\n  display: inline-flex;\n  gap: $icon-link-gap;\n  align-items: center;\n  -webkit-align-items: center;\n  text-decoration-color: rgba(var(--#{$prefix}link-color-rgb), var(--#{$prefix}link-opacity, .5));\n  text-underline-offset: $icon-link-underline-offset;\n  backface-visibility: hidden;\n  -webkit-backface-visibility: hidden;\n  -moz-backface-visibility: hidden;\n  -ms-backface-visibility: hidden;\n  -o-backface-visibility: hidden;\n\n  > .bi {\n    flex-shrink: 0;\n    -webkit-flex-shrink: 0;\n    width: $icon-link-icon-size;\n    height: $icon-link-icon-size;\n    fill: currentcolor;\n    @include transition($icon-link-icon-transition);\n  }\n}\n\n.icon-link-hover {\n  &:hover,\n  &:focus-visible {\n    > .bi {\n      transform: var(--#{$prefix}icon-link-transform, $icon-link-icon-transform);\n    }\n  }\n}\n",
		"// Credit: Nicolas Gallagher and SUIT CSS.\n\n.ratio {\n  position: relative;\n  width: 100%;\n\n  &::before {\n    display: block;\n    padding-top: var(--#{$prefix}aspect-ratio);\n    content: \"\";\n  }\n\n  > * {\n    position: absolute;\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 100%;\n  }\n}\n\n@each $key, $ratio in $aspect-ratios {\n  .ratio-#{$key} {\n    --#{$prefix}aspect-ratio: #{$ratio};\n  }\n}\n",
		"// Shorthand\n\n.fixed-top {\n  position: fixed;\n  top: 0;\n  right: 0;\n  left: 0;\n  z-index: $zindex-fixed;\n}\n\n.fixed-bottom {\n  position: fixed;\n  right: 0;\n  bottom: 0;\n  left: 0;\n  z-index: $zindex-fixed;\n}\n\n// Responsive sticky top and bottom\n@each $breakpoint in map-keys($grid-breakpoints) {\n  @include media-breakpoint-up($breakpoint) {\n    $infix: breakpoint-infix($breakpoint, $grid-breakpoints);\n\n    .sticky#{$infix}-top {\n      position: sticky;\n      top: 0;\n      z-index: $zindex-sticky;\n    }\n\n    .sticky#{$infix}-bottom {\n      position: sticky;\n      bottom: 0;\n      z-index: $zindex-sticky;\n    }\n  }\n}\n",
		"// scss-docs-start stacks\n.hstack {\n  display: flex;\n  display: -webkit-flex;\n  flex-direction: row;\n  -webkit-flex-direction: row;\n  align-items: center;\n  -webkit-align-items: center;\n  align-self: stretch;\n  -webkit-align-self: stretch;\n}\n\n.vstack {\n  display: flex;\n  display: -webkit-flex;\n  flex: 1 1 auto;\n  -webkit-flex: 1 1 auto;\n  flex-direction: column;\n  -webkit-flex-direction: column;\n  align-self: stretch;\n  -webkit-align-self: stretch;\n}\n// scss-docs-end stacks\n",
		"//\n// Visually hidden\n//\n\n.visually-hidden,\n.visually-hidden-focusable:not(:focus):not(:focus-within) {\n  @include visually-hidden();\n}\n",
		"//\n// Stretched link\n//\n\n.stretched-link {\n  &::#{$stretched-link-pseudo-element} {\n    position: absolute;\n    top: 0;\n    right: 0;\n    bottom: 0;\n    left: 0;\n    z-index: $stretched-link-z-index;\n    content: \"\";\n  }\n}\n",
		"//\n// Text truncation\n//\n\n.text-truncate {\n  @include text-truncate();\n}\n",
		".vr {\n  display: inline-block;\n  align-self: stretch;\n  -webkit-align-self: stretch;\n  width: $vr-border-width;\n  min-height: 1em;\n  background-color: currentcolor;\n  opacity: $hr-opacity;\n}\n",
		"// Loop over each breakpoint\n@each $breakpoint in map-keys($grid-breakpoints) {\n\n  // Generate media query if needed\n  @include media-breakpoint-up($breakpoint) {\n    $infix: breakpoint-infix($breakpoint, $grid-breakpoints);\n\n    // Loop over each utility property\n    @each $key, $utility in $utilities {\n      // The utility can be disabled with `false`, thus check if the utility is a map first\n      // Only proceed if responsive media queries are enabled or if it's the base media query\n      @if type-of($utility) == \"map\" and (map-get($utility, responsive) or $infix == \"\") {\n        @include generate-utility($utility, $infix);\n      }\n    }\n  }\n}\n\n// Add fg contrasts for each bg utility class\n@each $key, $val in $utilities-colors {\n  .bg-#{$key} {\n    color: color-contrast(rgb(nth($val, 1), nth($val, 2), nth($val, 3)));\n  }\n}\n\n// RFS rescaling\n@media (min-width: $rfs-mq-value) {\n  @each $breakpoint in map-keys($grid-breakpoints) {\n    $infix: breakpoint-infix($breakpoint, $grid-breakpoints);\n\n    @if (map-get($grid-breakpoints, $breakpoint) < $rfs-breakpoint) {\n      // Loop over each utility property\n      @each $key, $utility in $utilities {\n        // The utility can be disabled with `false`, thus check if the utility is a map first\n        // Only proceed if responsive media queries are enabled or if it's the base media query\n        @if type-of($utility) == \"map\" and map-get($utility, rfs) and (map-get($utility, responsive) or $infix == \"\") {\n          @include generate-utility($utility, $infix, true);\n        }\n      }\n    }\n  }\n}\n\n\n// Print utilities\n@media print {\n  @each $key, $utility in $utilities {\n    // The utility can be disabled with `false`, thus check if the utility is a map first\n    // Then check if the utility needs print styles\n    @if type-of($utility) == \"map\" and map-get($utility, print) == true {\n      @include generate-utility($utility, \"-print\");\n    }\n  }\n}\n",
		"@import \"wells\";\n@import \"help_text\";\n@import \"dropdown_compat\";\n@import \"navbar_compat\";\n@import \"nav_compat\";\n@import \"progress_compat\";\n@import \"dt_compat\";\n\n@import \"glyphicons\";\n\n@import \"shiny_input\";\n@import \"shiny_misc\";\n\n@import \"headers\";\n",
		"// Derives from BS3 SASS, but modified to inherit from BS4 vars\n// https://github.com/rstudio/bslib/blob/04925e1/inst/node_modules/bootstrap-sass/assets/stylesheets/bootstrap/_wells.scss#L1\n.well {\n  @extend .card;\n  display: block;\n  background-color: $well-bg;\n  color: $well-color;\n  padding: $card-spacer-x;\n  @include border-radius($border-radius)\n}\n\n// Sizes\n.well-lg {\n  padding: 1.5 * $spacer;\n  @include border-radius($border-radius-lg);\n}\n.well-sm {\n  padding: 0.5 * $spacer;\n  @include border-radius($border-radius-sm);\n}\n\n// For wellPanel() inside absolutePanel()\n@if $bootstrap-version == 4 {\n  .draggable .well {\n    background-color: opaque($body-bg, $well-bg);\n  }\n}\n",
		".help-text, .help-block {\n  @extend .form-text; @extend .text-muted;\n}\n",
		"// # DROPDOWNS\n//\n// In bs3, dropdown menus are .dropdown-menu>li.active>a\n// In bs4, dropdown menus are .dropdown-menu>.dropdown-item.active\n//\n// Also, bs3 dropdowns within tabs/pills are interfered with in bs4 by\n// selectors like `.bs-tabs li>a`, making menu items look like tabs.\n\n.dropdown-menu>li>a {\n  @extend .dropdown-item;\n}\n.dropdown-menu>li.active>a {\n  // This @extend works, but it litters `.dropdown-menu>li.active>a` all over\n  // the bootstrap.css output because it's such a common class. Instead, we\n  // copy these few properties from from _dropdown.scss.\n  // @extend .active;\n  color: $dropdown-link-active-color;\n  text-decoration: none;\n  @include gradient-bg($dropdown-link-active-bg);\n}\n.dropdown-menu>li.divider {\n  @extend .dropdown-divider;\n}\n",
		"$navbar-expand-breakpoint: if($bootstrap-version>=5, lg, sm) !default; \n\n// bs4 navbars require .navbar-expand[-sm|-md|-lg|-xl], but bs3 navbars\n// don't have them. This selector matches .navbar without .navbar-expand\n// and defaults it to .navbar-expand-sm.\n.navbar:not(.navbar-expand):not(.navbar-expand-sm):not(.navbar-expand-md):not(.navbar-expand-lg):not(.navbar-expand-xl) {\n  @extend .navbar-expand-#{$navbar-expand-breakpoint};\n}\n\n// Unfortunately the @extend above, combined with the @extend .nav-link below\n// results in .navbar-expand's padding rules taking precedence over\n// .nav-underline's padding rules (and unfortunately :where()/css-layers doesn't\n// help here, so just re-apply the padding rules)\n.navbar .nav.nav-underline {\n  --#{$prefix}navbar-nav-link-padding-x: 0;\n}\n\n.navbar:not(.fixed-bottom):not(.navbar-fixed-bottom) {\n  // Instead of exactly re-doing bs3's .navbar { margin-bottom }, set\n  // margin-top on each pane (so 'fill' panes can be flush with navbar)\n  & + div > .tab-content > .tab-pane {\n    --bslib-navbar-margin: #{$navbar-margin-bottom};\n    margin-top: var(--bslib-navbar-margin);\n  }\n}\n\n// Map BS3 navbar positioning to general utilities\n.navbar-fixed-top {\n  @extend .fixed-top;\n}\n.navbar-fixed-bottom {\n  @extend .fixed-bottom;\n}\n.navbar-sticky-top {\n  @extend .sticky-top;\n}\n\nul.nav.navbar-nav {\n  flex: 1;\n  -webkit-flex: 1;\n  &.navbar-right {\n    flex: unset;\n    -webkit-flex: unset;\n    display: flex;\n    display: -webkit-flex;\n    justify-content: flex-end;\n    -webkit-justify-content: flex-end;\n  }\n}\n\n// :where() lowers the specificity of the eventually @extend selector, which is\n// important to make sure those selectors don't get an artificial specificity\n// boost (e.g., we don't want `ul.nav.navbar-nav>li>a` to be more specific than\n// `.nav-underline .nav-link`)\n:where(ul.nav.navbar-nav > li) {\n  &:not(.dropdown) {\n    @extend .nav-item;\n  }\n\n  > a {\n    @extend .nav-link;\n  }\n  \n  &.active, &.show {\n    > a {\n      color: var(--#{$prefix}navbar-active-color);\n    }\n  }\n\n  &.bslib-nav-item {\n    color: var(--#{$prefix}navbar-active-color);\n  }\n}\n\n\n.navbar {\n\n  // Defaults to null (and in that case, we don't want to define the CSS var)\n  @if $navbar-light-bg {\n    --bslib-navbar-default-bg: #{$navbar-light-bg};\n  }\n  @if $navbar-dark-bg {\n    --bslib-navbar-inverse-bg: #{$navbar-dark-bg};\n  }\n\n  // BS3 .navbar-default -> BS4 .navbar-light\n  &.navbar-default {\n    // Sets a variety of fg colors which are configurable via $navbar-light-* options\n    @extend .navbar-light;\n    background-color: var(--bslib-navbar-default-bg, var(--#{$prefix}light)) !important;\n  }\n\n  // BS3 .navbar-inverse -> BS4 .navbar-dark\n  &.navbar-inverse {\n    // Sets a variety of fg colors which are configurable via $navbar-dark-* options\n    @extend .navbar-dark;\n    background-color: var(--bslib-navbar-inverse-bg, var(--#{$prefix}dark)) !important;\n    // For BS5+ lean on emphasis-color\n    --bs-emphasis-color: white;\n    --bs-emphasis-color-rgb: 255, 255, 255;\n  }\n}\n\n$enable-dark-mode: false !default;\n@if $enable-dark-mode {\n  @include color-mode(dark) {\n    .navbar.navbar-default {\n      background-color: var(--bslib-navbar-default-bg, var(--#{$prefix}dark)) !important;\n    }\n  }\n}\n\n// Implement bs3 navbar toggler; used in Rmd websites, i.e.\n// https://github.com/rstudio/rmarkdown-website/blob/453e1802b32b5baf1c8a67f80947adcc53e49b7f/_navbar.html\n.navbar-toggle {\n  @extend .navbar-toggler;\n}\n.navbar-toggle {\n  > .icon-bar {\n    display: none;\n    &:last-child {\n      @extend .navbar-toggler-icon;\n    }\n  }\n}\n\n// Make sure .navbar-toggle is right and center aligned when navbar is collapsed\n@if $bootstrap-version>=5 {\n\n  @include media-breakpoint-down($navbar-expand-breakpoint) {\n    .navbar-header {\n      width: 100%;\n      display: flex;\n      flex-direction: row;\n      align-items: center;\n      justify-content: space-between;\n      .navbar-toggle {\n        order: 2;\n      }\n    }\n  }\n  \n} @else {\n\n  // In BS4, media-breakpoint-down() does the _next_ breakpoint (xs->sm)\n  @include media-breakpoint-down(xs) {\n    .navbar-header {\n      width: 100%;\n      .navbar-toggle {\n        float: right;\n      }\n    }\n  }\n\n}",
		"// Fix tab selector borders in bs3.\n.nav-tabs>li,\n.nav-pills>li {\n  @extend .nav-item;\n}\n.nav-tabs>li>a,\n.nav-pills>li>a {\n  @extend .nav-link;\n}\n\n// Active tab/pill.\n//\n// bs3 uses .nav>li.active>a, bs4 uses .nav>li>a.active or .nav>li.show>a.\n//\n// My original approach to this was making .nav>li.active @extend .show, but\n// after a lot of trial and error I could not get it to fully work.\n.nav-tabs>li.active>a {\n  color: $nav-tabs-link-active-color;\n  background-color: $nav-tabs-link-active-bg;\n  border-color: $nav-tabs-link-active-border-color;\n}\n.nav-pills>li.active>a {\n  color: $nav-pills-link-active-color;\n  background-color: $nav-pills-link-active-bg;\n}\n\n// Support vertical pills\n.nav-stacked {\n  // Don't extend the .flex-column utility, it uses !important\n  // @extend .flex-column;\n  flex-direction: column;\n  -webkit-flex-direction: column;\n}\n\n\n.in {\n  @extend .show;\n}\n",
		"@each $color, $value in $theme-colors {\n  .progress-bar-#{$color} {\n    background-color: $value;\n    color: color-contrast($value);\n  }\n}\n",
		"// For DataTables with BS 5+\n@if $bootstrap-version >= 5 {\n  // Currently not possible through DT: rstudio/DT#1081\n  .datatables thead .form-group.has-feedback + div {\n    background-color: var(--bs-body-bg) !important;\n    color: var(--bs-body-color) !important;\n    border-color: var(--bs-border-color) !important;\n    border-width: var(--bs-border-width);\n    border-radius: var(--bs-border-radius);\n    border-style: var(--bs-border-style);\n  }\n}\n",
		"// This file is auto-generated by tools/glyphicons.R\n// Consider making edits there before editing this file.\n$bootstrap-sass-asset-helper: false;\n$icon-font-name: 'glyphicons-halflings-regular';\n$icon-font-svg-id: 'glyphicons_halflingsregular';\n$icon-font-path: 'fonts/bootstrap/';\n//\n// Glyphicons for Bootstrap\n//\n// Since icons are fonts, they can be placed anywhere text is placed and are\n// thus automatically sized to match the surrounding child. To use, create an\n// inline element with the appropriate classes, like so:\n//\n// <a href=\"#\"><span class=\"glyphicon glyphicon-star\"></span> Star</a>\n\n@at-root {\n  // Import the fonts\n  @font-face {\n    font-family: 'Glyphicons Halflings';\n    src: url(if($bootstrap-sass-asset-helper, twbs-font-path('#{$icon-font-path}#{$icon-font-name}.eot'), '#{$icon-font-path}#{$icon-font-name}.eot'));\n    src: url(if($bootstrap-sass-asset-helper, twbs-font-path('#{$icon-font-path}#{$icon-font-name}.eot?#iefix'), '#{$icon-font-path}#{$icon-font-name}.eot?#iefix')) format('embedded-opentype'),\n         url(if($bootstrap-sass-asset-helper, twbs-font-path('#{$icon-font-path}#{$icon-font-name}.woff2'), '#{$icon-font-path}#{$icon-font-name}.woff2')) format('woff2'),\n         url(if($bootstrap-sass-asset-helper, twbs-font-path('#{$icon-font-path}#{$icon-font-name}.woff'), '#{$icon-font-path}#{$icon-font-name}.woff')) format('woff'),\n         url(if($bootstrap-sass-asset-helper, twbs-font-path('#{$icon-font-path}#{$icon-font-name}.ttf'), '#{$icon-font-path}#{$icon-font-name}.ttf')) format('truetype'),\n         url(if($bootstrap-sass-asset-helper, twbs-font-path('#{$icon-font-path}#{$icon-font-name}.svg##{$icon-font-svg-id}'), '#{$icon-font-path}#{$icon-font-name}.svg##{$icon-font-svg-id}')) format('svg');\n  }\n}\n\n// Catchall baseclass\n.glyphicon {\n  position: relative;\n  top: 1px;\n  display: inline-block;\n  font-family: 'Glyphicons Halflings';\n  font-style: normal;\n  font-weight: normal;\n  line-height: 1;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n\n// Individual icons\n.glyphicon-asterisk               { &:before { content: \"\\2a\"; } }\n.glyphicon-plus                   { &:before { content: \"\\2b\"; } }\n.glyphicon-euro,\n.glyphicon-eur                    { &:before { content: \"\\20ac\"; } }\n.glyphicon-minus                  { &:before { content: \"\\2212\"; } }\n.glyphicon-cloud                  { &:before { content: \"\\2601\"; } }\n.glyphicon-envelope               { &:before { content: \"\\2709\"; } }\n.glyphicon-pencil                 { &:before { content: \"\\270f\"; } }\n.glyphicon-glass                  { &:before { content: \"\\e001\"; } }\n.glyphicon-music                  { &:before { content: \"\\e002\"; } }\n.glyphicon-search                 { &:before { content: \"\\e003\"; } }\n.glyphicon-heart                  { &:before { content: \"\\e005\"; } }\n.glyphicon-star                   { &:before { content: \"\\e006\"; } }\n.glyphicon-star-empty             { &:before { content: \"\\e007\"; } }\n.glyphicon-user                   { &:before { content: \"\\e008\"; } }\n.glyphicon-film                   { &:before { content: \"\\e009\"; } }\n.glyphicon-th-large               { &:before { content: \"\\e010\"; } }\n.glyphicon-th                     { &:before { content: \"\\e011\"; } }\n.glyphicon-th-list                { &:before { content: \"\\e012\"; } }\n.glyphicon-ok                     { &:before { content: \"\\e013\"; } }\n.glyphicon-remove                 { &:before { content: \"\\e014\"; } }\n.glyphicon-zoom-in                { &:before { content: \"\\e015\"; } }\n.glyphicon-zoom-out               { &:before { content: \"\\e016\"; } }\n.glyphicon-off                    { &:before { content: \"\\e017\"; } }\n.glyphicon-signal                 { &:before { content: \"\\e018\"; } }\n.glyphicon-cog                    { &:before { content: \"\\e019\"; } }\n.glyphicon-trash                  { &:before { content: \"\\e020\"; } }\n.glyphicon-home                   { &:before { content: \"\\e021\"; } }\n.glyphicon-file                   { &:before { content: \"\\e022\"; } }\n.glyphicon-time                   { &:before { content: \"\\e023\"; } }\n.glyphicon-road                   { &:before { content: \"\\e024\"; } }\n.glyphicon-download-alt           { &:before { content: \"\\e025\"; } }\n.glyphicon-download               { &:before { content: \"\\e026\"; } }\n.glyphicon-upload                 { &:before { content: \"\\e027\"; } }\n.glyphicon-inbox                  { &:before { content: \"\\e028\"; } }\n.glyphicon-play-circle            { &:before { content: \"\\e029\"; } }\n.glyphicon-repeat                 { &:before { content: \"\\e030\"; } }\n.glyphicon-refresh                { &:before { content: \"\\e031\"; } }\n.glyphicon-list-alt               { &:before { content: \"\\e032\"; } }\n.glyphicon-lock                   { &:before { content: \"\\e033\"; } }\n.glyphicon-flag                   { &:before { content: \"\\e034\"; } }\n.glyphicon-headphones             { &:before { content: \"\\e035\"; } }\n.glyphicon-volume-off             { &:before { content: \"\\e036\"; } }\n.glyphicon-volume-down            { &:before { content: \"\\e037\"; } }\n.glyphicon-volume-up              { &:before { content: \"\\e038\"; } }\n.glyphicon-qrcode                 { &:before { content: \"\\e039\"; } }\n.glyphicon-barcode                { &:before { content: \"\\e040\"; } }\n.glyphicon-tag                    { &:before { content: \"\\e041\"; } }\n.glyphicon-tags                   { &:before { content: \"\\e042\"; } }\n.glyphicon-book                   { &:before { content: \"\\e043\"; } }\n.glyphicon-bookmark               { &:before { content: \"\\e044\"; } }\n.glyphicon-print                  { &:before { content: \"\\e045\"; } }\n.glyphicon-camera                 { &:before { content: \"\\e046\"; } }\n.glyphicon-font                   { &:before { content: \"\\e047\"; } }\n.glyphicon-bold                   { &:before { content: \"\\e048\"; } }\n.glyphicon-italic                 { &:before { content: \"\\e049\"; } }\n.glyphicon-text-height            { &:before { content: \"\\e050\"; } }\n.glyphicon-text-width             { &:before { content: \"\\e051\"; } }\n.glyphicon-align-left             { &:before { content: \"\\e052\"; } }\n.glyphicon-align-center           { &:before { content: \"\\e053\"; } }\n.glyphicon-align-right            { &:before { content: \"\\e054\"; } }\n.glyphicon-align-justify          { &:before { content: \"\\e055\"; } }\n.glyphicon-list                   { &:before { content: \"\\e056\"; } }\n.glyphicon-indent-left            { &:before { content: \"\\e057\"; } }\n.glyphicon-indent-right           { &:before { content: \"\\e058\"; } }\n.glyphicon-facetime-video         { &:before { content: \"\\e059\"; } }\n.glyphicon-picture                { &:before { content: \"\\e060\"; } }\n.glyphicon-map-marker             { &:before { content: \"\\e062\"; } }\n.glyphicon-adjust                 { &:before { content: \"\\e063\"; } }\n.glyphicon-tint                   { &:before { content: \"\\e064\"; } }\n.glyphicon-edit                   { &:before { content: \"\\e065\"; } }\n.glyphicon-share                  { &:before { content: \"\\e066\"; } }\n.glyphicon-check                  { &:before { content: \"\\e067\"; } }\n.glyphicon-move                   { &:before { content: \"\\e068\"; } }\n.glyphicon-step-backward          { &:before { content: \"\\e069\"; } }\n.glyphicon-fast-backward          { &:before { content: \"\\e070\"; } }\n.glyphicon-backward               { &:before { content: \"\\e071\"; } }\n.glyphicon-play                   { &:before { content: \"\\e072\"; } }\n.glyphicon-pause                  { &:before { content: \"\\e073\"; } }\n.glyphicon-stop                   { &:before { content: \"\\e074\"; } }\n.glyphicon-forward                { &:before { content: \"\\e075\"; } }\n.glyphicon-fast-forward           { &:before { content: \"\\e076\"; } }\n.glyphicon-step-forward           { &:before { content: \"\\e077\"; } }\n.glyphicon-eject                  { &:before { content: \"\\e078\"; } }\n.glyphicon-chevron-left           { &:before { content: \"\\e079\"; } }\n.glyphicon-chevron-right          { &:before { content: \"\\e080\"; } }\n.glyphicon-plus-sign              { &:before { content: \"\\e081\"; } }\n.glyphicon-minus-sign             { &:before { content: \"\\e082\"; } }\n.glyphicon-remove-sign            { &:before { content: \"\\e083\"; } }\n.glyphicon-ok-sign                { &:before { content: \"\\e084\"; } }\n.glyphicon-question-sign          { &:before { content: \"\\e085\"; } }\n.glyphicon-info-sign              { &:before { content: \"\\e086\"; } }\n.glyphicon-screenshot             { &:before { content: \"\\e087\"; } }\n.glyphicon-remove-circle          { &:before { content: \"\\e088\"; } }\n.glyphicon-ok-circle              { &:before { content: \"\\e089\"; } }\n.glyphicon-ban-circle             { &:before { content: \"\\e090\"; } }\n.glyphicon-arrow-left             { &:before { content: \"\\e091\"; } }\n.glyphicon-arrow-right            { &:before { content: \"\\e092\"; } }\n.glyphicon-arrow-up               { &:before { content: \"\\e093\"; } }\n.glyphicon-arrow-down             { &:before { content: \"\\e094\"; } }\n.glyphicon-share-alt              { &:before { content: \"\\e095\"; } }\n.glyphicon-resize-full            { &:before { content: \"\\e096\"; } }\n.glyphicon-resize-small           { &:before { content: \"\\e097\"; } }\n.glyphicon-exclamation-sign       { &:before { content: \"\\e101\"; } }\n.glyphicon-gift                   { &:before { content: \"\\e102\"; } }\n.glyphicon-leaf                   { &:before { content: \"\\e103\"; } }\n.glyphicon-fire                   { &:before { content: \"\\e104\"; } }\n.glyphicon-eye-open               { &:before { content: \"\\e105\"; } }\n.glyphicon-eye-close              { &:before { content: \"\\e106\"; } }\n.glyphicon-warning-sign           { &:before { content: \"\\e107\"; } }\n.glyphicon-plane                  { &:before { content: \"\\e108\"; } }\n.glyphicon-calendar               { &:before { content: \"\\e109\"; } }\n.glyphicon-random                 { &:before { content: \"\\e110\"; } }\n.glyphicon-comment                { &:before { content: \"\\e111\"; } }\n.glyphicon-magnet                 { &:before { content: \"\\e112\"; } }\n.glyphicon-chevron-up             { &:before { content: \"\\e113\"; } }\n.glyphicon-chevron-down           { &:before { content: \"\\e114\"; } }\n.glyphicon-retweet                { &:before { content: \"\\e115\"; } }\n.glyphicon-shopping-cart          { &:before { content: \"\\e116\"; } }\n.glyphicon-folder-close           { &:before { content: \"\\e117\"; } }\n.glyphicon-folder-open            { &:before { content: \"\\e118\"; } }\n.glyphicon-resize-vertical        { &:before { content: \"\\e119\"; } }\n.glyphicon-resize-horizontal      { &:before { content: \"\\e120\"; } }\n.glyphicon-hdd                    { &:before { content: \"\\e121\"; } }\n.glyphicon-bullhorn               { &:before { content: \"\\e122\"; } }\n.glyphicon-bell                   { &:before { content: \"\\e123\"; } }\n.glyphicon-certificate            { &:before { content: \"\\e124\"; } }\n.glyphicon-thumbs-up              { &:before { content: \"\\e125\"; } }\n.glyphicon-thumbs-down            { &:before { content: \"\\e126\"; } }\n.glyphicon-hand-right             { &:before { content: \"\\e127\"; } }\n.glyphicon-hand-left              { &:before { content: \"\\e128\"; } }\n.glyphicon-hand-up                { &:before { content: \"\\e129\"; } }\n.glyphicon-hand-down              { &:before { content: \"\\e130\"; } }\n.glyphicon-circle-arrow-right     { &:before { content: \"\\e131\"; } }\n.glyphicon-circle-arrow-left      { &:before { content: \"\\e132\"; } }\n.glyphicon-circle-arrow-up        { &:before { content: \"\\e133\"; } }\n.glyphicon-circle-arrow-down      { &:before { content: \"\\e134\"; } }\n.glyphicon-globe                  { &:before { content: \"\\e135\"; } }\n.glyphicon-wrench                 { &:before { content: \"\\e136\"; } }\n.glyphicon-tasks                  { &:before { content: \"\\e137\"; } }\n.glyphicon-filter                 { &:before { content: \"\\e138\"; } }\n.glyphicon-briefcase              { &:before { content: \"\\e139\"; } }\n.glyphicon-fullscreen             { &:before { content: \"\\e140\"; } }\n.glyphicon-dashboard              { &:before { content: \"\\e141\"; } }\n.glyphicon-paperclip              { &:before { content: \"\\e142\"; } }\n.glyphicon-heart-empty            { &:before { content: \"\\e143\"; } }\n.glyphicon-link                   { &:before { content: \"\\e144\"; } }\n.glyphicon-phone                  { &:before { content: \"\\e145\"; } }\n.glyphicon-pushpin                { &:before { content: \"\\e146\"; } }\n.glyphicon-usd                    { &:before { content: \"\\e148\"; } }\n.glyphicon-gbp                    { &:before { content: \"\\e149\"; } }\n.glyphicon-sort                   { &:before { content: \"\\e150\"; } }\n.glyphicon-sort-by-alphabet       { &:before { content: \"\\e151\"; } }\n.glyphicon-sort-by-alphabet-alt   { &:before { content: \"\\e152\"; } }\n.glyphicon-sort-by-order          { &:before { content: \"\\e153\"; } }\n.glyphicon-sort-by-order-alt      { &:before { content: \"\\e154\"; } }\n.glyphicon-sort-by-attributes     { &:before { content: \"\\e155\"; } }\n.glyphicon-sort-by-attributes-alt { &:before { content: \"\\e156\"; } }\n.glyphicon-unchecked              { &:before { content: \"\\e157\"; } }\n.glyphicon-expand                 { &:before { content: \"\\e158\"; } }\n.glyphicon-collapse-down          { &:before { content: \"\\e159\"; } }\n.glyphicon-collapse-up            { &:before { content: \"\\e160\"; } }\n.glyphicon-log-in                 { &:before { content: \"\\e161\"; } }\n.glyphicon-flash                  { &:before { content: \"\\e162\"; } }\n.glyphicon-log-out                { &:before { content: \"\\e163\"; } }\n.glyphicon-new-window             { &:before { content: \"\\e164\"; } }\n.glyphicon-record                 { &:before { content: \"\\e165\"; } }\n.glyphicon-save                   { &:before { content: \"\\e166\"; } }\n.glyphicon-open                   { &:before { content: \"\\e167\"; } }\n.glyphicon-saved                  { &:before { content: \"\\e168\"; } }\n.glyphicon-import                 { &:before { content: \"\\e169\"; } }\n.glyphicon-export                 { &:before { content: \"\\e170\"; } }\n.glyphicon-send                   { &:before { content: \"\\e171\"; } }\n.glyphicon-floppy-disk            { &:before { content: \"\\e172\"; } }\n.glyphicon-floppy-saved           { &:before { content: \"\\e173\"; } }\n.glyphicon-floppy-remove          { &:before { content: \"\\e174\"; } }\n.glyphicon-floppy-save            { &:before { content: \"\\e175\"; } }\n.glyphicon-floppy-open            { &:before { content: \"\\e176\"; } }\n.glyphicon-credit-card            { &:before { content: \"\\e177\"; } }\n.glyphicon-transfer               { &:before { content: \"\\e178\"; } }\n.glyphicon-cutlery                { &:before { content: \"\\e179\"; } }\n.glyphicon-header                 { &:before { content: \"\\e180\"; } }\n.glyphicon-compressed             { &:before { content: \"\\e181\"; } }\n.glyphicon-earphone               { &:before { content: \"\\e182\"; } }\n.glyphicon-phone-alt              { &:before { content: \"\\e183\"; } }\n.glyphicon-tower                  { &:before { content: \"\\e184\"; } }\n.glyphicon-stats                  { &:before { content: \"\\e185\"; } }\n.glyphicon-sd-video               { &:before { content: \"\\e186\"; } }\n.glyphicon-hd-video               { &:before { content: \"\\e187\"; } }\n.glyphicon-subtitles              { &:before { content: \"\\e188\"; } }\n.glyphicon-sound-stereo           { &:before { content: \"\\e189\"; } }\n.glyphicon-sound-dolby            { &:before { content: \"\\e190\"; } }\n.glyphicon-sound-5-1              { &:before { content: \"\\e191\"; } }\n.glyphicon-sound-6-1              { &:before { content: \"\\e192\"; } }\n.glyphicon-sound-7-1              { &:before { content: \"\\e193\"; } }\n.glyphicon-copyright-mark         { &:before { content: \"\\e194\"; } }\n.glyphicon-registration-mark      { &:before { content: \"\\e195\"; } }\n.glyphicon-cloud-download         { &:before { content: \"\\e197\"; } }\n.glyphicon-cloud-upload           { &:before { content: \"\\e198\"; } }\n.glyphicon-tree-conifer           { &:before { content: \"\\e199\"; } }\n.glyphicon-tree-deciduous         { &:before { content: \"\\e200\"; } }\n.glyphicon-cd                     { &:before { content: \"\\e201\"; } }\n.glyphicon-save-file              { &:before { content: \"\\e202\"; } }\n.glyphicon-open-file              { &:before { content: \"\\e203\"; } }\n.glyphicon-level-up               { &:before { content: \"\\e204\"; } }\n.glyphicon-copy                   { &:before { content: \"\\e205\"; } }\n.glyphicon-paste                  { &:before { content: \"\\e206\"; } }\n// The following 2 Glyphicons are omitted for the time being because\n// they currently use Unicode codepoints that are outside the\n// Basic Multilingual Plane (BMP). Older buggy versions of WebKit can't handle\n// non-BMP codepoints in CSS string escapes, and thus can't display these two icons.\n// Notably, the bug affects some older versions of the Android Browser.\n// More info: https://github.com/twbs/bootstrap/issues/10106\n// .glyphicon-door                   { &:before { content: \"\\1f6aa\"; } }\n// .glyphicon-key                    { &:before { content: \"\\1f511\"; } }\n.glyphicon-alert                  { &:before { content: \"\\e209\"; } }\n.glyphicon-equalizer              { &:before { content: \"\\e210\"; } }\n.glyphicon-king                   { &:before { content: \"\\e211\"; } }\n.glyphicon-queen                  { &:before { content: \"\\e212\"; } }\n.glyphicon-pawn                   { &:before { content: \"\\e213\"; } }\n.glyphicon-bishop                 { &:before { content: \"\\e214\"; } }\n.glyphicon-knight                 { &:before { content: \"\\e215\"; } }\n.glyphicon-baby-formula           { &:before { content: \"\\e216\"; } }\n.glyphicon-tent                   { &:before { content: \"\\26fa\"; } }\n.glyphicon-blackboard             { &:before { content: \"\\e218\"; } }\n.glyphicon-bed                    { &:before { content: \"\\e219\"; } }\n.glyphicon-apple                  { &:before { content: \"\\f8ff\"; } }\n.glyphicon-erase                  { &:before { content: \"\\e221\"; } }\n.glyphicon-hourglass              { &:before { content: \"\\231b\"; } }\n.glyphicon-lamp                   { &:before { content: \"\\e223\"; } }\n.glyphicon-duplicate              { &:before { content: \"\\e224\"; } }\n.glyphicon-piggy-bank             { &:before { content: \"\\e225\"; } }\n.glyphicon-scissors               { &:before { content: \"\\e226\"; } }\n.glyphicon-bitcoin                { &:before { content: \"\\e227\"; } }\n.glyphicon-btc                    { &:before { content: \"\\e227\"; } }\n.glyphicon-xbt                    { &:before { content: \"\\e227\"; } }\n.glyphicon-yen                    { &:before { content: \"\\00a5\"; } }\n.glyphicon-jpy                    { &:before { content: \"\\00a5\"; } }\n.glyphicon-ruble                  { &:before { content: \"\\20bd\"; } }\n.glyphicon-rub                    { &:before { content: \"\\20bd\"; } }\n.glyphicon-scale                  { &:before { content: \"\\e230\"; } }\n.glyphicon-ice-lolly              { &:before { content: \"\\e231\"; } }\n.glyphicon-ice-lolly-tasted       { &:before { content: \"\\e232\"; } }\n.glyphicon-education              { &:before { content: \"\\e233\"; } }\n.glyphicon-option-horizontal      { &:before { content: \"\\e234\"; } }\n.glyphicon-option-vertical        { &:before { content: \"\\e235\"; } }\n.glyphicon-menu-hamburger         { &:before { content: \"\\e236\"; } }\n.glyphicon-modal-window           { &:before { content: \"\\e237\"; } }\n.glyphicon-oil                    { &:before { content: \"\\e238\"; } }\n.glyphicon-grain                  { &:before { content: \"\\e239\"; } }\n.glyphicon-sunglasses             { &:before { content: \"\\e240\"; } }\n.glyphicon-text-size              { &:before { content: \"\\e241\"; } }\n.glyphicon-text-color             { &:before { content: \"\\e242\"; } }\n.glyphicon-text-background        { &:before { content: \"\\e243\"; } }\n.glyphicon-object-align-top       { &:before { content: \"\\e244\"; } }\n.glyphicon-object-align-bottom    { &:before { content: \"\\e245\"; } }\n.glyphicon-object-align-horizontal{ &:before { content: \"\\e246\"; } }\n.glyphicon-object-align-left      { &:before { content: \"\\e247\"; } }\n.glyphicon-object-align-vertical  { &:before { content: \"\\e248\"; } }\n.glyphicon-object-align-right     { &:before { content: \"\\e249\"; } }\n.glyphicon-triangle-right         { &:before { content: \"\\e250\"; } }\n.glyphicon-triangle-left          { &:before { content: \"\\e251\"; } }\n.glyphicon-triangle-bottom        { &:before { content: \"\\e252\"; } }\n.glyphicon-triangle-top           { &:before { content: \"\\e253\"; } }\n.glyphicon-console                { &:before { content: \"\\e254\"; } }\n.glyphicon-superscript            { &:before { content: \"\\e255\"; } }\n.glyphicon-subscript              { &:before { content: \"\\e256\"; } }\n.glyphicon-menu-left              { &:before { content: \"\\e257\"; } }\n.glyphicon-menu-right             { &:before { content: \"\\e258\"; } }\n.glyphicon-menu-down              { &:before { content: \"\\e259\"; } }\n.glyphicon-menu-up                { &:before { content: \"\\e260\"; } }\n",
		"// Dropped in BS5, but this seems pretty fundamental?\n$form-group-margin-bottom: 1rem !default;\n.form-group {\n  margin-bottom: $form-group-margin-bottom;\n}\n\n// The @extends here add a lot of bloat to version=4 (& it's not entirely correct)\n// Instead of fixing, consider this deprecated, and for BS5, we'll modify\n// their selectors directly to accomodate shiny\n@if $bootstrap-version == 4 {\n  .shiny-input-checkboxgroup, .shiny-input-radiogroup {\n    // TODO: this is pretty expensive!\n    .checkbox, .radio {\n      @extend .form-check;\n      label {\n        @extend .form-check-label;\n      }\n      label > input {\n        @extend .form-check-input;\n      }\n    }\n\n  // Since these inline classes don't have a proper div container\n  // (they're labels), we borrow just the styling we need from\n  // .form-check-inline\n  // https://github.com/rstudio/bs4/blob/7aadd19/inst/node_modules/bootstrap/scss/_forms.scss#L227-L240\n    .checkbox-inline, .radio-inline {\n      padding-left: 0;\n      margin-right: $form-check-inline-margin-x;\n\n      label > input {\n        margin-top: 0;\n        margin-right: $form-check-inline-input-margin-x;\n        margin-bottom: 0;\n      }\n    }\n  }\n}\n\n.input-daterange .input-group-addon.input-group-prepend.input-group-append {\n  padding: inherit;\n  line-height: inherit;\n  text-shadow: inherit;\n  border-width: 0;\n  .input-group-text {\n    border-radius: 0;\n  }\n}\n\n.shiny-input-checkboxgroup .checkbox-inline,\n.shiny-input-radiogroup .radio-inline {\n  cursor: pointer;\n}\n\n// Fix the position of checkbox and radio group labels to match other inputs\n// labels, see https://github.com/rstudio/shiny/blob/6fc06281/inst/www/shared/shiny_scss/shiny.scss#L344-L356\n// TODO: Consider removing if we add `input_checkbox()` and `input_radio()`\n@if $bootstrap-version == 5 {\n  .shiny-input-checkboxgroup,\n  .shiny-input-radiogroup {\n    label ~ .shiny-options-group {\n      margin-top: calc(#{-($line-height-base - $form-check-input-width) * .5} - #{$input-btn-border-width});\n    }\n  }\n}\n",
		"// For code inside of showcase mode\n// TODO: this should probably ported to shiny itself\n// if and when shiny-showcase.css is ported to sass\npre.shiny-code {\n  padding: 0.5 * $spacer;\n}\n\n// BS5 changed float-left -> float-start\n@if $bootstrap-version != 4 {\n  .float-left {\n    @extend .float-start;\n  }\n  .float-right {\n    @extend .float-end;\n  }\n}\n",
		"// BS3 -> BS4 saw a removal of margin-top on headers,\n// which is a pretty jarring change, expecially for Rmd\n// https://github.com/twbs/bootstrap/blob/f17f882d/dist/css/bootstrap.css#L1219-L1250\n// https://github.com/twbs/bootstrap/blob/4de4874e/scss/_reboot.scss#L82-L89\n\n@mixin section-margin-top($levels, $margin-top) {\n  @each $level in $levels {\n    :where(.section.level#{$level}, section.level#{$level}) {\n      margin-top: $margin-top;\n    }\n  }\n}\n\n@if $bootstrap-version >= 5 {\n  // For BS5+, only apply the margin-top if pandoc's CSS classes\n  // are present. This way rmarkdown::html_document_base will continue\n  // to have margin-top (which is good), but 'raw' headers won't, which\n  // leads to a better experience with accordions, popovers, etc\n  // (their design/examples expect headers that don't have margin-top).\n  // It also seems as though Quarto docs don't generate these CSS classes,\n  // but it also seems they've added their own rules https://github.com/quarto-dev/quarto-cli/blob/0e662c/src/resources/formats/html/bootstrap/_bootstrap-rules.scss#L595-L613.\n  // In pandoc, `--to html4` writes `div.section.levelX` and `--to html5`\n  // produces `section.levelX` elements.\n\n  @include section-margin-top(1 2 3, 1.5 * $spacer);\n  @include section-margin-top(4 5 6, $spacer);\n\n} @else {\n\n  h1, h2, h3 { margin-top: 1.5 * $spacer;}\n  h4, h5, h6 { margin-top: $spacer; }\n\n}\n",
		"@import \"spacer\";\n@import \"tab-fill\";\n@import \"color-utilities\";\n",
		"$spacer: 1rem !default;\n\n:root {\n  // Controls default spacing in layout containers (e.g, layout_columns())\n  --bslib-spacer: #{$spacer};\n  --bslib-mb-spacer: var(--bslib-spacer, 1rem);\n}\n\n// Some things like card(), p(), inputs, etc. want some margin-bottom by default\n// so you can plop them anywhere and you get spacing between rows. However, now\n// that we have layout utilities like page_fillable(), layout_columns(),\n// layout_sidebar(), etc. where we can control the gap between rows/columns, we\n// need a way to reset those margin-bottom to 0 in those special contexts\n//\n// We do this by adding this class to components (e.g., card())...\n.bslib-mb-spacing {\n  margin-bottom: var(--bslib-mb-spacer);\n}\n\n// ...And this class for layout containers (e.g, layout_columns())\n.bslib-gap-spacing {\n  gap: var(--bslib-mb-spacer);\n  > .bslib-mb-spacing, > .form-group, > p, > pre {\n    margin-bottom: 0;\n  }\n}\n\n// We generally don't want mb spacing for _activated_ fill items\n.html-fill-container > .html-fill-item.bslib-mb-spacing {\n  margin-bottom: 0;\n}",
		".tab-content {\n  // Workaround for pkgdown's CSS to make tab-pane all a consistent height\n  // https://github.com/r-lib/pkgdown/blob/956f07/inst/BS5/assets/pkgdown.scss#L342-L355\n  >.tab-pane.html-fill-container {\n    display: none;\n  }\n\n  // Take precedence over Bootstrap's `display:block` rule\n  >.active.html-fill-container {\n    display: flex;\n  }\n\n  // Another workaround for pkgdown adding extra padding we didn't ask for\n  // https://github.com/r-lib/pkgdown/blob/956f07/inst/BS5/assets/pkgdown.scss#L335-L337\n  &.html-fill-container {\n    padding: 0;\n  }\n}\n",
		"$bslib-enable-color-utilities: $bootstrap-version >= 5 !default;\n\n@if ($bslib-enable-color-utilities) {\n  $bslib-gradient-colors: () !default;\n\n  $bslib-gradient-colors-defaults: ();\n  $bslib-color-names: (\"blue\", \"indigo\", \"purple\", \"pink\", \"red\", \"orange\", \"yellow\", \"green\", \"teal\", \"cyan\");\n\n  @each $name in $bslib-color-names {\n    @if (map-has-key($colors, $name)) {\n      $bslib-gradient-colors-defaults: map-merge(\n        $bslib-gradient-colors-defaults,\n        ($name: map-get($colors, $name))\n      );\n    }\n  }\n\n  $bslib-gradient-colors: map-merge(\n    $bslib-gradient-colors-defaults,\n    $bslib-gradient-colors\n  );\n\n  // Named color background and foreground utility classes ---------------------\n  @each $name, $color in $bslib-gradient-colors {\n    .bg-#{$name} {\n      --bslib-color-bg: #{$color};\n      --bslib-color-fg: #{color-contrast($color)};\n      background-color: var(--bslib-color-bg);\n      color: var(--bslib-color-fg);\n    }\n\n    .text-#{$name} {\n      --bslib-color-fg: #{$color};\n      color: var(--bslib-color-fg);\n    }\n  }\n\n  // Fill in the `--color-*` variables\n  @each $name, $color in $theme-colors {\n    .text-#{$name} {\n      --bslib-color-fg: #{$color};\n    }\n    .bg-#{$name} {\n      --bslib-color-bg: #{$color};\n      --bslib-color-fg: #{color-contrast($color)};\n    }\n  }\n\n  // Gradient backgrounds ------------------------------------------------------\n  //\n  // Creates gradient background for every named color pair. Users can add\n  // additional colors into the mix by setting $bslib-gradient-colors to a map of\n  // color names to colors. Creates class names like: .bg-gradient-{from}-{to}.\n  @each $name1, $color1 in $bslib-gradient-colors {\n    @each $name2, $color2 in $bslib-gradient-colors {\n      @if $name1 != $name2 {\n        .bg-gradient-#{$name1}-#{$name2} {\n          $color-mid: mix($color1, $color2, 60%);\n          $color-fg: color-contrast($color-mid);\n\n          --bslib-color-fg: #{$color-fg};\n          --bslib-color-bg: #{$color-mid};\n\n          background: linear-gradient(\n            var(--bg-gradient-deg, 140deg),\n            $color1 var(--bg-gradient-start, 36%),\n            $color2 var(--bg-gradient-end, 180%)\n          ) $color-mid;\n          color: $color-fg;\n        }\n      }\n    }\n  }\n}\n",
		"/*-- scss:rules --*/\n@import \"ionrangeslider/_rules.scss\";\n@import \"tables/_rules.scss\";\n\n$web-font-path: \"https://fonts.googleapis.com/css2?family=Open+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,300;1,400;1,500;1,600;1,700;1,800&family=Source+Code+Pro:ital,wght@0,400;0,600;1,400;1,600&display=swap\" !default;\n@if $web-font-path {\n  @import url($web-font-path);\n}\n\n// Variables\n:root {\n  --bslib-box-shadow-color-rgb: #{$bslib-box-shadow-color-rgb};\n}\n\n@include color-mode(dark) {\n  --bslib-box-shadow-color-rgb: #{$bslib-box-shadow-color-rgb-dark};\n}\n\n// For radioButtons()/checkboxGroupInput(), move text slightly to the right\n$bslib-checkbox-radio-margin-right: 0.35em !default;\n.checkbox,\n.radio {\n  input {\n    margin-right: $bslib-checkbox-radio-margin-right;\n  }\n}\n\n// Alignment fixes for radioButtons(inline=TRUE)/checkboxGroupInput(inline=TRUE)\n// TODO: It would be nice to do this for all inline groups, but that would\n// require updating the input markup to use <fieldset> and <legend>.\n.shiny-input-container-inline {\n  .shiny-options-group {\n    display: flex;\n    flex-wrap: wrap;\n    flex-direction: row;\n    column-gap: 1em;\n\n    .checkbox-inline, .radio-inline {\n      position: relative;\n      padding-left: calc(#{$form-check-input-width} + #{$bslib-checkbox-radio-margin-right} * 2);\n\n      input {\n        position: absolute;\n        margin-top: 0;\n        left: 0;\n        top: calc(#{($line-height-base - $form-check-input-width) * .5} + #{$input-btn-border-width});\n      }\n    }\n  }\n}\n\n// For shiny::dateRangeInput(), fix \"to\" width in the middle of the date picker\n.shiny-date-range-input .input-daterange .input-group-addon {\n  margin-right: -1px;\n}\n\n// Make the default shiny::actionButton() an outline variant, but not others\n.btn-outline-default,\n.btn-default:not(.btn-primary, .btn-secondary, .btn-info, .btn-success, .btn-danger, .btn-warning, .btn-light, .btn-dark, .btn-link, [class*=\"btn-outline-\"]) {\n  @include button-outline-variant($secondary);\n}\n\n// ... and make it look better in dark mode\n@if $enable-dark-mode {\n  @include color-mode(dark) {\n    .btn-outline-default,\n    .btn-default:not(.btn-primary, .btn-secondary, .btn-info, .btn-success, .btn-danger, .btn-warning, .btn-light, .btn-dark, .btn-link, [class*=\"btn-outline-\"]) {\n      @include button-outline-variant($dark-text-emphasis-dark);\n    }\n  }\n}\n\n// For selectizeInput(options = list(plugins = \"remove_button\"))\n// TODO: we should probably make this the default behavior in shiny\n.selectize-control.plugin-remove_button .item {\n  align-items: flex-start !important;\n  .remove {\n    border-left: none !important;\n  }\n}\n\n\n@if ($bslib-enable-shadows) {\n  // Add box-shadow & remove border from 'top-level' card()/layout_sidebar()\n  .bslib-card {\n    // BS doesn't include a box-shadow rule for .card when `enable-shadows: false`\n    box-shadow: var(--bslib-card-box-shadow, #{$box-shadow});\n\n    // Shadows on top-level cards, not in nested components\n    .bslib-card {\n      --bslib-card-box-shadow: ; // unset our shadow\n    }\n  }\n\n  .bslib-card-box-shadow-sm {\n    --bslib-card-box-shadow: var(--bslib-card-box-shadow-sm, #{$box-shadow-sm});\n  }\n  .bslib-card-box-shadow-md {\n    --bslib-card-box-shadow: var(--bslib-card-box-shadow-md, #{$box-shadow});\n  }\n  .bslib-card-box-shadow-lg {\n    --bslib-card-box-shadow: var(--bslib-card-box-shadow-lg, #{$box-shadow-lg});\n  }\n  .bslib-card-box-shadow-none {\n    --bslib-card-box-shadow: none;\n  }\n}\n\n// TODO: move this logic into a \"core\" bundle that comes with any theme\n// (but you only get the shadows by default in the preset theme)\n@if $bslib-dashboard-design {\n\n  :root {\n    --bslib-dashboard-sidebar-bg: var(--#{$prefix}body-bg);\n    --bslib-dashboard-sidebar-main-bg: var(--#{$prefix}body-bg);\n    --bslib-dashboard-main-bg: rgb(247, 247, 247);\n    --#{$prefix}card-border-color: var(--bslib-dashboard-border-color-translucent, var(--#{$prefix}border-color-translucent));\n    --bslib-sidebar-bg: var(--#{$prefix}body-bg);\n    --bslib-sidebar-fg: var(--#{$prefix}color);\n  }\n\n  @include color-mode(dark) {\n    --bslib-dashboard-main-bg: rgb(20, 20, 24);\n  }\n\n  .bslib-card {\n    .card-header, .card-footer {\n      background-color: transparent;\n      font-size: 0.9rem;\n    }\n    .card-header {\n      font-weight: $font-weight-semibold;\n      line-height: 1.375rem;\n    }\n  }\n\n  // Set the background color of page dashboard class...\n  .bslib-page-dashboard,\n  // or of global main content area in a page_navbar() with a global sidebar\n  .main:has(.tab-content > .bslib-page-dashboard.active) {\n    background-color: var(--bslib-dashboard-main-bg);\n    // or of main area of a page_sidebar()\n    --_main-bg: var(--bslib-dashboard-main-bg);\n  }\n\n  .bslib-page-navbar, .bslib-page-dashboard {\n    > .navbar {\n      --bslib-navbar-default-bg: var(--#{$prefix}body-bg);\n      --bslib-navbar-inverse-bg: var(--#{$prefix}body-color);\n    }\n\n    > .navbar + div {\n      // Since we're using a transparent navbar, we need to (generally) add a border-top\n      border-top: $card-border-width solid $card-border-color;\n\n      // Case 1: page_navbar(sidebar = ...)\n      // Case 2: page_navbar(nav_panel(layout_sidebar()))\n      > .bslib-sidebar-layout,\n      > .tab-content > .tab-pane.active.html-fill-container > .bslib-sidebar-layout.html-fill-item {\n        border-top: none !important; // Make sure we don't end up w/ a double border\n      }\n    }\n  }\n\n  .bslib-page-sidebar {\n    --bslib-page-sidebar-title-bg: var(--#{$prefix}body-bg);\n    --bslib-page-sidebar-title-color: var(--#{$prefix}body-color);\n\n    .bslib-page-title {\n      border-color: var(--#{$prefix}border-color-translucent);\n    }\n  }\n}\n\n// By default, non-active .nav links reflect the primary color. This styling\n// tweak brings them closer to how they'll appear in a navbar.\n.nav-underline {\n  --#{$prefix}link-color: rgba(var(--bs-body-color-rgb), 0.65);\n  --#{$prefix}link-hover-color: rgba(var(--bs-body-color-rgb), 0.8);\n  --#{$prefix}nav-link-font-size: 0.875rem;\n\n  .nav-link {\n    padding-left: 5px !important;\n    padding-right: 5px !important;\n\n    &.active {\n      font-weight: 500;\n    }\n  }\n}\n\n// When the navbar is collapsed (or collapsing) on mobile, remove the\n// .nav-underline border\n.navbar-collapse.show, .navbar-collapse.collapsing {\n  .nav-underline {\n    --#{$prefix}nav-underline-border-width: 0;\n    --#{$prefix}nav-underline-gap: 0;\n  }\n}\n\n// Align the bottom of .nav-link w/ the bottom of the navbar (when underlined)\n.navbar .nav-underline .nav-link {\n  padding-bottom: calc(var(--#{$prefix}navbar-padding-y, #{$navbar-padding-y}) * 2);\n  margin-bottom:  calc(var(--#{$prefix}navbar-padding-y, #{$navbar-padding-y}) * -1);\n}\n\n// For value_box(), apply a gradient to the icon (by default)\n$icon-classes: (\"bi\", \"fa\", \"fas\", \"far\", \"fab\", \"material-icons\") !default;\n.bslib-value-box.default .value-box-showcase {\n  > i {\n    @each $icon-class in $icon-classes {\n      &.#{$icon-class} {\n        background: linear-gradient(140deg, $blue 36%, $purple 180%) $blue;\n        -webkit-background-clip: text;\n        -webkit-text-fill-color: transparent;\n      }\n    }\n  }\n  > svg {\n    @each $icon-class in $icon-classes {\n      &.#{$icon-class} {\n        // Requires icon-gradient.svg which is added in the value_box() dependency\n        fill: url('#bslib---icon-gradient') $blue !important;\n      }\n    }\n  }\n}\n\n// For value_box(), improve contrast of text colors\n.bslib-value-box {\n  $cyan: #028097; // Contrast 4.63\n  $warning: #A87600; // Contrast 4 (okay for 16px+ text)\n\n  &.text-info {\n    &, &.text-cyan {\n      --bslib-color-fg: $cyan !important;\n    }\n    color: $cyan !important;\n  }\n\n  &.text-light {\n    --bslib-color-fg: $gray-600 !important;\n  }\n\n  &.text-warning {\n    &, &.text-yellow {\n      --bslib-color-fg: $warning !important;\n    }\n    color: $warning !important;\n  }\n\n  &.text-teal.text-teal {\n    --bslib-color-fg: #008558; // Contrast 4.67\n  }\n}\n\n// Modals\n.modal-body, .modal-footer {\n  padding: 1.5rem;\n}\n.modal-header .btn-close {\n  align-self: start;\n  display: flex;\n}\n#shiny-modal-wrapper:has( ~ .modal-backdrop) .modal {\n  // Blur the background when the modal has a backdrop\n  backdrop-filter: blur(2px);\n}\n\n// Progress Bars & Notifications\n// FIXME: Use css layers (dynamic themeing issue)\n#shiny-notification-panel#shiny-notification-panel {\n  position: fixed;\n  bottom: calc(var(--bslib-spacer, 1rem) / 2);\n  right: calc(var(--bslib-spacer, 1rem) / 2);\n  width: 450px;\n  z-index: $zindex-toast;\n}\n\n.progress-message {\n  margin-right: .6rem;\n}\n\n// FIXME: Use css layers (dynamic themeing issue)\n.shiny-notification.shiny-notification {\n  position: relative;\n  opacity: 0.96;\n  padding: calc(var(--bslib-spacer, 1rem) * 2);\n  margin: var(--bslib-spacer, 1rem);\n  border: $border-width solid var(--#{$prefix}border-color-translucent);\n  border-radius: $card-border-radius;\n  box-shadow: $box-shadow;\n\n  .shiny-notification-close {\n    position: absolute;\n    font-size: 1.5em;\n    width: 2rem;\n    height: 2rem;\n    top: 0;\n    right: 0;\n    bottom: unset;\n    display: flex;\n    align-items: center;\n    justify-content: center;\n    padding: 0.25rem;\n    cursor: pointer;\n    font-weight: 200;\n    color: currentColor;\n\n    &:hover {\n      font-weight: normal;\n    }\n  }\n\n  .shiny-notification-content-text :last-child {\n    margin-bottom: 0;\n  }\n}\n",
		".irs.irs--shiny {\n  $irs-shiny-space: 3px !default;\n\n  margin-top: $irs-shiny-space;\n\n  .irs-min,\n  .irs-max,\n  .irs-from,\n  .irs-to,\n  .irs-single {\n    padding: $irs-shiny-space $irs-shiny-space * 2;\n    top: -$irs-shiny-space;\n  }\n\n  .irs-handle {\n    top: $top - ($handle_height / 2) + ($line_height / 2);\n  }\n\n  .irs-bar {\n    top: 31px;\n    height: $irs-shiny-space;\n    border: none;\n  }\n\n  .irs-line {\n    // NOTE: not sure we need this border radius\n    border-radius: 8px;\n  }\n\n  .irs-grid-pol {\n    height: 6px;\n  }\n\n  .irs-grid-text {\n    bottom: 8px;\n  }\n\n  // make handles keyboard accessible\n  //\n  // We might need some javascript shenanigans to make the handles on the slider\n  // keyboard accessible.  I think we can do this by assigning it a role and and\n  // a tabindex? check out this article:\n  // https://www.456bereastreet.com/archive/201302/making_elements_keyboard_focusable_and_clickable/\n  .irs-handle:focus-visible,\n  .irs-handle:active {\n    // FIXME\n    color: shade-color($handle_color, 30%);\n    background-color: shade-color($handle_color, 30%);\n    border-color: shade-color($handle_color, 30);\n    outline: 0;\n    box-shadow: $btn-focus-box-shadow;\n  }\n\n  & ~ .slider-animate-container {\n    text-align: left;\n\n    .slider-animate-button {\n      opacity: 1;\n    }\n  }\n\n  &.irs-with-grid ~ .slider-animate-container {\n    margin-top: -5px;\n  }\n  &:not(.irs-with-grid) ~ .slider-animate-container {\n    margin-top: 5px;\n  }\n}\n",
		"// TODO: Many of these rules could be applied to all bslib themes\n.table.dataTable {\n  // CSS variables are scoped to datatables in Bootstrap\n  --dt-row-selected: var(--bs-primary-rgb, \"0,123,194\");\n  --dt-row-selected-text: var(--bs-white-rgb, \"255,255,255\");\n  --dt-row-selected-link: var(--bs-light-rgh, \"248,248,248\");\n}\n\n// Note CSS specificity hack because DT's CSS deps are loaded after the theme\n.table.dataTable.dataTable {\n  $class-stripe: \"even\";\n  $class-unstriped: \"odd\";\n\n  @if $table-striped-order == odd {\n    $class-stripe: \"odd\";\n    $class-unstriped: \"even\";\n  }\n\n  &.table-striped > tbody > tr.#{$class-unstriped}:not(.selected) > * {\n    box-shadow: none;\n  }\n\n  &.table-striped > tbody > tr.#{$class-stripe}:not(.selected) > * {\n    box-shadow: inset 0 0 0 9999px var(--bs-table-striped-bg);\n  }\n\n  tbody td.active,\n  tbody tr.active td {\n    background-color: var(--bs-table-active-bg);\n  }\n\n  &.table-hover > tbody > tr:hover:not(.selected) > * {\n    box-shadow: inset 0 0 0 9999px var(--bs-table-hover-bg);\n  }\n}\n\nthead, tbody, tfoot, tr, td, th {\n  border: none;\n}\n\n.table > thead {\n  border-bottom: 1px solid var(--bs-table-color);\n}\n\nth {\n  font-weight: 600;\n}\n\n.datatables {\n  // Table pagination row tweaks\n  .dataTables_wrapper div.dataTables_info {\n    padding-top: calc(var(--bslib-spacer, 1rem) * 1.65);\n    font-size: .95rem;\n  }\n\n  .dataTables_paginate {\n    padding-top: var(--bslib-spacer, 1rem);\n  }\n\n  .paginate_button a {\n    font-size: .95rem;\n  }\n\n  // create space between 'show ___ entries' and 'search' above table\n  .dataTables_length, .dataTables_filter {\n    padding-bottom: var(--bslib-spacer, 1rem);\n  }\n\n  // Scroll the data table container, not the entire wrapper\n  .dataTables_wrapper .dt-row {\n    max-width: 100%;\n    overflow: auto;\n  }\n\n  // Style the length and search inputs\n  .dataTables_wrapper .dataTables_length select,\n  .dataTables_wrapper .dataTables_filter input {\n    border: none;\n    border-bottom: 1px solid var(--bs-body-color);\n    border-radius: 0;\n  }\n}\n\n// TODO: This could be applied more generally via the card scss\n.bslib-card-table-sm {\n  &.bslib-card[data-full-screen=\"false\"] .datatables .dataTables_wrapper {\n    font-size: 85%;\n\n    // hide the supporting elements when inside a non-full-screen card\n    .dataTables_length,  // show ___ entries\n    .dataTables_filter,  // search\n    // .dataTables_info,    // showing 1 to 10 of 100 entries\n    .dataTables_paginate {\n      display: none;\n    }\n  }\n}\n"
	],
	"names": [],
	"mappings": "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"
} */
\ No newline at end of file
diff --git a/shiny/www/shared/bslib/_version.json b/shiny/www/shared/bslib/_version.json
index 0f53df0cf..c644f81de 100644
--- a/shiny/www/shared/bslib/_version.json
+++ b/shiny/www/shared/bslib/_version.json
@@ -1,5 +1,5 @@
{
"note!": "This file is auto-generated by scripts/htmlDependencies.R",
"package": "bslib",
- "version": "CRAN (R 4.3.1)"
+ "version": "Github (rstudio/bslib@f05bd23d7df5a7465e418a5794925dacdd27bb6b)"
}
diff --git a/shiny/www/shared/bslib/components/components.css b/shiny/www/shared/bslib/components/components.css
index 790cfd655..8a99ab809 100644
--- a/shiny/www/shared/bslib/components/components.css
+++ b/shiny/www/shared/bslib/components/components.css
@@ -1 +1 @@
-.accordion .accordion-header{font-size:calc(1.325rem + .9vw);margin-top:0;margin-bottom:.5rem;font-weight:400;line-height:1.2;color:var(--bs-heading-color);margin-bottom:0}@media (min-width: 1200px){.accordion .accordion-header{font-size:2rem}}.accordion .accordion-icon:not(:empty){margin-right:0.75rem;display:flex}.accordion .accordion-button:not(.collapsed){box-shadow:none}.accordion .accordion-button:not(.collapsed):focus{box-shadow:var(--bs-accordion-btn-focus-box-shadow)}.bslib-card{overflow:auto}.bslib-card .card-body+.card-body{padding-top:0}.bslib-card .card-body{overflow:auto}.bslib-card .card-body p{margin-top:0}.bslib-card .card-body p:last-child{margin-bottom:0}.bslib-card .card-body{max-height:var(--bslib-card-body-max-height, none)}.bslib-card[data-full-screen="true"]>.card-body{max-height:var(--bslib-card-body-max-height-full-screen, none)}.bslib-card .card-header .form-group{margin-bottom:0}.bslib-card .card-header .selectize-control{margin-bottom:0}.bslib-card .card-header .selectize-control .item{margin-right:1.15rem}.bslib-card .card-footer{margin-top:auto}.bslib-card .bslib-navs-card-title{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center}.bslib-card .bslib-navs-card-title .nav{margin-left:auto}.bslib-card .bslib-sidebar-layout:not([data-bslib-sidebar-border="true"]){border:none}.bslib-card .bslib-sidebar-layout:not([data-bslib-sidebar-border-radius="true"]){border-top-left-radius:0;border-top-right-radius:0}[data-full-screen="true"]{position:fixed;inset:3.5rem 1rem 1rem;height:auto !important;max-height:none !important;width:auto !important;z-index:1070}.bslib-full-screen-enter{display:none;position:absolute;bottom:var(--bslib-full-screen-enter-bottom, 0.2rem);right:var(--bslib-full-screen-enter-right, 0);top:var(--bslib-full-screen-enter-top);left:var(--bslib-full-screen-enter-left);color:var(--bslib-color-fg, var(--bs-card-color));background-color:var(--bslib-color-bg, var(--bs-card-bg, var(--bs-body-bg)));border:var(--bs-card-border-width) solid var(--bslib-color-fg, var(--bs-card-border-color));box-shadow:0 2px 4px rgba(0,0,0,0.15);margin:0.2rem 0.4rem;padding:0.55rem !important;font-size:.8rem;cursor:pointer;opacity:0.7;z-index:1070}.bslib-full-screen-enter:hover{opacity:1}.card[data-full-screen="false"]:hover>*>.bslib-full-screen-enter{display:block}.bslib-has-full-screen .card:hover>*>.bslib-full-screen-enter{display:none}@media (max-width: 575.98px){.bslib-full-screen-enter{display:none !important}}.bslib-full-screen-exit{position:relative;top:1.35rem;font-size:0.9rem;cursor:pointer;text-decoration:none;display:flex;float:right;margin-right:2.15rem;align-items:center;color:rgba(var(--bs-body-bg-rgb), 0.8)}.bslib-full-screen-exit:hover{color:rgba(var(--bs-body-bg-rgb), 1)}.bslib-full-screen-exit svg{margin-left:0.5rem;font-size:1.5rem}#bslib-full-screen-overlay{position:fixed;inset:0;background-color:rgba(var(--bs-body-color-rgb), 0.6);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);z-index:1069;animation:bslib-full-screen-overlay-enter 400ms cubic-bezier(0.6, 0.02, 0.65, 1) forwards}@keyframes bslib-full-screen-overlay-enter{0%{opacity:0}100%{opacity:1}}.bslib-grid{display:grid !important;gap:var(--bslib-spacer, 1rem);height:var(--bslib-grid-height)}.bslib-grid.grid{grid-template-columns:repeat(var(--bs-columns, 12), minmax(0, 1fr));grid-template-rows:unset;grid-auto-rows:var(--bslib-grid--row-heights);--bslib-grid--row-heights--xs: unset;--bslib-grid--row-heights--sm: unset;--bslib-grid--row-heights--md: unset;--bslib-grid--row-heights--lg: unset;--bslib-grid--row-heights--xl: unset;--bslib-grid--row-heights--xxl: unset}.bslib-grid.grid.bslib-grid--row-heights--xs{--bslib-grid--row-heights: var(--bslib-grid--row-heights--xs)}@media (min-width: 576px){.bslib-grid.grid.bslib-grid--row-heights--sm{--bslib-grid--row-heights: var(--bslib-grid--row-heights--sm)}}@media (min-width: 768px){.bslib-grid.grid.bslib-grid--row-heights--md{--bslib-grid--row-heights: var(--bslib-grid--row-heights--md)}}@media (min-width: 992px){.bslib-grid.grid.bslib-grid--row-heights--lg{--bslib-grid--row-heights: var(--bslib-grid--row-heights--lg)}}@media (min-width: 1200px){.bslib-grid.grid.bslib-grid--row-heights--xl{--bslib-grid--row-heights: var(--bslib-grid--row-heights--xl)}}@media (min-width: 1400px){.bslib-grid.grid.bslib-grid--row-heights--xxl{--bslib-grid--row-heights: var(--bslib-grid--row-heights--xxl)}}.bslib-grid>*>.shiny-input-container{width:100%}.bslib-grid-item{grid-column:auto/span 1}@media (max-width: 767.98px){.bslib-grid-item{grid-column:1 / -1}}@media (max-width: 575.98px){.bslib-grid{grid-template-columns:1fr !important;height:var(--bslib-grid-height-mobile)}.bslib-grid.grid{height:unset !important;grid-auto-rows:var(--bslib-grid--row-heights--xs, auto)}}@media (min-width: 576px){.nav:not(.nav-hidden){display:flex !important;display:-webkit-flex !important}.nav:not(.nav-hidden):not(.nav-stacked):not(.flex-column){float:none !important}.nav:not(.nav-hidden):not(.nav-stacked):not(.flex-column)>.bslib-nav-spacer{margin-left:auto !important}.nav:not(.nav-hidden):not(.nav-stacked):not(.flex-column)>.form-inline{margin-top:auto;margin-bottom:auto}.nav:not(.nav-hidden).nav-stacked{flex-direction:column;-webkit-flex-direction:column;height:100%}.nav:not(.nav-hidden).nav-stacked>.bslib-nav-spacer{margin-top:auto !important}}.bslib-page-fill{width:100%;height:100%;margin:0;padding:var(--bslib-spacer, 1rem);gap:var(--bslib-spacer, 1rem)}@media (max-width: 575.98px){.bslib-flow-mobile>.html-fill-item{flex:0 0 auto}.bslib-flow-mobile.bslib-page-sidebar>.html-fill-item,.bslib-flow-mobile.bslib-page-navbar.has-page-sidebar>.html-fill-item{flex:1 1 auto}.bslib-flow-mobile.bslib-page-sidebar>.bslib-sidebar-layout>.main>.html-fill-item,.bslib-flow-mobile.bslib-page-navbar.has-page-sidebar>.html-fill-container>.bslib-sidebar-layout>.main>.html-fill-item{flex:0 0 auto}.bslib-flow-mobile.bslib-page-sidebar>.bslib-sidebar-layout:not(.sidebar-right)>.main,.bslib-flow-mobile.bslib-page-navbar.has-page-sidebar>.html-fill-container>.bslib-sidebar-layout:not(.sidebar-right)>.main{padding-left:var(--_padding-icon);padding-top:var(--_padding)}.bslib-flow-mobile.bslib-page-sidebar>.bslib-sidebar-layout:not(.sidebar-right)>.collapse-toggle,.bslib-flow-mobile.bslib-page-navbar.has-page-sidebar>.html-fill-container>.bslib-sidebar-layout:not(.sidebar-right)>.collapse-toggle{left:calc(var(--_icon-size) / 2)}.bslib-flow-mobile.bslib-page-sidebar>.bslib-sidebar-layout.sidebar-right>.main,.bslib-flow-mobile.bslib-page-navbar.has-page-sidebar>.html-fill-container>.bslib-sidebar-layout.sidebar-right>.main{padding-right:var(--_padding-icon)}.bslib-flow-mobile.bslib-page-sidebar>.bslib-sidebar-layout.sidebar-right>.collapse-toggle,.bslib-flow-mobile.bslib-page-navbar.has-page-sidebar>.html-fill-container>.bslib-sidebar-layout.sidebar-right>.collapse-toggle{right:calc(var(--_icon-size) / 2)}}.navbar+.container-fluid:has(>.tab-content>.tab-pane.active.html-fill-container){padding-left:0;padding-right:0}.navbar+.container-fluid>.tab-content>.tab-pane.active.html-fill-container{padding:var(--bslib-spacer, 1rem);gap:var(--bslib-spacer, 1rem)}.navbar+.container-fluid>.tab-content>.tab-pane.active.html-fill-container:has(>.bslib-sidebar-layout:only-child){padding:0}.navbar+.container-fluid>.tab-content>.tab-pane.active.html-fill-container>.bslib-sidebar-layout:only-child:not([data-bslib-sidebar-border="true"]){border-left:none;border-right:none;border-bottom:none}.navbar+.container-fluid>.tab-content>.tab-pane.active.html-fill-container>.bslib-sidebar-layout:only-child:not([data-bslib-sidebar-border-radius="true"]){border-radius:0}.navbar+div>.bslib-sidebar-layout{border-top:var(--bslib-sidebar-border)}:root{--bslib-page-sidebar-title-bg: #202020;--bslib-page-sidebar-title-color: #fff}.bslib-page-title{background-color:var(--bslib-page-sidebar-title-bg);color:var(--bslib-page-sidebar-title-color);font-size:1.5rem;font-weight:300;padding:var(--bslib-spacer, 1rem);padding-left:1.5rem;margin-bottom:0;border-bottom:1px solid #dee2e6}.bslib-sidebar-layout{--_transition-duration: 0;--_transition-easing-x: var(--bslib-sidebar-transition-easing-x, cubic-bezier(0.8, 0.78, 0.22, 1.07));--_border: var(--bslib-sidebar-border, var(--bs-card-border-width, var(--bs-border-width)) solid var(--bs-card-border-color, var(--bs-border-color-translucent)));--_border-radius: var(--bslib-sidebar-border-radius, var(--bs-border-radius));--_vert-border: var(--bslib-sidebar-vert-border, var(--_border));--_sidebar-width: var(--bslib-sidebar-width, 250px);--_sidebar-bg: var(--bslib-sidebar-bg, rgba(var(--bs-emphasis-color-rgb, 0, 0, 0), 0.05));--_sidebar-fg: var(--bslib-sidebar-fg, var(--bs-emphasis-color, black));--_main-fg: var(--bslib-sidebar-main-fg, var(--bs-card-color, var(--bs-body-color)));--_main-bg: var(--bslib-sidebar-main-bg, transparent);--_toggle-bg: var(--bslib-sidebar-toggle-bg, rgba(var(--bs-emphasis-color-rgb, 0, 0, 0), 0.1));--_padding: var(--bslib-sidebar-padding, calc(var(--bslib-spacer) * 1.5));--_icon-size: var(--bslib-sidebar-icon-size, var(--bslib-spacer, 1rem));--_icon-button-size: var(--bslib-sidebar-icon-button-size, calc(var(--_icon-size, 1rem) * 2));--_padding-icon: calc(var(--_icon-button-size, 2rem) * 1.5);--_toggle-border-radius: var(--bslib-collapse-toggle-border-radius, var(--bs-border-radius, 3px));--_toggle-transform: var(--bslib-collapse-toggle-transform, 0deg);--_toggle-transition-easing: var(--bslib-sidebar-toggle-transition-easing, cubic-bezier(1, 0, 0, 1));--_toggle-right-transform: var(--bslib-collapse-toggle-right-transform, 180deg);--_toggle-position-y: calc(var(--_js-toggle-count-this-side, 0) * calc(var(--_icon-size) + var(--_padding)) + var(--_icon-size, 1rem) / 2);--_toggle-position-x: calc(-2.5 * var(--_icon-size) - var(--bs-card-border-width, 1px));--_mobile-max-height: var(--bslib-sidebar-mobile-max-height, var(--bslib-sidebar-max-height-mobile));--_sidebar-mobile-opacity: var(--bslib-sidebar-mobile-opacity);--_sidebar-mobile-max-width: var(--bslib-sidebar-mobile-max-width);--_sidebar-mobile-box-shadow: var(--bslib-sidebar-mobile-box-shadow);--_column-main: minmax(0, 1fr);--_toggle-collective-height: calc(calc(var(--_icon-button-size) + 0.5em) * var(--_js-toggle-count-max-side, 1));display:grid !important;grid-template-columns:Min(calc(100% - var(--_padding-icon)), var(--_sidebar-width)) var(--_column-main);position:relative;transition:grid-template-columns ease-in-out var(--_transition-duration);border:var(--_border);border-radius:var(--_border-radius)}.bslib-sidebar-layout.transitioning{--_transition-duration: max(var(--bslib-sidebar-transition-duration, 300ms), 5ms)}@media (prefers-reduced-motion: reduce){.bslib-sidebar-layout{transition:none}}.bslib-sidebar-layout,.html-fill-container>.bslib-sidebar-layout.html-fill-item{min-height:var(--_toggle-collective-height)}.bslib-sidebar-layout[data-bslib-sidebar-border="false"]{border:none}.bslib-sidebar-layout[data-bslib-sidebar-border-radius="false"]{border-radius:initial}.bslib-sidebar-layout>.main,.bslib-sidebar-layout>.sidebar{grid-row:1 / 2;border-radius:inherit;overflow:auto}.bslib-sidebar-layout>.main{grid-column:2 / 3;border-top-left-radius:0;border-bottom-left-radius:0;padding:var(--_padding);transition:padding var(--_transition-easing-x) var(--_transition-duration);color:var(--_main-fg);background-color:var(--_main-bg)}.bslib-sidebar-layout>.sidebar{grid-column:1 / 2;width:100%;border-right:var(--_vert-border);border-top-right-radius:0;border-bottom-right-radius:0;color:var(--_sidebar-fg);background-color:var(--_sidebar-bg);backdrop-filter:blur(5px)}.bslib-sidebar-layout>.sidebar>.sidebar-content{display:flex;flex-direction:column;gap:var(--bslib-spacer, 1rem);padding:var(--_padding);padding-top:var(--_padding-icon)}.bslib-sidebar-layout>.sidebar>.sidebar-content>:last-child:not(.sidebar-title){margin-bottom:0}.bslib-sidebar-layout>.sidebar>.sidebar-content>.accordion{margin-left:calc(-1 * var(--_padding));margin-right:calc(-1 * var(--_padding))}.bslib-sidebar-layout>.sidebar>.sidebar-content>.accordion:last-child{margin-bottom:calc(-1 * var(--_padding))}.bslib-sidebar-layout>.sidebar>.sidebar-content>.accordion:not(:last-child){margin-bottom:1rem}.bslib-sidebar-layout>.sidebar>.sidebar-content>.accordion .accordion-body{display:flex;flex-direction:column}.bslib-sidebar-layout>.sidebar>.sidebar-content>.accordion:not(:first-child) .accordion-item:first-child{border-top:var(--bs-accordion-border-width) solid var(--bs-accordion-border-color)}.bslib-sidebar-layout>.sidebar>.sidebar-content>.accordion:not(:last-child) .accordion-item:last-child{border-bottom:var(--bs-accordion-border-width) solid var(--bs-accordion-border-color)}.bslib-sidebar-layout>.sidebar>.sidebar-content.has-accordion>.sidebar-title{border-bottom:none;padding-bottom:0}.bslib-sidebar-layout>.sidebar .shiny-input-container{width:100%}.bslib-sidebar-layout[data-bslib-sidebar-open="always"]>.sidebar>.sidebar-content{padding-top:var(--_padding)}.bslib-sidebar-layout>.collapse-toggle{grid-row:1 / 2;grid-column:1 / 2;display:inline-flex;align-items:center;position:absolute;right:calc(var(--_icon-size));top:calc(var(--_icon-size, 1rem) / 2);border:none;border-radius:var(--_toggle-border-radius);height:var(--_icon-button-size, 2rem);width:var(--_icon-button-size, 2rem);display:flex;align-items:center;justify-content:center;padding:0;color:var(--_sidebar-fg);background-color:unset;transition:color var(--_transition-easing-x) var(--_transition-duration),top var(--_transition-easing-x) var(--_transition-duration),right var(--_transition-easing-x) var(--_transition-duration),left var(--_transition-easing-x) var(--_transition-duration)}.bslib-sidebar-layout>.collapse-toggle:hover{background-color:var(--_toggle-bg)}.bslib-sidebar-layout>.collapse-toggle>.collapse-icon{opacity:0.8;width:var(--_icon-size);height:var(--_icon-size);transform:rotateY(var(--_toggle-transform));transition:transform var(--_toggle-transition-easing) var(--_transition-duration)}.bslib-sidebar-layout>.collapse-toggle:hover>.collapse-icon{opacity:1}.bslib-sidebar-layout .sidebar-title{font-size:1.25rem;line-height:1.25;margin-top:0;margin-bottom:1rem;padding-bottom:1rem;border-bottom:var(--_border)}.bslib-sidebar-layout.sidebar-right{grid-template-columns:var(--_column-main) Min(calc(100% - var(--_padding-icon)), var(--_sidebar-width))}.bslib-sidebar-layout.sidebar-right>.main{grid-column:1 / 2;border-top-right-radius:0;border-bottom-right-radius:0;border-top-left-radius:inherit;border-bottom-left-radius:inherit}.bslib-sidebar-layout.sidebar-right>.sidebar{grid-column:2 / 3;border-right:none;border-left:var(--_vert-border);border-top-left-radius:0;border-bottom-left-radius:0}.bslib-sidebar-layout.sidebar-right>.collapse-toggle{grid-column:2 / 3;left:var(--_icon-size);right:unset;border:var(--bslib-collapse-toggle-border)}.bslib-sidebar-layout.sidebar-right>.collapse-toggle>.collapse-icon{transform:rotateY(var(--_toggle-right-transform))}.bslib-sidebar-layout.transitioning>.sidebar>.sidebar-content{display:none}.bslib-sidebar-layout.sidebar-collapsed{--_toggle-transform: 180deg;--_toggle-right-transform: 0deg;--_vert-border: none;grid-template-columns:0 minmax(0, 1fr)}.bslib-sidebar-layout.sidebar-collapsed.sidebar-right{grid-template-columns:minmax(0, 1fr) 0}.bslib-sidebar-layout.sidebar-collapsed:not(.transitioning)>.sidebar>*{display:none}.bslib-sidebar-layout.sidebar-collapsed>.main{border-radius:inherit;padding-left:var(--_padding-icon);padding-right:var(--_padding-icon)}.bslib-sidebar-layout.sidebar-collapsed>.collapse-toggle{color:var(--_main-fg);top:var(--_toggle-position-y);right:var(--_toggle-position-x)}.bslib-sidebar-layout.sidebar-collapsed.sidebar-right>.collapse-toggle{left:var(--_toggle-position-x);right:unset}@media (max-width: 575.98px){.bslib-sidebar-layout[data-bslib-sidebar-open="desktop"]{--bslib-sidebar-js-init-collapsed: true}.bslib-sidebar-layout>.sidebar,.bslib-sidebar-layout.sidebar-right>.sidebar{border:none}.bslib-sidebar-layout>.main,.bslib-sidebar-layout.sidebar-right>.main{grid-column:1 / 3}.bslib-sidebar-layout[data-bslib-sidebar-open="always"]{display:block !important}.bslib-sidebar-layout[data-bslib-sidebar-open="always"]>.sidebar{max-height:var(--_mobile-max-height);overflow-y:auto;border-top:var(--_vert-border)}.bslib-sidebar-layout:not([data-bslib-sidebar-open="always"]){grid-template-columns:100% 0}.bslib-sidebar-layout:not([data-bslib-sidebar-open="always"]):not(.sidebar-collapsed)>.sidebar,.bslib-sidebar-layout:not([data-bslib-sidebar-open="always"]).transitioning>.sidebar{z-index:1}.bslib-sidebar-layout:not([data-bslib-sidebar-open="always"]):not(.sidebar-collapsed)>.collapse-toggle,.bslib-sidebar-layout:not([data-bslib-sidebar-open="always"]).transitioning>.collapse-toggle{z-index:1}.bslib-sidebar-layout:not([data-bslib-sidebar-open="always"]):not(.sidebar-right)>.collapse-toggle{left:var(--_icon-size);right:unset}.bslib-sidebar-layout:not([data-bslib-sidebar-open="always"]).sidebar-right>.collapse-toggle{right:var(--_icon-size);left:unset}.bslib-sidebar-layout:not([data-bslib-sidebar-open="always"])>.sidebar{opacity:var(--_sidebar-mobile-opacity, 1);max-width:var(--_sidebar-mobile-max-width, 100%);box-shadow:var(--_sidebar-mobile-box-shadow)}.bslib-sidebar-layout:not([data-bslib-sidebar-open="always"]):not(.sidebar-right)>.sidebar{margin-right:auto}.bslib-sidebar-layout:not([data-bslib-sidebar-open="always"]).sidebar-right>.sidebar{margin-left:auto}.bslib-sidebar-layout:not([data-bslib-sidebar-open="always"]).sidebar-right{grid-template-columns:0 100%}.bslib-sidebar-layout:not([data-bslib-sidebar-open="always"]).sidebar-collapsed{grid-template-columns:0 100%}.bslib-sidebar-layout:not([data-bslib-sidebar-open="always"]).sidebar-collapsed.sidebar-right{grid-template-columns:100% 0}.bslib-sidebar-layout:not([data-bslib-sidebar-open="always"])>.main{padding-top:var(--_toggle-collective-height);padding-left:var(--_padding);padding-right:var(--_padding)}}.bslib-value-box{container-name:bslib-value-box;container-type:inline-size}.bslib-value-box.default{--bslib-value-box-bg-default: var(--bs-card-bg, #fff);--bslib-value-box-border-color-default: var(--bs-card-border-color, var(--bs-border-color-translucent));color:var(--bslib-value-box-color, var(--bs-body-color));background-color:var(--bslib-value-box-bg, var(--bslib-value-box-bg-default));border-color:var(--bslib-value-box-border-color, var(--bslib-value-box-border-color-default))}.bslib-value-box .value-box-grid{display:grid;grid-template-areas:"left right";align-items:center;overflow:hidden}.bslib-value-box .value-box-showcase{height:100%;max-height:var(---bslib-value-box-showcase-max-h, 100%)}.bslib-value-box .value-box-showcase,.bslib-value-box .value-box-showcase>.html-fill-item{width:100%}.bslib-value-box[data-full-screen="true"] .value-box-showcase{max-height:var(---bslib-value-box-showcase-max-h-fs, 100%)}@media screen and (min-width: 575.98px){@container bslib-value-box (max-width: 300px){.bslib-value-box:not(.showcase-bottom) .value-box-grid{grid-template-columns:1fr !important;grid-template-rows:auto auto;grid-template-areas:"top" "bottom"}.bslib-value-box:not(.showcase-bottom) .value-box-grid .value-box-showcase{grid-area:top !important}.bslib-value-box:not(.showcase-bottom) .value-box-grid .value-box-area{grid-area:bottom !important;justify-content:end}}}.bslib-value-box .value-box-area{justify-content:center;padding:1.5rem 1rem;font-size:.9rem;font-weight:500}.bslib-value-box .value-box-area *{margin-bottom:0;margin-top:0}.bslib-value-box .value-box-title{font-size:1rem;margin-top:0;margin-bottom:.5rem;font-weight:400;line-height:1.2}.bslib-value-box .value-box-title:empty::after{content:'\00a0 '}.bslib-value-box .value-box-value{font-size:calc(1.325rem + .9vw);margin-top:0;margin-bottom:.5rem;font-weight:400;line-height:1.2}@media (min-width: 1200px){.bslib-value-box .value-box-value{font-size:2rem}}.bslib-value-box .value-box-value:empty::after{content:'\00a0 '}.bslib-value-box .value-box-showcase{align-items:center;justify-content:center;margin-top:auto;margin-bottom:auto;padding:1rem}.bslib-value-box .value-box-showcase .bi,.bslib-value-box .value-box-showcase .fa,.bslib-value-box .value-box-showcase .fab,.bslib-value-box .value-box-showcase .fas,.bslib-value-box .value-box-showcase .far{opacity:.85;min-width:50px;max-width:125%}.bslib-value-box .value-box-showcase .bi,.bslib-value-box .value-box-showcase .fa,.bslib-value-box .value-box-showcase .fab,.bslib-value-box .value-box-showcase .fas,.bslib-value-box .value-box-showcase .far{font-size:4rem}.bslib-value-box.showcase-top-right .value-box-grid{grid-template-columns:1fr var(---bslib-value-box-showcase-w, 50%)}.bslib-value-box.showcase-top-right .value-box-grid .value-box-showcase{grid-area:right;margin-left:auto;align-self:start;align-items:end;padding-left:0;padding-bottom:0}.bslib-value-box.showcase-top-right .value-box-grid .value-box-area{grid-area:left;align-self:end}.bslib-value-box.showcase-top-right[data-full-screen="true"] .value-box-grid{grid-template-columns:auto var(---bslib-value-box-showcase-w-fs, 1fr)}.bslib-value-box.showcase-top-right[data-full-screen="true"] .value-box-grid>div{align-self:center}.bslib-value-box.showcase-top-right:not([data-full-screen="true"]) .value-box-showcase{margin-top:0}@container bslib-value-box (max-width: 300px){.bslib-value-box.showcase-top-right:not([data-full-screen="true"]) .value-box-grid .value-box-showcase{padding-left:1rem}}.bslib-value-box.showcase-left-center .value-box-grid{grid-template-columns:var(---bslib-value-box-showcase-w, 30%) auto}.bslib-value-box.showcase-left-center[data-full-screen="true"] .value-box-grid{grid-template-columns:var(---bslib-value-box-showcase-w-fs, 1fr) auto}.bslib-value-box.showcase-left-center:not([data-fill-screen="true"]) .value-box-grid .value-box-showcase{grid-area:left}.bslib-value-box.showcase-left-center:not([data-fill-screen="true"]) .value-box-grid .value-box-area{grid-area:right}.bslib-value-box.showcase-bottom .value-box-grid{grid-template-columns:1fr;grid-template-rows:1fr var(---bslib-value-box-showcase-h, auto);grid-template-areas:"top" "bottom";overflow:hidden}.bslib-value-box.showcase-bottom .value-box-grid .value-box-showcase{grid-area:bottom;padding:0;margin:0}.bslib-value-box.showcase-bottom .value-box-grid .value-box-area{grid-area:top}.bslib-value-box.showcase-bottom[data-full-screen="true"] .value-box-grid{grid-template-rows:1fr var(---bslib-value-box-showcase-h-fs, 2fr)}.bslib-value-box.showcase-bottom[data-full-screen="true"] .value-box-grid .value-box-showcase{padding:1rem}
+.accordion .accordion-header{font-size:calc(1.325rem + .9vw);margin-top:0;margin-bottom:.5rem;font-weight:400;line-height:1.2;color:var(--bs-heading-color);margin-bottom:0}@media (min-width: 1200px){.accordion .accordion-header{font-size:2rem}}.accordion .accordion-icon:not(:empty){margin-right:0.75rem;display:flex}.accordion .accordion-button:not(.collapsed){box-shadow:none}.accordion .accordion-button:not(.collapsed):focus{box-shadow:var(--bs-accordion-btn-focus-box-shadow)}.bslib-card{overflow:auto}.bslib-card .card-body+.card-body{padding-top:0}.bslib-card .card-body{overflow:auto}.bslib-card .card-body p{margin-top:0}.bslib-card .card-body p:last-child{margin-bottom:0}.bslib-card .card-body{max-height:var(--bslib-card-body-max-height, none)}.bslib-card[data-full-screen="true"]>.card-body{max-height:var(--bslib-card-body-max-height-full-screen, none)}.bslib-card .card-header .form-group{margin-bottom:0}.bslib-card .card-header .selectize-control{margin-bottom:0}.bslib-card .card-header .selectize-control .item{margin-right:1.15rem}.bslib-card .card-footer{margin-top:auto}.bslib-card .bslib-navs-card-title{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center}.bslib-card .bslib-navs-card-title .nav{margin-left:auto}.bslib-card .bslib-sidebar-layout:not([data-bslib-sidebar-border="true"]){border:none}.bslib-card .bslib-sidebar-layout:not([data-bslib-sidebar-border-radius="true"]){border-top-left-radius:0;border-top-right-radius:0}[data-full-screen="true"]{position:fixed;inset:3.5rem 1rem 1rem;height:auto !important;max-height:none !important;width:auto !important;z-index:1070}.bslib-full-screen-enter{display:none;position:absolute;bottom:var(--bslib-full-screen-enter-bottom, 0.2rem);right:var(--bslib-full-screen-enter-right, 0);top:var(--bslib-full-screen-enter-top);left:var(--bslib-full-screen-enter-left);color:var(--bslib-color-fg, var(--bs-card-color));background-color:var(--bslib-color-bg, var(--bs-card-bg, var(--bs-body-bg)));border:var(--bs-card-border-width) solid var(--bslib-color-fg, var(--bs-card-border-color));box-shadow:0 2px 4px rgba(0,0,0,0.15);margin:0.2rem 0.4rem;padding:0.55rem !important;font-size:.8rem;cursor:pointer;opacity:0.7;z-index:1070}.bslib-full-screen-enter:hover{opacity:1}.card[data-full-screen="false"]:hover>*>.bslib-full-screen-enter{display:block}.bslib-has-full-screen .card:hover>*>.bslib-full-screen-enter{display:none}@media (max-width: 575.98px){.bslib-full-screen-enter{display:none !important}}.bslib-full-screen-exit{position:relative;top:1.35rem;font-size:0.9rem;cursor:pointer;text-decoration:none;display:flex;float:right;margin-right:2.15rem;align-items:center;color:rgba(var(--bs-body-bg-rgb), 0.8)}.bslib-full-screen-exit:hover{color:rgba(var(--bs-body-bg-rgb), 1)}.bslib-full-screen-exit svg{margin-left:0.5rem;font-size:1.5rem}#bslib-full-screen-overlay{position:fixed;inset:0;background-color:rgba(var(--bs-body-color-rgb), 0.6);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);z-index:1069;animation:bslib-full-screen-overlay-enter 400ms cubic-bezier(0.6, 0.02, 0.65, 1) forwards}@keyframes bslib-full-screen-overlay-enter{0%{opacity:0}100%{opacity:1}}.bslib-grid{--_item-column-span: 1;display:grid !important;gap:var(--bslib-spacer, 1rem);height:var(--bslib-grid-height)}.bslib-grid>*{grid-column:auto/span var(--_item-column-span, 1)}.bslib-grid.grid{grid-template-columns:repeat(var(--bs-columns, 12), minmax(0, 1fr));grid-template-rows:unset;grid-auto-rows:var(--bslib-grid--row-heights);--bslib-grid--row-heights--xs: unset;--bslib-grid--row-heights--sm: unset;--bslib-grid--row-heights--md: unset;--bslib-grid--row-heights--lg: unset;--bslib-grid--row-heights--xl: unset;--bslib-grid--row-heights--xxl: unset}.bslib-grid.grid.bslib-grid--row-heights--xs{--bslib-grid--row-heights: var(--bslib-grid--row-heights--xs)}@media (min-width: 576px){.bslib-grid.grid.bslib-grid--row-heights--sm{--bslib-grid--row-heights: var(--bslib-grid--row-heights--sm)}}@media (min-width: 768px){.bslib-grid.grid.bslib-grid--row-heights--md{--bslib-grid--row-heights: var(--bslib-grid--row-heights--md)}}@media (min-width: 992px){.bslib-grid.grid.bslib-grid--row-heights--lg{--bslib-grid--row-heights: var(--bslib-grid--row-heights--lg)}}@media (min-width: 1200px){.bslib-grid.grid.bslib-grid--row-heights--xl{--bslib-grid--row-heights: var(--bslib-grid--row-heights--xl)}}@media (min-width: 1400px){.bslib-grid.grid.bslib-grid--row-heights--xxl{--bslib-grid--row-heights: var(--bslib-grid--row-heights--xxl)}}.bslib-grid>*>.shiny-input-container{width:100%}bslib-layout-columns.bslib-grid{--_item-column-span: 6}bslib-layout-columns[hidden-until-init]>*{display:none}@media (max-width: 767.98px){.bslib-grid>*{grid-column:1 / -1}}@media (max-width: 575.98px){.bslib-grid{grid-template-columns:1fr !important;height:var(--bslib-grid-height-mobile)}.bslib-grid.grid{height:unset !important}}@media (min-width: 576px){.nav:not(.nav-hidden){display:flex !important;display:-webkit-flex !important}.nav:not(.nav-hidden):not(.nav-stacked):not(.flex-column){float:none !important}.nav:not(.nav-hidden):not(.nav-stacked):not(.flex-column)>.bslib-nav-spacer{margin-left:auto !important}.nav:not(.nav-hidden):not(.nav-stacked):not(.flex-column)>.form-inline{margin-top:auto;margin-bottom:auto}.nav:not(.nav-hidden).nav-stacked{flex-direction:column;-webkit-flex-direction:column;height:100%}.nav:not(.nav-hidden).nav-stacked>.bslib-nav-spacer{margin-top:auto !important}}.bslib-page-fill{width:100%;height:100%;margin:0;padding:var(--bslib-spacer, 1rem);gap:var(--bslib-spacer, 1rem)}@media (max-width: 575.98px){.bslib-flow-mobile>.html-fill-item{flex:0 0 auto}.bslib-flow-mobile.bslib-page-sidebar>.html-fill-item,.bslib-flow-mobile.bslib-page-navbar.has-page-sidebar>.html-fill-item{flex:1 1 auto}.bslib-flow-mobile.bslib-page-sidebar>.bslib-sidebar-layout>.main>.html-fill-item,.bslib-flow-mobile.bslib-page-navbar.has-page-sidebar>.html-fill-container>.bslib-sidebar-layout>.main>.html-fill-item{flex:0 0 auto}.bslib-flow-mobile.bslib-page-sidebar>.bslib-sidebar-layout:not(.sidebar-right)>.main,.bslib-flow-mobile.bslib-page-navbar.has-page-sidebar>.html-fill-container>.bslib-sidebar-layout:not(.sidebar-right)>.main{padding-left:var(--_padding-icon);padding-top:var(--_padding)}.bslib-flow-mobile.bslib-page-sidebar>.bslib-sidebar-layout:not(.sidebar-right)>.collapse-toggle,.bslib-flow-mobile.bslib-page-navbar.has-page-sidebar>.html-fill-container>.bslib-sidebar-layout:not(.sidebar-right)>.collapse-toggle{left:calc(var(--_icon-size) / 2)}.bslib-flow-mobile.bslib-page-sidebar>.bslib-sidebar-layout.sidebar-right>.main,.bslib-flow-mobile.bslib-page-navbar.has-page-sidebar>.html-fill-container>.bslib-sidebar-layout.sidebar-right>.main{padding-right:var(--_padding-icon)}.bslib-flow-mobile.bslib-page-sidebar>.bslib-sidebar-layout.sidebar-right>.collapse-toggle,.bslib-flow-mobile.bslib-page-navbar.has-page-sidebar>.html-fill-container>.bslib-sidebar-layout.sidebar-right>.collapse-toggle{right:calc(var(--_icon-size) / 2)}}.navbar+.container-fluid:has(>.tab-content>.tab-pane.active.html-fill-container){padding-left:0;padding-right:0}.navbar+.container-fluid>.tab-content>.tab-pane.active.html-fill-container{padding:var(--bslib-spacer, 1rem);gap:var(--bslib-spacer, 1rem)}.navbar+.container-fluid>.tab-content>.tab-pane.active.html-fill-container:has(>.bslib-sidebar-layout:only-child){padding:0}.navbar+.container-fluid>.tab-content>.tab-pane.active.html-fill-container>.bslib-sidebar-layout:only-child:not([data-bslib-sidebar-border="true"]){border-left:none;border-right:none;border-bottom:none}.navbar+.container-fluid>.tab-content>.tab-pane.active.html-fill-container>.bslib-sidebar-layout:only-child:not([data-bslib-sidebar-border-radius="true"]){border-radius:0}.navbar+div>.bslib-sidebar-layout{border-top:var(--bslib-sidebar-border)}:root{--bslib-page-sidebar-title-bg: #202020;--bslib-page-sidebar-title-color: #fff}.bslib-page-title{background-color:var(--bslib-page-sidebar-title-bg);color:var(--bslib-page-sidebar-title-color);font-size:1.5rem;font-weight:300;padding:var(--bslib-spacer, 1rem);padding-left:1.5rem;margin-bottom:0;border-bottom:1px solid #dee2e6}.bslib-sidebar-layout{--_transition-duration: 0;--_transition-easing-x: var(--bslib-sidebar-transition-easing-x, cubic-bezier(0.8, 0.78, 0.22, 1.07));--_border: var(--bslib-sidebar-border, var(--bs-card-border-width, var(--bs-border-width)) solid var(--bs-card-border-color, var(--bs-border-color-translucent)));--_border-radius: var(--bslib-sidebar-border-radius, var(--bs-border-radius));--_vert-border: var(--bslib-sidebar-vert-border, var(--_border));--_sidebar-width: var(--bslib-sidebar-width, 250px);--_sidebar-bg: var(--bslib-sidebar-bg, rgba(var(--bs-emphasis-color-rgb, 0, 0, 0), 0.05));--_sidebar-fg: var(--bslib-sidebar-fg, var(--bs-emphasis-color, black));--_main-fg: var(--bslib-sidebar-main-fg, var(--bs-card-color, var(--bs-body-color)));--_main-bg: var(--bslib-sidebar-main-bg, transparent);--_toggle-bg: var(--bslib-sidebar-toggle-bg, rgba(var(--bs-emphasis-color-rgb, 0, 0, 0), 0.1));--_padding: var(--bslib-sidebar-padding, calc(var(--bslib-spacer) * 1.5));--_icon-size: var(--bslib-sidebar-icon-size, var(--bslib-spacer, 1rem));--_icon-button-size: var(--bslib-sidebar-icon-button-size, calc(var(--_icon-size, 1rem) * 2));--_padding-icon: calc(var(--_icon-button-size, 2rem) * 1.5);--_toggle-border-radius: var(--bslib-collapse-toggle-border-radius, var(--bs-border-radius, 3px));--_toggle-transform: var(--bslib-collapse-toggle-transform, 0deg);--_toggle-transition-easing: var(--bslib-sidebar-toggle-transition-easing, cubic-bezier(1, 0, 0, 1));--_toggle-right-transform: var(--bslib-collapse-toggle-right-transform, 180deg);--_toggle-position-y: calc(var(--_js-toggle-count-this-side, 0) * calc(var(--_icon-size) + var(--_padding)) + var(--_icon-size, 1rem) / 2);--_toggle-position-x: calc(-2.5 * var(--_icon-size) - var(--bs-card-border-width, 1px));--_mobile-max-height: var(--bslib-sidebar-mobile-max-height, var(--bslib-sidebar-max-height-mobile));--_sidebar-mobile-opacity: var(--bslib-sidebar-mobile-opacity);--_sidebar-mobile-max-width: var(--bslib-sidebar-mobile-max-width);--_sidebar-mobile-box-shadow: var(--bslib-sidebar-mobile-box-shadow);--_column-main: minmax(0, 1fr);--_toggle-collective-height: calc(calc(var(--_icon-button-size) + 0.5em) * var(--_js-toggle-count-max-side, 1));display:grid !important;grid-template-columns:Min(calc(100% - var(--_padding-icon)), var(--_sidebar-width)) var(--_column-main);position:relative;transition:grid-template-columns ease-in-out var(--_transition-duration);border:var(--_border);border-radius:var(--_border-radius)}.bslib-sidebar-layout.transitioning{--_transition-duration: max(var(--bslib-sidebar-transition-duration, 300ms), 5ms)}@media (prefers-reduced-motion: reduce){.bslib-sidebar-layout{transition:none}}.bslib-sidebar-layout,.html-fill-container>.bslib-sidebar-layout.html-fill-item{min-height:var(--_toggle-collective-height)}.bslib-sidebar-layout[data-bslib-sidebar-border="false"]{border:none}.bslib-sidebar-layout[data-bslib-sidebar-border-radius="false"]{border-radius:initial}.bslib-sidebar-layout>.main,.bslib-sidebar-layout>.sidebar{grid-row:1 / 2;border-radius:inherit;overflow:auto}.bslib-sidebar-layout>.main{grid-column:2 / 3;border-top-left-radius:0;border-bottom-left-radius:0;padding:var(--_padding);transition:padding var(--_transition-easing-x) var(--_transition-duration);color:var(--_main-fg);background-color:var(--_main-bg)}.bslib-sidebar-layout>.sidebar{grid-column:1 / 2;width:100%;border-right:var(--_vert-border);border-top-right-radius:0;border-bottom-right-radius:0;color:var(--_sidebar-fg);background-color:var(--_sidebar-bg);backdrop-filter:blur(5px)}.bslib-sidebar-layout>.sidebar>.sidebar-content{display:flex;flex-direction:column;gap:var(--bslib-spacer, 1rem);padding:var(--_padding);padding-top:var(--_padding-icon)}.bslib-sidebar-layout>.sidebar>.sidebar-content>:last-child:not(.sidebar-title){margin-bottom:0}.bslib-sidebar-layout>.sidebar>.sidebar-content>.accordion{margin-left:calc(-1 * var(--_padding));margin-right:calc(-1 * var(--_padding))}.bslib-sidebar-layout>.sidebar>.sidebar-content>.accordion:last-child{margin-bottom:calc(-1 * var(--_padding))}.bslib-sidebar-layout>.sidebar>.sidebar-content>.accordion:not(:last-child){margin-bottom:1rem}.bslib-sidebar-layout>.sidebar>.sidebar-content>.accordion .accordion-body{display:flex;flex-direction:column}.bslib-sidebar-layout>.sidebar>.sidebar-content>.accordion:not(:first-child) .accordion-item:first-child{border-top:var(--bs-accordion-border-width) solid var(--bs-accordion-border-color)}.bslib-sidebar-layout>.sidebar>.sidebar-content>.accordion:not(:last-child) .accordion-item:last-child{border-bottom:var(--bs-accordion-border-width) solid var(--bs-accordion-border-color)}.bslib-sidebar-layout>.sidebar>.sidebar-content.has-accordion>.sidebar-title{border-bottom:none;padding-bottom:0}.bslib-sidebar-layout>.sidebar .shiny-input-container{width:100%}.bslib-sidebar-layout[data-bslib-sidebar-open="always"]>.sidebar>.sidebar-content{padding-top:var(--_padding)}.bslib-sidebar-layout>.collapse-toggle{grid-row:1 / 2;grid-column:1 / 2;display:inline-flex;align-items:center;position:absolute;right:calc(var(--_icon-size));top:calc(var(--_icon-size, 1rem) / 2);border:none;border-radius:var(--_toggle-border-radius);height:var(--_icon-button-size, 2rem);width:var(--_icon-button-size, 2rem);display:flex;align-items:center;justify-content:center;padding:0;color:var(--_sidebar-fg);background-color:unset;transition:color var(--_transition-easing-x) var(--_transition-duration),top var(--_transition-easing-x) var(--_transition-duration),right var(--_transition-easing-x) var(--_transition-duration),left var(--_transition-easing-x) var(--_transition-duration)}.bslib-sidebar-layout>.collapse-toggle:hover{background-color:var(--_toggle-bg)}.bslib-sidebar-layout>.collapse-toggle>.collapse-icon{opacity:0.8;width:var(--_icon-size);height:var(--_icon-size);transform:rotateY(var(--_toggle-transform));transition:transform var(--_toggle-transition-easing) var(--_transition-duration)}.bslib-sidebar-layout>.collapse-toggle:hover>.collapse-icon{opacity:1}.bslib-sidebar-layout .sidebar-title{font-size:1.25rem;line-height:1.25;margin-top:0;margin-bottom:1rem;padding-bottom:1rem;border-bottom:var(--_border)}.bslib-sidebar-layout.sidebar-right{grid-template-columns:var(--_column-main) Min(calc(100% - var(--_padding-icon)), var(--_sidebar-width))}.bslib-sidebar-layout.sidebar-right>.main{grid-column:1 / 2;border-top-right-radius:0;border-bottom-right-radius:0;border-top-left-radius:inherit;border-bottom-left-radius:inherit}.bslib-sidebar-layout.sidebar-right>.sidebar{grid-column:2 / 3;border-right:none;border-left:var(--_vert-border);border-top-left-radius:0;border-bottom-left-radius:0}.bslib-sidebar-layout.sidebar-right>.collapse-toggle{grid-column:2 / 3;left:var(--_icon-size);right:unset;border:var(--bslib-collapse-toggle-border)}.bslib-sidebar-layout.sidebar-right>.collapse-toggle>.collapse-icon{transform:rotateY(var(--_toggle-right-transform))}.bslib-sidebar-layout.transitioning>.sidebar>.sidebar-content{display:none}.bslib-sidebar-layout.sidebar-collapsed{--_toggle-transform: 180deg;--_toggle-right-transform: 0deg;--_vert-border: none;grid-template-columns:0 minmax(0, 1fr)}.bslib-sidebar-layout.sidebar-collapsed.sidebar-right{grid-template-columns:minmax(0, 1fr) 0}.bslib-sidebar-layout.sidebar-collapsed:not(.transitioning)>.sidebar>*{display:none}.bslib-sidebar-layout.sidebar-collapsed>.main{border-radius:inherit;padding-left:var(--_padding-icon);padding-right:var(--_padding-icon)}.bslib-sidebar-layout.sidebar-collapsed>.collapse-toggle{color:var(--_main-fg);top:var(--_toggle-position-y);right:var(--_toggle-position-x)}.bslib-sidebar-layout.sidebar-collapsed.sidebar-right>.collapse-toggle{left:var(--_toggle-position-x);right:unset}@media (max-width: 575.98px){.bslib-sidebar-layout[data-bslib-sidebar-open="desktop"]{--bslib-sidebar-js-init-collapsed: true}.bslib-sidebar-layout>.sidebar,.bslib-sidebar-layout.sidebar-right>.sidebar{border:none}.bslib-sidebar-layout>.main,.bslib-sidebar-layout.sidebar-right>.main{grid-column:1 / 3}.bslib-sidebar-layout[data-bslib-sidebar-open="always"]{display:block !important}.bslib-sidebar-layout[data-bslib-sidebar-open="always"]>.sidebar{max-height:var(--_mobile-max-height);overflow-y:auto;border-top:var(--_vert-border)}.bslib-sidebar-layout:not([data-bslib-sidebar-open="always"]){grid-template-columns:100% 0}.bslib-sidebar-layout:not([data-bslib-sidebar-open="always"]):not(.sidebar-collapsed)>.sidebar,.bslib-sidebar-layout:not([data-bslib-sidebar-open="always"]).transitioning>.sidebar{z-index:1}.bslib-sidebar-layout:not([data-bslib-sidebar-open="always"]):not(.sidebar-collapsed)>.collapse-toggle,.bslib-sidebar-layout:not([data-bslib-sidebar-open="always"]).transitioning>.collapse-toggle{z-index:1}.bslib-sidebar-layout:not([data-bslib-sidebar-open="always"]):not(.sidebar-right)>.collapse-toggle{left:var(--_icon-size);right:unset}.bslib-sidebar-layout:not([data-bslib-sidebar-open="always"]).sidebar-right>.collapse-toggle{right:var(--_icon-size);left:unset}.bslib-sidebar-layout:not([data-bslib-sidebar-open="always"])>.sidebar{opacity:var(--_sidebar-mobile-opacity, 1);max-width:var(--_sidebar-mobile-max-width, 100%);box-shadow:var(--_sidebar-mobile-box-shadow)}.bslib-sidebar-layout:not([data-bslib-sidebar-open="always"]):not(.sidebar-right)>.sidebar{margin-right:auto}.bslib-sidebar-layout:not([data-bslib-sidebar-open="always"]).sidebar-right>.sidebar{margin-left:auto}.bslib-sidebar-layout:not([data-bslib-sidebar-open="always"]).sidebar-right{grid-template-columns:0 100%}.bslib-sidebar-layout:not([data-bslib-sidebar-open="always"]).sidebar-collapsed{grid-template-columns:0 100%}.bslib-sidebar-layout:not([data-bslib-sidebar-open="always"]).sidebar-collapsed.sidebar-right{grid-template-columns:100% 0}.bslib-sidebar-layout:not([data-bslib-sidebar-open="always"])>.main{padding-top:var(--_toggle-collective-height);padding-left:var(--_padding);padding-right:var(--_padding)}}.bslib-value-box{container-name:bslib-value-box;container-type:inline-size}.bslib-value-box.default{--bslib-value-box-bg-default: var(--bs-card-bg, #fff);--bslib-value-box-border-color-default: var(--bs-card-border-color, var(--bs-border-color-translucent));color:var(--bslib-value-box-color, var(--bs-body-color));background-color:var(--bslib-value-box-bg, var(--bslib-value-box-bg-default));border-color:var(--bslib-value-box-border-color, var(--bslib-value-box-border-color-default))}.bslib-value-box .value-box-grid{display:grid;grid-template-areas:"left right";align-items:center;overflow:hidden}.bslib-value-box .value-box-showcase{height:100%;max-height:var(---bslib-value-box-showcase-max-h, 100%)}.bslib-value-box .value-box-showcase,.bslib-value-box .value-box-showcase>.html-fill-item{width:100%}.bslib-value-box[data-full-screen="true"] .value-box-showcase{max-height:var(---bslib-value-box-showcase-max-h-fs, 100%)}@media screen and (min-width: 575.98px){@container bslib-value-box (max-width: 300px){.bslib-value-box:not(.showcase-bottom) .value-box-grid{grid-template-columns:1fr !important;grid-template-rows:auto auto;grid-template-areas:"top" "bottom"}.bslib-value-box:not(.showcase-bottom) .value-box-grid .value-box-showcase{grid-area:top !important}.bslib-value-box:not(.showcase-bottom) .value-box-grid .value-box-area{grid-area:bottom !important;justify-content:end}}}.bslib-value-box .value-box-area{justify-content:center;padding:1.5rem 1rem;font-size:.9rem;font-weight:500}.bslib-value-box .value-box-area *{margin-bottom:0;margin-top:0}.bslib-value-box .value-box-title{font-size:1rem;margin-top:0;margin-bottom:.5rem;font-weight:400;line-height:1.2}.bslib-value-box .value-box-title:empty::after{content:'\00a0 '}.bslib-value-box .value-box-value{font-size:calc(1.325rem + .9vw);margin-top:0;margin-bottom:.5rem;font-weight:400;line-height:1.2}@media (min-width: 1200px){.bslib-value-box .value-box-value{font-size:2rem}}.bslib-value-box .value-box-value:empty::after{content:'\00a0 '}.bslib-value-box .value-box-showcase{align-items:center;justify-content:center;margin-top:auto;margin-bottom:auto;padding:1rem}.bslib-value-box .value-box-showcase .bi,.bslib-value-box .value-box-showcase .fa,.bslib-value-box .value-box-showcase .fab,.bslib-value-box .value-box-showcase .fas,.bslib-value-box .value-box-showcase .far{opacity:.85;min-width:50px;max-width:125%}.bslib-value-box .value-box-showcase .bi,.bslib-value-box .value-box-showcase .fa,.bslib-value-box .value-box-showcase .fab,.bslib-value-box .value-box-showcase .fas,.bslib-value-box .value-box-showcase .far{font-size:4rem}.bslib-value-box.showcase-top-right .value-box-grid{grid-template-columns:1fr var(---bslib-value-box-showcase-w, 50%)}.bslib-value-box.showcase-top-right .value-box-grid .value-box-showcase{grid-area:right;margin-left:auto;align-self:start;align-items:end;padding-left:0;padding-bottom:0}.bslib-value-box.showcase-top-right .value-box-grid .value-box-area{grid-area:left;align-self:end}.bslib-value-box.showcase-top-right[data-full-screen="true"] .value-box-grid{grid-template-columns:auto var(---bslib-value-box-showcase-w-fs, 1fr)}.bslib-value-box.showcase-top-right[data-full-screen="true"] .value-box-grid>div{align-self:center}.bslib-value-box.showcase-top-right:not([data-full-screen="true"]) .value-box-showcase{margin-top:0}@container bslib-value-box (max-width: 300px){.bslib-value-box.showcase-top-right:not([data-full-screen="true"]) .value-box-grid .value-box-showcase{padding-left:1rem}}.bslib-value-box.showcase-left-center .value-box-grid{grid-template-columns:var(---bslib-value-box-showcase-w, 30%) auto}.bslib-value-box.showcase-left-center[data-full-screen="true"] .value-box-grid{grid-template-columns:var(---bslib-value-box-showcase-w-fs, 1fr) auto}.bslib-value-box.showcase-left-center:not([data-fill-screen="true"]) .value-box-grid .value-box-showcase{grid-area:left}.bslib-value-box.showcase-left-center:not([data-fill-screen="true"]) .value-box-grid .value-box-area{grid-area:right}.bslib-value-box.showcase-bottom .value-box-grid{grid-template-columns:1fr;grid-template-rows:1fr var(---bslib-value-box-showcase-h, auto);grid-template-areas:"top" "bottom";overflow:hidden}.bslib-value-box.showcase-bottom .value-box-grid .value-box-showcase{grid-area:bottom;padding:0;margin:0}.bslib-value-box.showcase-bottom .value-box-grid .value-box-area{grid-area:top}.bslib-value-box.showcase-bottom[data-full-screen="true"] .value-box-grid{grid-template-rows:1fr var(---bslib-value-box-showcase-h-fs, 2fr)}.bslib-value-box.showcase-bottom[data-full-screen="true"] .value-box-grid .value-box-showcase{padding:1rem}
diff --git a/shiny/www/shared/bslib/components/components.min.js b/shiny/www/shared/bslib/components/components.min.js
index 17b4c08b3..61a5c5589 100644
--- a/shiny/www/shared/bslib/components/components.min.js
+++ b/shiny/www/shared/bslib/components/components.min.js
@@ -1,4 +1,4 @@
-/*! bslib 0.6.1 | (c) 2012-2023 RStudio, PBC. | License: MIT + file LICENSE */
+/*! bslib 0.6.1.9000 | (c) 2012-2023 RStudio, PBC. | License: MIT + file LICENSE */
"use strict";(()=>{var f=(r,e)=>()=>(r&&(e=r(r=0)),e);var x=(r,e)=>()=>(e||r((e={exports:{}}).exports,e),e.exports);var h=(r,e,t)=>new Promise((n,s)=>{var i=o=>{try{d(t.next(o))}catch(p){s(p)}},c=o=>{try{d(t.throw(o))}catch(p){s(p)}},d=o=>o.done?n(o.value):Promise.resolve(o.value).then(i,c);d((t=t.apply(r,e)).next())});function L(r,e){window.Shiny&&Shiny.inputBindings.register(new r,"bslib."+e)}function E(r,e){return Object.prototype.hasOwnProperty.call(r,e)&&r[e]!==void 0}function w(r){let e=["a[href]","area[href]","button","details summary","input","iframe","select","textarea",'[contentEditable=""]','[contentEditable="true"]','[contentEditable="TRUE"]',"[tabindex]"],t=[':not([tabindex="-1"])',":not([disabled])"],n=e.map(i=>i+t.join("")),s=r.querySelectorAll(n.join(", "));return Array.from(s)}function g(...r){return h(this,null,function*(){if(!window.Shiny)throw new Error("This function must be called in a Shiny app.");return Shiny.renderContentAsync?yield Shiny.renderContentAsync.apply(null,r):yield Shiny.renderContent.apply(null,r)})}var b,v=f(()=>{"use strict";b=window.Shiny?Shiny.InputBinding:class{}});var M,H=f(()=>{"use strict";v();M=class extends b{find(e){return $(e).find(".accordion.bslib-accordion-input")}getValue(e){let n=this._getItemInfo(e).filter(s=>s.isOpen()).map(s=>s.value);return n.length===0?null:n}subscribe(e,t){$(e).on("shown.bs.collapse.accordionInputBinding hidden.bs.collapse.accordionInputBinding",function(n){t(!0)})}unsubscribe(e){$(e).off(".accordionInputBinding")}receiveMessage(e,t){return h(this,null,function*(){let n=t.method;if(n==="set")this._setItems(e,t);else if(n==="open")this._openItems(e,t);else if(n==="close")this._closeItems(e,t);else if(n==="remove")this._removeItem(e,t);else if(n==="insert")yield this._insertItem(e,t);else if(n==="update")yield this._updateItem(e,t);else throw new Error(`Method not yet implemented: ${n}`)})}_setItems(e,t){let n=this._getItemInfo(e),s=this._getValues(e,n,t.values);n.forEach(i=>{s.indexOf(i.value)>-1?i.show():i.hide()})}_openItems(e,t){let n=this._getItemInfo(e),s=this._getValues(e,n,t.values);n.forEach(i=>{s.indexOf(i.value)>-1&&i.show()})}_closeItems(e,t){let n=this._getItemInfo(e),s=this._getValues(e,n,t.values);n.forEach(i=>{s.indexOf(i.value)>-1&&i.hide()})}_insertItem(e,t){return h(this,null,function*(){let n=this._findItem(e,t.target);n||(n=t.position==="before"?e.firstElementChild:e.lastElementChild);let s=t.panel;if(n?yield g(n,s,t.position==="before"?"beforeBegin":"afterEnd"):yield g(e,s),this._isAutoClosing(e)){let i=$(s.html).attr("data-value");$(e).find(`[data-value="${i}"] .accordion-collapse`).attr("data-bs-parent","#"+e.id)}})}_removeItem(e,t){let n=this._getItemInfo(e).filter(i=>t.target.indexOf(i.value)>-1),s=Shiny==null?void 0:Shiny.unbindAll;n.forEach(i=>{s&&s(i.item),i.item.remove()})}_updateItem(e,t){return h(this,null,function*(){let n=this._findItem(e,t.target);if(!n)throw new Error(`Unable to find an accordion_panel() with a value of ${t.target}`);if(E(t,"value")&&(n.dataset.value=t.value),E(t,"body")){let i=n.querySelector(".accordion-body");yield g(i,t.body)}let s=n.querySelector(".accordion-header");if(E(t,"title")){let i=s.querySelector(".accordion-title");yield g(i,t.title)}if(E(t,"icon")){let i=s.querySelector(".accordion-button > .accordion-icon");yield g(i,t.icon)}})}_getItemInfo(e){return Array.from(e.querySelectorAll(":scope > .accordion-item")).map(n=>this._getSingleItemInfo(n))}_getSingleItemInfo(e){let t=e.querySelector(".accordion-collapse"),n=()=>$(t).hasClass("show");return{item:e,value:e.dataset.value,isOpen:n,show:()=>{n()||$(t).collapse("show")},hide:()=>{n()&&$(t).collapse("hide")}}}_getValues(e,t,n){let s=n!==!0?n:t.map(c=>c.value);return this._isAutoClosing(e)&&(s=s.slice(s.length-1,s.length)),s}_findItem(e,t){return e.querySelector(`[data-value="${t}"]`)}_isAutoClosing(e){return e.classList.contains("autoclose")}};L(M,"accordion")});var y,T=f(()=>{"use strict";y=class{constructor(){this.resizeObserverEntries=[],this.resizeObserver=new ResizeObserver(e=>{let t=new Event("resize");if(window.dispatchEvent(t),!window.Shiny)return;let n=[];for(let s of e)s.target instanceof HTMLElement&&s.target.querySelector(".shiny-bound-output")&&s.target.querySelectorAll(".shiny-bound-output").forEach(i=>{if(n.includes(i))return;let{binding:c,onResize:d}=$(i).data("shinyOutputBinding");if(!c||!c.resize)return;let o=i.shinyResizeObserver;if(o&&o!==this||(o||(i.shinyResizeObserver=this),d(i),n.push(i),!i.classList.contains("shiny-plot-output")))return;let p=i.querySelector('img:not([width="100%"])');p&&p.setAttribute("width","100%")})})}observe(e){this.resizeObserver.observe(e),this.resizeObserverEntries.push(e)}unobserve(e){let t=this.resizeObserverEntries.indexOf(e);t<0||(this.resizeObserver.unobserve(e),this.resizeObserverEntries.splice(t,1))}flush(){this.resizeObserverEntries.forEach(e=>{document.body.contains(e)||this.unobserve(e)})}}});var a,m,I=f(()=>{"use strict";v();T();a=class{constructor(e){var t;e.removeAttribute(a.attr.ATTR_INIT),(t=e.querySelector(`script[${a.attr.ATTR_INIT}]`))==null||t.remove(),this.card=e,a.instanceMap.set(e,this),a.shinyResizeObserver.observe(this.card),this._addEventListeners(),this.overlay=this._createOverlay(),this._exitFullScreenOnEscape=this._exitFullScreenOnEscape.bind(this),this._trapFocusExit=this._trapFocusExit.bind(this)}enterFullScreen(e){var t;e&&e.preventDefault(),document.addEventListener("keydown",this._exitFullScreenOnEscape,!1),document.addEventListener("keydown",this._trapFocusExit,!0),this.card.setAttribute(a.attr.ATTR_FULL_SCREEN,"true"),document.body.classList.add(a.attr.CLASS_HAS_FULL_SCREEN),this.card.insertAdjacentElement("beforebegin",this.overlay.container),(!this.card.contains(document.activeElement)||(t=document.activeElement)!=null&&t.classList.contains(a.attr.CLASS_FULL_SCREEN_ENTER))&&(this.card.setAttribute("tabindex","-1"),this.card.focus())}exitFullScreen(){document.removeEventListener("keydown",this._exitFullScreenOnEscape,!1),document.removeEventListener("keydown",this._trapFocusExit,!0),this.overlay.container.remove(),this.card.setAttribute(a.attr.ATTR_FULL_SCREEN,"false"),this.card.removeAttribute("tabindex"),document.body.classList.remove(a.attr.CLASS_HAS_FULL_SCREEN)}_addEventListeners(){let e=this.card.querySelector(`:scope > * > .${a.attr.CLASS_FULL_SCREEN_ENTER}`);e&&e.addEventListener("click",t=>this.enterFullScreen(t))}_exitFullScreenOnEscape(e){if(!(e.target instanceof HTMLElement))return;let t=["select[open]","input[aria-expanded='true']"];e.target.matches(t.join(", "))||e.key==="Escape"&&this.exitFullScreen()}_trapFocusExit(e){if(!(e instanceof KeyboardEvent)||e.key!=="Tab")return;let t=e.target===this.card,n=e.target===this.overlay.anchor,s=this.card.contains(e.target),i=()=>{e.preventDefault(),e.stopImmediatePropagation()};if(!(s||t||n)){i(),this.card.focus();return}let c=w(this.card).filter(S=>!S.classList.contains(a.attr.CLASS_FULL_SCREEN_ENTER));if(!(c.length>0)){i(),this.overlay.anchor.focus();return}if(t)return;let o=c[c.length-1],p=e.target===o;if(n&&e.shiftKey){i(),o.focus();return}if(p&&!e.shiftKey){i(),this.overlay.anchor.focus();return}}_createOverlay(){let e=document.createElement("div");e.id=a.attr.ID_FULL_SCREEN_OVERLAY,e.onclick=this.exitFullScreen.bind(this);let t=this._createOverlayCloseAnchor();return e.appendChild(t),{container:e,anchor:t}}_createOverlayCloseAnchor(){let e=document.createElement("a");return e.classList.add(a.attr.CLASS_FULL_SCREEN_EXIT),e.tabIndex=0,e.onclick=()=>this.exitFullScreen(),e.onkeydown=t=>{(t.key==="Enter"||t.key===" ")&&this.exitFullScreen()},e.innerHTML=this._overlayCloseHtml(),e}_overlayCloseHtml(){return"Close "}static getInstance(e){return a.instanceMap.get(e)}static initializeAllCards(e=!0){if(document.readyState==="loading"){a.onReadyScheduled||(a.onReadyScheduled=!0,document.addEventListener("DOMContentLoaded",()=>{a.initializeAllCards(!1)}));return}e&&a.shinyResizeObserver.flush();let t=`.${a.attr.CLASS_CARD}[${a.attr.ATTR_INIT}]`;if(!document.querySelector(t))return;document.querySelectorAll(t).forEach(s=>new a(s))}},m=a;m.attr={ATTR_INIT:"data-bslib-card-init",CLASS_CARD:"bslib-card",ATTR_FULL_SCREEN:"data-full-screen",CLASS_HAS_FULL_SCREEN:"bslib-has-full-screen",CLASS_FULL_SCREEN_ENTER:"bslib-full-screen-enter",CLASS_FULL_SCREEN_EXIT:"bslib-full-screen-exit",ID_FULL_SCREEN_OVERLAY:"bslib-full-screen-overlay"},m.shinyResizeObserver=new y,m.instanceMap=new WeakMap,m.onReadyScheduled=!1;window.bslib=window.bslib||{};window.bslib.Card=m});var l,u,C,A=f(()=>{"use strict";v();T();l=class{constructor(e){var s;l.instanceMap.set(e,this),this.layout={container:e,main:e.querySelector(":scope > .main"),sidebar:e.querySelector(":scope > .sidebar"),toggle:e.querySelector(":scope > .collapse-toggle")};let t=this.layout.sidebar.querySelector(":scope > .sidebar-content > .accordion");t&&((s=t==null?void 0:t.parentElement)==null||s.classList.add("has-accordion"),t.classList.add("accordion-flush")),this.layout.toggle&&(this._initEventListeners(),this._initSidebarCounters(),this._initDesktop()),l.shinyResizeObserver.observe(this.layout.main),e.removeAttribute("data-bslib-sidebar-init");let n=e.querySelector(":scope > script[data-bslib-sidebar-init]");n&&e.removeChild(n)}get isClosed(){return this.layout.container.classList.contains(l.classes.COLLAPSE)}static getInstance(e){return l.instanceMap.get(e)}static initCollapsibleAll(e=!0){if(document.readyState==="loading"){l.onReadyScheduled||(l.onReadyScheduled=!0,document.addEventListener("DOMContentLoaded",()=>{l.initCollapsibleAll(!1)}));return}let t=`.${l.classes.LAYOUT}[data-bslib-sidebar-init]`;if(!document.querySelector(t))return;e&&l.shinyResizeObserver.flush(),document.querySelectorAll(t).forEach(s=>new l(s))}_initEventListeners(){var t;let{toggle:e}=this.layout;e.addEventListener("click",n=>{n.preventDefault(),this.toggle("toggle")}),(t=e.querySelector(".collapse-icon"))==null||t.addEventListener("transitionend",()=>this._finalizeState())}_initSidebarCounters(){let{container:e}=this.layout,t=`.${l.classes.LAYOUT}> .main > .${l.classes.LAYOUT}:not([data-bslib-sidebar-open="always"])`;if(!(e.querySelector(t)===null))return;function s(o){return o=o?o.parentElement:null,o&&o.classList.contains("main")&&(o=o.parentElement),o&&o.classList.contains(l.classes.LAYOUT)?o:null}let i=[e],c=s(e);for(;c;)i.unshift(c),c=s(c);let d={left:0,right:0};i.forEach(function(o){let S=o.classList.contains("sidebar-right")?d.right++:d.left++;o.style.setProperty("--_js-toggle-count-this-side",S.toString()),o.style.setProperty("--_js-toggle-count-max-side",Math.max(d.right,d.left).toString())})}_initDesktop(){var s;let{container:e}=this.layout;if(((s=e.dataset.bslibSidebarOpen)==null?void 0:s.trim())!=="desktop")return;let n=window.getComputedStyle(e).getPropertyValue("--bslib-sidebar-js-init-collapsed").trim()==="true"?"close":"open";this.toggle(n,!0)}toggle(e,t=!1){typeof e=="undefined"&&(e="toggle");let{container:n,sidebar:s}=this.layout,i=this.isClosed;if(["open","close","toggle"].indexOf(e)===-1)throw new Error(`Unknown method ${e}`);if(e==="toggle"&&(e=i?"open":"close"),i&&e==="close"||!i&&e==="open"){t&&this._finalizeState();return}e==="open"&&(s.hidden=!1),n.classList.toggle(l.classes.TRANSITIONING,!t),n.classList.toggle(l.classes.COLLAPSE),t&&this._finalizeState()}_finalizeState(){let{container:e,sidebar:t,toggle:n}=this.layout;e.classList.remove(l.classes.TRANSITIONING),t.hidden=this.isClosed,n.setAttribute("aria-expanded",this.isClosed?"false":"true");let s=new CustomEvent("bslib.sidebar",{bubbles:!0,detail:{open:!this.isClosed}});t.dispatchEvent(s),$(t).trigger("toggleCollapse.sidebarInputBinding"),$(t).trigger(this.isClosed?"hidden":"shown")}},u=l;u.shinyResizeObserver=new y,u.classes={LAYOUT:"bslib-sidebar-layout",COLLAPSE:"sidebar-collapsed",TRANSITIONING:"transitioning"},u.onReadyScheduled=!1,u.instanceMap=new WeakMap;C=class extends b{find(e){return $(e).find(`.${u.classes.LAYOUT} > .bslib-sidebar-input`)}getValue(e){let t=u.getInstance(e.parentElement);return t?!t.isClosed:!1}setValue(e,t){let n=t?"open":"close";this.receiveMessage(e,{method:n})}subscribe(e,t){$(e).on("toggleCollapse.sidebarInputBinding",function(n){t(!0)})}unsubscribe(e){$(e).off(".sidebarInputBinding")}receiveMessage(e,t){let n=u.getInstance(e.parentElement);n&&n.toggle(t.method)}};L(C,"sidebar");window.bslib=window.bslib||{};window.bslib.Sidebar=u});function O(r){if(window.Shiny)for(let[e,t]of Object.entries(r))Shiny.addCustomMessageHandler(e,t)}var _=f(()=>{"use strict"});var N=x(F=>{H();I();A();v();_();var z={"bslib.toggle-input-binary":r=>h(F,null,function*(){let e=document.getElementById(r.id);e||console.warn("[bslib.toggle-input-binary] No element found",r);let t=$(e).data("shiny-input-binding");if(!(t instanceof b)){console.warn("[bslib.toggle-input-binary] No input binding found",r);return}let n=r.value;typeof n=="undefined"&&(n=!t.getValue(e)),yield t.receiveMessage(e,{value:n})})};window.Shiny&&O(z);function R(){let r=document.createElement("div");r.innerHTML=`
- `}onClick(e){e.stopPropagation(),this.mode=this.mode==="light"?"dark":"light"}updated(e){e.has("mode")&&(this.reflectPreference(),this.onChangeCallback(!0))}reflectPreference(){document.documentElement.setAttribute(this.attribute,this.mode),window.dispatchEvent(new Event("resize"))}};E.isShinyInput=!0,E.tagName="bslib-input-dark-mode",E.shinyCustomMessageHandlers={"bslib.toggle-dark-mode":({method:e,value:i})=>{e==="toggle"&&((typeof i=="undefined"||i===null)&&(i=(document.documentElement.dataset.bsTheme||"light")==="light"?"dark":"light"),document.documentElement.dataset.bsTheme=i)}},E.styles=[A`
+ `}onClick(e){e.stopPropagation(),this.mode=this.mode==="light"?"dark":"light"}updated(e){e.has("mode")&&(this.reflectPreference(),this.onChangeCallback(!0))}reflectPreference(){document.documentElement.setAttribute(this.attribute,this.mode),window.dispatchEvent(new Event("resize"))}};_.isShinyInput=!0,_.tagName="bslib-input-dark-mode",_.shinyCustomMessageHandlers={"bslib.toggle-dark-mode":({method:e,value:i})=>{e==="toggle"&&((typeof i=="undefined"||i===null)&&(i=(document.documentElement.dataset.bsTheme||"light")==="light"?"dark":"light"),document.documentElement.dataset.bsTheme=i)}},_.styles=[S`
:host {
/* open-props.style via shinycomponent */
--text-1: var(--text-1-light, var(--gray-8, #343a40));
@@ -67,7 +67,7 @@
the button up or down to keep it looking right inline */
--vertical-correction: calc((var(--size) - 1em) / 2);
}
- `,A`
+ `,S`
.sun-and-moon > :is(.moon, .sun, .sun-beams) {
transform-origin: center center;
}
@@ -113,7 +113,7 @@
cx: 15;
}
}
- `,A`
+ `,S`
.sun-and-moon > .sun {
transition: transform var(--speed-fast) var(--ease-in-out-2)
var(--speed-fast),
@@ -156,7 +156,7 @@
opacity var(--speed-fast) var(--ease-out-1);
transition-delay: 0s;
}
- `,A`
+ `,S`
:host {
display: inline-block;
@@ -206,7 +206,7 @@
svg circle {
vector-effect: non-scaling-stroke;
}
- `],C([g({type:String,reflect:!0})],E.prototype,"mode",2);function qe(n,{type:t=null}={}){if(!window.Shiny)return;class e extends Shiny.InputBinding{constructor(){super()}find(s){return $(s).find(n)}getValue(s){return"getValue"in s?s.getValue():s.value}getType(s){return t}subscribe(s,r){s.onChangeCallback=r}unsubscribe(s){s.onChangeCallback=r=>{}}receiveMessage(s,r){s.receiveMessage(s,r)}}Shiny.inputBindings.register(new e,`${n}-Binding`)}function je(n){if(window.Shiny)for(let[t,e]of Object.entries(n))Shiny.addCustomMessageHandler(t,e)}[b,y,E].forEach(n=>{customElements.define(n.tagName,n),window.Shiny&&(n.isShinyInput&&qe(n.tagName),"shinyCustomMessageHandlers"in n&&je(n.shinyCustomMessageHandlers))});})();
+ `],A([g({type:String,reflect:!0})],_.prototype,"mode",2);function Ge(n,{type:t=null}={}){if(!window.Shiny)return;class e extends Shiny.InputBinding{constructor(){super()}find(s){return $(s).find(n)}getValue(s){return"getValue"in s?s.getValue():s.value}getType(s){return t}subscribe(s,r){s.onChangeCallback=r}unsubscribe(s){s.onChangeCallback=r=>{}}receiveMessage(s,r){s.receiveMessage(s,r)}}Shiny.inputBindings.register(new e,`${n}-Binding`)}function Je(n){if(window.Shiny)for(let[t,e]of Object.entries(n))Shiny.addCustomMessageHandler(t,e)}var Ae=class extends HTMLElement{constructor(){super(...arguments);this._colUnits=12}static defaultColWidths(){return new Map(Object.entries({sm:null,lg:null}))}get colUnits(){return this._colUnits}set colUnits(e){this.style.setProperty("--bs-columns",`${e}`),this._colUnits=e}setFallbackItemSpan(e){this.style.setProperty("--_item-column-span",`${e}`)}connectedCallback(){this.classList.add("grid"),this.colWidths=this._readColWidths(),setTimeout(()=>{this._applyColWidthsSpec(),this.removeAttribute("hidden-until-init")})}_readColWidths(){let e=ut(this,"col-widths-");if(!e.size)return Ae.defaultColWidths();let i=new Map,s=["sm","md","lg","xl","xxl"],r=o=>["null","true",""].includes(o)?null:Array.from(o.split(",").map(Number));return s.forEach(o=>{let c=`col-widths-${o}`,a=e.get(c);typeof a!="undefined"&&(i.set(o,r(a)),e.delete(c))}),e.forEach((o,c)=>{i.set(c.replace("col-widths-",""),r(o))}),i}_resolveColWidthsSpec(){let e=Array.from(this.colWidths.values()).map(we),i=l=>l.every(h=>h===!0);if(!(l=>l.some(h=>h===!0))(e))return Qe(this.colWidths);let r=new Map,o=i(e),c=o?null:12,a=this.children.length;for(let[l,h]of this.colWidths)if(h===null){let p=["sm","md"].includes(l),d=ct(a,p,c);o&&(this.colUnits=d.units,d.units!==12&&this.setFallbackItemSpan(d.units>a?a:1)),r.set(l,d.widths)}else r.set(l,h);return Qe(r)}_applyColWidthsSpec(){if(this.colWidthsSpec||(this.colWidthsSpec=this._resolveColWidthsSpec()),!this.colWidthsSpec)throw new Error("Column widths must be specified.");let e=this.children;pt(this.colWidthsSpec,e,this.colUnits)}},B=Ae;B.tagName="bslib-layout-columns",B.isShinyInput=!1;function ct(n,t=!1,e=null){let i={units:e,widths:[0]};if(we(i.units)){if(i.units=n>7?12:n>3?n*2:n,n<4)return i.widths=[1],i;if(n<=7)return i.widths=[t?n:2],i}if(i.units===12){if(n<=3)return i.widths=[[12,6,4][n-1]],i;if(n===5||n===7)return i.widths=[t?4:3],i;if(n===6)return i.widths=[t?4:2],i}let s=t?[6,4,3]:[2,3,4],r=s.map(l=>l*n),a=r.map(l=>Math.ceil(l/12)).map(l=>l*12).map((l,h)=>l-r[h]);return i.widths=[s[a.indexOf(Math.min(...a))]],i}function Qe(n){if(!(n instanceof Map))throw new Error("Column widths must be specified as a Map or an object.");let t=new Map;for(let[e,i]of n){if(i.some(d=>d===0))throw new Error("Column values must be greater than 0 to indicate width, or negative to indicate a column offset.");if(i.length>1&&i.some(d=>isNaN(d)))throw new Error("Cannot mix widths and missing values. All column widths must be specified, or choose auto widths using a single `null` value.");if(i.every(d=>we(d))||i.every(d=>d>0)){t.set(e,{width:i,before:Array(i.length).fill(0),after:Array(i.length).fill(0)});continue}if(!i.some(d=>d>0))throw new Error("Column values must include at least one positive integer width.");let s=i.map((d,m)=>d>0?m:-1).filter(d=>d!==-1),r=Math.max(...s),o=s.length,c=s.map(d=>i[d]),a=Array(o).fill(0),l=Array(o).fill(0),h=0,p=0;for(;h0?p++:h>r?l[l.length-1]+=Math.abs(i[h]):a[p]+=Math.abs(i[h]),h++;t.set(e,{width:c,before:a,after:l})}return t}function pt(n,t,e=12){let i=t.length;function s(r,o){t[r].classList.add(o)}for(let[r,o]of n){if(o.width.length>i){let d=`Truncating number of widths at '${r}' breakpoint to match number of elements.`;console.warn(d,{widths:o.width.length,elements:i})}let c=Ce(o.width,i),a=Ce(o.before,i),l=Ce(o.after,i),h=0,p=(d,m=!1)=>{h=Math.abs(h);let v=h+d;v==e&&(v=0),v>e&&(v=m?-1*(v%e):d),h=v};for(let d=0;d0?l[d-1]:0),C=Math.min(c[d],e),Se=e-h;v>0&&(p(v,!0),h<0&&(h=Math.abs(h),c[d]>e-h&&(h=0),Se=0),m=Se>=c[d]||h>0),h>0&&h+c[d]>e&&(m=!0,h=0),m&&s(d,r==="xs"?`g-start-${h+1}`:`g-start-${r}-${h+1}`),s(d,r==="xs"?`g-col-${C}`:`g-col-${r}-${C}`),p(C,!1)}}}function ut(n,t){let e=new Map,i=n.getAttributeNames().filter(s=>s.startsWith(t));for(let s of i)e.set(s,n.getAttribute(s));return e}function Ce(n,t){let e=Array(t).fill(0);for(let i=0;i{customElements.define(n.tagName,n),window.Shiny&&(n.isShinyInput&&Ge(n.tagName),"shinyCustomMessageHandlers"in n&&Je(n.shinyCustomMessageHandlers))});})();
/*! Bundled license information:
@lit/reactive-element/decorators/custom-element.js:
diff --git a/shiny/www/shared/bslib/components/web-components.min.js.map b/shiny/www/shared/bslib/components/web-components.min.js.map
index 71db59d16..6563deccd 100644
--- a/shiny/www/shared/bslib/components/web-components.min.js.map
+++ b/shiny/www/shared/bslib/components/web-components.min.js.map
@@ -1,7 +1,7 @@
{
"version": 3,
- "sources": ["../../../node_modules/@lit/reactive-element/src/decorators/property.ts", "../../../node_modules/@lit/reactive-element/src/decorators/query-assigned-elements.ts", "../../../node_modules/@lit/reactive-element/src/css-tag.ts", "../../../node_modules/@lit/reactive-element/src/reactive-element.ts", "../../../node_modules/lit-html/src/lit-html.ts", "../../../node_modules/lit-element/src/lit-element.ts", "../../../srcts/src/components/webcomponents/_bslibElement.ts", "../../../srcts/src/components/_utilsTooltip.ts", "../../../srcts/src/components/_shinyResizeObserver.ts", "../../../srcts/src/components/webcomponents/tooltip.ts", "../../../srcts/src/components/webcomponents/popover.ts", "../../../srcts/src/components/webcomponents/inputDarkMode.ts", "../../../srcts/src/components/webcomponents/_makeInputBinding.ts", "../../../srcts/src/components/_shinyAddCustomMessageHandlers.ts", "../../../srcts/src/components/webcomponents/index.ts"],
- "sourcesContent": ["/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\n\n/*\n * IMPORTANT: For compatibility with tsickle and the Closure JS compiler, all\n * property decorators (but not class decorators) in this file that have\n * an @ExportDecoratedItems annotation must be defined as a regular function,\n * not an arrow function.\n */\nimport {PropertyDeclaration, ReactiveElement} from '../reactive-element.js';\nimport {ClassElement} from './base.js';\n\nconst standardProperty = (\n options: PropertyDeclaration,\n element: ClassElement\n) => {\n // When decorating an accessor, pass it through and add property metadata.\n // Note, the `hasOwnProperty` check in `createProperty` ensures we don't\n // stomp over the user's accessor.\n if (\n element.kind === 'method' &&\n element.descriptor &&\n !('value' in element.descriptor)\n ) {\n return {\n ...element,\n finisher(clazz: typeof ReactiveElement) {\n clazz.createProperty(element.key, options);\n },\n };\n } else {\n // createProperty() takes care of defining the property, but we still\n // must return some kind of descriptor, so return a descriptor for an\n // unused prototype field. The finisher calls createProperty().\n return {\n kind: 'field',\n key: Symbol(),\n placement: 'own',\n descriptor: {},\n // store the original key so subsequent decorators have access to it.\n originalKey: element.key,\n // When @babel/plugin-proposal-decorators implements initializers,\n // do this instead of the initializer below. See:\n // https://github.com/babel/babel/issues/9260 extras: [\n // {\n // kind: 'initializer',\n // placement: 'own',\n // initializer: descriptor.initializer,\n // }\n // ],\n initializer(this: {[key: string]: unknown}) {\n if (typeof element.initializer === 'function') {\n this[element.key as string] = element.initializer.call(this);\n }\n },\n finisher(clazz: typeof ReactiveElement) {\n clazz.createProperty(element.key, options);\n },\n };\n }\n};\n\nconst legacyProperty = (\n options: PropertyDeclaration,\n proto: Object,\n name: PropertyKey\n) => {\n (proto.constructor as typeof ReactiveElement).createProperty(name, options);\n};\n\n/**\n * A property decorator which creates a reactive property that reflects a\n * corresponding attribute value. When a decorated property is set\n * the element will update and render. A {@linkcode PropertyDeclaration} may\n * optionally be supplied to configure property features.\n *\n * This decorator should only be used for public fields. As public fields,\n * properties should be considered as primarily settable by element users,\n * either via attribute or the property itself.\n *\n * Generally, properties that are changed by the element should be private or\n * protected fields and should use the {@linkcode state} decorator.\n *\n * However, sometimes element code does need to set a public property. This\n * should typically only be done in response to user interaction, and an event\n * should be fired informing the user; for example, a checkbox sets its\n * `checked` property when clicked and fires a `changed` event. Mutating public\n * properties should typically not be done for non-primitive (object or array)\n * properties. In other cases when an element needs to manage state, a private\n * property decorated via the {@linkcode state} decorator should be used. When\n * needed, state properties can be initialized via public properties to\n * facilitate complex interactions.\n *\n * ```ts\n * class MyElement {\n * @property({ type: Boolean })\n * clicked = false;\n * }\n * ```\n * @category Decorator\n * @ExportDecoratedItems\n */\nexport function property(options?: PropertyDeclaration) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return (protoOrDescriptor: Object | ClassElement, name?: PropertyKey): any =>\n name !== undefined\n ? legacyProperty(options!, protoOrDescriptor as Object, name)\n : standardProperty(options!, protoOrDescriptor as ClassElement);\n}\n", "/**\n * @license\n * Copyright 2021 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\n\n/*\n * IMPORTANT: For compatibility with tsickle and the Closure JS compiler, all\n * property decorators (but not class decorators) in this file that have\n * an @ExportDecoratedItems annotation must be defined as a regular function,\n * not an arrow function.\n */\n\nimport {decorateProperty} from './base.js';\n\nimport type {ReactiveElement} from '../reactive-element.js';\nimport type {QueryAssignedNodesOptions} from './query-assigned-nodes.js';\n\nconst NODE_MODE = false;\nconst global = NODE_MODE ? globalThis : window;\n\n/**\n * A tiny module scoped polyfill for HTMLSlotElement.assignedElements.\n */\nconst slotAssignedElements =\n global.HTMLSlotElement?.prototype.assignedElements != null\n ? (slot: HTMLSlotElement, opts?: AssignedNodesOptions) =>\n slot.assignedElements(opts)\n : (slot: HTMLSlotElement, opts?: AssignedNodesOptions) =>\n slot\n .assignedNodes(opts)\n .filter(\n (node): node is Element => node.nodeType === Node.ELEMENT_NODE\n );\n\n/**\n * Options for the {@linkcode queryAssignedElements} decorator. Extends the\n * options that can be passed into\n * [HTMLSlotElement.assignedElements](https://developer.mozilla.org/en-US/docs/Web/API/HTMLSlotElement/assignedElements).\n */\nexport interface QueryAssignedElementsOptions\n extends QueryAssignedNodesOptions {\n /**\n * CSS selector used to filter the elements returned. For example, a selector\n * of `\".item\"` will only include elements with the `item` class.\n */\n selector?: string;\n}\n\n/**\n * A property decorator that converts a class property into a getter that\n * returns the `assignedElements` of the given `slot`. Provides a declarative\n * way to use\n * [`HTMLSlotElement.assignedElements`](https://developer.mozilla.org/en-US/docs/Web/API/HTMLSlotElement/assignedElements).\n *\n * Can be passed an optional {@linkcode QueryAssignedElementsOptions} object.\n *\n * Example usage:\n * ```ts\n * class MyElement {\n * @queryAssignedElements({ slot: 'list' })\n * listItems!: Array;\n * @queryAssignedElements()\n * unnamedSlotEls!: Array;\n *\n * render() {\n * return html`\n * \n * \n * `;\n * }\n * }\n * ```\n *\n * Note, the type of this property should be annotated as `Array`.\n *\n * @category Decorator\n */\nexport function queryAssignedElements(options?: QueryAssignedElementsOptions) {\n const {slot, selector} = options ?? {};\n return decorateProperty({\n descriptor: (_name: PropertyKey) => ({\n get(this: ReactiveElement) {\n const slotSelector = `slot${slot ? `[name=${slot}]` : ':not([name])'}`;\n const slotEl =\n this.renderRoot?.querySelector(slotSelector);\n const elements =\n slotEl != null ? slotAssignedElements(slotEl, options) : [];\n if (selector) {\n return elements.filter((node) => node.matches(selector));\n }\n return elements;\n },\n enumerable: true,\n configurable: true,\n }),\n });\n}\n", "/**\n * @license\n * Copyright 2019 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\n\nconst NODE_MODE = false;\nconst global = NODE_MODE ? globalThis : window;\n\n/**\n * Whether the current browser supports `adoptedStyleSheets`.\n */\nexport const supportsAdoptingStyleSheets: boolean =\n global.ShadowRoot &&\n (global.ShadyCSS === undefined || global.ShadyCSS.nativeShadow) &&\n 'adoptedStyleSheets' in Document.prototype &&\n 'replace' in CSSStyleSheet.prototype;\n\n/**\n * A CSSResult or native CSSStyleSheet.\n *\n * In browsers that support constructible CSS style sheets, CSSStyleSheet\n * object can be used for styling along side CSSResult from the `css`\n * template tag.\n */\nexport type CSSResultOrNative = CSSResult | CSSStyleSheet;\n\nexport type CSSResultArray = Array;\n\n/**\n * A single CSSResult, CSSStyleSheet, or an array or nested arrays of those.\n */\nexport type CSSResultGroup = CSSResultOrNative | CSSResultArray;\n\nconst constructionToken = Symbol();\n\nconst cssTagCache = new WeakMap();\n\n/**\n * A container for a string of CSS text, that may be used to create a CSSStyleSheet.\n *\n * CSSResult is the return value of `css`-tagged template literals and\n * `unsafeCSS()`. In order to ensure that CSSResults are only created via the\n * `css` tag and `unsafeCSS()`, CSSResult cannot be constructed directly.\n */\nexport class CSSResult {\n // This property needs to remain unminified.\n ['_$cssResult$'] = true;\n readonly cssText: string;\n private _styleSheet?: CSSStyleSheet;\n private _strings: TemplateStringsArray | undefined;\n\n private constructor(\n cssText: string,\n strings: TemplateStringsArray | undefined,\n safeToken: symbol\n ) {\n if (safeToken !== constructionToken) {\n throw new Error(\n 'CSSResult is not constructable. Use `unsafeCSS` or `css` instead.'\n );\n }\n this.cssText = cssText;\n this._strings = strings;\n }\n\n // This is a getter so that it's lazy. In practice, this means stylesheets\n // are not created until the first element instance is made.\n get styleSheet(): CSSStyleSheet | undefined {\n // If `supportsAdoptingStyleSheets` is true then we assume CSSStyleSheet is\n // constructable.\n let styleSheet = this._styleSheet;\n const strings = this._strings;\n if (supportsAdoptingStyleSheets && styleSheet === undefined) {\n const cacheable = strings !== undefined && strings.length === 1;\n if (cacheable) {\n styleSheet = cssTagCache.get(strings);\n }\n if (styleSheet === undefined) {\n (this._styleSheet = styleSheet = new CSSStyleSheet()).replaceSync(\n this.cssText\n );\n if (cacheable) {\n cssTagCache.set(strings, styleSheet);\n }\n }\n }\n return styleSheet;\n }\n\n toString(): string {\n return this.cssText;\n }\n}\n\ntype ConstructableCSSResult = CSSResult & {\n new (\n cssText: string,\n strings: TemplateStringsArray | undefined,\n safeToken: symbol\n ): CSSResult;\n};\n\nconst textFromCSSResult = (value: CSSResultGroup | number) => {\n // This property needs to remain unminified.\n if ((value as CSSResult)['_$cssResult$'] === true) {\n return (value as CSSResult).cssText;\n } else if (typeof value === 'number') {\n return value;\n } else {\n throw new Error(\n `Value passed to 'css' function must be a 'css' function result: ` +\n `${value}. Use 'unsafeCSS' to pass non-literal values, but take care ` +\n `to ensure page security.`\n );\n }\n};\n\n/**\n * Wrap a value for interpolation in a {@linkcode css} tagged template literal.\n *\n * This is unsafe because untrusted CSS text can be used to phone home\n * or exfiltrate data to an attacker controlled site. Take care to only use\n * this with trusted input.\n */\nexport const unsafeCSS = (value: unknown) =>\n new (CSSResult as ConstructableCSSResult)(\n typeof value === 'string' ? value : String(value),\n undefined,\n constructionToken\n );\n\n/**\n * A template literal tag which can be used with LitElement's\n * {@linkcode LitElement.styles} property to set element styles.\n *\n * For security reasons, only literal string values and number may be used in\n * embedded expressions. To incorporate non-literal values {@linkcode unsafeCSS}\n * may be used inside an expression.\n */\nexport const css = (\n strings: TemplateStringsArray,\n ...values: (CSSResultGroup | number)[]\n): CSSResult => {\n const cssText =\n strings.length === 1\n ? strings[0]\n : values.reduce(\n (acc, v, idx) => acc + textFromCSSResult(v) + strings[idx + 1],\n strings[0]\n );\n return new (CSSResult as ConstructableCSSResult)(\n cssText,\n strings,\n constructionToken\n );\n};\n\n/**\n * Applies the given styles to a `shadowRoot`. When Shadow DOM is\n * available but `adoptedStyleSheets` is not, styles are appended to the\n * `shadowRoot` to [mimic spec behavior](https://wicg.github.io/construct-stylesheets/#using-constructed-stylesheets).\n * Note, when shimming is used, any styles that are subsequently placed into\n * the shadowRoot should be placed *before* any shimmed adopted styles. This\n * will match spec behavior that gives adopted sheets precedence over styles in\n * shadowRoot.\n */\nexport const adoptStyles = (\n renderRoot: ShadowRoot,\n styles: Array\n) => {\n if (supportsAdoptingStyleSheets) {\n (renderRoot as ShadowRoot).adoptedStyleSheets = styles.map((s) =>\n s instanceof CSSStyleSheet ? s : s.styleSheet!\n );\n } else {\n styles.forEach((s) => {\n const style = document.createElement('style');\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const nonce = (global as any)['litNonce'];\n if (nonce !== undefined) {\n style.setAttribute('nonce', nonce);\n }\n style.textContent = (s as CSSResult).cssText;\n renderRoot.appendChild(style);\n });\n }\n};\n\nconst cssResultFromStyleSheet = (sheet: CSSStyleSheet) => {\n let cssText = '';\n for (const rule of sheet.cssRules) {\n cssText += rule.cssText;\n }\n return unsafeCSS(cssText);\n};\n\nexport const getCompatibleStyle =\n supportsAdoptingStyleSheets ||\n (NODE_MODE && global.CSSStyleSheet === undefined)\n ? (s: CSSResultOrNative) => s\n : (s: CSSResultOrNative) =>\n s instanceof CSSStyleSheet ? cssResultFromStyleSheet(s) : s;\n", "/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\n\n/**\n * Use this module if you want to create your own base class extending\n * {@link ReactiveElement}.\n * @packageDocumentation\n */\n\nimport {\n getCompatibleStyle,\n adoptStyles,\n CSSResultGroup,\n CSSResultOrNative,\n} from './css-tag.js';\nimport type {\n ReactiveController,\n ReactiveControllerHost,\n} from './reactive-controller.js';\n\n// In the Node build, this import will be injected by Rollup:\n// import {HTMLElement, customElements} from '@lit-labs/ssr-dom-shim';\n\nexport * from './css-tag.js';\nexport type {\n ReactiveController,\n ReactiveControllerHost,\n} from './reactive-controller.js';\n\nconst NODE_MODE = false;\nconst global = NODE_MODE ? globalThis : window;\n\nif (NODE_MODE) {\n global.customElements ??= customElements;\n}\n\nconst DEV_MODE = true;\n\nlet requestUpdateThenable: (name: string) => {\n then: (\n onfulfilled?: (value: boolean) => void,\n _onrejected?: () => void\n ) => void;\n};\n\nlet issueWarning: (code: string, warning: string) => void;\n\nconst trustedTypes = (global as unknown as {trustedTypes?: {emptyScript: ''}})\n .trustedTypes;\n\n// Temporary workaround for https://crbug.com/993268\n// Currently, any attribute starting with \"on\" is considered to be a\n// TrustedScript source. Such boolean attributes must be set to the equivalent\n// trusted emptyScript value.\nconst emptyStringForBooleanAttribute = trustedTypes\n ? (trustedTypes.emptyScript as unknown as '')\n : '';\n\nconst polyfillSupport = DEV_MODE\n ? global.reactiveElementPolyfillSupportDevMode\n : global.reactiveElementPolyfillSupport;\n\nif (DEV_MODE) {\n // Ensure warnings are issued only 1x, even if multiple versions of Lit\n // are loaded.\n const issuedWarnings: Set = (global.litIssuedWarnings ??=\n new Set());\n\n // Issue a warning, if we haven't already.\n issueWarning = (code: string, warning: string) => {\n warning += ` See https://lit.dev/msg/${code} for more information.`;\n if (!issuedWarnings.has(warning)) {\n console.warn(warning);\n issuedWarnings.add(warning);\n }\n };\n\n issueWarning(\n 'dev-mode',\n `Lit is in dev mode. Not recommended for production!`\n );\n\n // Issue polyfill support warning.\n if (global.ShadyDOM?.inUse && polyfillSupport === undefined) {\n issueWarning(\n 'polyfill-support-missing',\n `Shadow DOM is being polyfilled via \\`ShadyDOM\\` but ` +\n `the \\`polyfill-support\\` module has not been loaded.`\n );\n }\n\n requestUpdateThenable = (name) => ({\n then: (\n onfulfilled?: (value: boolean) => void,\n _onrejected?: () => void\n ) => {\n issueWarning(\n 'request-update-promise',\n `The \\`requestUpdate\\` method should no longer return a Promise but ` +\n `does so on \\`${name}\\`. Use \\`updateComplete\\` instead.`\n );\n if (onfulfilled !== undefined) {\n onfulfilled(false);\n }\n },\n });\n}\n\n/**\n * Contains types that are part of the unstable debug API.\n *\n * Everything in this API is not stable and may change or be removed in the future,\n * even on patch releases.\n */\n// eslint-disable-next-line @typescript-eslint/no-namespace\nexport namespace ReactiveUnstable {\n /**\n * When Lit is running in dev mode and `window.emitLitDebugLogEvents` is true,\n * we will emit 'lit-debug' events to window, with live details about the update and render\n * lifecycle. These can be useful for writing debug tooling and visualizations.\n *\n * Please be aware that running with window.emitLitDebugLogEvents has performance overhead,\n * making certain operations that are normally very cheap (like a no-op render) much slower,\n * because we must copy data and dispatch events.\n */\n // eslint-disable-next-line @typescript-eslint/no-namespace\n export namespace DebugLog {\n export type Entry = Update;\n export interface Update {\n kind: 'update';\n }\n }\n}\n\ninterface DebugLoggingWindow {\n // Even in dev mode, we generally don't want to emit these events, as that's\n // another level of cost, so only emit them when DEV_MODE is true _and_ when\n // window.emitLitDebugEvents is true.\n emitLitDebugLogEvents?: boolean;\n}\n\n/**\n * Useful for visualizing and logging insights into what the Lit template system is doing.\n *\n * Compiled out of prod mode builds.\n */\nconst debugLogEvent = DEV_MODE\n ? (event: ReactiveUnstable.DebugLog.Entry) => {\n const shouldEmit = (global as unknown as DebugLoggingWindow)\n .emitLitDebugLogEvents;\n if (!shouldEmit) {\n return;\n }\n global.dispatchEvent(\n new CustomEvent('lit-debug', {\n detail: event,\n })\n );\n }\n : undefined;\n\n/*\n * When using Closure Compiler, JSCompiler_renameProperty(property, object) is\n * replaced at compile time by the munged name for object[property]. We cannot\n * alias this function, so we have to use a small shim that has the same\n * behavior when not compiling.\n */\n/*@__INLINE__*/\nconst JSCompiler_renameProperty =
(\n prop: P,\n _obj: unknown\n): P => prop;\n\n/**\n * Converts property values to and from attribute values.\n */\nexport interface ComplexAttributeConverter {\n /**\n * Called to convert an attribute value to a property\n * value.\n */\n fromAttribute?(value: string | null, type?: TypeHint): Type;\n\n /**\n * Called to convert a property value to an attribute\n * value.\n *\n * It returns unknown instead of string, to be compatible with\n * https://github.com/WICG/trusted-types (and similar efforts).\n */\n toAttribute?(value: Type, type?: TypeHint): unknown;\n}\n\ntype AttributeConverter =\n | ComplexAttributeConverter\n | ((value: string | null, type?: TypeHint) => Type);\n\n/**\n * Defines options for a property accessor.\n */\nexport interface PropertyDeclaration {\n /**\n * When set to `true`, indicates the property is internal private state. The\n * property should not be set by users. When using TypeScript, this property\n * should be marked as `private` or `protected`, and it is also a common\n * practice to use a leading `_` in the name. The property is not added to\n * `observedAttributes`.\n */\n readonly state?: boolean;\n\n /**\n * Indicates how and whether the property becomes an observed attribute.\n * If the value is `false`, the property is not added to `observedAttributes`.\n * If true or absent, the lowercased property name is observed (e.g. `fooBar`\n * becomes `foobar`). If a string, the string value is observed (e.g\n * `attribute: 'foo-bar'`).\n */\n readonly attribute?: boolean | string;\n\n /**\n * Indicates the type of the property. This is used only as a hint for the\n * `converter` to determine how to convert the attribute\n * to/from a property.\n */\n readonly type?: TypeHint;\n\n /**\n * Indicates how to convert the attribute to/from a property. If this value\n * is a function, it is used to convert the attribute value a the property\n * value. If it's an object, it can have keys for `fromAttribute` and\n * `toAttribute`. If no `toAttribute` function is provided and\n * `reflect` is set to `true`, the property value is set directly to the\n * attribute. A default `converter` is used if none is provided; it supports\n * `Boolean`, `String`, `Number`, `Object`, and `Array`. Note,\n * when a property changes and the converter is used to update the attribute,\n * the property is never updated again as a result of the attribute changing,\n * and vice versa.\n */\n readonly converter?: AttributeConverter;\n\n /**\n * Indicates if the property should reflect to an attribute.\n * If `true`, when the property is set, the attribute is set using the\n * attribute name determined according to the rules for the `attribute`\n * property option and the value of the property converted using the rules\n * from the `converter` property option.\n */\n readonly reflect?: boolean;\n\n /**\n * A function that indicates if a property should be considered changed when\n * it is set. The function should take the `newValue` and `oldValue` and\n * return `true` if an update should be requested.\n */\n hasChanged?(value: Type, oldValue: Type): boolean;\n\n /**\n * Indicates whether an accessor will be created for this property. By\n * default, an accessor will be generated for this property that requests an\n * update when set. If this flag is `true`, no accessor will be created, and\n * it will be the user's responsibility to call\n * `this.requestUpdate(propertyName, oldValue)` to request an update when\n * the property changes.\n */\n readonly noAccessor?: boolean;\n}\n\n/**\n * Map of properties to PropertyDeclaration options. For each property an\n * accessor is made, and the property is processed according to the\n * PropertyDeclaration options.\n */\nexport interface PropertyDeclarations {\n readonly [key: string]: PropertyDeclaration;\n}\n\ntype PropertyDeclarationMap = Map;\n\ntype AttributeMap = Map;\n\n/**\n * A Map of property keys to values.\n *\n * Takes an optional type parameter T, which when specified as a non-any,\n * non-unknown type, will make the Map more strongly-typed, associating the map\n * keys with their corresponding value type on T.\n *\n * Use `PropertyValues` when overriding ReactiveElement.update() and\n * other lifecycle methods in order to get stronger type-checking on keys\n * and values.\n */\n// This type is conditional so that if the parameter T is not specified, or\n// is `any`, the type will include `Map`. Since T is not\n// given in the uses of PropertyValues in this file, all uses here fallback to\n// meaning `Map`, but if a developer uses\n// `PropertyValues` (or any other value for T) they will get a\n// strongly-typed Map type.\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport type PropertyValues = T extends object\n ? PropertyValueMap\n : Map;\n\n/**\n * Do not use, instead prefer {@linkcode PropertyValues}.\n */\n// This type must be exported such that JavaScript generated by the Google\n// Closure Compiler can import a type reference.\nexport interface PropertyValueMap extends Map {\n get(k: K): T[K];\n set(key: K, value: T[K]): this;\n has(k: K): boolean;\n delete(k: K): boolean;\n}\n\nexport const defaultConverter: ComplexAttributeConverter = {\n toAttribute(value: unknown, type?: unknown): unknown {\n switch (type) {\n case Boolean:\n value = value ? emptyStringForBooleanAttribute : null;\n break;\n case Object:\n case Array:\n // if the value is `null` or `undefined` pass this through\n // to allow removing/no change behavior.\n value = value == null ? value : JSON.stringify(value);\n break;\n }\n return value;\n },\n\n fromAttribute(value: string | null, type?: unknown) {\n let fromValue: unknown = value;\n switch (type) {\n case Boolean:\n fromValue = value !== null;\n break;\n case Number:\n fromValue = value === null ? null : Number(value);\n break;\n case Object:\n case Array:\n // Do *not* generate exception when invalid JSON is set as elements\n // don't normally complain on being mis-configured.\n // TODO(sorvell): Do generate exception in *dev mode*.\n try {\n // Assert to adhere to Bazel's \"must type assert JSON parse\" rule.\n fromValue = JSON.parse(value!) as unknown;\n } catch (e) {\n fromValue = null;\n }\n break;\n }\n return fromValue;\n },\n};\n\nexport interface HasChanged {\n (value: unknown, old: unknown): boolean;\n}\n\n/**\n * Change function that returns true if `value` is different from `oldValue`.\n * This method is used as the default for a property's `hasChanged` function.\n */\nexport const notEqual: HasChanged = (value: unknown, old: unknown): boolean => {\n // This ensures (old==NaN, value==NaN) always returns false\n return old !== value && (old === old || value === value);\n};\n\nconst defaultPropertyDeclaration: PropertyDeclaration = {\n attribute: true,\n type: String,\n converter: defaultConverter,\n reflect: false,\n hasChanged: notEqual,\n};\n\n/**\n * The Closure JS Compiler doesn't currently have good support for static\n * property semantics where \"this\" is dynamic (e.g.\n * https://github.com/google/closure-compiler/issues/3177 and others) so we use\n * this hack to bypass any rewriting by the compiler.\n */\nconst finalized = 'finalized';\n\n/**\n * A string representing one of the supported dev mode warning categories.\n */\nexport type WarningKind = 'change-in-update' | 'migration';\n\nexport type Initializer = (element: ReactiveElement) => void;\n\n/**\n * Base element class which manages element properties and attributes. When\n * properties change, the `update` method is asynchronously called. This method\n * should be supplied by subclassers to render updates as desired.\n * @noInheritDoc\n */\nexport abstract class ReactiveElement\n // In the Node build, this `extends` clause will be substituted with\n // `(globalThis.HTMLElement ?? HTMLElement)`.\n //\n // This way, we will first prefer any global `HTMLElement` polyfill that the\n // user has assigned, and then fall back to the `HTMLElement` shim which has\n // been imported (see note at the top of this file about how this import is\n // generated by Rollup). Note that the `HTMLElement` variable has been\n // shadowed by this import, so it no longer refers to the global.\n extends HTMLElement\n implements ReactiveControllerHost\n{\n // Note: these are patched in only in DEV_MODE.\n /**\n * Read or set all the enabled warning categories for this class.\n *\n * This property is only used in development builds.\n *\n * @nocollapse\n * @category dev-mode\n */\n static enabledWarnings?: WarningKind[];\n\n /**\n * Enable the given warning category for this class.\n *\n * This method only exists in development builds, so it should be accessed\n * with a guard like:\n *\n * ```ts\n * // Enable for all ReactiveElement subclasses\n * ReactiveElement.enableWarning?.('migration');\n *\n * // Enable for only MyElement and subclasses\n * MyElement.enableWarning?.('migration');\n * ```\n *\n * @nocollapse\n * @category dev-mode\n */\n static enableWarning?: (warningKind: WarningKind) => void;\n\n /**\n * Disable the given warning category for this class.\n *\n * This method only exists in development builds, so it should be accessed\n * with a guard like:\n *\n * ```ts\n * // Disable for all ReactiveElement subclasses\n * ReactiveElement.disableWarning?.('migration');\n *\n * // Disable for only MyElement and subclasses\n * MyElement.disableWarning?.('migration');\n * ```\n *\n * @nocollapse\n * @category dev-mode\n */\n static disableWarning?: (warningKind: WarningKind) => void;\n\n /**\n * Adds an initializer function to the class that is called during instance\n * construction.\n *\n * This is useful for code that runs against a `ReactiveElement`\n * subclass, such as a decorator, that needs to do work for each\n * instance, such as setting up a `ReactiveController`.\n *\n * ```ts\n * const myDecorator = (target: typeof ReactiveElement, key: string) => {\n * target.addInitializer((instance: ReactiveElement) => {\n * // This is run during construction of the element\n * new MyController(instance);\n * });\n * }\n * ```\n *\n * Decorating a field will then cause each instance to run an initializer\n * that adds a controller:\n *\n * ```ts\n * class MyElement extends LitElement {\n * @myDecorator foo;\n * }\n * ```\n *\n * Initializers are stored per-constructor. Adding an initializer to a\n * subclass does not add it to a superclass. Since initializers are run in\n * constructors, initializers will run in order of the class hierarchy,\n * starting with superclasses and progressing to the instance's class.\n *\n * @nocollapse\n */\n static addInitializer(initializer: Initializer) {\n this.finalize();\n (this._initializers ??= []).push(initializer);\n }\n\n static _initializers?: Initializer[];\n\n /*\n * Due to closure compiler ES6 compilation bugs, @nocollapse is required on\n * all static methods and properties with initializers. Reference:\n * - https://github.com/google/closure-compiler/issues/1776\n */\n\n /**\n * Maps attribute names to properties; for example `foobar` attribute to\n * `fooBar` property. Created lazily on user subclasses when finalizing the\n * class.\n * @nocollapse\n */\n private static __attributeToPropertyMap: AttributeMap;\n\n /**\n * Marks class as having finished creating properties.\n */\n protected static [finalized] = true;\n\n /**\n * Memoized list of all element properties, including any superclass properties.\n * Created lazily on user subclasses when finalizing the class.\n * @nocollapse\n * @category properties\n */\n static elementProperties: PropertyDeclarationMap = new Map();\n\n /**\n * User-supplied object that maps property names to `PropertyDeclaration`\n * objects containing options for configuring reactive properties. When\n * a reactive property is set the element will update and render.\n *\n * By default properties are public fields, and as such, they should be\n * considered as primarily settable by element users, either via attribute or\n * the property itself.\n *\n * Generally, properties that are changed by the element should be private or\n * protected fields and should use the `state: true` option. Properties\n * marked as `state` do not reflect from the corresponding attribute\n *\n * However, sometimes element code does need to set a public property. This\n * should typically only be done in response to user interaction, and an event\n * should be fired informing the user; for example, a checkbox sets its\n * `checked` property when clicked and fires a `changed` event. Mutating\n * public properties should typically not be done for non-primitive (object or\n * array) properties. In other cases when an element needs to manage state, a\n * private property set with the `state: true` option should be used. When\n * needed, state properties can be initialized via public properties to\n * facilitate complex interactions.\n * @nocollapse\n * @category properties\n */\n static properties: PropertyDeclarations;\n\n /**\n * Memoized list of all element styles.\n * Created lazily on user subclasses when finalizing the class.\n * @nocollapse\n * @category styles\n */\n static elementStyles: Array = [];\n\n /**\n * Array of styles to apply to the element. The styles should be defined\n * using the {@linkcode css} tag function, via constructible stylesheets, or\n * imported from native CSS module scripts.\n *\n * Note on Content Security Policy:\n *\n * Element styles are implemented with `