aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorErg <uinarf@autistici.org>2024-11-28 16:42:41 +0100
committerErg <uinarf@autistici.org>2024-11-28 16:42:41 +0100
commitd12675c238c77dc83a92eaaf8ec70a9dcf26a363 (patch)
tree5cf27ecfab92577e574e832ea5a7824474066460
parentbf8efbce7f202f1f7650f628955fb0e42d343a1f (diff)
downloadfastapi_blog-private.tar.gz
fastapi_blog-private.tar.bz2
fastapi_blog-private.zip
Add Private files :Pprivate
-rw-r--r--jupyter_files/Binhost_folder_structure.ipynb184
-rw-r--r--jupyter_files/Untitled.ipynb211
-rw-r--r--jupyter_files/creating_fastapi_static_blog.ipynb507
-rw-r--r--static/html/Binhost_folder_structure.html7736
-rw-r--r--static/html/creating_fastapi_static_blog.html8160
5 files changed, 16798 insertions, 0 deletions
diff --git a/jupyter_files/Binhost_folder_structure.ipynb b/jupyter_files/Binhost_folder_structure.ipynb
new file mode 100644
index 0000000..da2c7ed
--- /dev/null
+++ b/jupyter_files/Binhost_folder_structure.ipynb
@@ -0,0 +1,184 @@
+{
+ "cells": [
+ {
+ "cell_type": "markdown",
+ "id": "0b397cbb-8db3-40d9-a0a9-27ba0a774021",
+ "metadata": {},
+ "source": [
+ "## Automatically creating new binhost directories when profile or gcc version changes"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "97c6e8be-a571-4fea-84c4-b226f03f56c6",
+ "metadata": {},
+ "source": [
+ "On Gentoo Linux packages are compiled which is a time and energy consuming.\n",
+ "To minimise both, I have a binhost to share compiled binaries between devices.\n",
+ "The issues occurs when gcc major version changes - or a profile bump happens.\n",
+ "If I do not notice either - problem. Binaries might not be compatible.\n",
+ "So I wanted to automate a process of detection of those changes and automatically create subfolder for new binaries.\n",
+ "When investigating I learned a neat trick. For the wise ones this is trivial, for me it was enligtening.\n",
+ "Here it comes."
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "2a688afd-5f24-4eab-a1c7-119d372367b5",
+ "metadata": {},
+ "source": [
+ "On a regular system, emerge resides here:"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "b1098db8-2f77-4b56-acef-f58113107dad",
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "$ which emerge\n",
+ "/usr/bin/emerge"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "9a1dcd6c-3f8c-455f-9d56-21e5157d0846",
+ "metadata": {},
+ "source": [
+ "On my box with binhost:"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "bcb9918c-20fb-49fd-baaf-b3b63356de5a",
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "$ which emerge\n",
+ "/usr/local/bin/emerge"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "a84cf35c-e744-47c9-9500-d9b8c7d3bfef",
+ "metadata": {},
+ "source": [
+ "And here is $PATH:"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "94092561-ae6b-41eb-831a-71bffcf30e6e",
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "$ echo $PATH\n",
+ "/usr/local/sbin:/usr/local/bin:/usr/bin:/opt/bin:/usr/lib/llvm/18/bin:/usr/lib/llvm/17/bin"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "eb05de7d-f2f3-4cd3-acc2-769e096a3a5b",
+ "metadata": {},
+ "source": [
+ "So we see that on binhost box, there is emerge that resides in location preceeding regular emerge - so it gets called first.\n",
+ "It contains a shell script as follows:"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "b9f78265-a1de-47eb-be21-bb66c1ed3bed",
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "#!/usr/bin/env bash\n",
+ "#\n",
+ "# Script checking that binhost path exists before running emerge and\n",
+ "# creating it if not exists\n",
+ "\n",
+ "PROFILE=$(eselect profile show|sed -n 2p|cut -d '/' -f4)\n",
+ "GCC_VERSION=$(eselect gcc show|cut -d '-' -f5)\n",
+ "BINHOST_DIR=\"/var/cache/binpkgs/${PROFILE}/gcc-${GCC_VERSION}.x/armv8a\"\n",
+ "\n",
+ "if [ ! -d \"${BINHOST_DIR}\" ]; then\n",
+ " echo \"${BINHOST_DIR} does not exist, creating\"\n",
+ " mkdir -p \"${BINHOST_DIR}\"\n",
+ "else echo \"Binhost directory ${BINHOST_DIR} exists, proceeding with emerge ...\"\n",
+ "fi\n",
+ "\n",
+ "PKGDIR=\"${BINHOST_DIR}\" /usr/bin/emerge \"$@\""
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "d6d085ea-b68f-4220-adaf-00223393e58e",
+ "metadata": {},
+ "source": [
+ "So on every profile change subfolder to /var/cache/binpkgs gets created,\n",
+ "on every gcc major version change, subfolder to /var/cache/binpkgs/<profile> gets created.\n",
+ "If folder already exists script only prints a message.\n",
+ "Then it calls /usr/bin/emerge - the regular emerge - with $PKGDIR variable, so binary packages are saved to the correct directory. "
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "1d464645-b7ac-4cbc-b5cc-1bd4bd976f06",
+ "metadata": {},
+ "source": [
+ "This is structure of /var/cache/binpkgs:"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "dee2b348-d16d-4709-a7cd-ac9424934009",
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "$ tree -L 3 /var/cache/binpkgs/\n",
+ "/var/cache/binpkgs/\n",
+ "├── 17.0\n",
+ "│   └── gcc-13.x\n",
+ "│   └── armv8a\n",
+ "└── 23.0\n",
+ " ├── gcc-13.x\n",
+ " │   └── armv8a\n",
+ " └── gcc-14.x\n",
+ " └── armv8a"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "9f8f4a71-9fd1-4678-9cb0-a580c94f4582",
+ "metadata": {},
+ "source": [
+ "One less thing to worry about."
+ ]
+ }
+ ],
+ "metadata": {
+ "kernelspec": {
+ "display_name": "Python 3 (ipykernel)",
+ "language": "python",
+ "name": "python3"
+ },
+ "language_info": {
+ "codemirror_mode": {
+ "name": "ipython",
+ "version": 3
+ },
+ "file_extension": ".py",
+ "mimetype": "text/x-python",
+ "name": "python",
+ "nbconvert_exporter": "python",
+ "pygments_lexer": "ipython3",
+ "version": "3.12.7"
+ }
+ },
+ "nbformat": 4,
+ "nbformat_minor": 5
+}
diff --git a/jupyter_files/Untitled.ipynb b/jupyter_files/Untitled.ipynb
new file mode 100644
index 0000000..feca323
--- /dev/null
+++ b/jupyter_files/Untitled.ipynb
@@ -0,0 +1,211 @@
+{
+ "cells": [
+ {
+ "cell_type": "markdown",
+ "id": "78a149e6-ef3b-4b6e-a633-0c1d2eb2a7b1",
+ "metadata": {},
+ "source": [
+ "# Setting up Docker for FastAPI and Jenkins CI-CD on Gentoo\n",
+ "\n",
+ "## Prerequisites:\n",
+ "- Docker\n",
+ "- Jenkins\n",
+ "- FastAPI\n",
+ "\n",
+ "## Preparations.\n",
+ "\n",
+ "\n",
+ "Create directory for your stuff, call it tech_project, enter it."
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "4d35806b-a9f8-43b0-82fd-b9a669295562",
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "$ mkdir tech_project && cd tech_project"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "bdfd8575-625f-488b-aec3-73ce987086d2",
+ "metadata": {},
+ "source": [
+ "Create virtual Python environment:"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "42b86b21-ffa1-4d22-af97-a130b76e04d0",
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "$ python -m venv venv"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "ba4a8e5c-5e31-4e67-9c8f-17c75b52f5e2",
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "You can activate it now with:"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "edaeb7c2-f19a-4a6b-bb5f-4c5fd93dcf60",
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "$ source venv/bin/activate"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "8ebfbc06-03a0-4380-a9aa-970aafdbde75",
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "(venv) - That's what should prepend your prompt now."
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "bb6d9596-a6fd-4127-a626-e63851a3e38f",
+ "metadata": {},
+ "source": [
+ "Create a requirements.txt file, check which versions of fastapi and pydantic you have and use those:"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "a199797a-73ea-4015-b58f-e87ead2ea3f0",
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "fastapi>=0.111\n",
+ "pydantic>=2.7.3\n",
+ "uvicorn>=0.30.1"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "25c4e82b-0685-400e-9f40-c171deefcc1f",
+ "metadata": {},
+ "source": [
+ "Create a Dockerfile:"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "237c5063-5370-4be7-8e29-e0e9802077e6",
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "FROM python:3.12\n",
+ "WORKDIR app/ .\n",
+ "COPY requirements.txt .\n",
+ "RUN pip install --no-cache-dir -r requirements.txt\n",
+ "CMD [\"python\", \"main.py\"]"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "e2b41ff9-c9d3-4a84-bb22-0494990ef272",
+ "metadata": {},
+ "source": [
+ "Start docker service (as root):"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "37b1ef3f-8ed1-4c40-9ce9-5e88843356f9",
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "# rc-service docker start"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "7df0e4c5-20f2-4367-be36-e43617dab0ed",
+ "metadata": {},
+ "source": [
+ "Build docker image:"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "1220f1b3-1b2c-4bba-a51f-54bd1401b1ec",
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "$ docker build -t fastapi_tech_blog ."
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "36881148-8ff4-48e6-80d9-8c53a05bb90b",
+ "metadata": {},
+ "source": [
+ "Watch if warn you and build:"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "c962a037-75ef-4b22-b46a-f24da4994be4",
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "WARNING: Running pip as the 'root' user can result in broken permissions and conflicting behaviour with the system package manager. It is recommended to use a virtual environment instead: https://pip.pypa.io/warnings/venv\n",
+ " ---> Removed intermediate container bb903c49b10d\n",
+ " ---> 2a71d86268fd\n",
+ "Step 5/7 : COPY . .\n",
+ " ---> 9fdcdd3d46cb\n",
+ "Step 6/7 : EXPOSE 8000\n",
+ " ---> Running in e63e0e7b3ccc\n",
+ " ---> Removed intermediate container e63e0e7b3ccc\n",
+ " ---> 72d0d9f39af7\n",
+ "Step 7/7 : CMD [\"python\", \"main.py\"]\n",
+ " ---> Running in b49bc996f993\n",
+ " ---> Removed intermediate container b49bc996f993\n",
+ " ---> fb426f2a7e15\n",
+ "Successfully built fb426f2a7e15\n",
+ "Successfully tagged fastapi_tech_blog:latest"
+ ]
+ }
+ ],
+ "metadata": {
+ "kernelspec": {
+ "display_name": "Python 3 (ipykernel)",
+ "language": "python",
+ "name": "python3"
+ },
+ "language_info": {
+ "codemirror_mode": {
+ "name": "ipython",
+ "version": 3
+ },
+ "file_extension": ".py",
+ "mimetype": "text/x-python",
+ "name": "python",
+ "nbconvert_exporter": "python",
+ "pygments_lexer": "ipython3",
+ "version": "3.12.7"
+ }
+ },
+ "nbformat": 4,
+ "nbformat_minor": 5
+}
diff --git a/jupyter_files/creating_fastapi_static_blog.ipynb b/jupyter_files/creating_fastapi_static_blog.ipynb
new file mode 100644
index 0000000..b2c1851
--- /dev/null
+++ b/jupyter_files/creating_fastapi_static_blog.ipynb
@@ -0,0 +1,507 @@
+{
+ "cells": [
+ {
+ "cell_type": "markdown",
+ "id": "d745c9ae-31f8-47e5-83df-42c0a39e700e",
+ "metadata": {},
+ "source": [
+ "# Setting up FastAPI with Uvicorn and Openrc to serve Jupyter Notebook generated html files."
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "5dec85d7-1ac2-4bdd-a5c4-40dc8ec80c1f",
+ "metadata": {},
+ "source": [
+ "## Prerequisites:\n",
+ "- system with openrc\n",
+ "- fastapi\n",
+ "- uvicorn\n",
+ "- jupyter notebook (optional)\n",
+ "- nginx"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "3d5a9177-1fcd-4bc6-97dd-f85c712e8a9e",
+ "metadata": {},
+ "source": [
+ "## Creating FastAPI application"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "6f2751d9-cdfe-417e-8a30-8768e2fd828e",
+ "metadata": {},
+ "source": [
+ "Create a directory for project and enter it:"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "58fe2a08-afb0-400b-a8a2-063da88a2559",
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "$ mkdir -p ~/Fastapi_blog/static && cd ~/Fastapi_blog"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "2ad52653-7f16-489f-8a4b-e2fd08f90d05",
+ "metadata": {},
+ "source": [
+ "Create a file containing code and html template folder and template for the main page:"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "27e461b5-279f-4143-ac69-5ef61b75e6af",
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "$ touch main.py\n",
+ "$ mkdir templates\n",
+ "$ touch templates/main_page.html"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "9c3d9c08-81ea-43b0-bea8-8486adb06d85",
+ "metadata": {},
+ "source": [
+ "main_page.html can be really minimal:"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "e6a61c2c-708e-462d-b487-0ddd23b5e08a",
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "<html>\n",
+ "<body>\n",
+ " <h1>List of articles</h1>\n",
+ " <h2>Number of posts: {{ files|length }}</h2>\n",
+ " {% if files %}\n",
+ " {% for item in files %}\n",
+ " <a href=\"static/html/{{ item }}\">{{ item }}</a><br>\n",
+ " {% endfor %}\n",
+ " {% endif %}\n",
+ "</body>\n",
+ "</html>"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "b15b4217-9343-4c73-aa44-f069f6d5e776",
+ "metadata": {},
+ "source": [
+ "Create basic FastAPI application serving static files at '/'. I want that as I'll be serving if from behind Nginx reverse proxy. Prefix will be set with Nginx conf file"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "90f95ae9-4079-440e-9f40-2889541cb727",
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "#!/usr/bin/env python\n",
+ "\n",
+ "\"\"\"\n",
+ "FastAPI site serving static html files.\n",
+ "\"\"\"\n",
+ "\n",
+ "from os import listdir\n",
+ "from fastapi import FastAPI\n",
+ "from fastapi.staticfiles import StaticFiles\n",
+ "from fastapi import FastAPI, Request\n",
+ "from fastapi.staticfiles import StaticFiles\n",
+ "from fastapi.templating import Jinja2Templates\n",
+ "\n",
+ "\n",
+ "ARTICLES = 'static/html'\n",
+ "templates = Jinja2Templates(directory=\"templates\")\n",
+ "LIST_OF_ARTICLES = [i for i in listdir(ARTICLES) if i.endswith('.html')]\n",
+ "\n",
+ "app = FastAPI()\n",
+ "\n",
+ "app.mount(\"/\", StaticFiles(directory=\"static\", html=True), name=\"static\")\n",
+ "\n",
+ "\n",
+ "@app.get(\"/\")\n",
+ "async def main_page(request: Request):\n",
+ " \"\"\"Generate main page\"\"\"\n",
+ " return templates.TemplateResponse(\n",
+ " \"main_page.html\", {\n",
+ " \"request\": request,\n",
+ " \"files\": LIST_OF_ARTICLES,\n",
+ " \"static\": ARTICLES,\n",
+ " }\n",
+ " )\n",
+ "\n",
+ "\n",
+ "if __name__ == \"__main__\":\n",
+ " uvicorn.run(\n",
+ " app,\n",
+ " port=8000,\n",
+ " host='127.0.0.1',\n",
+ " log_level=\"info\",\n",
+ " # uds=\"/run/tech_blog.sock\", <- uncomment if you want Unix socket\n",
+ " )"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "0def2ab2-e037-4997-b472-59784554d12f",
+ "metadata": {},
+ "source": [
+ "Test run:"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "7e4b78e2-9412-40a0-ad23-b1ebdc32b34d",
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "$ uvicorn main:app --reload"
+ ]
+ },
+ {
+ "attachments": {},
+ "cell_type": "markdown",
+ "id": "1ff45780-0f1a-4f8a-a50d-7c52ad08f52d",
+ "metadata": {},
+ "source": [
+ "If we try to run it as regular user with 'uds=\"/run/tech_blog.sock\"' line uncommented we should get permission denied error as we don't have rights to create files in /run.\n",
+ "\n",
+ "In browser, take a peek at http://localhost:8000 and you should already see something.\n",
+ "\n",
+ "Create a file with a test html code:"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "f2cb8101-4914-494e-9c6e-222cd9cdb148",
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "$ touch static/test.html"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "0496d679-15a2-4610-815b-9e1b57285ebf",
+ "metadata": {},
+ "source": [
+ "Put this in it:"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "3db82cd2-3f9f-4c74-b98b-2cf1b19dd353",
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "<html>\n",
+ "<body>\n",
+ "\n",
+ "<h1>Fun stuff comming up</h1>\n",
+ "<p>Bob's your uncle!</p>\n",
+ "\n",
+ "</body>\n",
+ "</html> "
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "fd3b37dc-e3d3-48a0-a496-7f0060bc69c0",
+ "metadata": {},
+ "source": [
+ "Visit http://localhost:8000/\n",
+ "You should see the main page with test article and you should be able to navigate to the article clicking the link."
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "cba92c27-c741-4959-88c5-b9790de7eddf",
+ "metadata": {},
+ "source": [
+ "## Jupyter side note"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "f7fefa06-9d13-4793-8bb6-3f96f2171f25",
+ "metadata": {},
+ "source": [
+ "To write stuff with Jupyter Notebook start it up:"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "f7eadb7f-e811-4bee-a8d7-68c68ec9f9ca",
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "$ jupyter-notebook"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "d0ce0f2c-e633-4974-8ed4-1f4b3a021d6a",
+ "metadata": {},
+ "source": [
+ "In browser a new tab with jupyter notebook should have started. Write your fun stuff. Save it. If you don't want to execute cell content convert to html with:"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "7a4da315-d47b-4bec-8b17-f2cbf494f4d4",
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "$ jupyter nbconvert --to html <path to your file>"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "80c327c4-d985-47d6-94fa-10e8e5b7d2b4",
+ "metadata": {},
+ "source": [
+ "If you want to execute cell content convert with:"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "54af67cd-0d26-4373-9647-8943dec2f4ab",
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "$ jupyter nbconvert --execute --to html <path to your file>"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "f8653115-4f64-40a7-9d72-0e088a607a07",
+ "metadata": {},
+ "source": [
+ "Want to change theme to dark?"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "52d5866b-813d-4ef3-9886-c775e1c67d5b",
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "$ jupyter nbconvert --execute --to html <path to your file> --HTMLExporter.theme=dark"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "e73f69fc-6c8a-4617-90bd-a0e788b89756",
+ "metadata": {},
+ "source": [
+ "Now put it in your `static` folder. It will be served by your FastAPI application."
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "c56ef398-9f2e-4253-bc37-22b5926b8c7c",
+ "metadata": {},
+ "source": [
+ "## Bash script"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "f37aba78-c09b-4807-ba02-c72f48b9dba5",
+ "metadata": {},
+ "source": [
+ "In order to run our python script with Openrc first we need to create a Bash script:"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "6f4052ac-f582-47fa-b702-34f1341dec88",
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "#!/usr/bin/env bash\n",
+ "\n",
+ "cd /home/discordia/Fastapi_blog || exit # If your login is different, change home directory name.\n",
+ "exec python main.py"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "dedf511e-f6fd-4c41-8b02-a2eb25e9604a",
+ "metadata": {},
+ "source": [
+ "Save it (here as fastapi_blog.sh) as a root user to /usr/local/bin and make executable:"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "7c6e7b2d-33a3-4305-917b-c24155a648f2",
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "# chmod ugo+x /usr/local/bin/fastapi_blog.sh"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "1bf1a799-25b0-4008-b1d2-1a555cef79c5",
+ "metadata": {},
+ "source": [
+ "## Openrc service file"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "43794484-8e10-400d-a598-d1acefd455ee",
+ "metadata": {},
+ "source": [
+ "Now create a minimal service file"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "f14c6b71-3f1f-4dd8-b62d-d79721a8d6fe",
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "#!/sbin/openrc-run\n",
+ "\n",
+ "supervisor=supervise-daemon\n",
+ "command=\"/usr/local/bin/fastapi_blog.sh\"\n",
+ "pidfile=\"/run/${RC_SVCNAME}.pid\"\n",
+ "command_args=\"-p ${pidfile}\"\n",
+ "command_background=True"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "8982eef9-a095-4b57-b0a6-5d59ac12be78",
+ "metadata": {},
+ "source": [
+ "Save it as a root user in /etc/init.d and make executable:"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "6336a60f-6e8a-489b-8bc8-9b9e6f8e02fc",
+ "metadata": {},
+ "source": [
+ "Save it as a root user in /etc/init.d and make executable:"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "445a5744-8e71-4104-8601-ad444ca0f9c1",
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "# chmod ugo+x /etc/init.d/fastapi_blog"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "0985e123-559c-4f9b-8bfc-7f75e9251756",
+ "metadata": {},
+ "source": [
+ "You should be able to start/restart/stop it normally:"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "c856613b-8541-43e4-b7e0-1d0f2a4a6d22",
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "# rc-service fastapi_blog start\n",
+ "# rc-service fastapi_blog restart\n",
+ "# rc-service fastapi_blog stop"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "719552bc-b736-41db-939c-6a1010ca9557",
+ "metadata": {},
+ "source": [
+ "If you're using Unix socket, check for existence of /run/fastapi_blog.sock.\n",
+ "Else navigate to http://127.0.0.1:8000/test.html to see page is indeed there."
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "id": "b8f408bf-120c-4adf-8e8b-3dc019a015ae",
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "$ ps aux | grep \"python main.py\""
+ ]
+ },
+ {
+ "attachments": {},
+ "cell_type": "markdown",
+ "id": "13c17523-3603-4b8a-b8a2-563ae6dc27d5",
+ "metadata": {},
+ "source": [
+ "You want to see only one 'python main.py'.\n",
+ "At first I did not use exec which resulted in lingering processess. You don't want that.\n",
+ "\n",
+ "Now you can plug it in to your preffered proxy server using either a unix socket or a TCP socket."
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "id": "3134cb86-be0f-456c-b755-cd4f43ef2810",
+ "metadata": {},
+ "source": [
+ "If you're using unix socket, check for existence of /run/fastapi_blog.sock, else either use lsof to see what's using port 8000 or navigate to http://127.0.0.1:8000/test.html"
+ ]
+ }
+ ],
+ "metadata": {
+ "kernelspec": {
+ "display_name": "Python 3 (ipykernel)",
+ "language": "python",
+ "name": "python3"
+ },
+ "language_info": {
+ "codemirror_mode": {
+ "name": "ipython",
+ "version": 3
+ },
+ "file_extension": ".py",
+ "mimetype": "text/x-python",
+ "name": "python",
+ "nbconvert_exporter": "python",
+ "pygments_lexer": "ipython3",
+ "version": "3.12.7"
+ }
+ },
+ "nbformat": 4,
+ "nbformat_minor": 5
+}
diff --git a/static/html/Binhost_folder_structure.html b/static/html/Binhost_folder_structure.html
new file mode 100644
index 0000000..1aaddb5
--- /dev/null
+++ b/static/html/Binhost_folder_structure.html
@@ -0,0 +1,7736 @@
+<!DOCTYPE html>
+
+<html lang="en">
+<head><meta charset="utf-8"/>
+<meta content="width=device-width, initial-scale=1.0" name="viewport"/>
+<title>Binhost_folder_structure</title><script src="https://cdnjs.cloudflare.com/ajax/libs/require.js/2.1.10/require.min.js"></script>
+<style type="text/css">
+ pre { line-height: 125%; }
+td.linenos .normal { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; }
+span.linenos { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; }
+td.linenos .special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; }
+span.linenos.special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; }
+.highlight .hll { background-color: var(--jp-cell-editor-active-background) }
+.highlight { background: var(--jp-cell-editor-background); color: var(--jp-mirror-editor-variable-color) }
+.highlight .c { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment */
+.highlight .err { color: var(--jp-mirror-editor-error-color) } /* Error */
+.highlight .k { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword */
+.highlight .o { color: var(--jp-mirror-editor-operator-color); font-weight: bold } /* Operator */
+.highlight .p { color: var(--jp-mirror-editor-punctuation-color) } /* Punctuation */
+.highlight .ch { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.Hashbang */
+.highlight .cm { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.Multiline */
+.highlight .cp { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.Preproc */
+.highlight .cpf { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.PreprocFile */
+.highlight .c1 { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.Single */
+.highlight .cs { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.Special */
+.highlight .kc { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Constant */
+.highlight .kd { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Declaration */
+.highlight .kn { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Namespace */
+.highlight .kp { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Pseudo */
+.highlight .kr { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Reserved */
+.highlight .kt { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Type */
+.highlight .m { color: var(--jp-mirror-editor-number-color) } /* Literal.Number */
+.highlight .s { color: var(--jp-mirror-editor-string-color) } /* Literal.String */
+.highlight .ow { color: var(--jp-mirror-editor-operator-color); font-weight: bold } /* Operator.Word */
+.highlight .pm { color: var(--jp-mirror-editor-punctuation-color) } /* Punctuation.Marker */
+.highlight .w { color: var(--jp-mirror-editor-variable-color) } /* Text.Whitespace */
+.highlight .mb { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Bin */
+.highlight .mf { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Float */
+.highlight .mh { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Hex */
+.highlight .mi { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Integer */
+.highlight .mo { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Oct */
+.highlight .sa { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Affix */
+.highlight .sb { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Backtick */
+.highlight .sc { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Char */
+.highlight .dl { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Delimiter */
+.highlight .sd { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Doc */
+.highlight .s2 { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Double */
+.highlight .se { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Escape */
+.highlight .sh { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Heredoc */
+.highlight .si { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Interpol */
+.highlight .sx { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Other */
+.highlight .sr { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Regex */
+.highlight .s1 { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Single */
+.highlight .ss { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Symbol */
+.highlight .il { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Integer.Long */
+ </style>
+<style type="text/css">
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/*
+ * Mozilla scrollbar styling
+ */
+
+/* use standard opaque scrollbars for most nodes */
+[data-jp-theme-scrollbars='true'] {
+ scrollbar-color: rgb(var(--jp-scrollbar-thumb-color))
+ var(--jp-scrollbar-background-color);
+}
+
+/* for code nodes, use a transparent style of scrollbar. These selectors
+ * will match lower in the tree, and so will override the above */
+[data-jp-theme-scrollbars='true'] .CodeMirror-hscrollbar,
+[data-jp-theme-scrollbars='true'] .CodeMirror-vscrollbar {
+ scrollbar-color: rgba(var(--jp-scrollbar-thumb-color), 0.5) transparent;
+}
+
+/* tiny scrollbar */
+
+.jp-scrollbar-tiny {
+ scrollbar-color: rgba(var(--jp-scrollbar-thumb-color), 0.5) transparent;
+ scrollbar-width: thin;
+}
+
+/* tiny scrollbar */
+
+.jp-scrollbar-tiny::-webkit-scrollbar,
+.jp-scrollbar-tiny::-webkit-scrollbar-corner {
+ background-color: transparent;
+ height: 4px;
+ width: 4px;
+}
+
+.jp-scrollbar-tiny::-webkit-scrollbar-thumb {
+ background: rgba(var(--jp-scrollbar-thumb-color), 0.5);
+}
+
+.jp-scrollbar-tiny::-webkit-scrollbar-track:horizontal {
+ border-left: 0 solid transparent;
+ border-right: 0 solid transparent;
+}
+
+.jp-scrollbar-tiny::-webkit-scrollbar-track:vertical {
+ border-top: 0 solid transparent;
+ border-bottom: 0 solid transparent;
+}
+
+/*
+ * Lumino
+ */
+
+.lm-ScrollBar[data-orientation='horizontal'] {
+ min-height: 16px;
+ max-height: 16px;
+ min-width: 45px;
+ border-top: 1px solid #a0a0a0;
+}
+
+.lm-ScrollBar[data-orientation='vertical'] {
+ min-width: 16px;
+ max-width: 16px;
+ min-height: 45px;
+ border-left: 1px solid #a0a0a0;
+}
+
+.lm-ScrollBar-button {
+ background-color: #f0f0f0;
+ background-position: center center;
+ min-height: 15px;
+ max-height: 15px;
+ min-width: 15px;
+ max-width: 15px;
+}
+
+.lm-ScrollBar-button:hover {
+ background-color: #dadada;
+}
+
+.lm-ScrollBar-button.lm-mod-active {
+ background-color: #cdcdcd;
+}
+
+.lm-ScrollBar-track {
+ background: #f0f0f0;
+}
+
+.lm-ScrollBar-thumb {
+ background: #cdcdcd;
+}
+
+.lm-ScrollBar-thumb:hover {
+ background: #bababa;
+}
+
+.lm-ScrollBar-thumb.lm-mod-active {
+ background: #a0a0a0;
+}
+
+.lm-ScrollBar[data-orientation='horizontal'] .lm-ScrollBar-thumb {
+ height: 100%;
+ min-width: 15px;
+ border-left: 1px solid #a0a0a0;
+ border-right: 1px solid #a0a0a0;
+}
+
+.lm-ScrollBar[data-orientation='vertical'] .lm-ScrollBar-thumb {
+ width: 100%;
+ min-height: 15px;
+ border-top: 1px solid #a0a0a0;
+ border-bottom: 1px solid #a0a0a0;
+}
+
+.lm-ScrollBar[data-orientation='horizontal']
+ .lm-ScrollBar-button[data-action='decrement'] {
+ background-image: var(--jp-icon-caret-left);
+ background-size: 17px;
+}
+
+.lm-ScrollBar[data-orientation='horizontal']
+ .lm-ScrollBar-button[data-action='increment'] {
+ background-image: var(--jp-icon-caret-right);
+ background-size: 17px;
+}
+
+.lm-ScrollBar[data-orientation='vertical']
+ .lm-ScrollBar-button[data-action='decrement'] {
+ background-image: var(--jp-icon-caret-up);
+ background-size: 17px;
+}
+
+.lm-ScrollBar[data-orientation='vertical']
+ .lm-ScrollBar-button[data-action='increment'] {
+ background-image: var(--jp-icon-caret-down);
+ background-size: 17px;
+}
+
+/*
+ * Copyright (c) Jupyter Development Team.
+ * Distributed under the terms of the Modified BSD License.
+ */
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Copyright (c) 2014-2017, PhosphorJS Contributors
+|
+| Distributed under the terms of the BSD 3-Clause License.
+|
+| The full license is in the file LICENSE, distributed with this software.
+|----------------------------------------------------------------------------*/
+
+.lm-Widget {
+ box-sizing: border-box;
+ position: relative;
+ overflow: hidden;
+}
+
+.lm-Widget.lm-mod-hidden {
+ display: none !important;
+}
+
+/*
+ * Copyright (c) Jupyter Development Team.
+ * Distributed under the terms of the Modified BSD License.
+ */
+
+.lm-AccordionPanel[data-orientation='horizontal'] > .lm-AccordionPanel-title {
+ /* Title is rotated for horizontal accordion panel using CSS */
+ display: block;
+ transform-origin: top left;
+ transform: rotate(-90deg) translate(-100%);
+}
+
+/*
+ * Copyright (c) Jupyter Development Team.
+ * Distributed under the terms of the Modified BSD License.
+ */
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Copyright (c) 2014-2017, PhosphorJS Contributors
+|
+| Distributed under the terms of the BSD 3-Clause License.
+|
+| The full license is in the file LICENSE, distributed with this software.
+|----------------------------------------------------------------------------*/
+
+.lm-CommandPalette {
+ display: flex;
+ flex-direction: column;
+ -webkit-user-select: none;
+ -moz-user-select: none;
+ -ms-user-select: none;
+ user-select: none;
+}
+
+.lm-CommandPalette-search {
+ flex: 0 0 auto;
+}
+
+.lm-CommandPalette-content {
+ flex: 1 1 auto;
+ margin: 0;
+ padding: 0;
+ min-height: 0;
+ overflow: auto;
+ list-style-type: none;
+}
+
+.lm-CommandPalette-header {
+ overflow: hidden;
+ white-space: nowrap;
+ text-overflow: ellipsis;
+}
+
+.lm-CommandPalette-item {
+ display: flex;
+ flex-direction: row;
+}
+
+.lm-CommandPalette-itemIcon {
+ flex: 0 0 auto;
+}
+
+.lm-CommandPalette-itemContent {
+ flex: 1 1 auto;
+ overflow: hidden;
+}
+
+.lm-CommandPalette-itemShortcut {
+ flex: 0 0 auto;
+}
+
+.lm-CommandPalette-itemLabel {
+ overflow: hidden;
+ white-space: nowrap;
+ text-overflow: ellipsis;
+}
+
+.lm-close-icon {
+ border: 1px solid transparent;
+ background-color: transparent;
+ position: absolute;
+ z-index: 1;
+ right: 3%;
+ top: 0;
+ bottom: 0;
+ margin: auto;
+ padding: 7px 0;
+ display: none;
+ vertical-align: middle;
+ outline: 0;
+ cursor: pointer;
+}
+.lm-close-icon:after {
+ content: 'X';
+ display: block;
+ width: 15px;
+ height: 15px;
+ text-align: center;
+ color: #000;
+ font-weight: normal;
+ font-size: 12px;
+ cursor: pointer;
+}
+
+/*
+ * Copyright (c) Jupyter Development Team.
+ * Distributed under the terms of the Modified BSD License.
+ */
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Copyright (c) 2014-2017, PhosphorJS Contributors
+|
+| Distributed under the terms of the BSD 3-Clause License.
+|
+| The full license is in the file LICENSE, distributed with this software.
+|----------------------------------------------------------------------------*/
+
+.lm-DockPanel {
+ z-index: 0;
+}
+
+.lm-DockPanel-widget {
+ z-index: 0;
+}
+
+.lm-DockPanel-tabBar {
+ z-index: 1;
+}
+
+.lm-DockPanel-handle {
+ z-index: 2;
+}
+
+.lm-DockPanel-handle.lm-mod-hidden {
+ display: none !important;
+}
+
+.lm-DockPanel-handle:after {
+ position: absolute;
+ top: 0;
+ left: 0;
+ width: 100%;
+ height: 100%;
+ content: '';
+}
+
+.lm-DockPanel-handle[data-orientation='horizontal'] {
+ cursor: ew-resize;
+}
+
+.lm-DockPanel-handle[data-orientation='vertical'] {
+ cursor: ns-resize;
+}
+
+.lm-DockPanel-handle[data-orientation='horizontal']:after {
+ left: 50%;
+ min-width: 8px;
+ transform: translateX(-50%);
+}
+
+.lm-DockPanel-handle[data-orientation='vertical']:after {
+ top: 50%;
+ min-height: 8px;
+ transform: translateY(-50%);
+}
+
+.lm-DockPanel-overlay {
+ z-index: 3;
+ box-sizing: border-box;
+ pointer-events: none;
+}
+
+.lm-DockPanel-overlay.lm-mod-hidden {
+ display: none !important;
+}
+
+/*
+ * Copyright (c) Jupyter Development Team.
+ * Distributed under the terms of the Modified BSD License.
+ */
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Copyright (c) 2014-2017, PhosphorJS Contributors
+|
+| Distributed under the terms of the BSD 3-Clause License.
+|
+| The full license is in the file LICENSE, distributed with this software.
+|----------------------------------------------------------------------------*/
+
+.lm-Menu {
+ z-index: 10000;
+ position: absolute;
+ white-space: nowrap;
+ overflow-x: hidden;
+ overflow-y: auto;
+ outline: none;
+ -webkit-user-select: none;
+ -moz-user-select: none;
+ -ms-user-select: none;
+ user-select: none;
+}
+
+.lm-Menu-content {
+ margin: 0;
+ padding: 0;
+ display: table;
+ list-style-type: none;
+}
+
+.lm-Menu-item {
+ display: table-row;
+}
+
+.lm-Menu-item.lm-mod-hidden,
+.lm-Menu-item.lm-mod-collapsed {
+ display: none !important;
+}
+
+.lm-Menu-itemIcon,
+.lm-Menu-itemSubmenuIcon {
+ display: table-cell;
+ text-align: center;
+}
+
+.lm-Menu-itemLabel {
+ display: table-cell;
+ text-align: left;
+}
+
+.lm-Menu-itemShortcut {
+ display: table-cell;
+ text-align: right;
+}
+
+/*
+ * Copyright (c) Jupyter Development Team.
+ * Distributed under the terms of the Modified BSD License.
+ */
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Copyright (c) 2014-2017, PhosphorJS Contributors
+|
+| Distributed under the terms of the BSD 3-Clause License.
+|
+| The full license is in the file LICENSE, distributed with this software.
+|----------------------------------------------------------------------------*/
+
+.lm-MenuBar {
+ outline: none;
+ -webkit-user-select: none;
+ -moz-user-select: none;
+ -ms-user-select: none;
+ user-select: none;
+}
+
+.lm-MenuBar-content {
+ margin: 0;
+ padding: 0;
+ display: flex;
+ flex-direction: row;
+ list-style-type: none;
+}
+
+.lm-MenuBar-item {
+ box-sizing: border-box;
+}
+
+.lm-MenuBar-itemIcon,
+.lm-MenuBar-itemLabel {
+ display: inline-block;
+}
+
+/*
+ * Copyright (c) Jupyter Development Team.
+ * Distributed under the terms of the Modified BSD License.
+ */
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Copyright (c) 2014-2017, PhosphorJS Contributors
+|
+| Distributed under the terms of the BSD 3-Clause License.
+|
+| The full license is in the file LICENSE, distributed with this software.
+|----------------------------------------------------------------------------*/
+
+.lm-ScrollBar {
+ display: flex;
+ -webkit-user-select: none;
+ -moz-user-select: none;
+ -ms-user-select: none;
+ user-select: none;
+}
+
+.lm-ScrollBar[data-orientation='horizontal'] {
+ flex-direction: row;
+}
+
+.lm-ScrollBar[data-orientation='vertical'] {
+ flex-direction: column;
+}
+
+.lm-ScrollBar-button {
+ box-sizing: border-box;
+ flex: 0 0 auto;
+}
+
+.lm-ScrollBar-track {
+ box-sizing: border-box;
+ position: relative;
+ overflow: hidden;
+ flex: 1 1 auto;
+}
+
+.lm-ScrollBar-thumb {
+ box-sizing: border-box;
+ position: absolute;
+}
+
+/*
+ * Copyright (c) Jupyter Development Team.
+ * Distributed under the terms of the Modified BSD License.
+ */
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Copyright (c) 2014-2017, PhosphorJS Contributors
+|
+| Distributed under the terms of the BSD 3-Clause License.
+|
+| The full license is in the file LICENSE, distributed with this software.
+|----------------------------------------------------------------------------*/
+
+.lm-SplitPanel-child {
+ z-index: 0;
+}
+
+.lm-SplitPanel-handle {
+ z-index: 1;
+}
+
+.lm-SplitPanel-handle.lm-mod-hidden {
+ display: none !important;
+}
+
+.lm-SplitPanel-handle:after {
+ position: absolute;
+ top: 0;
+ left: 0;
+ width: 100%;
+ height: 100%;
+ content: '';
+}
+
+.lm-SplitPanel[data-orientation='horizontal'] > .lm-SplitPanel-handle {
+ cursor: ew-resize;
+}
+
+.lm-SplitPanel[data-orientation='vertical'] > .lm-SplitPanel-handle {
+ cursor: ns-resize;
+}
+
+.lm-SplitPanel[data-orientation='horizontal'] > .lm-SplitPanel-handle:after {
+ left: 50%;
+ min-width: 8px;
+ transform: translateX(-50%);
+}
+
+.lm-SplitPanel[data-orientation='vertical'] > .lm-SplitPanel-handle:after {
+ top: 50%;
+ min-height: 8px;
+ transform: translateY(-50%);
+}
+
+/*
+ * Copyright (c) Jupyter Development Team.
+ * Distributed under the terms of the Modified BSD License.
+ */
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Copyright (c) 2014-2017, PhosphorJS Contributors
+|
+| Distributed under the terms of the BSD 3-Clause License.
+|
+| The full license is in the file LICENSE, distributed with this software.
+|----------------------------------------------------------------------------*/
+
+.lm-TabBar {
+ display: flex;
+ -webkit-user-select: none;
+ -moz-user-select: none;
+ -ms-user-select: none;
+ user-select: none;
+}
+
+.lm-TabBar[data-orientation='horizontal'] {
+ flex-direction: row;
+ align-items: flex-end;
+}
+
+.lm-TabBar[data-orientation='vertical'] {
+ flex-direction: column;
+ align-items: flex-end;
+}
+
+.lm-TabBar-content {
+ margin: 0;
+ padding: 0;
+ display: flex;
+ flex: 1 1 auto;
+ list-style-type: none;
+}
+
+.lm-TabBar[data-orientation='horizontal'] > .lm-TabBar-content {
+ flex-direction: row;
+}
+
+.lm-TabBar[data-orientation='vertical'] > .lm-TabBar-content {
+ flex-direction: column;
+}
+
+.lm-TabBar-tab {
+ display: flex;
+ flex-direction: row;
+ box-sizing: border-box;
+ overflow: hidden;
+ touch-action: none; /* Disable native Drag/Drop */
+}
+
+.lm-TabBar-tabIcon,
+.lm-TabBar-tabCloseIcon {
+ flex: 0 0 auto;
+}
+
+.lm-TabBar-tabLabel {
+ flex: 1 1 auto;
+ overflow: hidden;
+ white-space: nowrap;
+}
+
+.lm-TabBar-tabInput {
+ user-select: all;
+ width: 100%;
+ box-sizing: border-box;
+}
+
+.lm-TabBar-tab.lm-mod-hidden {
+ display: none !important;
+}
+
+.lm-TabBar-addButton.lm-mod-hidden {
+ display: none !important;
+}
+
+.lm-TabBar.lm-mod-dragging .lm-TabBar-tab {
+ position: relative;
+}
+
+.lm-TabBar.lm-mod-dragging[data-orientation='horizontal'] .lm-TabBar-tab {
+ left: 0;
+ transition: left 150ms ease;
+}
+
+.lm-TabBar.lm-mod-dragging[data-orientation='vertical'] .lm-TabBar-tab {
+ top: 0;
+ transition: top 150ms ease;
+}
+
+.lm-TabBar.lm-mod-dragging .lm-TabBar-tab.lm-mod-dragging {
+ transition: none;
+}
+
+.lm-TabBar-tabLabel .lm-TabBar-tabInput {
+ user-select: all;
+ width: 100%;
+ box-sizing: border-box;
+ background: inherit;
+}
+
+/*
+ * Copyright (c) Jupyter Development Team.
+ * Distributed under the terms of the Modified BSD License.
+ */
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Copyright (c) 2014-2017, PhosphorJS Contributors
+|
+| Distributed under the terms of the BSD 3-Clause License.
+|
+| The full license is in the file LICENSE, distributed with this software.
+|----------------------------------------------------------------------------*/
+
+.lm-TabPanel-tabBar {
+ z-index: 1;
+}
+
+.lm-TabPanel-stackedPanel {
+ z-index: 0;
+}
+
+/*
+ * Copyright (c) Jupyter Development Team.
+ * Distributed under the terms of the Modified BSD License.
+ */
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Copyright (c) 2014-2017, PhosphorJS Contributors
+|
+| Distributed under the terms of the BSD 3-Clause License.
+|
+| The full license is in the file LICENSE, distributed with this software.
+|----------------------------------------------------------------------------*/
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+.jp-Collapse {
+ display: flex;
+ flex-direction: column;
+ align-items: stretch;
+}
+
+.jp-Collapse-header {
+ padding: 1px 12px;
+ background-color: var(--jp-layout-color1);
+ border-bottom: solid var(--jp-border-width) var(--jp-border-color2);
+ color: var(--jp-ui-font-color1);
+ cursor: pointer;
+ display: flex;
+ align-items: center;
+ font-size: var(--jp-ui-font-size0);
+ font-weight: 600;
+ text-transform: uppercase;
+ user-select: none;
+}
+
+.jp-Collapser-icon {
+ height: 16px;
+}
+
+.jp-Collapse-header-collapsed .jp-Collapser-icon {
+ transform: rotate(-90deg);
+ margin: auto 0;
+}
+
+.jp-Collapser-title {
+ line-height: 25px;
+}
+
+.jp-Collapse-contents {
+ padding: 0 12px;
+ background-color: var(--jp-layout-color1);
+ color: var(--jp-ui-font-color1);
+ overflow: auto;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/* This file was auto-generated by ensureUiComponents() in @jupyterlab/buildutils */
+
+/**
+ * (DEPRECATED) Support for consuming icons as CSS background images
+ */
+
+/* Icons urls */
+
+:root {
+ --jp-icon-add-above: url();
+ --jp-icon-add-below: url();
+ --jp-icon-add: url();
+ --jp-icon-bell: url();
+ --jp-icon-bug-dot: url();
+ --jp-icon-bug: url();
+ --jp-icon-build: url();
+ --jp-icon-caret-down-empty-thin: url();
+ --jp-icon-caret-down-empty: url();
+ --jp-icon-caret-down: url();
+ --jp-icon-caret-left: url();
+ --jp-icon-caret-right: url();
+ --jp-icon-caret-up-empty-thin: url();
+ --jp-icon-caret-up: url();
+ --jp-icon-case-sensitive: url();
+ --jp-icon-check: url();
+ --jp-icon-circle-empty: url();
+ --jp-icon-circle: url();
+ --jp-icon-clear: url();
+ --jp-icon-close: url();
+ --jp-icon-code-check: url();
+ --jp-icon-code: url();
+ --jp-icon-collapse-all: url();
+ --jp-icon-console: url();
+ --jp-icon-copy: url();
+ --jp-icon-copyright: url();
+ --jp-icon-cut: url();
+ --jp-icon-delete: url();
+ --jp-icon-download: url();
+ --jp-icon-duplicate: url();
+ --jp-icon-edit: url();
+ --jp-icon-ellipses: url();
+ --jp-icon-error: url();
+ --jp-icon-expand-all: url();
+ --jp-icon-extension: url();
+ --jp-icon-fast-forward: url();
+ --jp-icon-file-upload: url();
+ --jp-icon-file: url();
+ --jp-icon-filter-dot: url();
+ --jp-icon-filter-list: url();
+ --jp-icon-filter: url();
+ --jp-icon-folder-favorite: url();
+ --jp-icon-folder: url();
+ --jp-icon-home: url();
+ --jp-icon-html5: url();
+ --jp-icon-image: url();
+ --jp-icon-info: url();
+ --jp-icon-inspector: url();
+ --jp-icon-json: url();
+ --jp-icon-julia: url();
+ --jp-icon-jupyter-favicon: url();
+ --jp-icon-jupyter: url();
+ --jp-icon-jupyterlab-wordmark: url();
+ --jp-icon-kernel: url();
+ --jp-icon-keyboard: url();
+ --jp-icon-launch: url();
+ --jp-icon-launcher: url();
+ --jp-icon-line-form: url();
+ --jp-icon-link: url();
+ --jp-icon-list: url();
+ --jp-icon-markdown: url();
+ --jp-icon-move-down: url();
+ --jp-icon-move-up: url();
+ --jp-icon-new-folder: url();
+ --jp-icon-not-trusted: url();
+ --jp-icon-notebook: url();
+ --jp-icon-numbering: url();
+ --jp-icon-offline-bolt: url();
+ --jp-icon-palette: url();
+ --jp-icon-paste: url();
+ --jp-icon-pdf: url();
+ --jp-icon-python: url();
+ --jp-icon-r-kernel: url();
+ --jp-icon-react: url();
+ --jp-icon-redo: url();
+ --jp-icon-refresh: url();
+ --jp-icon-regex: url();
+ --jp-icon-run: url();
+ --jp-icon-running: url();
+ --jp-icon-save: url();
+ --jp-icon-search: url();
+ --jp-icon-settings: url();
+ --jp-icon-share: url();
+ --jp-icon-spreadsheet: url();
+ --jp-icon-stop: url();
+ --jp-icon-tab: url();
+ --jp-icon-table-rows: url();
+ --jp-icon-tag: url();
+ --jp-icon-terminal: url();
+ --jp-icon-text-editor: url();
+ --jp-icon-toc: url();
+ --jp-icon-tree-view: url();
+ --jp-icon-trusted: url();
+ --jp-icon-undo: url();
+ --jp-icon-user: url();
+ --jp-icon-users: url();
+ --jp-icon-vega: url();
+ --jp-icon-word: url();
+ --jp-icon-yaml: url();
+}
+
+/* Icon CSS class declarations */
+
+.jp-AddAboveIcon {
+ background-image: var(--jp-icon-add-above);
+}
+
+.jp-AddBelowIcon {
+ background-image: var(--jp-icon-add-below);
+}
+
+.jp-AddIcon {
+ background-image: var(--jp-icon-add);
+}
+
+.jp-BellIcon {
+ background-image: var(--jp-icon-bell);
+}
+
+.jp-BugDotIcon {
+ background-image: var(--jp-icon-bug-dot);
+}
+
+.jp-BugIcon {
+ background-image: var(--jp-icon-bug);
+}
+
+.jp-BuildIcon {
+ background-image: var(--jp-icon-build);
+}
+
+.jp-CaretDownEmptyIcon {
+ background-image: var(--jp-icon-caret-down-empty);
+}
+
+.jp-CaretDownEmptyThinIcon {
+ background-image: var(--jp-icon-caret-down-empty-thin);
+}
+
+.jp-CaretDownIcon {
+ background-image: var(--jp-icon-caret-down);
+}
+
+.jp-CaretLeftIcon {
+ background-image: var(--jp-icon-caret-left);
+}
+
+.jp-CaretRightIcon {
+ background-image: var(--jp-icon-caret-right);
+}
+
+.jp-CaretUpEmptyThinIcon {
+ background-image: var(--jp-icon-caret-up-empty-thin);
+}
+
+.jp-CaretUpIcon {
+ background-image: var(--jp-icon-caret-up);
+}
+
+.jp-CaseSensitiveIcon {
+ background-image: var(--jp-icon-case-sensitive);
+}
+
+.jp-CheckIcon {
+ background-image: var(--jp-icon-check);
+}
+
+.jp-CircleEmptyIcon {
+ background-image: var(--jp-icon-circle-empty);
+}
+
+.jp-CircleIcon {
+ background-image: var(--jp-icon-circle);
+}
+
+.jp-ClearIcon {
+ background-image: var(--jp-icon-clear);
+}
+
+.jp-CloseIcon {
+ background-image: var(--jp-icon-close);
+}
+
+.jp-CodeCheckIcon {
+ background-image: var(--jp-icon-code-check);
+}
+
+.jp-CodeIcon {
+ background-image: var(--jp-icon-code);
+}
+
+.jp-CollapseAllIcon {
+ background-image: var(--jp-icon-collapse-all);
+}
+
+.jp-ConsoleIcon {
+ background-image: var(--jp-icon-console);
+}
+
+.jp-CopyIcon {
+ background-image: var(--jp-icon-copy);
+}
+
+.jp-CopyrightIcon {
+ background-image: var(--jp-icon-copyright);
+}
+
+.jp-CutIcon {
+ background-image: var(--jp-icon-cut);
+}
+
+.jp-DeleteIcon {
+ background-image: var(--jp-icon-delete);
+}
+
+.jp-DownloadIcon {
+ background-image: var(--jp-icon-download);
+}
+
+.jp-DuplicateIcon {
+ background-image: var(--jp-icon-duplicate);
+}
+
+.jp-EditIcon {
+ background-image: var(--jp-icon-edit);
+}
+
+.jp-EllipsesIcon {
+ background-image: var(--jp-icon-ellipses);
+}
+
+.jp-ErrorIcon {
+ background-image: var(--jp-icon-error);
+}
+
+.jp-ExpandAllIcon {
+ background-image: var(--jp-icon-expand-all);
+}
+
+.jp-ExtensionIcon {
+ background-image: var(--jp-icon-extension);
+}
+
+.jp-FastForwardIcon {
+ background-image: var(--jp-icon-fast-forward);
+}
+
+.jp-FileIcon {
+ background-image: var(--jp-icon-file);
+}
+
+.jp-FileUploadIcon {
+ background-image: var(--jp-icon-file-upload);
+}
+
+.jp-FilterDotIcon {
+ background-image: var(--jp-icon-filter-dot);
+}
+
+.jp-FilterIcon {
+ background-image: var(--jp-icon-filter);
+}
+
+.jp-FilterListIcon {
+ background-image: var(--jp-icon-filter-list);
+}
+
+.jp-FolderFavoriteIcon {
+ background-image: var(--jp-icon-folder-favorite);
+}
+
+.jp-FolderIcon {
+ background-image: var(--jp-icon-folder);
+}
+
+.jp-HomeIcon {
+ background-image: var(--jp-icon-home);
+}
+
+.jp-Html5Icon {
+ background-image: var(--jp-icon-html5);
+}
+
+.jp-ImageIcon {
+ background-image: var(--jp-icon-image);
+}
+
+.jp-InfoIcon {
+ background-image: var(--jp-icon-info);
+}
+
+.jp-InspectorIcon {
+ background-image: var(--jp-icon-inspector);
+}
+
+.jp-JsonIcon {
+ background-image: var(--jp-icon-json);
+}
+
+.jp-JuliaIcon {
+ background-image: var(--jp-icon-julia);
+}
+
+.jp-JupyterFaviconIcon {
+ background-image: var(--jp-icon-jupyter-favicon);
+}
+
+.jp-JupyterIcon {
+ background-image: var(--jp-icon-jupyter);
+}
+
+.jp-JupyterlabWordmarkIcon {
+ background-image: var(--jp-icon-jupyterlab-wordmark);
+}
+
+.jp-KernelIcon {
+ background-image: var(--jp-icon-kernel);
+}
+
+.jp-KeyboardIcon {
+ background-image: var(--jp-icon-keyboard);
+}
+
+.jp-LaunchIcon {
+ background-image: var(--jp-icon-launch);
+}
+
+.jp-LauncherIcon {
+ background-image: var(--jp-icon-launcher);
+}
+
+.jp-LineFormIcon {
+ background-image: var(--jp-icon-line-form);
+}
+
+.jp-LinkIcon {
+ background-image: var(--jp-icon-link);
+}
+
+.jp-ListIcon {
+ background-image: var(--jp-icon-list);
+}
+
+.jp-MarkdownIcon {
+ background-image: var(--jp-icon-markdown);
+}
+
+.jp-MoveDownIcon {
+ background-image: var(--jp-icon-move-down);
+}
+
+.jp-MoveUpIcon {
+ background-image: var(--jp-icon-move-up);
+}
+
+.jp-NewFolderIcon {
+ background-image: var(--jp-icon-new-folder);
+}
+
+.jp-NotTrustedIcon {
+ background-image: var(--jp-icon-not-trusted);
+}
+
+.jp-NotebookIcon {
+ background-image: var(--jp-icon-notebook);
+}
+
+.jp-NumberingIcon {
+ background-image: var(--jp-icon-numbering);
+}
+
+.jp-OfflineBoltIcon {
+ background-image: var(--jp-icon-offline-bolt);
+}
+
+.jp-PaletteIcon {
+ background-image: var(--jp-icon-palette);
+}
+
+.jp-PasteIcon {
+ background-image: var(--jp-icon-paste);
+}
+
+.jp-PdfIcon {
+ background-image: var(--jp-icon-pdf);
+}
+
+.jp-PythonIcon {
+ background-image: var(--jp-icon-python);
+}
+
+.jp-RKernelIcon {
+ background-image: var(--jp-icon-r-kernel);
+}
+
+.jp-ReactIcon {
+ background-image: var(--jp-icon-react);
+}
+
+.jp-RedoIcon {
+ background-image: var(--jp-icon-redo);
+}
+
+.jp-RefreshIcon {
+ background-image: var(--jp-icon-refresh);
+}
+
+.jp-RegexIcon {
+ background-image: var(--jp-icon-regex);
+}
+
+.jp-RunIcon {
+ background-image: var(--jp-icon-run);
+}
+
+.jp-RunningIcon {
+ background-image: var(--jp-icon-running);
+}
+
+.jp-SaveIcon {
+ background-image: var(--jp-icon-save);
+}
+
+.jp-SearchIcon {
+ background-image: var(--jp-icon-search);
+}
+
+.jp-SettingsIcon {
+ background-image: var(--jp-icon-settings);
+}
+
+.jp-ShareIcon {
+ background-image: var(--jp-icon-share);
+}
+
+.jp-SpreadsheetIcon {
+ background-image: var(--jp-icon-spreadsheet);
+}
+
+.jp-StopIcon {
+ background-image: var(--jp-icon-stop);
+}
+
+.jp-TabIcon {
+ background-image: var(--jp-icon-tab);
+}
+
+.jp-TableRowsIcon {
+ background-image: var(--jp-icon-table-rows);
+}
+
+.jp-TagIcon {
+ background-image: var(--jp-icon-tag);
+}
+
+.jp-TerminalIcon {
+ background-image: var(--jp-icon-terminal);
+}
+
+.jp-TextEditorIcon {
+ background-image: var(--jp-icon-text-editor);
+}
+
+.jp-TocIcon {
+ background-image: var(--jp-icon-toc);
+}
+
+.jp-TreeViewIcon {
+ background-image: var(--jp-icon-tree-view);
+}
+
+.jp-TrustedIcon {
+ background-image: var(--jp-icon-trusted);
+}
+
+.jp-UndoIcon {
+ background-image: var(--jp-icon-undo);
+}
+
+.jp-UserIcon {
+ background-image: var(--jp-icon-user);
+}
+
+.jp-UsersIcon {
+ background-image: var(--jp-icon-users);
+}
+
+.jp-VegaIcon {
+ background-image: var(--jp-icon-vega);
+}
+
+.jp-WordIcon {
+ background-image: var(--jp-icon-word);
+}
+
+.jp-YamlIcon {
+ background-image: var(--jp-icon-yaml);
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/**
+ * (DEPRECATED) Support for consuming icons as CSS background images
+ */
+
+.jp-Icon,
+.jp-MaterialIcon {
+ background-position: center;
+ background-repeat: no-repeat;
+ background-size: 16px;
+ min-width: 16px;
+ min-height: 16px;
+}
+
+.jp-Icon-cover {
+ background-position: center;
+ background-repeat: no-repeat;
+ background-size: cover;
+}
+
+/**
+ * (DEPRECATED) Support for specific CSS icon sizes
+ */
+
+.jp-Icon-16 {
+ background-size: 16px;
+ min-width: 16px;
+ min-height: 16px;
+}
+
+.jp-Icon-18 {
+ background-size: 18px;
+ min-width: 18px;
+ min-height: 18px;
+}
+
+.jp-Icon-20 {
+ background-size: 20px;
+ min-width: 20px;
+ min-height: 20px;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+.lm-TabBar .lm-TabBar-addButton {
+ align-items: center;
+ display: flex;
+ padding: 4px;
+ padding-bottom: 5px;
+ margin-right: 1px;
+ background-color: var(--jp-layout-color2);
+}
+
+.lm-TabBar .lm-TabBar-addButton:hover {
+ background-color: var(--jp-layout-color1);
+}
+
+.lm-DockPanel-tabBar .lm-TabBar-tab {
+ width: var(--jp-private-horizontal-tab-width);
+}
+
+.lm-DockPanel-tabBar .lm-TabBar-content {
+ flex: unset;
+}
+
+.lm-DockPanel-tabBar[data-orientation='horizontal'] {
+ flex: 1 1 auto;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/**
+ * Support for icons as inline SVG HTMLElements
+ */
+
+/* recolor the primary elements of an icon */
+.jp-icon0[fill] {
+ fill: var(--jp-inverse-layout-color0);
+}
+
+.jp-icon1[fill] {
+ fill: var(--jp-inverse-layout-color1);
+}
+
+.jp-icon2[fill] {
+ fill: var(--jp-inverse-layout-color2);
+}
+
+.jp-icon3[fill] {
+ fill: var(--jp-inverse-layout-color3);
+}
+
+.jp-icon4[fill] {
+ fill: var(--jp-inverse-layout-color4);
+}
+
+.jp-icon0[stroke] {
+ stroke: var(--jp-inverse-layout-color0);
+}
+
+.jp-icon1[stroke] {
+ stroke: var(--jp-inverse-layout-color1);
+}
+
+.jp-icon2[stroke] {
+ stroke: var(--jp-inverse-layout-color2);
+}
+
+.jp-icon3[stroke] {
+ stroke: var(--jp-inverse-layout-color3);
+}
+
+.jp-icon4[stroke] {
+ stroke: var(--jp-inverse-layout-color4);
+}
+
+/* recolor the accent elements of an icon */
+.jp-icon-accent0[fill] {
+ fill: var(--jp-layout-color0);
+}
+
+.jp-icon-accent1[fill] {
+ fill: var(--jp-layout-color1);
+}
+
+.jp-icon-accent2[fill] {
+ fill: var(--jp-layout-color2);
+}
+
+.jp-icon-accent3[fill] {
+ fill: var(--jp-layout-color3);
+}
+
+.jp-icon-accent4[fill] {
+ fill: var(--jp-layout-color4);
+}
+
+.jp-icon-accent0[stroke] {
+ stroke: var(--jp-layout-color0);
+}
+
+.jp-icon-accent1[stroke] {
+ stroke: var(--jp-layout-color1);
+}
+
+.jp-icon-accent2[stroke] {
+ stroke: var(--jp-layout-color2);
+}
+
+.jp-icon-accent3[stroke] {
+ stroke: var(--jp-layout-color3);
+}
+
+.jp-icon-accent4[stroke] {
+ stroke: var(--jp-layout-color4);
+}
+
+/* set the color of an icon to transparent */
+.jp-icon-none[fill] {
+ fill: none;
+}
+
+.jp-icon-none[stroke] {
+ stroke: none;
+}
+
+/* brand icon colors. Same for light and dark */
+.jp-icon-brand0[fill] {
+ fill: var(--jp-brand-color0);
+}
+
+.jp-icon-brand1[fill] {
+ fill: var(--jp-brand-color1);
+}
+
+.jp-icon-brand2[fill] {
+ fill: var(--jp-brand-color2);
+}
+
+.jp-icon-brand3[fill] {
+ fill: var(--jp-brand-color3);
+}
+
+.jp-icon-brand4[fill] {
+ fill: var(--jp-brand-color4);
+}
+
+.jp-icon-brand0[stroke] {
+ stroke: var(--jp-brand-color0);
+}
+
+.jp-icon-brand1[stroke] {
+ stroke: var(--jp-brand-color1);
+}
+
+.jp-icon-brand2[stroke] {
+ stroke: var(--jp-brand-color2);
+}
+
+.jp-icon-brand3[stroke] {
+ stroke: var(--jp-brand-color3);
+}
+
+.jp-icon-brand4[stroke] {
+ stroke: var(--jp-brand-color4);
+}
+
+/* warn icon colors. Same for light and dark */
+.jp-icon-warn0[fill] {
+ fill: var(--jp-warn-color0);
+}
+
+.jp-icon-warn1[fill] {
+ fill: var(--jp-warn-color1);
+}
+
+.jp-icon-warn2[fill] {
+ fill: var(--jp-warn-color2);
+}
+
+.jp-icon-warn3[fill] {
+ fill: var(--jp-warn-color3);
+}
+
+.jp-icon-warn0[stroke] {
+ stroke: var(--jp-warn-color0);
+}
+
+.jp-icon-warn1[stroke] {
+ stroke: var(--jp-warn-color1);
+}
+
+.jp-icon-warn2[stroke] {
+ stroke: var(--jp-warn-color2);
+}
+
+.jp-icon-warn3[stroke] {
+ stroke: var(--jp-warn-color3);
+}
+
+/* icon colors that contrast well with each other and most backgrounds */
+.jp-icon-contrast0[fill] {
+ fill: var(--jp-icon-contrast-color0);
+}
+
+.jp-icon-contrast1[fill] {
+ fill: var(--jp-icon-contrast-color1);
+}
+
+.jp-icon-contrast2[fill] {
+ fill: var(--jp-icon-contrast-color2);
+}
+
+.jp-icon-contrast3[fill] {
+ fill: var(--jp-icon-contrast-color3);
+}
+
+.jp-icon-contrast0[stroke] {
+ stroke: var(--jp-icon-contrast-color0);
+}
+
+.jp-icon-contrast1[stroke] {
+ stroke: var(--jp-icon-contrast-color1);
+}
+
+.jp-icon-contrast2[stroke] {
+ stroke: var(--jp-icon-contrast-color2);
+}
+
+.jp-icon-contrast3[stroke] {
+ stroke: var(--jp-icon-contrast-color3);
+}
+
+.jp-icon-dot[fill] {
+ fill: var(--jp-warn-color0);
+}
+
+.jp-jupyter-icon-color[fill] {
+ fill: var(--jp-jupyter-icon-color, var(--jp-warn-color0));
+}
+
+.jp-notebook-icon-color[fill] {
+ fill: var(--jp-notebook-icon-color, var(--jp-warn-color0));
+}
+
+.jp-json-icon-color[fill] {
+ fill: var(--jp-json-icon-color, var(--jp-warn-color1));
+}
+
+.jp-console-icon-color[fill] {
+ fill: var(--jp-console-icon-color, white);
+}
+
+.jp-console-icon-background-color[fill] {
+ fill: var(--jp-console-icon-background-color, var(--jp-brand-color1));
+}
+
+.jp-terminal-icon-color[fill] {
+ fill: var(--jp-terminal-icon-color, var(--jp-layout-color2));
+}
+
+.jp-terminal-icon-background-color[fill] {
+ fill: var(
+ --jp-terminal-icon-background-color,
+ var(--jp-inverse-layout-color2)
+ );
+}
+
+.jp-text-editor-icon-color[fill] {
+ fill: var(--jp-text-editor-icon-color, var(--jp-inverse-layout-color3));
+}
+
+.jp-inspector-icon-color[fill] {
+ fill: var(--jp-inspector-icon-color, var(--jp-inverse-layout-color3));
+}
+
+/* CSS for icons in selected filebrowser listing items */
+.jp-DirListing-item.jp-mod-selected .jp-icon-selectable[fill] {
+ fill: #fff;
+}
+
+.jp-DirListing-item.jp-mod-selected .jp-icon-selectable-inverse[fill] {
+ fill: var(--jp-brand-color1);
+}
+
+/* stylelint-disable selector-max-class, selector-max-compound-selectors */
+
+/**
+* TODO: come up with non css-hack solution for showing the busy icon on top
+* of the close icon
+* CSS for complex behavior of close icon of tabs in the main area tabbar
+*/
+.lm-DockPanel-tabBar
+ .lm-TabBar-tab.lm-mod-closable.jp-mod-dirty
+ > .lm-TabBar-tabCloseIcon
+ > :not(:hover)
+ > .jp-icon3[fill] {
+ fill: none;
+}
+
+.lm-DockPanel-tabBar
+ .lm-TabBar-tab.lm-mod-closable.jp-mod-dirty
+ > .lm-TabBar-tabCloseIcon
+ > :not(:hover)
+ > .jp-icon-busy[fill] {
+ fill: var(--jp-inverse-layout-color3);
+}
+
+/* stylelint-enable selector-max-class, selector-max-compound-selectors */
+
+/* CSS for icons in status bar */
+#jp-main-statusbar .jp-mod-selected .jp-icon-selectable[fill] {
+ fill: #fff;
+}
+
+#jp-main-statusbar .jp-mod-selected .jp-icon-selectable-inverse[fill] {
+ fill: var(--jp-brand-color1);
+}
+
+/* special handling for splash icon CSS. While the theme CSS reloads during
+ splash, the splash icon can loose theming. To prevent that, we set a
+ default for its color variable */
+:root {
+ --jp-warn-color0: var(--md-orange-700);
+}
+
+/* not sure what to do with this one, used in filebrowser listing */
+.jp-DragIcon {
+ margin-right: 4px;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/**
+ * Support for alt colors for icons as inline SVG HTMLElements
+ */
+
+/* alt recolor the primary elements of an icon */
+.jp-icon-alt .jp-icon0[fill] {
+ fill: var(--jp-layout-color0);
+}
+
+.jp-icon-alt .jp-icon1[fill] {
+ fill: var(--jp-layout-color1);
+}
+
+.jp-icon-alt .jp-icon2[fill] {
+ fill: var(--jp-layout-color2);
+}
+
+.jp-icon-alt .jp-icon3[fill] {
+ fill: var(--jp-layout-color3);
+}
+
+.jp-icon-alt .jp-icon4[fill] {
+ fill: var(--jp-layout-color4);
+}
+
+.jp-icon-alt .jp-icon0[stroke] {
+ stroke: var(--jp-layout-color0);
+}
+
+.jp-icon-alt .jp-icon1[stroke] {
+ stroke: var(--jp-layout-color1);
+}
+
+.jp-icon-alt .jp-icon2[stroke] {
+ stroke: var(--jp-layout-color2);
+}
+
+.jp-icon-alt .jp-icon3[stroke] {
+ stroke: var(--jp-layout-color3);
+}
+
+.jp-icon-alt .jp-icon4[stroke] {
+ stroke: var(--jp-layout-color4);
+}
+
+/* alt recolor the accent elements of an icon */
+.jp-icon-alt .jp-icon-accent0[fill] {
+ fill: var(--jp-inverse-layout-color0);
+}
+
+.jp-icon-alt .jp-icon-accent1[fill] {
+ fill: var(--jp-inverse-layout-color1);
+}
+
+.jp-icon-alt .jp-icon-accent2[fill] {
+ fill: var(--jp-inverse-layout-color2);
+}
+
+.jp-icon-alt .jp-icon-accent3[fill] {
+ fill: var(--jp-inverse-layout-color3);
+}
+
+.jp-icon-alt .jp-icon-accent4[fill] {
+ fill: var(--jp-inverse-layout-color4);
+}
+
+.jp-icon-alt .jp-icon-accent0[stroke] {
+ stroke: var(--jp-inverse-layout-color0);
+}
+
+.jp-icon-alt .jp-icon-accent1[stroke] {
+ stroke: var(--jp-inverse-layout-color1);
+}
+
+.jp-icon-alt .jp-icon-accent2[stroke] {
+ stroke: var(--jp-inverse-layout-color2);
+}
+
+.jp-icon-alt .jp-icon-accent3[stroke] {
+ stroke: var(--jp-inverse-layout-color3);
+}
+
+.jp-icon-alt .jp-icon-accent4[stroke] {
+ stroke: var(--jp-inverse-layout-color4);
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+.jp-icon-hoverShow:not(:hover) .jp-icon-hoverShow-content {
+ display: none !important;
+}
+
+/**
+ * Support for hover colors for icons as inline SVG HTMLElements
+ */
+
+/**
+ * regular colors
+ */
+
+/* recolor the primary elements of an icon */
+.jp-icon-hover :hover .jp-icon0-hover[fill] {
+ fill: var(--jp-inverse-layout-color0);
+}
+
+.jp-icon-hover :hover .jp-icon1-hover[fill] {
+ fill: var(--jp-inverse-layout-color1);
+}
+
+.jp-icon-hover :hover .jp-icon2-hover[fill] {
+ fill: var(--jp-inverse-layout-color2);
+}
+
+.jp-icon-hover :hover .jp-icon3-hover[fill] {
+ fill: var(--jp-inverse-layout-color3);
+}
+
+.jp-icon-hover :hover .jp-icon4-hover[fill] {
+ fill: var(--jp-inverse-layout-color4);
+}
+
+.jp-icon-hover :hover .jp-icon0-hover[stroke] {
+ stroke: var(--jp-inverse-layout-color0);
+}
+
+.jp-icon-hover :hover .jp-icon1-hover[stroke] {
+ stroke: var(--jp-inverse-layout-color1);
+}
+
+.jp-icon-hover :hover .jp-icon2-hover[stroke] {
+ stroke: var(--jp-inverse-layout-color2);
+}
+
+.jp-icon-hover :hover .jp-icon3-hover[stroke] {
+ stroke: var(--jp-inverse-layout-color3);
+}
+
+.jp-icon-hover :hover .jp-icon4-hover[stroke] {
+ stroke: var(--jp-inverse-layout-color4);
+}
+
+/* recolor the accent elements of an icon */
+.jp-icon-hover :hover .jp-icon-accent0-hover[fill] {
+ fill: var(--jp-layout-color0);
+}
+
+.jp-icon-hover :hover .jp-icon-accent1-hover[fill] {
+ fill: var(--jp-layout-color1);
+}
+
+.jp-icon-hover :hover .jp-icon-accent2-hover[fill] {
+ fill: var(--jp-layout-color2);
+}
+
+.jp-icon-hover :hover .jp-icon-accent3-hover[fill] {
+ fill: var(--jp-layout-color3);
+}
+
+.jp-icon-hover :hover .jp-icon-accent4-hover[fill] {
+ fill: var(--jp-layout-color4);
+}
+
+.jp-icon-hover :hover .jp-icon-accent0-hover[stroke] {
+ stroke: var(--jp-layout-color0);
+}
+
+.jp-icon-hover :hover .jp-icon-accent1-hover[stroke] {
+ stroke: var(--jp-layout-color1);
+}
+
+.jp-icon-hover :hover .jp-icon-accent2-hover[stroke] {
+ stroke: var(--jp-layout-color2);
+}
+
+.jp-icon-hover :hover .jp-icon-accent3-hover[stroke] {
+ stroke: var(--jp-layout-color3);
+}
+
+.jp-icon-hover :hover .jp-icon-accent4-hover[stroke] {
+ stroke: var(--jp-layout-color4);
+}
+
+/* set the color of an icon to transparent */
+.jp-icon-hover :hover .jp-icon-none-hover[fill] {
+ fill: none;
+}
+
+.jp-icon-hover :hover .jp-icon-none-hover[stroke] {
+ stroke: none;
+}
+
+/**
+ * inverse colors
+ */
+
+/* inverse recolor the primary elements of an icon */
+.jp-icon-hover.jp-icon-alt :hover .jp-icon0-hover[fill] {
+ fill: var(--jp-layout-color0);
+}
+
+.jp-icon-hover.jp-icon-alt :hover .jp-icon1-hover[fill] {
+ fill: var(--jp-layout-color1);
+}
+
+.jp-icon-hover.jp-icon-alt :hover .jp-icon2-hover[fill] {
+ fill: var(--jp-layout-color2);
+}
+
+.jp-icon-hover.jp-icon-alt :hover .jp-icon3-hover[fill] {
+ fill: var(--jp-layout-color3);
+}
+
+.jp-icon-hover.jp-icon-alt :hover .jp-icon4-hover[fill] {
+ fill: var(--jp-layout-color4);
+}
+
+.jp-icon-hover.jp-icon-alt :hover .jp-icon0-hover[stroke] {
+ stroke: var(--jp-layout-color0);
+}
+
+.jp-icon-hover.jp-icon-alt :hover .jp-icon1-hover[stroke] {
+ stroke: var(--jp-layout-color1);
+}
+
+.jp-icon-hover.jp-icon-alt :hover .jp-icon2-hover[stroke] {
+ stroke: var(--jp-layout-color2);
+}
+
+.jp-icon-hover.jp-icon-alt :hover .jp-icon3-hover[stroke] {
+ stroke: var(--jp-layout-color3);
+}
+
+.jp-icon-hover.jp-icon-alt :hover .jp-icon4-hover[stroke] {
+ stroke: var(--jp-layout-color4);
+}
+
+/* inverse recolor the accent elements of an icon */
+.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent0-hover[fill] {
+ fill: var(--jp-inverse-layout-color0);
+}
+
+.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent1-hover[fill] {
+ fill: var(--jp-inverse-layout-color1);
+}
+
+.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent2-hover[fill] {
+ fill: var(--jp-inverse-layout-color2);
+}
+
+.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent3-hover[fill] {
+ fill: var(--jp-inverse-layout-color3);
+}
+
+.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent4-hover[fill] {
+ fill: var(--jp-inverse-layout-color4);
+}
+
+.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent0-hover[stroke] {
+ stroke: var(--jp-inverse-layout-color0);
+}
+
+.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent1-hover[stroke] {
+ stroke: var(--jp-inverse-layout-color1);
+}
+
+.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent2-hover[stroke] {
+ stroke: var(--jp-inverse-layout-color2);
+}
+
+.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent3-hover[stroke] {
+ stroke: var(--jp-inverse-layout-color3);
+}
+
+.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent4-hover[stroke] {
+ stroke: var(--jp-inverse-layout-color4);
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+.jp-IFrame {
+ width: 100%;
+ height: 100%;
+}
+
+.jp-IFrame > iframe {
+ border: none;
+}
+
+/*
+When drag events occur, `lm-mod-override-cursor` is added to the body.
+Because iframes steal all cursor events, the following two rules are necessary
+to suppress pointer events while resize drags are occurring. There may be a
+better solution to this problem.
+*/
+body.lm-mod-override-cursor .jp-IFrame {
+ position: relative;
+}
+
+body.lm-mod-override-cursor .jp-IFrame::before {
+ content: '';
+ position: absolute;
+ top: 0;
+ left: 0;
+ right: 0;
+ bottom: 0;
+ background: transparent;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) 2014-2016, Jupyter Development Team.
+|
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+.jp-HoverBox {
+ position: fixed;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+.jp-FormGroup-content fieldset {
+ border: none;
+ padding: 0;
+ min-width: 0;
+ width: 100%;
+}
+
+/* stylelint-disable selector-max-type */
+
+.jp-FormGroup-content fieldset .jp-inputFieldWrapper input,
+.jp-FormGroup-content fieldset .jp-inputFieldWrapper select,
+.jp-FormGroup-content fieldset .jp-inputFieldWrapper textarea {
+ font-size: var(--jp-content-font-size2);
+ border-color: var(--jp-input-border-color);
+ border-style: solid;
+ border-radius: var(--jp-border-radius);
+ border-width: 1px;
+ padding: 6px 8px;
+ background: none;
+ color: var(--jp-ui-font-color0);
+ height: inherit;
+}
+
+.jp-FormGroup-content fieldset input[type='checkbox'] {
+ position: relative;
+ top: 2px;
+ margin-left: 0;
+}
+
+.jp-FormGroup-content button.jp-mod-styled {
+ cursor: pointer;
+}
+
+.jp-FormGroup-content .checkbox label {
+ cursor: pointer;
+ font-size: var(--jp-content-font-size1);
+}
+
+.jp-FormGroup-content .jp-root > fieldset > legend {
+ display: none;
+}
+
+.jp-FormGroup-content .jp-root > fieldset > p {
+ display: none;
+}
+
+/** copy of `input.jp-mod-styled:focus` style */
+.jp-FormGroup-content fieldset input:focus,
+.jp-FormGroup-content fieldset select:focus {
+ -moz-outline-radius: unset;
+ outline: var(--jp-border-width) solid var(--md-blue-500);
+ outline-offset: -1px;
+ box-shadow: inset 0 0 4px var(--md-blue-300);
+}
+
+.jp-FormGroup-content fieldset input:hover:not(:focus),
+.jp-FormGroup-content fieldset select:hover:not(:focus) {
+ background-color: var(--jp-border-color2);
+}
+
+/* stylelint-enable selector-max-type */
+
+.jp-FormGroup-content .checkbox .field-description {
+ /* Disable default description field for checkbox:
+ because other widgets do not have description fields,
+ we add descriptions to each widget on the field level.
+ */
+ display: none;
+}
+
+.jp-FormGroup-content #root__description {
+ display: none;
+}
+
+.jp-FormGroup-content .jp-modifiedIndicator {
+ width: 5px;
+ background-color: var(--jp-brand-color2);
+ margin-top: 0;
+ margin-left: calc(var(--jp-private-settingeditor-modifier-indent) * -1);
+ flex-shrink: 0;
+}
+
+.jp-FormGroup-content .jp-modifiedIndicator.jp-errorIndicator {
+ background-color: var(--jp-error-color0);
+ margin-right: 0.5em;
+}
+
+/* RJSF ARRAY style */
+
+.jp-arrayFieldWrapper legend {
+ font-size: var(--jp-content-font-size2);
+ color: var(--jp-ui-font-color0);
+ flex-basis: 100%;
+ padding: 4px 0;
+ font-weight: var(--jp-content-heading-font-weight);
+ border-bottom: 1px solid var(--jp-border-color2);
+}
+
+.jp-arrayFieldWrapper .field-description {
+ padding: 4px 0;
+ white-space: pre-wrap;
+}
+
+.jp-arrayFieldWrapper .array-item {
+ width: 100%;
+ border: 1px solid var(--jp-border-color2);
+ border-radius: 4px;
+ margin: 4px;
+}
+
+.jp-ArrayOperations {
+ display: flex;
+ margin-left: 8px;
+}
+
+.jp-ArrayOperationsButton {
+ margin: 2px;
+}
+
+.jp-ArrayOperationsButton .jp-icon3[fill] {
+ fill: var(--jp-ui-font-color0);
+}
+
+button.jp-ArrayOperationsButton.jp-mod-styled:disabled {
+ cursor: not-allowed;
+ opacity: 0.5;
+}
+
+/* RJSF form validation error */
+
+.jp-FormGroup-content .validationErrors {
+ color: var(--jp-error-color0);
+}
+
+/* Hide panel level error as duplicated the field level error */
+.jp-FormGroup-content .panel.errors {
+ display: none;
+}
+
+/* RJSF normal content (settings-editor) */
+
+.jp-FormGroup-contentNormal {
+ display: flex;
+ align-items: center;
+ flex-wrap: wrap;
+}
+
+.jp-FormGroup-contentNormal .jp-FormGroup-contentItem {
+ margin-left: 7px;
+ color: var(--jp-ui-font-color0);
+}
+
+.jp-FormGroup-contentNormal .jp-FormGroup-description {
+ flex-basis: 100%;
+ padding: 4px 7px;
+}
+
+.jp-FormGroup-contentNormal .jp-FormGroup-default {
+ flex-basis: 100%;
+ padding: 4px 7px;
+}
+
+.jp-FormGroup-contentNormal .jp-FormGroup-fieldLabel {
+ font-size: var(--jp-content-font-size1);
+ font-weight: normal;
+ min-width: 120px;
+}
+
+.jp-FormGroup-contentNormal fieldset:not(:first-child) {
+ margin-left: 7px;
+}
+
+.jp-FormGroup-contentNormal .field-array-of-string .array-item {
+ /* Display `jp-ArrayOperations` buttons side-by-side with content except
+ for small screens where flex-wrap will place them one below the other.
+ */
+ display: flex;
+ align-items: center;
+ flex-wrap: wrap;
+}
+
+.jp-FormGroup-contentNormal .jp-objectFieldWrapper .form-group {
+ padding: 2px 8px 2px var(--jp-private-settingeditor-modifier-indent);
+ margin-top: 2px;
+}
+
+/* RJSF compact content (metadata-form) */
+
+.jp-FormGroup-content.jp-FormGroup-contentCompact {
+ width: 100%;
+}
+
+.jp-FormGroup-contentCompact .form-group {
+ display: flex;
+ padding: 0.5em 0.2em 0.5em 0;
+}
+
+.jp-FormGroup-contentCompact
+ .jp-FormGroup-compactTitle
+ .jp-FormGroup-description {
+ font-size: var(--jp-ui-font-size1);
+ color: var(--jp-ui-font-color2);
+}
+
+.jp-FormGroup-contentCompact .jp-FormGroup-fieldLabel {
+ padding-bottom: 0.3em;
+}
+
+.jp-FormGroup-contentCompact .jp-inputFieldWrapper .form-control {
+ width: 100%;
+ box-sizing: border-box;
+}
+
+.jp-FormGroup-contentCompact .jp-arrayFieldWrapper .jp-FormGroup-compactTitle {
+ padding-bottom: 7px;
+}
+
+.jp-FormGroup-contentCompact
+ .jp-objectFieldWrapper
+ .jp-objectFieldWrapper
+ .form-group {
+ padding: 2px 8px 2px var(--jp-private-settingeditor-modifier-indent);
+ margin-top: 2px;
+}
+
+.jp-FormGroup-contentCompact ul.error-detail {
+ margin-block-start: 0.5em;
+ margin-block-end: 0.5em;
+ padding-inline-start: 1em;
+}
+
+/*
+ * Copyright (c) Jupyter Development Team.
+ * Distributed under the terms of the Modified BSD License.
+ */
+
+.jp-SidePanel {
+ display: flex;
+ flex-direction: column;
+ min-width: var(--jp-sidebar-min-width);
+ overflow-y: auto;
+ color: var(--jp-ui-font-color1);
+ background: var(--jp-layout-color1);
+ font-size: var(--jp-ui-font-size1);
+}
+
+.jp-SidePanel-header {
+ flex: 0 0 auto;
+ display: flex;
+ border-bottom: var(--jp-border-width) solid var(--jp-border-color2);
+ font-size: var(--jp-ui-font-size0);
+ font-weight: 600;
+ letter-spacing: 1px;
+ margin: 0;
+ padding: 2px;
+ text-transform: uppercase;
+}
+
+.jp-SidePanel-toolbar {
+ flex: 0 0 auto;
+}
+
+.jp-SidePanel-content {
+ flex: 1 1 auto;
+}
+
+.jp-SidePanel-toolbar,
+.jp-AccordionPanel-toolbar {
+ height: var(--jp-private-toolbar-height);
+}
+
+.jp-SidePanel-toolbar.jp-Toolbar-micro {
+ display: none;
+}
+
+.lm-AccordionPanel .jp-AccordionPanel-title {
+ box-sizing: border-box;
+ line-height: 25px;
+ margin: 0;
+ display: flex;
+ align-items: center;
+ background: var(--jp-layout-color1);
+ color: var(--jp-ui-font-color1);
+ border-bottom: var(--jp-border-width) solid var(--jp-toolbar-border-color);
+ box-shadow: var(--jp-toolbar-box-shadow);
+ font-size: var(--jp-ui-font-size0);
+}
+
+.jp-AccordionPanel-title {
+ cursor: pointer;
+ user-select: none;
+ -moz-user-select: none;
+ -webkit-user-select: none;
+ text-transform: uppercase;
+}
+
+.lm-AccordionPanel[data-orientation='horizontal'] > .jp-AccordionPanel-title {
+ /* Title is rotated for horizontal accordion panel using CSS */
+ display: block;
+ transform-origin: top left;
+ transform: rotate(-90deg) translate(-100%);
+}
+
+.jp-AccordionPanel-title .lm-AccordionPanel-titleLabel {
+ user-select: none;
+ text-overflow: ellipsis;
+ white-space: nowrap;
+ overflow: hidden;
+}
+
+.jp-AccordionPanel-title .lm-AccordionPanel-titleCollapser {
+ transform: rotate(-90deg);
+ margin: auto 0;
+ height: 16px;
+}
+
+.jp-AccordionPanel-title.lm-mod-expanded .lm-AccordionPanel-titleCollapser {
+ transform: rotate(0deg);
+}
+
+.lm-AccordionPanel .jp-AccordionPanel-toolbar {
+ background: none;
+ box-shadow: none;
+ border: none;
+ margin-left: auto;
+}
+
+.lm-AccordionPanel .lm-SplitPanel-handle:hover {
+ background: var(--jp-layout-color3);
+}
+
+.jp-text-truncated {
+ overflow: hidden;
+ text-overflow: ellipsis;
+ white-space: nowrap;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) 2017, Jupyter Development Team.
+|
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+.jp-Spinner {
+ position: absolute;
+ display: flex;
+ justify-content: center;
+ align-items: center;
+ z-index: 10;
+ left: 0;
+ top: 0;
+ width: 100%;
+ height: 100%;
+ background: var(--jp-layout-color0);
+ outline: none;
+}
+
+.jp-SpinnerContent {
+ font-size: 10px;
+ margin: 50px auto;
+ text-indent: -9999em;
+ width: 3em;
+ height: 3em;
+ border-radius: 50%;
+ background: var(--jp-brand-color3);
+ background: linear-gradient(
+ to right,
+ #f37626 10%,
+ rgba(255, 255, 255, 0) 42%
+ );
+ position: relative;
+ animation: load3 1s infinite linear, fadeIn 1s;
+}
+
+.jp-SpinnerContent::before {
+ width: 50%;
+ height: 50%;
+ background: #f37626;
+ border-radius: 100% 0 0;
+ position: absolute;
+ top: 0;
+ left: 0;
+ content: '';
+}
+
+.jp-SpinnerContent::after {
+ background: var(--jp-layout-color0);
+ width: 75%;
+ height: 75%;
+ border-radius: 50%;
+ content: '';
+ margin: auto;
+ position: absolute;
+ top: 0;
+ left: 0;
+ bottom: 0;
+ right: 0;
+}
+
+@keyframes fadeIn {
+ 0% {
+ opacity: 0;
+ }
+
+ 100% {
+ opacity: 1;
+ }
+}
+
+@keyframes load3 {
+ 0% {
+ transform: rotate(0deg);
+ }
+
+ 100% {
+ transform: rotate(360deg);
+ }
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) 2014-2017, Jupyter Development Team.
+|
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+button.jp-mod-styled {
+ font-size: var(--jp-ui-font-size1);
+ color: var(--jp-ui-font-color0);
+ border: none;
+ box-sizing: border-box;
+ text-align: center;
+ line-height: 32px;
+ height: 32px;
+ padding: 0 12px;
+ letter-spacing: 0.8px;
+ outline: none;
+ appearance: none;
+ -webkit-appearance: none;
+ -moz-appearance: none;
+}
+
+input.jp-mod-styled {
+ background: var(--jp-input-background);
+ height: 28px;
+ box-sizing: border-box;
+ border: var(--jp-border-width) solid var(--jp-border-color1);
+ padding-left: 7px;
+ padding-right: 7px;
+ font-size: var(--jp-ui-font-size2);
+ color: var(--jp-ui-font-color0);
+ outline: none;
+ appearance: none;
+ -webkit-appearance: none;
+ -moz-appearance: none;
+}
+
+input[type='checkbox'].jp-mod-styled {
+ appearance: checkbox;
+ -webkit-appearance: checkbox;
+ -moz-appearance: checkbox;
+ height: auto;
+}
+
+input.jp-mod-styled:focus {
+ border: var(--jp-border-width) solid var(--md-blue-500);
+ box-shadow: inset 0 0 4px var(--md-blue-300);
+}
+
+.jp-select-wrapper {
+ display: flex;
+ position: relative;
+ flex-direction: column;
+ padding: 1px;
+ background-color: var(--jp-layout-color1);
+ box-sizing: border-box;
+ margin-bottom: 12px;
+}
+
+.jp-select-wrapper:not(.multiple) {
+ height: 28px;
+}
+
+.jp-select-wrapper.jp-mod-focused select.jp-mod-styled {
+ border: var(--jp-border-width) solid var(--jp-input-active-border-color);
+ box-shadow: var(--jp-input-box-shadow);
+ background-color: var(--jp-input-active-background);
+}
+
+select.jp-mod-styled:hover {
+ cursor: pointer;
+ color: var(--jp-ui-font-color0);
+ background-color: var(--jp-input-hover-background);
+ box-shadow: inset 0 0 1px rgba(0, 0, 0, 0.5);
+}
+
+select.jp-mod-styled {
+ flex: 1 1 auto;
+ width: 100%;
+ font-size: var(--jp-ui-font-size2);
+ background: var(--jp-input-background);
+ color: var(--jp-ui-font-color0);
+ padding: 0 25px 0 8px;
+ border: var(--jp-border-width) solid var(--jp-input-border-color);
+ border-radius: 0;
+ outline: none;
+ appearance: none;
+ -webkit-appearance: none;
+ -moz-appearance: none;
+}
+
+select.jp-mod-styled:not([multiple]) {
+ height: 32px;
+}
+
+select.jp-mod-styled[multiple] {
+ max-height: 200px;
+ overflow-y: auto;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+.jp-switch {
+ display: flex;
+ align-items: center;
+ padding-left: 4px;
+ padding-right: 4px;
+ font-size: var(--jp-ui-font-size1);
+ background-color: transparent;
+ color: var(--jp-ui-font-color1);
+ border: none;
+ height: 20px;
+}
+
+.jp-switch:hover {
+ background-color: var(--jp-layout-color2);
+}
+
+.jp-switch-label {
+ margin-right: 5px;
+ font-family: var(--jp-ui-font-family);
+}
+
+.jp-switch-track {
+ cursor: pointer;
+ background-color: var(--jp-switch-color, var(--jp-border-color1));
+ -webkit-transition: 0.4s;
+ transition: 0.4s;
+ border-radius: 34px;
+ height: 16px;
+ width: 35px;
+ position: relative;
+}
+
+.jp-switch-track::before {
+ content: '';
+ position: absolute;
+ height: 10px;
+ width: 10px;
+ margin: 3px;
+ left: 0;
+ background-color: var(--jp-ui-inverse-font-color1);
+ -webkit-transition: 0.4s;
+ transition: 0.4s;
+ border-radius: 50%;
+}
+
+.jp-switch[aria-checked='true'] .jp-switch-track {
+ background-color: var(--jp-switch-true-position-color, var(--jp-warn-color0));
+}
+
+.jp-switch[aria-checked='true'] .jp-switch-track::before {
+ /* track width (35) - margins (3 + 3) - thumb width (10) */
+ left: 19px;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) 2014-2016, Jupyter Development Team.
+|
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+:root {
+ --jp-private-toolbar-height: calc(
+ 28px + var(--jp-border-width)
+ ); /* leave 28px for content */
+}
+
+.jp-Toolbar {
+ color: var(--jp-ui-font-color1);
+ flex: 0 0 auto;
+ display: flex;
+ flex-direction: row;
+ border-bottom: var(--jp-border-width) solid var(--jp-toolbar-border-color);
+ box-shadow: var(--jp-toolbar-box-shadow);
+ background: var(--jp-toolbar-background);
+ min-height: var(--jp-toolbar-micro-height);
+ padding: 2px;
+ z-index: 8;
+ overflow-x: hidden;
+}
+
+/* Toolbar items */
+
+.jp-Toolbar > .jp-Toolbar-item.jp-Toolbar-spacer {
+ flex-grow: 1;
+ flex-shrink: 1;
+}
+
+.jp-Toolbar-item.jp-Toolbar-kernelStatus {
+ display: inline-block;
+ width: 32px;
+ background-repeat: no-repeat;
+ background-position: center;
+ background-size: 16px;
+}
+
+.jp-Toolbar > .jp-Toolbar-item {
+ flex: 0 0 auto;
+ display: flex;
+ padding-left: 1px;
+ padding-right: 1px;
+ font-size: var(--jp-ui-font-size1);
+ line-height: var(--jp-private-toolbar-height);
+ height: 100%;
+}
+
+/* Toolbar buttons */
+
+/* This is the div we use to wrap the react component into a Widget */
+div.jp-ToolbarButton {
+ color: transparent;
+ border: none;
+ box-sizing: border-box;
+ outline: none;
+ appearance: none;
+ -webkit-appearance: none;
+ -moz-appearance: none;
+ padding: 0;
+ margin: 0;
+}
+
+button.jp-ToolbarButtonComponent {
+ background: var(--jp-layout-color1);
+ border: none;
+ box-sizing: border-box;
+ outline: none;
+ appearance: none;
+ -webkit-appearance: none;
+ -moz-appearance: none;
+ padding: 0 6px;
+ margin: 0;
+ height: 24px;
+ border-radius: var(--jp-border-radius);
+ display: flex;
+ align-items: center;
+ text-align: center;
+ font-size: 14px;
+ min-width: unset;
+ min-height: unset;
+}
+
+button.jp-ToolbarButtonComponent:disabled {
+ opacity: 0.4;
+}
+
+button.jp-ToolbarButtonComponent > span {
+ padding: 0;
+ flex: 0 0 auto;
+}
+
+button.jp-ToolbarButtonComponent .jp-ToolbarButtonComponent-label {
+ font-size: var(--jp-ui-font-size1);
+ line-height: 100%;
+ padding-left: 2px;
+ color: var(--jp-ui-font-color1);
+ font-family: var(--jp-ui-font-family);
+}
+
+#jp-main-dock-panel[data-mode='single-document']
+ .jp-MainAreaWidget
+ > .jp-Toolbar.jp-Toolbar-micro {
+ padding: 0;
+ min-height: 0;
+}
+
+#jp-main-dock-panel[data-mode='single-document']
+ .jp-MainAreaWidget
+ > .jp-Toolbar {
+ border: none;
+ box-shadow: none;
+}
+
+/*
+ * Copyright (c) Jupyter Development Team.
+ * Distributed under the terms of the Modified BSD License.
+ */
+
+.jp-WindowedPanel-outer {
+ position: relative;
+ overflow-y: auto;
+}
+
+.jp-WindowedPanel-inner {
+ position: relative;
+}
+
+.jp-WindowedPanel-window {
+ position: absolute;
+ left: 0;
+ right: 0;
+ overflow: visible;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/* Sibling imports */
+
+body {
+ color: var(--jp-ui-font-color1);
+ font-size: var(--jp-ui-font-size1);
+}
+
+/* Disable native link decoration styles everywhere outside of dialog boxes */
+a {
+ text-decoration: unset;
+ color: unset;
+}
+
+a:hover {
+ text-decoration: unset;
+ color: unset;
+}
+
+/* Accessibility for links inside dialog box text */
+.jp-Dialog-content a {
+ text-decoration: revert;
+ color: var(--jp-content-link-color);
+}
+
+.jp-Dialog-content a:hover {
+ text-decoration: revert;
+}
+
+/* Styles for ui-components */
+.jp-Button {
+ color: var(--jp-ui-font-color2);
+ border-radius: var(--jp-border-radius);
+ padding: 0 12px;
+ font-size: var(--jp-ui-font-size1);
+
+ /* Copy from blueprint 3 */
+ display: inline-flex;
+ flex-direction: row;
+ border: none;
+ cursor: pointer;
+ align-items: center;
+ justify-content: center;
+ text-align: left;
+ vertical-align: middle;
+ min-height: 30px;
+ min-width: 30px;
+}
+
+.jp-Button:disabled {
+ cursor: not-allowed;
+}
+
+.jp-Button:empty {
+ padding: 0 !important;
+}
+
+.jp-Button.jp-mod-small {
+ min-height: 24px;
+ min-width: 24px;
+ font-size: 12px;
+ padding: 0 7px;
+}
+
+/* Use our own theme for hover styles */
+.jp-Button.jp-mod-minimal:hover {
+ background-color: var(--jp-layout-color2);
+}
+
+.jp-Button.jp-mod-minimal {
+ background: none;
+}
+
+.jp-InputGroup {
+ display: block;
+ position: relative;
+}
+
+.jp-InputGroup input {
+ box-sizing: border-box;
+ border: none;
+ border-radius: 0;
+ background-color: transparent;
+ color: var(--jp-ui-font-color0);
+ box-shadow: inset 0 0 0 var(--jp-border-width) var(--jp-input-border-color);
+ padding-bottom: 0;
+ padding-top: 0;
+ padding-left: 10px;
+ padding-right: 28px;
+ position: relative;
+ width: 100%;
+ -webkit-appearance: none;
+ -moz-appearance: none;
+ appearance: none;
+ font-size: 14px;
+ font-weight: 400;
+ height: 30px;
+ line-height: 30px;
+ outline: none;
+ vertical-align: middle;
+}
+
+.jp-InputGroup input:focus {
+ box-shadow: inset 0 0 0 var(--jp-border-width)
+ var(--jp-input-active-box-shadow-color),
+ inset 0 0 0 3px var(--jp-input-active-box-shadow-color);
+}
+
+.jp-InputGroup input:disabled {
+ cursor: not-allowed;
+ resize: block;
+ background-color: var(--jp-layout-color2);
+ color: var(--jp-ui-font-color2);
+}
+
+.jp-InputGroup input:disabled ~ span {
+ cursor: not-allowed;
+ color: var(--jp-ui-font-color2);
+}
+
+.jp-InputGroup input::placeholder,
+input::placeholder {
+ color: var(--jp-ui-font-color2);
+}
+
+.jp-InputGroupAction {
+ position: absolute;
+ bottom: 1px;
+ right: 0;
+ padding: 6px;
+}
+
+.jp-HTMLSelect.jp-DefaultStyle select {
+ background-color: initial;
+ border: none;
+ border-radius: 0;
+ box-shadow: none;
+ color: var(--jp-ui-font-color0);
+ display: block;
+ font-size: var(--jp-ui-font-size1);
+ font-family: var(--jp-ui-font-family);
+ height: 24px;
+ line-height: 14px;
+ padding: 0 25px 0 10px;
+ text-align: left;
+ -moz-appearance: none;
+ -webkit-appearance: none;
+}
+
+.jp-HTMLSelect.jp-DefaultStyle select:disabled {
+ background-color: var(--jp-layout-color2);
+ color: var(--jp-ui-font-color2);
+ cursor: not-allowed;
+ resize: block;
+}
+
+.jp-HTMLSelect.jp-DefaultStyle select:disabled ~ span {
+ cursor: not-allowed;
+}
+
+/* Use our own theme for hover and option styles */
+/* stylelint-disable-next-line selector-max-type */
+.jp-HTMLSelect.jp-DefaultStyle select:hover,
+.jp-HTMLSelect.jp-DefaultStyle select > option {
+ background-color: var(--jp-layout-color2);
+ color: var(--jp-ui-font-color0);
+}
+
+select {
+ box-sizing: border-box;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/*-----------------------------------------------------------------------------
+| Styles
+|----------------------------------------------------------------------------*/
+
+.jp-StatusBar-Widget {
+ display: flex;
+ align-items: center;
+ background: var(--jp-layout-color2);
+ min-height: var(--jp-statusbar-height);
+ justify-content: space-between;
+ padding: 0 10px;
+}
+
+.jp-StatusBar-Left {
+ display: flex;
+ align-items: center;
+ flex-direction: row;
+}
+
+.jp-StatusBar-Middle {
+ display: flex;
+ align-items: center;
+}
+
+.jp-StatusBar-Right {
+ display: flex;
+ align-items: center;
+ flex-direction: row-reverse;
+}
+
+.jp-StatusBar-Item {
+ max-height: var(--jp-statusbar-height);
+ margin: 0 2px;
+ height: var(--jp-statusbar-height);
+ white-space: nowrap;
+ text-overflow: ellipsis;
+ color: var(--jp-ui-font-color1);
+ padding: 0 6px;
+}
+
+.jp-mod-highlighted:hover {
+ background-color: var(--jp-layout-color3);
+}
+
+.jp-mod-clicked {
+ background-color: var(--jp-brand-color1);
+}
+
+.jp-mod-clicked:hover {
+ background-color: var(--jp-brand-color0);
+}
+
+.jp-mod-clicked .jp-StatusBar-TextItem {
+ color: var(--jp-ui-inverse-font-color1);
+}
+
+.jp-StatusBar-HoverItem {
+ box-shadow: '0px 4px 4px rgba(0, 0, 0, 0.25)';
+}
+
+.jp-StatusBar-TextItem {
+ font-size: var(--jp-ui-font-size1);
+ font-family: var(--jp-ui-font-family);
+ line-height: 24px;
+ color: var(--jp-ui-font-color1);
+}
+
+.jp-StatusBar-GroupItem {
+ display: flex;
+ align-items: center;
+ flex-direction: row;
+}
+
+.jp-Statusbar-ProgressCircle svg {
+ display: block;
+ margin: 0 auto;
+ width: 16px;
+ height: 24px;
+ align-self: normal;
+}
+
+.jp-Statusbar-ProgressCircle path {
+ fill: var(--jp-inverse-layout-color3);
+}
+
+.jp-Statusbar-ProgressBar-progress-bar {
+ height: 10px;
+ width: 100px;
+ border: solid 0.25px var(--jp-brand-color2);
+ border-radius: 3px;
+ overflow: hidden;
+ align-self: center;
+}
+
+.jp-Statusbar-ProgressBar-progress-bar > div {
+ background-color: var(--jp-brand-color2);
+ background-image: linear-gradient(
+ -45deg,
+ rgba(255, 255, 255, 0.2) 25%,
+ transparent 25%,
+ transparent 50%,
+ rgba(255, 255, 255, 0.2) 50%,
+ rgba(255, 255, 255, 0.2) 75%,
+ transparent 75%,
+ transparent
+ );
+ background-size: 40px 40px;
+ float: left;
+ width: 0%;
+ height: 100%;
+ font-size: 12px;
+ line-height: 14px;
+ color: #fff;
+ text-align: center;
+ animation: jp-Statusbar-ExecutionTime-progress-bar 2s linear infinite;
+}
+
+.jp-Statusbar-ProgressBar-progress-bar p {
+ color: var(--jp-ui-font-color1);
+ font-family: var(--jp-ui-font-family);
+ font-size: var(--jp-ui-font-size1);
+ line-height: 10px;
+ width: 100px;
+}
+
+@keyframes jp-Statusbar-ExecutionTime-progress-bar {
+ 0% {
+ background-position: 0 0;
+ }
+
+ 100% {
+ background-position: 40px 40px;
+ }
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/*-----------------------------------------------------------------------------
+| Variables
+|----------------------------------------------------------------------------*/
+
+:root {
+ --jp-private-commandpalette-search-height: 28px;
+}
+
+/*-----------------------------------------------------------------------------
+| Overall styles
+|----------------------------------------------------------------------------*/
+
+.lm-CommandPalette {
+ padding-bottom: 0;
+ color: var(--jp-ui-font-color1);
+ background: var(--jp-layout-color1);
+
+ /* This is needed so that all font sizing of children done in ems is
+ * relative to this base size */
+ font-size: var(--jp-ui-font-size1);
+}
+
+/*-----------------------------------------------------------------------------
+| Modal variant
+|----------------------------------------------------------------------------*/
+
+.jp-ModalCommandPalette {
+ position: absolute;
+ z-index: 10000;
+ top: 38px;
+ left: 30%;
+ margin: 0;
+ padding: 4px;
+ width: 40%;
+ box-shadow: var(--jp-elevation-z4);
+ border-radius: 4px;
+ background: var(--jp-layout-color0);
+}
+
+.jp-ModalCommandPalette .lm-CommandPalette {
+ max-height: 40vh;
+}
+
+.jp-ModalCommandPalette .lm-CommandPalette .lm-close-icon::after {
+ display: none;
+}
+
+.jp-ModalCommandPalette .lm-CommandPalette .lm-CommandPalette-header {
+ display: none;
+}
+
+.jp-ModalCommandPalette .lm-CommandPalette .lm-CommandPalette-item {
+ margin-left: 4px;
+ margin-right: 4px;
+}
+
+.jp-ModalCommandPalette
+ .lm-CommandPalette
+ .lm-CommandPalette-item.lm-mod-disabled {
+ display: none;
+}
+
+/*-----------------------------------------------------------------------------
+| Search
+|----------------------------------------------------------------------------*/
+
+.lm-CommandPalette-search {
+ padding: 4px;
+ background-color: var(--jp-layout-color1);
+ z-index: 2;
+}
+
+.lm-CommandPalette-wrapper {
+ overflow: overlay;
+ padding: 0 9px;
+ background-color: var(--jp-input-active-background);
+ height: 30px;
+ box-shadow: inset 0 0 0 var(--jp-border-width) var(--jp-input-border-color);
+}
+
+.lm-CommandPalette.lm-mod-focused .lm-CommandPalette-wrapper {
+ box-shadow: inset 0 0 0 1px var(--jp-input-active-box-shadow-color),
+ inset 0 0 0 3px var(--jp-input-active-box-shadow-color);
+}
+
+.jp-SearchIconGroup {
+ color: white;
+ background-color: var(--jp-brand-color1);
+ position: absolute;
+ top: 4px;
+ right: 4px;
+ padding: 5px 5px 1px;
+}
+
+.jp-SearchIconGroup svg {
+ height: 20px;
+ width: 20px;
+}
+
+.jp-SearchIconGroup .jp-icon3[fill] {
+ fill: var(--jp-layout-color0);
+}
+
+.lm-CommandPalette-input {
+ background: transparent;
+ width: calc(100% - 18px);
+ float: left;
+ border: none;
+ outline: none;
+ font-size: var(--jp-ui-font-size1);
+ color: var(--jp-ui-font-color0);
+ line-height: var(--jp-private-commandpalette-search-height);
+}
+
+.lm-CommandPalette-input::-webkit-input-placeholder,
+.lm-CommandPalette-input::-moz-placeholder,
+.lm-CommandPalette-input:-ms-input-placeholder {
+ color: var(--jp-ui-font-color2);
+ font-size: var(--jp-ui-font-size1);
+}
+
+/*-----------------------------------------------------------------------------
+| Results
+|----------------------------------------------------------------------------*/
+
+.lm-CommandPalette-header:first-child {
+ margin-top: 0;
+}
+
+.lm-CommandPalette-header {
+ border-bottom: solid var(--jp-border-width) var(--jp-border-color2);
+ color: var(--jp-ui-font-color1);
+ cursor: pointer;
+ display: flex;
+ font-size: var(--jp-ui-font-size0);
+ font-weight: 600;
+ letter-spacing: 1px;
+ margin-top: 8px;
+ padding: 8px 0 8px 12px;
+ text-transform: uppercase;
+}
+
+.lm-CommandPalette-header.lm-mod-active {
+ background: var(--jp-layout-color2);
+}
+
+.lm-CommandPalette-header > mark {
+ background-color: transparent;
+ font-weight: bold;
+ color: var(--jp-ui-font-color1);
+}
+
+.lm-CommandPalette-item {
+ padding: 4px 12px 4px 4px;
+ color: var(--jp-ui-font-color1);
+ font-size: var(--jp-ui-font-size1);
+ font-weight: 400;
+ display: flex;
+}
+
+.lm-CommandPalette-item.lm-mod-disabled {
+ color: var(--jp-ui-font-color2);
+}
+
+.lm-CommandPalette-item.lm-mod-active {
+ color: var(--jp-ui-inverse-font-color1);
+ background: var(--jp-brand-color1);
+}
+
+.lm-CommandPalette-item.lm-mod-active .lm-CommandPalette-itemLabel > mark {
+ color: var(--jp-ui-inverse-font-color0);
+}
+
+.lm-CommandPalette-item.lm-mod-active .jp-icon-selectable[fill] {
+ fill: var(--jp-layout-color0);
+}
+
+.lm-CommandPalette-item.lm-mod-active:hover:not(.lm-mod-disabled) {
+ color: var(--jp-ui-inverse-font-color1);
+ background: var(--jp-brand-color1);
+}
+
+.lm-CommandPalette-item:hover:not(.lm-mod-active):not(.lm-mod-disabled) {
+ background: var(--jp-layout-color2);
+}
+
+.lm-CommandPalette-itemContent {
+ overflow: hidden;
+}
+
+.lm-CommandPalette-itemLabel > mark {
+ color: var(--jp-ui-font-color0);
+ background-color: transparent;
+ font-weight: bold;
+}
+
+.lm-CommandPalette-item.lm-mod-disabled mark {
+ color: var(--jp-ui-font-color2);
+}
+
+.lm-CommandPalette-item .lm-CommandPalette-itemIcon {
+ margin: 0 4px 0 0;
+ position: relative;
+ width: 16px;
+ top: 2px;
+ flex: 0 0 auto;
+}
+
+.lm-CommandPalette-item.lm-mod-disabled .lm-CommandPalette-itemIcon {
+ opacity: 0.6;
+}
+
+.lm-CommandPalette-item .lm-CommandPalette-itemShortcut {
+ flex: 0 0 auto;
+}
+
+.lm-CommandPalette-itemCaption {
+ display: none;
+}
+
+.lm-CommandPalette-content {
+ background-color: var(--jp-layout-color1);
+}
+
+.lm-CommandPalette-content:empty::after {
+ content: 'No results';
+ margin: auto;
+ margin-top: 20px;
+ width: 100px;
+ display: block;
+ font-size: var(--jp-ui-font-size2);
+ font-family: var(--jp-ui-font-family);
+ font-weight: lighter;
+}
+
+.lm-CommandPalette-emptyMessage {
+ text-align: center;
+ margin-top: 24px;
+ line-height: 1.32;
+ padding: 0 8px;
+ color: var(--jp-content-font-color3);
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) 2014-2017, Jupyter Development Team.
+|
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+.jp-Dialog {
+ position: absolute;
+ z-index: 10000;
+ display: flex;
+ flex-direction: column;
+ align-items: center;
+ justify-content: center;
+ top: 0;
+ left: 0;
+ margin: 0;
+ padding: 0;
+ width: 100%;
+ height: 100%;
+ background: var(--jp-dialog-background);
+}
+
+.jp-Dialog-content {
+ display: flex;
+ flex-direction: column;
+ margin-left: auto;
+ margin-right: auto;
+ background: var(--jp-layout-color1);
+ padding: 24px 24px 12px;
+ min-width: 300px;
+ min-height: 150px;
+ max-width: 1000px;
+ max-height: 500px;
+ box-sizing: border-box;
+ box-shadow: var(--jp-elevation-z20);
+ word-wrap: break-word;
+ border-radius: var(--jp-border-radius);
+
+ /* This is needed so that all font sizing of children done in ems is
+ * relative to this base size */
+ font-size: var(--jp-ui-font-size1);
+ color: var(--jp-ui-font-color1);
+ resize: both;
+}
+
+.jp-Dialog-content.jp-Dialog-content-small {
+ max-width: 500px;
+}
+
+.jp-Dialog-button {
+ overflow: visible;
+}
+
+button.jp-Dialog-button:focus {
+ outline: 1px solid var(--jp-brand-color1);
+ outline-offset: 4px;
+ -moz-outline-radius: 0;
+}
+
+button.jp-Dialog-button:focus::-moz-focus-inner {
+ border: 0;
+}
+
+button.jp-Dialog-button.jp-mod-styled.jp-mod-accept:focus,
+button.jp-Dialog-button.jp-mod-styled.jp-mod-warn:focus,
+button.jp-Dialog-button.jp-mod-styled.jp-mod-reject:focus {
+ outline-offset: 4px;
+ -moz-outline-radius: 0;
+}
+
+button.jp-Dialog-button.jp-mod-styled.jp-mod-accept:focus {
+ outline: 1px solid var(--jp-accept-color-normal, var(--jp-brand-color1));
+}
+
+button.jp-Dialog-button.jp-mod-styled.jp-mod-warn:focus {
+ outline: 1px solid var(--jp-warn-color-normal, var(--jp-error-color1));
+}
+
+button.jp-Dialog-button.jp-mod-styled.jp-mod-reject:focus {
+ outline: 1px solid var(--jp-reject-color-normal, var(--md-grey-600));
+}
+
+button.jp-Dialog-close-button {
+ padding: 0;
+ height: 100%;
+ min-width: unset;
+ min-height: unset;
+}
+
+.jp-Dialog-header {
+ display: flex;
+ justify-content: space-between;
+ flex: 0 0 auto;
+ padding-bottom: 12px;
+ font-size: var(--jp-ui-font-size3);
+ font-weight: 400;
+ color: var(--jp-ui-font-color1);
+}
+
+.jp-Dialog-body {
+ display: flex;
+ flex-direction: column;
+ flex: 1 1 auto;
+ font-size: var(--jp-ui-font-size1);
+ background: var(--jp-layout-color1);
+ color: var(--jp-ui-font-color1);
+ overflow: auto;
+}
+
+.jp-Dialog-footer {
+ display: flex;
+ flex-direction: row;
+ justify-content: flex-end;
+ align-items: center;
+ flex: 0 0 auto;
+ margin-left: -12px;
+ margin-right: -12px;
+ padding: 12px;
+}
+
+.jp-Dialog-checkbox {
+ padding-right: 5px;
+}
+
+.jp-Dialog-checkbox > input:focus-visible {
+ outline: 1px solid var(--jp-input-active-border-color);
+ outline-offset: 1px;
+}
+
+.jp-Dialog-spacer {
+ flex: 1 1 auto;
+}
+
+.jp-Dialog-title {
+ overflow: hidden;
+ white-space: nowrap;
+ text-overflow: ellipsis;
+}
+
+.jp-Dialog-body > .jp-select-wrapper {
+ width: 100%;
+}
+
+.jp-Dialog-body > button {
+ padding: 0 16px;
+}
+
+.jp-Dialog-body > label {
+ line-height: 1.4;
+ color: var(--jp-ui-font-color0);
+}
+
+.jp-Dialog-button.jp-mod-styled:not(:last-child) {
+ margin-right: 12px;
+}
+
+/*
+ * Copyright (c) Jupyter Development Team.
+ * Distributed under the terms of the Modified BSD License.
+ */
+
+.jp-Input-Boolean-Dialog {
+ flex-direction: row-reverse;
+ align-items: end;
+ width: 100%;
+}
+
+.jp-Input-Boolean-Dialog > label {
+ flex: 1 1 auto;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) 2014-2016, Jupyter Development Team.
+|
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+.jp-MainAreaWidget > :focus {
+ outline: none;
+}
+
+.jp-MainAreaWidget .jp-MainAreaWidget-error {
+ padding: 6px;
+}
+
+.jp-MainAreaWidget .jp-MainAreaWidget-error > pre {
+ width: auto;
+ padding: 10px;
+ background: var(--jp-error-color3);
+ border: var(--jp-border-width) solid var(--jp-error-color1);
+ border-radius: var(--jp-border-radius);
+ color: var(--jp-ui-font-color1);
+ font-size: var(--jp-ui-font-size1);
+ white-space: pre-wrap;
+ word-wrap: break-word;
+}
+
+/*
+ * Copyright (c) Jupyter Development Team.
+ * Distributed under the terms of the Modified BSD License.
+ */
+
+/**
+ * google-material-color v1.2.6
+ * https://github.com/danlevan/google-material-color
+ */
+:root {
+ --md-red-50: #ffebee;
+ --md-red-100: #ffcdd2;
+ --md-red-200: #ef9a9a;
+ --md-red-300: #e57373;
+ --md-red-400: #ef5350;
+ --md-red-500: #f44336;
+ --md-red-600: #e53935;
+ --md-red-700: #d32f2f;
+ --md-red-800: #c62828;
+ --md-red-900: #b71c1c;
+ --md-red-A100: #ff8a80;
+ --md-red-A200: #ff5252;
+ --md-red-A400: #ff1744;
+ --md-red-A700: #d50000;
+ --md-pink-50: #fce4ec;
+ --md-pink-100: #f8bbd0;
+ --md-pink-200: #f48fb1;
+ --md-pink-300: #f06292;
+ --md-pink-400: #ec407a;
+ --md-pink-500: #e91e63;
+ --md-pink-600: #d81b60;
+ --md-pink-700: #c2185b;
+ --md-pink-800: #ad1457;
+ --md-pink-900: #880e4f;
+ --md-pink-A100: #ff80ab;
+ --md-pink-A200: #ff4081;
+ --md-pink-A400: #f50057;
+ --md-pink-A700: #c51162;
+ --md-purple-50: #f3e5f5;
+ --md-purple-100: #e1bee7;
+ --md-purple-200: #ce93d8;
+ --md-purple-300: #ba68c8;
+ --md-purple-400: #ab47bc;
+ --md-purple-500: #9c27b0;
+ --md-purple-600: #8e24aa;
+ --md-purple-700: #7b1fa2;
+ --md-purple-800: #6a1b9a;
+ --md-purple-900: #4a148c;
+ --md-purple-A100: #ea80fc;
+ --md-purple-A200: #e040fb;
+ --md-purple-A400: #d500f9;
+ --md-purple-A700: #a0f;
+ --md-deep-purple-50: #ede7f6;
+ --md-deep-purple-100: #d1c4e9;
+ --md-deep-purple-200: #b39ddb;
+ --md-deep-purple-300: #9575cd;
+ --md-deep-purple-400: #7e57c2;
+ --md-deep-purple-500: #673ab7;
+ --md-deep-purple-600: #5e35b1;
+ --md-deep-purple-700: #512da8;
+ --md-deep-purple-800: #4527a0;
+ --md-deep-purple-900: #311b92;
+ --md-deep-purple-A100: #b388ff;
+ --md-deep-purple-A200: #7c4dff;
+ --md-deep-purple-A400: #651fff;
+ --md-deep-purple-A700: #6200ea;
+ --md-indigo-50: #e8eaf6;
+ --md-indigo-100: #c5cae9;
+ --md-indigo-200: #9fa8da;
+ --md-indigo-300: #7986cb;
+ --md-indigo-400: #5c6bc0;
+ --md-indigo-500: #3f51b5;
+ --md-indigo-600: #3949ab;
+ --md-indigo-700: #303f9f;
+ --md-indigo-800: #283593;
+ --md-indigo-900: #1a237e;
+ --md-indigo-A100: #8c9eff;
+ --md-indigo-A200: #536dfe;
+ --md-indigo-A400: #3d5afe;
+ --md-indigo-A700: #304ffe;
+ --md-blue-50: #e3f2fd;
+ --md-blue-100: #bbdefb;
+ --md-blue-200: #90caf9;
+ --md-blue-300: #64b5f6;
+ --md-blue-400: #42a5f5;
+ --md-blue-500: #2196f3;
+ --md-blue-600: #1e88e5;
+ --md-blue-700: #1976d2;
+ --md-blue-800: #1565c0;
+ --md-blue-900: #0d47a1;
+ --md-blue-A100: #82b1ff;
+ --md-blue-A200: #448aff;
+ --md-blue-A400: #2979ff;
+ --md-blue-A700: #2962ff;
+ --md-light-blue-50: #e1f5fe;
+ --md-light-blue-100: #b3e5fc;
+ --md-light-blue-200: #81d4fa;
+ --md-light-blue-300: #4fc3f7;
+ --md-light-blue-400: #29b6f6;
+ --md-light-blue-500: #03a9f4;
+ --md-light-blue-600: #039be5;
+ --md-light-blue-700: #0288d1;
+ --md-light-blue-800: #0277bd;
+ --md-light-blue-900: #01579b;
+ --md-light-blue-A100: #80d8ff;
+ --md-light-blue-A200: #40c4ff;
+ --md-light-blue-A400: #00b0ff;
+ --md-light-blue-A700: #0091ea;
+ --md-cyan-50: #e0f7fa;
+ --md-cyan-100: #b2ebf2;
+ --md-cyan-200: #80deea;
+ --md-cyan-300: #4dd0e1;
+ --md-cyan-400: #26c6da;
+ --md-cyan-500: #00bcd4;
+ --md-cyan-600: #00acc1;
+ --md-cyan-700: #0097a7;
+ --md-cyan-800: #00838f;
+ --md-cyan-900: #006064;
+ --md-cyan-A100: #84ffff;
+ --md-cyan-A200: #18ffff;
+ --md-cyan-A400: #00e5ff;
+ --md-cyan-A700: #00b8d4;
+ --md-teal-50: #e0f2f1;
+ --md-teal-100: #b2dfdb;
+ --md-teal-200: #80cbc4;
+ --md-teal-300: #4db6ac;
+ --md-teal-400: #26a69a;
+ --md-teal-500: #009688;
+ --md-teal-600: #00897b;
+ --md-teal-700: #00796b;
+ --md-teal-800: #00695c;
+ --md-teal-900: #004d40;
+ --md-teal-A100: #a7ffeb;
+ --md-teal-A200: #64ffda;
+ --md-teal-A400: #1de9b6;
+ --md-teal-A700: #00bfa5;
+ --md-green-50: #e8f5e9;
+ --md-green-100: #c8e6c9;
+ --md-green-200: #a5d6a7;
+ --md-green-300: #81c784;
+ --md-green-400: #66bb6a;
+ --md-green-500: #4caf50;
+ --md-green-600: #43a047;
+ --md-green-700: #388e3c;
+ --md-green-800: #2e7d32;
+ --md-green-900: #1b5e20;
+ --md-green-A100: #b9f6ca;
+ --md-green-A200: #69f0ae;
+ --md-green-A400: #00e676;
+ --md-green-A700: #00c853;
+ --md-light-green-50: #f1f8e9;
+ --md-light-green-100: #dcedc8;
+ --md-light-green-200: #c5e1a5;
+ --md-light-green-300: #aed581;
+ --md-light-green-400: #9ccc65;
+ --md-light-green-500: #8bc34a;
+ --md-light-green-600: #7cb342;
+ --md-light-green-700: #689f38;
+ --md-light-green-800: #558b2f;
+ --md-light-green-900: #33691e;
+ --md-light-green-A100: #ccff90;
+ --md-light-green-A200: #b2ff59;
+ --md-light-green-A400: #76ff03;
+ --md-light-green-A700: #64dd17;
+ --md-lime-50: #f9fbe7;
+ --md-lime-100: #f0f4c3;
+ --md-lime-200: #e6ee9c;
+ --md-lime-300: #dce775;
+ --md-lime-400: #d4e157;
+ --md-lime-500: #cddc39;
+ --md-lime-600: #c0ca33;
+ --md-lime-700: #afb42b;
+ --md-lime-800: #9e9d24;
+ --md-lime-900: #827717;
+ --md-lime-A100: #f4ff81;
+ --md-lime-A200: #eeff41;
+ --md-lime-A400: #c6ff00;
+ --md-lime-A700: #aeea00;
+ --md-yellow-50: #fffde7;
+ --md-yellow-100: #fff9c4;
+ --md-yellow-200: #fff59d;
+ --md-yellow-300: #fff176;
+ --md-yellow-400: #ffee58;
+ --md-yellow-500: #ffeb3b;
+ --md-yellow-600: #fdd835;
+ --md-yellow-700: #fbc02d;
+ --md-yellow-800: #f9a825;
+ --md-yellow-900: #f57f17;
+ --md-yellow-A100: #ffff8d;
+ --md-yellow-A200: #ff0;
+ --md-yellow-A400: #ffea00;
+ --md-yellow-A700: #ffd600;
+ --md-amber-50: #fff8e1;
+ --md-amber-100: #ffecb3;
+ --md-amber-200: #ffe082;
+ --md-amber-300: #ffd54f;
+ --md-amber-400: #ffca28;
+ --md-amber-500: #ffc107;
+ --md-amber-600: #ffb300;
+ --md-amber-700: #ffa000;
+ --md-amber-800: #ff8f00;
+ --md-amber-900: #ff6f00;
+ --md-amber-A100: #ffe57f;
+ --md-amber-A200: #ffd740;
+ --md-amber-A400: #ffc400;
+ --md-amber-A700: #ffab00;
+ --md-orange-50: #fff3e0;
+ --md-orange-100: #ffe0b2;
+ --md-orange-200: #ffcc80;
+ --md-orange-300: #ffb74d;
+ --md-orange-400: #ffa726;
+ --md-orange-500: #ff9800;
+ --md-orange-600: #fb8c00;
+ --md-orange-700: #f57c00;
+ --md-orange-800: #ef6c00;
+ --md-orange-900: #e65100;
+ --md-orange-A100: #ffd180;
+ --md-orange-A200: #ffab40;
+ --md-orange-A400: #ff9100;
+ --md-orange-A700: #ff6d00;
+ --md-deep-orange-50: #fbe9e7;
+ --md-deep-orange-100: #ffccbc;
+ --md-deep-orange-200: #ffab91;
+ --md-deep-orange-300: #ff8a65;
+ --md-deep-orange-400: #ff7043;
+ --md-deep-orange-500: #ff5722;
+ --md-deep-orange-600: #f4511e;
+ --md-deep-orange-700: #e64a19;
+ --md-deep-orange-800: #d84315;
+ --md-deep-orange-900: #bf360c;
+ --md-deep-orange-A100: #ff9e80;
+ --md-deep-orange-A200: #ff6e40;
+ --md-deep-orange-A400: #ff3d00;
+ --md-deep-orange-A700: #dd2c00;
+ --md-brown-50: #efebe9;
+ --md-brown-100: #d7ccc8;
+ --md-brown-200: #bcaaa4;
+ --md-brown-300: #a1887f;
+ --md-brown-400: #8d6e63;
+ --md-brown-500: #795548;
+ --md-brown-600: #6d4c41;
+ --md-brown-700: #5d4037;
+ --md-brown-800: #4e342e;
+ --md-brown-900: #3e2723;
+ --md-grey-50: #fafafa;
+ --md-grey-100: #f5f5f5;
+ --md-grey-200: #eee;
+ --md-grey-300: #e0e0e0;
+ --md-grey-400: #bdbdbd;
+ --md-grey-500: #9e9e9e;
+ --md-grey-600: #757575;
+ --md-grey-700: #616161;
+ --md-grey-800: #424242;
+ --md-grey-900: #212121;
+ --md-blue-grey-50: #eceff1;
+ --md-blue-grey-100: #cfd8dc;
+ --md-blue-grey-200: #b0bec5;
+ --md-blue-grey-300: #90a4ae;
+ --md-blue-grey-400: #78909c;
+ --md-blue-grey-500: #607d8b;
+ --md-blue-grey-600: #546e7a;
+ --md-blue-grey-700: #455a64;
+ --md-blue-grey-800: #37474f;
+ --md-blue-grey-900: #263238;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) 2014-2017, Jupyter Development Team.
+|
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/*-----------------------------------------------------------------------------
+| RenderedText
+|----------------------------------------------------------------------------*/
+
+:root {
+ /* This is the padding value to fill the gaps between lines containing spans with background color. */
+ --jp-private-code-span-padding: calc(
+ (var(--jp-code-line-height) - 1) * var(--jp-code-font-size) / 2
+ );
+}
+
+.jp-RenderedText {
+ text-align: left;
+ padding-left: var(--jp-code-padding);
+ line-height: var(--jp-code-line-height);
+ font-family: var(--jp-code-font-family);
+}
+
+.jp-RenderedText pre,
+.jp-RenderedJavaScript pre,
+.jp-RenderedHTMLCommon pre {
+ color: var(--jp-content-font-color1);
+ font-size: var(--jp-code-font-size);
+ border: none;
+ margin: 0;
+ padding: 0;
+}
+
+.jp-RenderedText pre a:link {
+ text-decoration: none;
+ color: var(--jp-content-link-color);
+}
+
+.jp-RenderedText pre a:hover {
+ text-decoration: underline;
+ color: var(--jp-content-link-color);
+}
+
+.jp-RenderedText pre a:visited {
+ text-decoration: none;
+ color: var(--jp-content-link-color);
+}
+
+/* console foregrounds and backgrounds */
+.jp-RenderedText pre .ansi-black-fg {
+ color: #3e424d;
+}
+
+.jp-RenderedText pre .ansi-red-fg {
+ color: #e75c58;
+}
+
+.jp-RenderedText pre .ansi-green-fg {
+ color: #00a250;
+}
+
+.jp-RenderedText pre .ansi-yellow-fg {
+ color: #ddb62b;
+}
+
+.jp-RenderedText pre .ansi-blue-fg {
+ color: #208ffb;
+}
+
+.jp-RenderedText pre .ansi-magenta-fg {
+ color: #d160c4;
+}
+
+.jp-RenderedText pre .ansi-cyan-fg {
+ color: #60c6c8;
+}
+
+.jp-RenderedText pre .ansi-white-fg {
+ color: #c5c1b4;
+}
+
+.jp-RenderedText pre .ansi-black-bg {
+ background-color: #3e424d;
+ padding: var(--jp-private-code-span-padding) 0;
+}
+
+.jp-RenderedText pre .ansi-red-bg {
+ background-color: #e75c58;
+ padding: var(--jp-private-code-span-padding) 0;
+}
+
+.jp-RenderedText pre .ansi-green-bg {
+ background-color: #00a250;
+ padding: var(--jp-private-code-span-padding) 0;
+}
+
+.jp-RenderedText pre .ansi-yellow-bg {
+ background-color: #ddb62b;
+ padding: var(--jp-private-code-span-padding) 0;
+}
+
+.jp-RenderedText pre .ansi-blue-bg {
+ background-color: #208ffb;
+ padding: var(--jp-private-code-span-padding) 0;
+}
+
+.jp-RenderedText pre .ansi-magenta-bg {
+ background-color: #d160c4;
+ padding: var(--jp-private-code-span-padding) 0;
+}
+
+.jp-RenderedText pre .ansi-cyan-bg {
+ background-color: #60c6c8;
+ padding: var(--jp-private-code-span-padding) 0;
+}
+
+.jp-RenderedText pre .ansi-white-bg {
+ background-color: #c5c1b4;
+ padding: var(--jp-private-code-span-padding) 0;
+}
+
+.jp-RenderedText pre .ansi-black-intense-fg {
+ color: #282c36;
+}
+
+.jp-RenderedText pre .ansi-red-intense-fg {
+ color: #b22b31;
+}
+
+.jp-RenderedText pre .ansi-green-intense-fg {
+ color: #007427;
+}
+
+.jp-RenderedText pre .ansi-yellow-intense-fg {
+ color: #b27d12;
+}
+
+.jp-RenderedText pre .ansi-blue-intense-fg {
+ color: #0065ca;
+}
+
+.jp-RenderedText pre .ansi-magenta-intense-fg {
+ color: #a03196;
+}
+
+.jp-RenderedText pre .ansi-cyan-intense-fg {
+ color: #258f8f;
+}
+
+.jp-RenderedText pre .ansi-white-intense-fg {
+ color: #a1a6b2;
+}
+
+.jp-RenderedText pre .ansi-black-intense-bg {
+ background-color: #282c36;
+ padding: var(--jp-private-code-span-padding) 0;
+}
+
+.jp-RenderedText pre .ansi-red-intense-bg {
+ background-color: #b22b31;
+ padding: var(--jp-private-code-span-padding) 0;
+}
+
+.jp-RenderedText pre .ansi-green-intense-bg {
+ background-color: #007427;
+ padding: var(--jp-private-code-span-padding) 0;
+}
+
+.jp-RenderedText pre .ansi-yellow-intense-bg {
+ background-color: #b27d12;
+ padding: var(--jp-private-code-span-padding) 0;
+}
+
+.jp-RenderedText pre .ansi-blue-intense-bg {
+ background-color: #0065ca;
+ padding: var(--jp-private-code-span-padding) 0;
+}
+
+.jp-RenderedText pre .ansi-magenta-intense-bg {
+ background-color: #a03196;
+ padding: var(--jp-private-code-span-padding) 0;
+}
+
+.jp-RenderedText pre .ansi-cyan-intense-bg {
+ background-color: #258f8f;
+ padding: var(--jp-private-code-span-padding) 0;
+}
+
+.jp-RenderedText pre .ansi-white-intense-bg {
+ background-color: #a1a6b2;
+ padding: var(--jp-private-code-span-padding) 0;
+}
+
+.jp-RenderedText pre .ansi-default-inverse-fg {
+ color: var(--jp-ui-inverse-font-color0);
+}
+
+.jp-RenderedText pre .ansi-default-inverse-bg {
+ background-color: var(--jp-inverse-layout-color0);
+ padding: var(--jp-private-code-span-padding) 0;
+}
+
+.jp-RenderedText pre .ansi-bold {
+ font-weight: bold;
+}
+
+.jp-RenderedText pre .ansi-underline {
+ text-decoration: underline;
+}
+
+.jp-RenderedText[data-mime-type='application/vnd.jupyter.stderr'] {
+ background: var(--jp-rendermime-error-background);
+ padding-top: var(--jp-code-padding);
+}
+
+/*-----------------------------------------------------------------------------
+| RenderedLatex
+|----------------------------------------------------------------------------*/
+
+.jp-RenderedLatex {
+ color: var(--jp-content-font-color1);
+ font-size: var(--jp-content-font-size1);
+ line-height: var(--jp-content-line-height);
+}
+
+/* Left-justify outputs.*/
+.jp-OutputArea-output.jp-RenderedLatex {
+ padding: var(--jp-code-padding);
+ text-align: left;
+}
+
+/*-----------------------------------------------------------------------------
+| RenderedHTML
+|----------------------------------------------------------------------------*/
+
+.jp-RenderedHTMLCommon {
+ color: var(--jp-content-font-color1);
+ font-family: var(--jp-content-font-family);
+ font-size: var(--jp-content-font-size1);
+ line-height: var(--jp-content-line-height);
+
+ /* Give a bit more R padding on Markdown text to keep line lengths reasonable */
+ padding-right: 20px;
+}
+
+.jp-RenderedHTMLCommon em {
+ font-style: italic;
+}
+
+.jp-RenderedHTMLCommon strong {
+ font-weight: bold;
+}
+
+.jp-RenderedHTMLCommon u {
+ text-decoration: underline;
+}
+
+.jp-RenderedHTMLCommon a:link {
+ text-decoration: none;
+ color: var(--jp-content-link-color);
+}
+
+.jp-RenderedHTMLCommon a:hover {
+ text-decoration: underline;
+ color: var(--jp-content-link-color);
+}
+
+.jp-RenderedHTMLCommon a:visited {
+ text-decoration: none;
+ color: var(--jp-content-link-color);
+}
+
+/* Headings */
+
+.jp-RenderedHTMLCommon h1,
+.jp-RenderedHTMLCommon h2,
+.jp-RenderedHTMLCommon h3,
+.jp-RenderedHTMLCommon h4,
+.jp-RenderedHTMLCommon h5,
+.jp-RenderedHTMLCommon h6 {
+ line-height: var(--jp-content-heading-line-height);
+ font-weight: var(--jp-content-heading-font-weight);
+ font-style: normal;
+ margin: var(--jp-content-heading-margin-top) 0
+ var(--jp-content-heading-margin-bottom) 0;
+}
+
+.jp-RenderedHTMLCommon h1:first-child,
+.jp-RenderedHTMLCommon h2:first-child,
+.jp-RenderedHTMLCommon h3:first-child,
+.jp-RenderedHTMLCommon h4:first-child,
+.jp-RenderedHTMLCommon h5:first-child,
+.jp-RenderedHTMLCommon h6:first-child {
+ margin-top: calc(0.5 * var(--jp-content-heading-margin-top));
+}
+
+.jp-RenderedHTMLCommon h1:last-child,
+.jp-RenderedHTMLCommon h2:last-child,
+.jp-RenderedHTMLCommon h3:last-child,
+.jp-RenderedHTMLCommon h4:last-child,
+.jp-RenderedHTMLCommon h5:last-child,
+.jp-RenderedHTMLCommon h6:last-child {
+ margin-bottom: calc(0.5 * var(--jp-content-heading-margin-bottom));
+}
+
+.jp-RenderedHTMLCommon h1 {
+ font-size: var(--jp-content-font-size5);
+}
+
+.jp-RenderedHTMLCommon h2 {
+ font-size: var(--jp-content-font-size4);
+}
+
+.jp-RenderedHTMLCommon h3 {
+ font-size: var(--jp-content-font-size3);
+}
+
+.jp-RenderedHTMLCommon h4 {
+ font-size: var(--jp-content-font-size2);
+}
+
+.jp-RenderedHTMLCommon h5 {
+ font-size: var(--jp-content-font-size1);
+}
+
+.jp-RenderedHTMLCommon h6 {
+ font-size: var(--jp-content-font-size0);
+}
+
+/* Lists */
+
+/* stylelint-disable selector-max-type, selector-max-compound-selectors */
+
+.jp-RenderedHTMLCommon ul:not(.list-inline),
+.jp-RenderedHTMLCommon ol:not(.list-inline) {
+ padding-left: 2em;
+}
+
+.jp-RenderedHTMLCommon ul {
+ list-style: disc;
+}
+
+.jp-RenderedHTMLCommon ul ul {
+ list-style: square;
+}
+
+.jp-RenderedHTMLCommon ul ul ul {
+ list-style: circle;
+}
+
+.jp-RenderedHTMLCommon ol {
+ list-style: decimal;
+}
+
+.jp-RenderedHTMLCommon ol ol {
+ list-style: upper-alpha;
+}
+
+.jp-RenderedHTMLCommon ol ol ol {
+ list-style: lower-alpha;
+}
+
+.jp-RenderedHTMLCommon ol ol ol ol {
+ list-style: lower-roman;
+}
+
+.jp-RenderedHTMLCommon ol ol ol ol ol {
+ list-style: decimal;
+}
+
+.jp-RenderedHTMLCommon ol,
+.jp-RenderedHTMLCommon ul {
+ margin-bottom: 1em;
+}
+
+.jp-RenderedHTMLCommon ul ul,
+.jp-RenderedHTMLCommon ul ol,
+.jp-RenderedHTMLCommon ol ul,
+.jp-RenderedHTMLCommon ol ol {
+ margin-bottom: 0;
+}
+
+/* stylelint-enable selector-max-type, selector-max-compound-selectors */
+
+.jp-RenderedHTMLCommon hr {
+ color: var(--jp-border-color2);
+ background-color: var(--jp-border-color1);
+ margin-top: 1em;
+ margin-bottom: 1em;
+}
+
+.jp-RenderedHTMLCommon > pre {
+ margin: 1.5em 2em;
+}
+
+.jp-RenderedHTMLCommon pre,
+.jp-RenderedHTMLCommon code {
+ border: 0;
+ background-color: var(--jp-layout-color0);
+ color: var(--jp-content-font-color1);
+ font-family: var(--jp-code-font-family);
+ font-size: inherit;
+ line-height: var(--jp-code-line-height);
+ padding: 0;
+ white-space: pre-wrap;
+}
+
+.jp-RenderedHTMLCommon :not(pre) > code {
+ background-color: var(--jp-layout-color2);
+ padding: 1px 5px;
+}
+
+/* Tables */
+
+.jp-RenderedHTMLCommon table {
+ border-collapse: collapse;
+ border-spacing: 0;
+ border: none;
+ color: var(--jp-ui-font-color1);
+ font-size: var(--jp-ui-font-size1);
+ table-layout: fixed;
+ margin-left: auto;
+ margin-bottom: 1em;
+ margin-right: auto;
+}
+
+.jp-RenderedHTMLCommon thead {
+ border-bottom: var(--jp-border-width) solid var(--jp-border-color1);
+ vertical-align: bottom;
+}
+
+.jp-RenderedHTMLCommon td,
+.jp-RenderedHTMLCommon th,
+.jp-RenderedHTMLCommon tr {
+ vertical-align: middle;
+ padding: 0.5em;
+ line-height: normal;
+ white-space: normal;
+ max-width: none;
+ border: none;
+}
+
+.jp-RenderedMarkdown.jp-RenderedHTMLCommon td,
+.jp-RenderedMarkdown.jp-RenderedHTMLCommon th {
+ max-width: none;
+}
+
+:not(.jp-RenderedMarkdown).jp-RenderedHTMLCommon td,
+:not(.jp-RenderedMarkdown).jp-RenderedHTMLCommon th,
+:not(.jp-RenderedMarkdown).jp-RenderedHTMLCommon tr {
+ text-align: right;
+}
+
+.jp-RenderedHTMLCommon th {
+ font-weight: bold;
+}
+
+.jp-RenderedHTMLCommon tbody tr:nth-child(odd) {
+ background: var(--jp-layout-color0);
+}
+
+.jp-RenderedHTMLCommon tbody tr:nth-child(even) {
+ background: var(--jp-rendermime-table-row-background);
+}
+
+.jp-RenderedHTMLCommon tbody tr:hover {
+ background: var(--jp-rendermime-table-row-hover-background);
+}
+
+.jp-RenderedHTMLCommon p {
+ text-align: left;
+ margin: 0;
+ margin-bottom: 1em;
+}
+
+.jp-RenderedHTMLCommon img {
+ -moz-force-broken-image-icon: 1;
+}
+
+/* Restrict to direct children as other images could be nested in other content. */
+.jp-RenderedHTMLCommon > img {
+ display: block;
+ margin-left: 0;
+ margin-right: 0;
+ margin-bottom: 1em;
+}
+
+/* Change color behind transparent images if they need it... */
+[data-jp-theme-light='false'] .jp-RenderedImage img.jp-needs-light-background {
+ background-color: var(--jp-inverse-layout-color1);
+}
+
+[data-jp-theme-light='true'] .jp-RenderedImage img.jp-needs-dark-background {
+ background-color: var(--jp-inverse-layout-color1);
+}
+
+.jp-RenderedHTMLCommon img,
+.jp-RenderedImage img,
+.jp-RenderedHTMLCommon svg,
+.jp-RenderedSVG svg {
+ max-width: 100%;
+ height: auto;
+}
+
+.jp-RenderedHTMLCommon img.jp-mod-unconfined,
+.jp-RenderedImage img.jp-mod-unconfined,
+.jp-RenderedHTMLCommon svg.jp-mod-unconfined,
+.jp-RenderedSVG svg.jp-mod-unconfined {
+ max-width: none;
+}
+
+.jp-RenderedHTMLCommon .alert {
+ padding: var(--jp-notebook-padding);
+ border: var(--jp-border-width) solid transparent;
+ border-radius: var(--jp-border-radius);
+ margin-bottom: 1em;
+}
+
+.jp-RenderedHTMLCommon .alert-info {
+ color: var(--jp-info-color0);
+ background-color: var(--jp-info-color3);
+ border-color: var(--jp-info-color2);
+}
+
+.jp-RenderedHTMLCommon .alert-info hr {
+ border-color: var(--jp-info-color3);
+}
+
+.jp-RenderedHTMLCommon .alert-info > p:last-child,
+.jp-RenderedHTMLCommon .alert-info > ul:last-child {
+ margin-bottom: 0;
+}
+
+.jp-RenderedHTMLCommon .alert-warning {
+ color: var(--jp-warn-color0);
+ background-color: var(--jp-warn-color3);
+ border-color: var(--jp-warn-color2);
+}
+
+.jp-RenderedHTMLCommon .alert-warning hr {
+ border-color: var(--jp-warn-color3);
+}
+
+.jp-RenderedHTMLCommon .alert-warning > p:last-child,
+.jp-RenderedHTMLCommon .alert-warning > ul:last-child {
+ margin-bottom: 0;
+}
+
+.jp-RenderedHTMLCommon .alert-success {
+ color: var(--jp-success-color0);
+ background-color: var(--jp-success-color3);
+ border-color: var(--jp-success-color2);
+}
+
+.jp-RenderedHTMLCommon .alert-success hr {
+ border-color: var(--jp-success-color3);
+}
+
+.jp-RenderedHTMLCommon .alert-success > p:last-child,
+.jp-RenderedHTMLCommon .alert-success > ul:last-child {
+ margin-bottom: 0;
+}
+
+.jp-RenderedHTMLCommon .alert-danger {
+ color: var(--jp-error-color0);
+ background-color: var(--jp-error-color3);
+ border-color: var(--jp-error-color2);
+}
+
+.jp-RenderedHTMLCommon .alert-danger hr {
+ border-color: var(--jp-error-color3);
+}
+
+.jp-RenderedHTMLCommon .alert-danger > p:last-child,
+.jp-RenderedHTMLCommon .alert-danger > ul:last-child {
+ margin-bottom: 0;
+}
+
+.jp-RenderedHTMLCommon blockquote {
+ margin: 1em 2em;
+ padding: 0 1em;
+ border-left: 5px solid var(--jp-border-color2);
+}
+
+a.jp-InternalAnchorLink {
+ visibility: hidden;
+ margin-left: 8px;
+ color: var(--md-blue-800);
+}
+
+h1:hover .jp-InternalAnchorLink,
+h2:hover .jp-InternalAnchorLink,
+h3:hover .jp-InternalAnchorLink,
+h4:hover .jp-InternalAnchorLink,
+h5:hover .jp-InternalAnchorLink,
+h6:hover .jp-InternalAnchorLink {
+ visibility: visible;
+}
+
+.jp-RenderedHTMLCommon kbd {
+ background-color: var(--jp-rendermime-table-row-background);
+ border: 1px solid var(--jp-border-color0);
+ border-bottom-color: var(--jp-border-color2);
+ border-radius: 3px;
+ box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.25);
+ display: inline-block;
+ font-size: var(--jp-ui-font-size0);
+ line-height: 1em;
+ padding: 0.2em 0.5em;
+}
+
+/* Most direct children of .jp-RenderedHTMLCommon have a margin-bottom of 1.0.
+ * At the bottom of cells this is a bit too much as there is also spacing
+ * between cells. Going all the way to 0 gets too tight between markdown and
+ * code cells.
+ */
+.jp-RenderedHTMLCommon > *:last-child {
+ margin-bottom: 0.5em;
+}
+
+/*
+ * Copyright (c) Jupyter Development Team.
+ * Distributed under the terms of the Modified BSD License.
+ */
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Copyright (c) 2014-2017, PhosphorJS Contributors
+|
+| Distributed under the terms of the BSD 3-Clause License.
+|
+| The full license is in the file LICENSE, distributed with this software.
+|----------------------------------------------------------------------------*/
+
+.lm-cursor-backdrop {
+ position: fixed;
+ width: 200px;
+ height: 200px;
+ margin-top: -100px;
+ margin-left: -100px;
+ will-change: transform;
+ z-index: 100;
+}
+
+.lm-mod-drag-image {
+ will-change: transform;
+}
+
+/*
+ * Copyright (c) Jupyter Development Team.
+ * Distributed under the terms of the Modified BSD License.
+ */
+
+.jp-lineFormSearch {
+ padding: 4px 12px;
+ background-color: var(--jp-layout-color2);
+ box-shadow: var(--jp-toolbar-box-shadow);
+ z-index: 2;
+ font-size: var(--jp-ui-font-size1);
+}
+
+.jp-lineFormCaption {
+ font-size: var(--jp-ui-font-size0);
+ line-height: var(--jp-ui-font-size1);
+ margin-top: 4px;
+ color: var(--jp-ui-font-color0);
+}
+
+.jp-baseLineForm {
+ border: none;
+ border-radius: 0;
+ position: absolute;
+ background-size: 16px;
+ background-repeat: no-repeat;
+ background-position: center;
+ outline: none;
+}
+
+.jp-lineFormButtonContainer {
+ top: 4px;
+ right: 8px;
+ height: 24px;
+ padding: 0 12px;
+ width: 12px;
+}
+
+.jp-lineFormButtonIcon {
+ top: 0;
+ right: 0;
+ background-color: var(--jp-brand-color1);
+ height: 100%;
+ width: 100%;
+ box-sizing: border-box;
+ padding: 4px 6px;
+}
+
+.jp-lineFormButton {
+ top: 0;
+ right: 0;
+ background-color: transparent;
+ height: 100%;
+ width: 100%;
+ box-sizing: border-box;
+}
+
+.jp-lineFormWrapper {
+ overflow: hidden;
+ padding: 0 8px;
+ border: 1px solid var(--jp-border-color0);
+ background-color: var(--jp-input-active-background);
+ height: 22px;
+}
+
+.jp-lineFormWrapperFocusWithin {
+ border: var(--jp-border-width) solid var(--md-blue-500);
+ box-shadow: inset 0 0 4px var(--md-blue-300);
+}
+
+.jp-lineFormInput {
+ background: transparent;
+ width: 200px;
+ height: 100%;
+ border: none;
+ outline: none;
+ color: var(--jp-ui-font-color0);
+ line-height: 28px;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) 2014-2016, Jupyter Development Team.
+|
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+.jp-JSONEditor {
+ display: flex;
+ flex-direction: column;
+ width: 100%;
+}
+
+.jp-JSONEditor-host {
+ flex: 1 1 auto;
+ border: var(--jp-border-width) solid var(--jp-input-border-color);
+ border-radius: 0;
+ background: var(--jp-layout-color0);
+ min-height: 50px;
+ padding: 1px;
+}
+
+.jp-JSONEditor.jp-mod-error .jp-JSONEditor-host {
+ border-color: red;
+ outline-color: red;
+}
+
+.jp-JSONEditor-header {
+ display: flex;
+ flex: 1 0 auto;
+ padding: 0 0 0 12px;
+}
+
+.jp-JSONEditor-header label {
+ flex: 0 0 auto;
+}
+
+.jp-JSONEditor-commitButton {
+ height: 16px;
+ width: 16px;
+ background-size: 18px;
+ background-repeat: no-repeat;
+ background-position: center;
+}
+
+.jp-JSONEditor-host.jp-mod-focused {
+ background-color: var(--jp-input-active-background);
+ border: 1px solid var(--jp-input-active-border-color);
+ box-shadow: var(--jp-input-box-shadow);
+}
+
+.jp-Editor.jp-mod-dropTarget {
+ border: var(--jp-border-width) solid var(--jp-input-active-border-color);
+ box-shadow: var(--jp-input-box-shadow);
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+.jp-DocumentSearch-input {
+ border: none;
+ outline: none;
+ color: var(--jp-ui-font-color0);
+ font-size: var(--jp-ui-font-size1);
+ background-color: var(--jp-layout-color0);
+ font-family: var(--jp-ui-font-family);
+ padding: 2px 1px;
+ resize: none;
+}
+
+.jp-DocumentSearch-overlay {
+ position: absolute;
+ background-color: var(--jp-toolbar-background);
+ border-bottom: var(--jp-border-width) solid var(--jp-toolbar-border-color);
+ border-left: var(--jp-border-width) solid var(--jp-toolbar-border-color);
+ top: 0;
+ right: 0;
+ z-index: 7;
+ min-width: 405px;
+ padding: 2px;
+ font-size: var(--jp-ui-font-size1);
+
+ --jp-private-document-search-button-height: 20px;
+}
+
+.jp-DocumentSearch-overlay button {
+ background-color: var(--jp-toolbar-background);
+ outline: 0;
+}
+
+.jp-DocumentSearch-overlay button:hover {
+ background-color: var(--jp-layout-color2);
+}
+
+.jp-DocumentSearch-overlay button:active {
+ background-color: var(--jp-layout-color3);
+}
+
+.jp-DocumentSearch-overlay-row {
+ display: flex;
+ align-items: center;
+ margin-bottom: 2px;
+}
+
+.jp-DocumentSearch-button-content {
+ display: inline-block;
+ cursor: pointer;
+ box-sizing: border-box;
+ width: 100%;
+ height: 100%;
+}
+
+.jp-DocumentSearch-button-content svg {
+ width: 100%;
+ height: 100%;
+}
+
+.jp-DocumentSearch-input-wrapper {
+ border: var(--jp-border-width) solid var(--jp-border-color0);
+ display: flex;
+ background-color: var(--jp-layout-color0);
+ margin: 2px;
+}
+
+.jp-DocumentSearch-input-wrapper:focus-within {
+ border-color: var(--jp-cell-editor-active-border-color);
+}
+
+.jp-DocumentSearch-toggle-wrapper,
+.jp-DocumentSearch-button-wrapper {
+ all: initial;
+ overflow: hidden;
+ display: inline-block;
+ border: none;
+ box-sizing: border-box;
+}
+
+.jp-DocumentSearch-toggle-wrapper {
+ width: 14px;
+ height: 14px;
+}
+
+.jp-DocumentSearch-button-wrapper {
+ width: var(--jp-private-document-search-button-height);
+ height: var(--jp-private-document-search-button-height);
+}
+
+.jp-DocumentSearch-toggle-wrapper:focus,
+.jp-DocumentSearch-button-wrapper:focus {
+ outline: var(--jp-border-width) solid
+ var(--jp-cell-editor-active-border-color);
+ outline-offset: -1px;
+}
+
+.jp-DocumentSearch-toggle-wrapper,
+.jp-DocumentSearch-button-wrapper,
+.jp-DocumentSearch-button-content:focus {
+ outline: none;
+}
+
+.jp-DocumentSearch-toggle-placeholder {
+ width: 5px;
+}
+
+.jp-DocumentSearch-input-button::before {
+ display: block;
+ padding-top: 100%;
+}
+
+.jp-DocumentSearch-input-button-off {
+ opacity: var(--jp-search-toggle-off-opacity);
+}
+
+.jp-DocumentSearch-input-button-off:hover {
+ opacity: var(--jp-search-toggle-hover-opacity);
+}
+
+.jp-DocumentSearch-input-button-on {
+ opacity: var(--jp-search-toggle-on-opacity);
+}
+
+.jp-DocumentSearch-index-counter {
+ padding-left: 10px;
+ padding-right: 10px;
+ user-select: none;
+ min-width: 35px;
+ display: inline-block;
+}
+
+.jp-DocumentSearch-up-down-wrapper {
+ display: inline-block;
+ padding-right: 2px;
+ margin-left: auto;
+ white-space: nowrap;
+}
+
+.jp-DocumentSearch-spacer {
+ margin-left: auto;
+}
+
+.jp-DocumentSearch-up-down-wrapper button {
+ outline: 0;
+ border: none;
+ width: var(--jp-private-document-search-button-height);
+ height: var(--jp-private-document-search-button-height);
+ vertical-align: middle;
+ margin: 1px 5px 2px;
+}
+
+.jp-DocumentSearch-up-down-button:hover {
+ background-color: var(--jp-layout-color2);
+}
+
+.jp-DocumentSearch-up-down-button:active {
+ background-color: var(--jp-layout-color3);
+}
+
+.jp-DocumentSearch-filter-button {
+ border-radius: var(--jp-border-radius);
+}
+
+.jp-DocumentSearch-filter-button:hover {
+ background-color: var(--jp-layout-color2);
+}
+
+.jp-DocumentSearch-filter-button-enabled {
+ background-color: var(--jp-layout-color2);
+}
+
+.jp-DocumentSearch-filter-button-enabled:hover {
+ background-color: var(--jp-layout-color3);
+}
+
+.jp-DocumentSearch-search-options {
+ padding: 0 8px;
+ margin-left: 3px;
+ width: 100%;
+ display: grid;
+ justify-content: start;
+ grid-template-columns: 1fr 1fr;
+ align-items: center;
+ justify-items: stretch;
+}
+
+.jp-DocumentSearch-search-filter-disabled {
+ color: var(--jp-ui-font-color2);
+}
+
+.jp-DocumentSearch-search-filter {
+ display: flex;
+ align-items: center;
+ user-select: none;
+}
+
+.jp-DocumentSearch-regex-error {
+ color: var(--jp-error-color0);
+}
+
+.jp-DocumentSearch-replace-button-wrapper {
+ overflow: hidden;
+ display: inline-block;
+ box-sizing: border-box;
+ border: var(--jp-border-width) solid var(--jp-border-color0);
+ margin: auto 2px;
+ padding: 1px 4px;
+ height: calc(var(--jp-private-document-search-button-height) + 2px);
+}
+
+.jp-DocumentSearch-replace-button-wrapper:focus {
+ border: var(--jp-border-width) solid var(--jp-cell-editor-active-border-color);
+}
+
+.jp-DocumentSearch-replace-button {
+ display: inline-block;
+ text-align: center;
+ cursor: pointer;
+ box-sizing: border-box;
+ color: var(--jp-ui-font-color1);
+
+ /* height - 2 * (padding of wrapper) */
+ line-height: calc(var(--jp-private-document-search-button-height) - 2px);
+ width: 100%;
+ height: 100%;
+}
+
+.jp-DocumentSearch-replace-button:focus {
+ outline: none;
+}
+
+.jp-DocumentSearch-replace-wrapper-class {
+ margin-left: 14px;
+ display: flex;
+}
+
+.jp-DocumentSearch-replace-toggle {
+ border: none;
+ background-color: var(--jp-toolbar-background);
+ border-radius: var(--jp-border-radius);
+}
+
+.jp-DocumentSearch-replace-toggle:hover {
+ background-color: var(--jp-layout-color2);
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+.cm-editor {
+ line-height: var(--jp-code-line-height);
+ font-size: var(--jp-code-font-size);
+ font-family: var(--jp-code-font-family);
+ border: 0;
+ border-radius: 0;
+ height: auto;
+
+ /* Changed to auto to autogrow */
+}
+
+.cm-editor pre {
+ padding: 0 var(--jp-code-padding);
+}
+
+.jp-CodeMirrorEditor[data-type='inline'] .cm-dialog {
+ background-color: var(--jp-layout-color0);
+ color: var(--jp-content-font-color1);
+}
+
+.jp-CodeMirrorEditor {
+ cursor: text;
+}
+
+/* When zoomed out 67% and 33% on a screen of 1440 width x 900 height */
+@media screen and (min-width: 2138px) and (max-width: 4319px) {
+ .jp-CodeMirrorEditor[data-type='inline'] .cm-cursor {
+ border-left: var(--jp-code-cursor-width1) solid
+ var(--jp-editor-cursor-color);
+ }
+}
+
+/* When zoomed out less than 33% */
+@media screen and (min-width: 4320px) {
+ .jp-CodeMirrorEditor[data-type='inline'] .cm-cursor {
+ border-left: var(--jp-code-cursor-width2) solid
+ var(--jp-editor-cursor-color);
+ }
+}
+
+.cm-editor.jp-mod-readOnly .cm-cursor {
+ display: none;
+}
+
+.jp-CollaboratorCursor {
+ border-left: 5px solid transparent;
+ border-right: 5px solid transparent;
+ border-top: none;
+ border-bottom: 3px solid;
+ background-clip: content-box;
+ margin-left: -5px;
+ margin-right: -5px;
+}
+
+.cm-searching,
+.cm-searching span {
+ /* `.cm-searching span`: we need to override syntax highlighting */
+ background-color: var(--jp-search-unselected-match-background-color);
+ color: var(--jp-search-unselected-match-color);
+}
+
+.cm-searching::selection,
+.cm-searching span::selection {
+ background-color: var(--jp-search-unselected-match-background-color);
+ color: var(--jp-search-unselected-match-color);
+}
+
+.jp-current-match > .cm-searching,
+.jp-current-match > .cm-searching span,
+.cm-searching > .jp-current-match,
+.cm-searching > .jp-current-match span {
+ background-color: var(--jp-search-selected-match-background-color);
+ color: var(--jp-search-selected-match-color);
+}
+
+.jp-current-match > .cm-searching::selection,
+.cm-searching > .jp-current-match::selection,
+.jp-current-match > .cm-searching span::selection {
+ background-color: var(--jp-search-selected-match-background-color);
+ color: var(--jp-search-selected-match-color);
+}
+
+.cm-trailingspace {
+ background-image: url();
+ background-position: center left;
+ background-repeat: repeat-x;
+}
+
+.jp-CollaboratorCursor-hover {
+ position: absolute;
+ z-index: 1;
+ transform: translateX(-50%);
+ color: white;
+ border-radius: 3px;
+ padding-left: 4px;
+ padding-right: 4px;
+ padding-top: 1px;
+ padding-bottom: 1px;
+ text-align: center;
+ font-size: var(--jp-ui-font-size1);
+ white-space: nowrap;
+}
+
+.jp-CodeMirror-ruler {
+ border-left: 1px dashed var(--jp-border-color2);
+}
+
+/* Styles for shared cursors (remote cursor locations and selected ranges) */
+.jp-CodeMirrorEditor .cm-ySelectionCaret {
+ position: relative;
+ border-left: 1px solid black;
+ margin-left: -1px;
+ margin-right: -1px;
+ box-sizing: border-box;
+}
+
+.jp-CodeMirrorEditor .cm-ySelectionCaret > .cm-ySelectionInfo {
+ white-space: nowrap;
+ position: absolute;
+ top: -1.15em;
+ padding-bottom: 0.05em;
+ left: -1px;
+ font-size: 0.95em;
+ font-family: var(--jp-ui-font-family);
+ font-weight: bold;
+ line-height: normal;
+ user-select: none;
+ color: white;
+ padding-left: 2px;
+ padding-right: 2px;
+ z-index: 101;
+ transition: opacity 0.3s ease-in-out;
+}
+
+.jp-CodeMirrorEditor .cm-ySelectionInfo {
+ transition-delay: 0.7s;
+ opacity: 0;
+}
+
+.jp-CodeMirrorEditor .cm-ySelectionCaret:hover > .cm-ySelectionInfo {
+ opacity: 1;
+ transition-delay: 0s;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+.jp-MimeDocument {
+ outline: none;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/*-----------------------------------------------------------------------------
+| Variables
+|----------------------------------------------------------------------------*/
+
+:root {
+ --jp-private-filebrowser-button-height: 28px;
+ --jp-private-filebrowser-button-width: 48px;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+.jp-FileBrowser .jp-SidePanel-content {
+ display: flex;
+ flex-direction: column;
+}
+
+.jp-FileBrowser-toolbar.jp-Toolbar {
+ flex-wrap: wrap;
+ row-gap: 12px;
+ border-bottom: none;
+ height: auto;
+ margin: 8px 12px 0;
+ box-shadow: none;
+ padding: 0;
+ justify-content: flex-start;
+}
+
+.jp-FileBrowser-Panel {
+ flex: 1 1 auto;
+ display: flex;
+ flex-direction: column;
+}
+
+.jp-BreadCrumbs {
+ flex: 0 0 auto;
+ margin: 8px 12px;
+}
+
+.jp-BreadCrumbs-item {
+ margin: 0 2px;
+ padding: 0 2px;
+ border-radius: var(--jp-border-radius);
+ cursor: pointer;
+}
+
+.jp-BreadCrumbs-item:hover {
+ background-color: var(--jp-layout-color2);
+}
+
+.jp-BreadCrumbs-item:first-child {
+ margin-left: 0;
+}
+
+.jp-BreadCrumbs-item.jp-mod-dropTarget {
+ background-color: var(--jp-brand-color2);
+ opacity: 0.7;
+}
+
+/*-----------------------------------------------------------------------------
+| Buttons
+|----------------------------------------------------------------------------*/
+
+.jp-FileBrowser-toolbar > .jp-Toolbar-item {
+ flex: 0 0 auto;
+ padding-left: 0;
+ padding-right: 2px;
+ align-items: center;
+ height: unset;
+}
+
+.jp-FileBrowser-toolbar > .jp-Toolbar-item .jp-ToolbarButtonComponent {
+ width: 40px;
+}
+
+/*-----------------------------------------------------------------------------
+| Other styles
+|----------------------------------------------------------------------------*/
+
+.jp-FileDialog.jp-mod-conflict input {
+ color: var(--jp-error-color1);
+}
+
+.jp-FileDialog .jp-new-name-title {
+ margin-top: 12px;
+}
+
+.jp-LastModified-hidden {
+ display: none;
+}
+
+.jp-FileSize-hidden {
+ display: none;
+}
+
+.jp-FileBrowser .lm-AccordionPanel > h3:first-child {
+ display: none;
+}
+
+/*-----------------------------------------------------------------------------
+| DirListing
+|----------------------------------------------------------------------------*/
+
+.jp-DirListing {
+ flex: 1 1 auto;
+ display: flex;
+ flex-direction: column;
+ outline: 0;
+}
+
+.jp-DirListing-header {
+ flex: 0 0 auto;
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ overflow: hidden;
+ border-top: var(--jp-border-width) solid var(--jp-border-color2);
+ border-bottom: var(--jp-border-width) solid var(--jp-border-color1);
+ box-shadow: var(--jp-toolbar-box-shadow);
+ z-index: 2;
+}
+
+.jp-DirListing-headerItem {
+ padding: 4px 12px 2px;
+ font-weight: 500;
+}
+
+.jp-DirListing-headerItem:hover {
+ background: var(--jp-layout-color2);
+}
+
+.jp-DirListing-headerItem.jp-id-name {
+ flex: 1 0 84px;
+}
+
+.jp-DirListing-headerItem.jp-id-modified {
+ flex: 0 0 112px;
+ border-left: var(--jp-border-width) solid var(--jp-border-color2);
+ text-align: right;
+}
+
+.jp-DirListing-headerItem.jp-id-filesize {
+ flex: 0 0 75px;
+ border-left: var(--jp-border-width) solid var(--jp-border-color2);
+ text-align: right;
+}
+
+.jp-id-narrow {
+ display: none;
+ flex: 0 0 5px;
+ padding: 4px;
+ border-left: var(--jp-border-width) solid var(--jp-border-color2);
+ text-align: right;
+ color: var(--jp-border-color2);
+}
+
+.jp-DirListing-narrow .jp-id-narrow {
+ display: block;
+}
+
+.jp-DirListing-narrow .jp-id-modified,
+.jp-DirListing-narrow .jp-DirListing-itemModified {
+ display: none;
+}
+
+.jp-DirListing-headerItem.jp-mod-selected {
+ font-weight: 600;
+}
+
+/* increase specificity to override bundled default */
+.jp-DirListing-content {
+ flex: 1 1 auto;
+ margin: 0;
+ padding: 0;
+ list-style-type: none;
+ overflow: auto;
+ background-color: var(--jp-layout-color1);
+}
+
+.jp-DirListing-content mark {
+ color: var(--jp-ui-font-color0);
+ background-color: transparent;
+ font-weight: bold;
+}
+
+.jp-DirListing-content .jp-DirListing-item.jp-mod-selected mark {
+ color: var(--jp-ui-inverse-font-color0);
+}
+
+/* Style the directory listing content when a user drops a file to upload */
+.jp-DirListing.jp-mod-native-drop .jp-DirListing-content {
+ outline: 5px dashed rgba(128, 128, 128, 0.5);
+ outline-offset: -10px;
+ cursor: copy;
+}
+
+.jp-DirListing-item {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ padding: 4px 12px;
+ -webkit-user-select: none;
+ -moz-user-select: none;
+ -ms-user-select: none;
+ user-select: none;
+}
+
+.jp-DirListing-checkboxWrapper {
+ /* Increases hit area of checkbox. */
+ padding: 4px;
+}
+
+.jp-DirListing-header
+ .jp-DirListing-checkboxWrapper
+ + .jp-DirListing-headerItem {
+ padding-left: 4px;
+}
+
+.jp-DirListing-content .jp-DirListing-checkboxWrapper {
+ position: relative;
+ left: -4px;
+ margin: -4px 0 -4px -8px;
+}
+
+.jp-DirListing-checkboxWrapper.jp-mod-visible {
+ visibility: visible;
+}
+
+/* For devices that support hovering, hide checkboxes until hovered, selected...
+*/
+@media (hover: hover) {
+ .jp-DirListing-checkboxWrapper {
+ visibility: hidden;
+ }
+
+ .jp-DirListing-item:hover .jp-DirListing-checkboxWrapper,
+ .jp-DirListing-item.jp-mod-selected .jp-DirListing-checkboxWrapper {
+ visibility: visible;
+ }
+}
+
+.jp-DirListing-item[data-is-dot] {
+ opacity: 75%;
+}
+
+.jp-DirListing-item.jp-mod-selected {
+ color: var(--jp-ui-inverse-font-color1);
+ background: var(--jp-brand-color1);
+}
+
+.jp-DirListing-item.jp-mod-dropTarget {
+ background: var(--jp-brand-color3);
+}
+
+.jp-DirListing-item:hover:not(.jp-mod-selected) {
+ background: var(--jp-layout-color2);
+}
+
+.jp-DirListing-itemIcon {
+ flex: 0 0 20px;
+ margin-right: 4px;
+}
+
+.jp-DirListing-itemText {
+ flex: 1 0 64px;
+ white-space: nowrap;
+ overflow: hidden;
+ text-overflow: ellipsis;
+ user-select: none;
+}
+
+.jp-DirListing-itemText:focus {
+ outline-width: 2px;
+ outline-color: var(--jp-inverse-layout-color1);
+ outline-style: solid;
+ outline-offset: 1px;
+}
+
+.jp-DirListing-item.jp-mod-selected .jp-DirListing-itemText:focus {
+ outline-color: var(--jp-layout-color1);
+}
+
+.jp-DirListing-itemModified {
+ flex: 0 0 125px;
+ text-align: right;
+}
+
+.jp-DirListing-itemFileSize {
+ flex: 0 0 90px;
+ text-align: right;
+}
+
+.jp-DirListing-editor {
+ flex: 1 0 64px;
+ outline: none;
+ border: none;
+ color: var(--jp-ui-font-color1);
+ background-color: var(--jp-layout-color1);
+}
+
+.jp-DirListing-item.jp-mod-running .jp-DirListing-itemIcon::before {
+ color: var(--jp-success-color1);
+ content: '\25CF';
+ font-size: 8px;
+ position: absolute;
+ left: -8px;
+}
+
+.jp-DirListing-item.jp-mod-running.jp-mod-selected
+ .jp-DirListing-itemIcon::before {
+ color: var(--jp-ui-inverse-font-color1);
+}
+
+.jp-DirListing-item.lm-mod-drag-image,
+.jp-DirListing-item.jp-mod-selected.lm-mod-drag-image {
+ font-size: var(--jp-ui-font-size1);
+ padding-left: 4px;
+ margin-left: 4px;
+ width: 160px;
+ background-color: var(--jp-ui-inverse-font-color2);
+ box-shadow: var(--jp-elevation-z2);
+ border-radius: 0;
+ color: var(--jp-ui-font-color1);
+ transform: translateX(-40%) translateY(-58%);
+}
+
+.jp-Document {
+ min-width: 120px;
+ min-height: 120px;
+ outline: none;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/*-----------------------------------------------------------------------------
+| Main OutputArea
+| OutputArea has a list of Outputs
+|----------------------------------------------------------------------------*/
+
+.jp-OutputArea {
+ overflow-y: auto;
+}
+
+.jp-OutputArea-child {
+ display: table;
+ table-layout: fixed;
+ width: 100%;
+ overflow: hidden;
+}
+
+.jp-OutputPrompt {
+ width: var(--jp-cell-prompt-width);
+ color: var(--jp-cell-outprompt-font-color);
+ font-family: var(--jp-cell-prompt-font-family);
+ padding: var(--jp-code-padding);
+ letter-spacing: var(--jp-cell-prompt-letter-spacing);
+ line-height: var(--jp-code-line-height);
+ font-size: var(--jp-code-font-size);
+ border: var(--jp-border-width) solid transparent;
+ opacity: var(--jp-cell-prompt-opacity);
+
+ /* Right align prompt text, don't wrap to handle large prompt numbers */
+ text-align: right;
+ white-space: nowrap;
+ overflow: hidden;
+ text-overflow: ellipsis;
+
+ /* Disable text selection */
+ -webkit-user-select: none;
+ -moz-user-select: none;
+ -ms-user-select: none;
+ user-select: none;
+}
+
+.jp-OutputArea-prompt {
+ display: table-cell;
+ vertical-align: top;
+}
+
+.jp-OutputArea-output {
+ display: table-cell;
+ width: 100%;
+ height: auto;
+ overflow: auto;
+ user-select: text;
+ -moz-user-select: text;
+ -webkit-user-select: text;
+ -ms-user-select: text;
+}
+
+.jp-OutputArea .jp-RenderedText {
+ padding-left: 1ch;
+}
+
+/**
+ * Prompt overlay.
+ */
+
+.jp-OutputArea-promptOverlay {
+ position: absolute;
+ top: 0;
+ width: var(--jp-cell-prompt-width);
+ height: 100%;
+ opacity: 0.5;
+}
+
+.jp-OutputArea-promptOverlay:hover {
+ background: var(--jp-layout-color2);
+ box-shadow: inset 0 0 1px var(--jp-inverse-layout-color0);
+ cursor: zoom-out;
+}
+
+.jp-mod-outputsScrolled .jp-OutputArea-promptOverlay:hover {
+ cursor: zoom-in;
+}
+
+/**
+ * Isolated output.
+ */
+.jp-OutputArea-output.jp-mod-isolated {
+ width: 100%;
+ display: block;
+}
+
+/*
+When drag events occur, `lm-mod-override-cursor` is added to the body.
+Because iframes steal all cursor events, the following two rules are necessary
+to suppress pointer events while resize drags are occurring. There may be a
+better solution to this problem.
+*/
+body.lm-mod-override-cursor .jp-OutputArea-output.jp-mod-isolated {
+ position: relative;
+}
+
+body.lm-mod-override-cursor .jp-OutputArea-output.jp-mod-isolated::before {
+ content: '';
+ position: absolute;
+ top: 0;
+ left: 0;
+ right: 0;
+ bottom: 0;
+ background: transparent;
+}
+
+/* pre */
+
+.jp-OutputArea-output pre {
+ border: none;
+ margin: 0;
+ padding: 0;
+ overflow-x: auto;
+ overflow-y: auto;
+ word-break: break-all;
+ word-wrap: break-word;
+ white-space: pre-wrap;
+}
+
+/* tables */
+
+.jp-OutputArea-output.jp-RenderedHTMLCommon table {
+ margin-left: 0;
+ margin-right: 0;
+}
+
+/* description lists */
+
+.jp-OutputArea-output dl,
+.jp-OutputArea-output dt,
+.jp-OutputArea-output dd {
+ display: block;
+}
+
+.jp-OutputArea-output dl {
+ width: 100%;
+ overflow: hidden;
+ padding: 0;
+ margin: 0;
+}
+
+.jp-OutputArea-output dt {
+ font-weight: bold;
+ float: left;
+ width: 20%;
+ padding: 0;
+ margin: 0;
+}
+
+.jp-OutputArea-output dd {
+ float: left;
+ width: 80%;
+ padding: 0;
+ margin: 0;
+}
+
+.jp-TrimmedOutputs pre {
+ background: var(--jp-layout-color3);
+ font-size: calc(var(--jp-code-font-size) * 1.4);
+ text-align: center;
+ text-transform: uppercase;
+}
+
+/* Hide the gutter in case of
+ * - nested output areas (e.g. in the case of output widgets)
+ * - mirrored output areas
+ */
+.jp-OutputArea .jp-OutputArea .jp-OutputArea-prompt {
+ display: none;
+}
+
+/* Hide empty lines in the output area, for instance due to cleared widgets */
+.jp-OutputArea-prompt:empty {
+ padding: 0;
+ border: 0;
+}
+
+/*-----------------------------------------------------------------------------
+| executeResult is added to any Output-result for the display of the object
+| returned by a cell
+|----------------------------------------------------------------------------*/
+
+.jp-OutputArea-output.jp-OutputArea-executeResult {
+ margin-left: 0;
+ width: 100%;
+}
+
+/* Text output with the Out[] prompt needs a top padding to match the
+ * alignment of the Out[] prompt itself.
+ */
+.jp-OutputArea-executeResult .jp-RenderedText.jp-OutputArea-output {
+ padding-top: var(--jp-code-padding);
+ border-top: var(--jp-border-width) solid transparent;
+}
+
+/*-----------------------------------------------------------------------------
+| The Stdin output
+|----------------------------------------------------------------------------*/
+
+.jp-Stdin-prompt {
+ color: var(--jp-content-font-color0);
+ padding-right: var(--jp-code-padding);
+ vertical-align: baseline;
+ flex: 0 0 auto;
+}
+
+.jp-Stdin-input {
+ font-family: var(--jp-code-font-family);
+ font-size: inherit;
+ color: inherit;
+ background-color: inherit;
+ width: 42%;
+ min-width: 200px;
+
+ /* make sure input baseline aligns with prompt */
+ vertical-align: baseline;
+
+ /* padding + margin = 0.5em between prompt and cursor */
+ padding: 0 0.25em;
+ margin: 0 0.25em;
+ flex: 0 0 70%;
+}
+
+.jp-Stdin-input::placeholder {
+ opacity: 0;
+}
+
+.jp-Stdin-input:focus {
+ box-shadow: none;
+}
+
+.jp-Stdin-input:focus::placeholder {
+ opacity: 1;
+}
+
+/*-----------------------------------------------------------------------------
+| Output Area View
+|----------------------------------------------------------------------------*/
+
+.jp-LinkedOutputView .jp-OutputArea {
+ height: 100%;
+ display: block;
+}
+
+.jp-LinkedOutputView .jp-OutputArea-output:only-child {
+ height: 100%;
+}
+
+/*-----------------------------------------------------------------------------
+| Printing
+|----------------------------------------------------------------------------*/
+
+@media print {
+ .jp-OutputArea-child {
+ break-inside: avoid-page;
+ }
+}
+
+/*-----------------------------------------------------------------------------
+| Mobile
+|----------------------------------------------------------------------------*/
+@media only screen and (max-width: 760px) {
+ .jp-OutputPrompt {
+ display: table-row;
+ text-align: left;
+ }
+
+ .jp-OutputArea-child .jp-OutputArea-output {
+ display: table-row;
+ margin-left: var(--jp-notebook-padding);
+ }
+}
+
+/* Trimmed outputs warning */
+.jp-TrimmedOutputs > a {
+ margin: 10px;
+ text-decoration: none;
+ cursor: pointer;
+}
+
+.jp-TrimmedOutputs > a:hover {
+ text-decoration: none;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/*-----------------------------------------------------------------------------
+| Table of Contents
+|----------------------------------------------------------------------------*/
+
+:root {
+ --jp-private-toc-active-width: 4px;
+}
+
+.jp-TableOfContents {
+ display: flex;
+ flex-direction: column;
+ background: var(--jp-layout-color1);
+ color: var(--jp-ui-font-color1);
+ font-size: var(--jp-ui-font-size1);
+ height: 100%;
+}
+
+.jp-TableOfContents-placeholder {
+ text-align: center;
+}
+
+.jp-TableOfContents-placeholderContent {
+ color: var(--jp-content-font-color2);
+ padding: 8px;
+}
+
+.jp-TableOfContents-placeholderContent > h3 {
+ margin-bottom: var(--jp-content-heading-margin-bottom);
+}
+
+.jp-TableOfContents .jp-SidePanel-content {
+ overflow-y: auto;
+}
+
+.jp-TableOfContents-tree {
+ margin: 4px;
+}
+
+.jp-TableOfContents ol {
+ list-style-type: none;
+}
+
+/* stylelint-disable-next-line selector-max-type */
+.jp-TableOfContents li > ol {
+ /* Align left border with triangle icon center */
+ padding-left: 11px;
+}
+
+.jp-TableOfContents-content {
+ /* left margin for the active heading indicator */
+ margin: 0 0 0 var(--jp-private-toc-active-width);
+ padding: 0;
+ background-color: var(--jp-layout-color1);
+}
+
+.jp-tocItem {
+ -webkit-user-select: none;
+ -moz-user-select: none;
+ -ms-user-select: none;
+ user-select: none;
+}
+
+.jp-tocItem-heading {
+ display: flex;
+ cursor: pointer;
+}
+
+.jp-tocItem-heading:hover {
+ background-color: var(--jp-layout-color2);
+}
+
+.jp-tocItem-content {
+ display: block;
+ padding: 4px 0;
+ white-space: nowrap;
+ text-overflow: ellipsis;
+ overflow-x: hidden;
+}
+
+.jp-tocItem-collapser {
+ height: 20px;
+ margin: 2px 2px 0;
+ padding: 0;
+ background: none;
+ border: none;
+ cursor: pointer;
+}
+
+.jp-tocItem-collapser:hover {
+ background-color: var(--jp-layout-color3);
+}
+
+/* Active heading indicator */
+
+.jp-tocItem-heading::before {
+ content: ' ';
+ background: transparent;
+ width: var(--jp-private-toc-active-width);
+ height: 24px;
+ position: absolute;
+ left: 0;
+ border-radius: var(--jp-border-radius);
+}
+
+.jp-tocItem-heading.jp-tocItem-active::before {
+ background-color: var(--jp-brand-color1);
+}
+
+.jp-tocItem-heading:hover.jp-tocItem-active::before {
+ background: var(--jp-brand-color0);
+ opacity: 1;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+.jp-Collapser {
+ flex: 0 0 var(--jp-cell-collapser-width);
+ padding: 0;
+ margin: 0;
+ border: none;
+ outline: none;
+ background: transparent;
+ border-radius: var(--jp-border-radius);
+ opacity: 1;
+}
+
+.jp-Collapser-child {
+ display: block;
+ width: 100%;
+ box-sizing: border-box;
+
+ /* height: 100% doesn't work because the height of its parent is computed from content */
+ position: absolute;
+ top: 0;
+ bottom: 0;
+}
+
+/*-----------------------------------------------------------------------------
+| Printing
+|----------------------------------------------------------------------------*/
+
+/*
+Hiding collapsers in print mode.
+
+Note: input and output wrappers have "display: block" propery in print mode.
+*/
+
+@media print {
+ .jp-Collapser {
+ display: none;
+ }
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/*-----------------------------------------------------------------------------
+| Header/Footer
+|----------------------------------------------------------------------------*/
+
+/* Hidden by zero height by default */
+.jp-CellHeader,
+.jp-CellFooter {
+ height: 0;
+ width: 100%;
+ padding: 0;
+ margin: 0;
+ border: none;
+ outline: none;
+ background: transparent;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/*-----------------------------------------------------------------------------
+| Input
+|----------------------------------------------------------------------------*/
+
+/* All input areas */
+.jp-InputArea {
+ display: table;
+ table-layout: fixed;
+ width: 100%;
+ overflow: hidden;
+}
+
+.jp-InputArea-editor {
+ display: table-cell;
+ overflow: hidden;
+ vertical-align: top;
+
+ /* This is the non-active, default styling */
+ border: var(--jp-border-width) solid var(--jp-cell-editor-border-color);
+ border-radius: 0;
+ background: var(--jp-cell-editor-background);
+}
+
+.jp-InputPrompt {
+ display: table-cell;
+ vertical-align: top;
+ width: var(--jp-cell-prompt-width);
+ color: var(--jp-cell-inprompt-font-color);
+ font-family: var(--jp-cell-prompt-font-family);
+ padding: var(--jp-code-padding);
+ letter-spacing: var(--jp-cell-prompt-letter-spacing);
+ opacity: var(--jp-cell-prompt-opacity);
+ line-height: var(--jp-code-line-height);
+ font-size: var(--jp-code-font-size);
+ border: var(--jp-border-width) solid transparent;
+
+ /* Right align prompt text, don't wrap to handle large prompt numbers */
+ text-align: right;
+ white-space: nowrap;
+ overflow: hidden;
+ text-overflow: ellipsis;
+
+ /* Disable text selection */
+ -webkit-user-select: none;
+ -moz-user-select: none;
+ -ms-user-select: none;
+ user-select: none;
+}
+
+/*-----------------------------------------------------------------------------
+| Mobile
+|----------------------------------------------------------------------------*/
+@media only screen and (max-width: 760px) {
+ .jp-InputArea-editor {
+ display: table-row;
+ margin-left: var(--jp-notebook-padding);
+ }
+
+ .jp-InputPrompt {
+ display: table-row;
+ text-align: left;
+ }
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/*-----------------------------------------------------------------------------
+| Placeholder
+|----------------------------------------------------------------------------*/
+
+.jp-Placeholder {
+ display: table;
+ table-layout: fixed;
+ width: 100%;
+}
+
+.jp-Placeholder-prompt {
+ display: table-cell;
+ box-sizing: border-box;
+}
+
+.jp-Placeholder-content {
+ display: table-cell;
+ padding: 4px 6px;
+ border: 1px solid transparent;
+ border-radius: 0;
+ background: none;
+ box-sizing: border-box;
+ cursor: pointer;
+}
+
+.jp-Placeholder-contentContainer {
+ display: flex;
+}
+
+.jp-Placeholder-content:hover,
+.jp-InputPlaceholder > .jp-Placeholder-content:hover {
+ border-color: var(--jp-layout-color3);
+}
+
+.jp-Placeholder-content .jp-MoreHorizIcon {
+ width: 32px;
+ height: 16px;
+ border: 1px solid transparent;
+ border-radius: var(--jp-border-radius);
+}
+
+.jp-Placeholder-content .jp-MoreHorizIcon:hover {
+ border: 1px solid var(--jp-border-color1);
+ box-shadow: 0 0 2px 0 rgba(0, 0, 0, 0.25);
+ background-color: var(--jp-layout-color0);
+}
+
+.jp-PlaceholderText {
+ white-space: nowrap;
+ overflow-x: hidden;
+ color: var(--jp-inverse-layout-color3);
+ font-family: var(--jp-code-font-family);
+}
+
+.jp-InputPlaceholder > .jp-Placeholder-content {
+ border-color: var(--jp-cell-editor-border-color);
+ background: var(--jp-cell-editor-background);
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/*-----------------------------------------------------------------------------
+| Private CSS variables
+|----------------------------------------------------------------------------*/
+
+:root {
+ --jp-private-cell-scrolling-output-offset: 5px;
+}
+
+/*-----------------------------------------------------------------------------
+| Cell
+|----------------------------------------------------------------------------*/
+
+.jp-Cell {
+ padding: var(--jp-cell-padding);
+ margin: 0;
+ border: none;
+ outline: none;
+ background: transparent;
+}
+
+/*-----------------------------------------------------------------------------
+| Common input/output
+|----------------------------------------------------------------------------*/
+
+.jp-Cell-inputWrapper,
+.jp-Cell-outputWrapper {
+ display: flex;
+ flex-direction: row;
+ padding: 0;
+ margin: 0;
+
+ /* Added to reveal the box-shadow on the input and output collapsers. */
+ overflow: visible;
+}
+
+/* Only input/output areas inside cells */
+.jp-Cell-inputArea,
+.jp-Cell-outputArea {
+ flex: 1 1 auto;
+}
+
+/*-----------------------------------------------------------------------------
+| Collapser
+|----------------------------------------------------------------------------*/
+
+/* Make the output collapser disappear when there is not output, but do so
+ * in a manner that leaves it in the layout and preserves its width.
+ */
+.jp-Cell.jp-mod-noOutputs .jp-Cell-outputCollapser {
+ border: none !important;
+ background: transparent !important;
+}
+
+.jp-Cell:not(.jp-mod-noOutputs) .jp-Cell-outputCollapser {
+ min-height: var(--jp-cell-collapser-min-height);
+}
+
+/*-----------------------------------------------------------------------------
+| Output
+|----------------------------------------------------------------------------*/
+
+/* Put a space between input and output when there IS output */
+.jp-Cell:not(.jp-mod-noOutputs) .jp-Cell-outputWrapper {
+ margin-top: 5px;
+}
+
+.jp-CodeCell.jp-mod-outputsScrolled .jp-Cell-outputArea {
+ overflow-y: auto;
+ max-height: 24em;
+ margin-left: var(--jp-private-cell-scrolling-output-offset);
+ resize: vertical;
+}
+
+.jp-CodeCell.jp-mod-outputsScrolled .jp-Cell-outputArea[style*='height'] {
+ max-height: unset;
+}
+
+.jp-CodeCell.jp-mod-outputsScrolled .jp-Cell-outputArea::after {
+ content: ' ';
+ box-shadow: inset 0 0 6px 2px rgb(0 0 0 / 30%);
+ width: 100%;
+ height: 100%;
+ position: sticky;
+ bottom: 0;
+ top: 0;
+ margin-top: -50%;
+ float: left;
+ display: block;
+ pointer-events: none;
+}
+
+.jp-CodeCell.jp-mod-outputsScrolled .jp-OutputArea-child {
+ padding-top: 6px;
+}
+
+.jp-CodeCell.jp-mod-outputsScrolled .jp-OutputArea-prompt {
+ width: calc(
+ var(--jp-cell-prompt-width) - var(--jp-private-cell-scrolling-output-offset)
+ );
+}
+
+.jp-CodeCell.jp-mod-outputsScrolled .jp-OutputArea-promptOverlay {
+ left: calc(-1 * var(--jp-private-cell-scrolling-output-offset));
+}
+
+/*-----------------------------------------------------------------------------
+| CodeCell
+|----------------------------------------------------------------------------*/
+
+/*-----------------------------------------------------------------------------
+| MarkdownCell
+|----------------------------------------------------------------------------*/
+
+.jp-MarkdownOutput {
+ display: table-cell;
+ width: 100%;
+ margin-top: 0;
+ margin-bottom: 0;
+ padding-left: var(--jp-code-padding);
+}
+
+.jp-MarkdownOutput.jp-RenderedHTMLCommon {
+ overflow: auto;
+}
+
+/* collapseHeadingButton (show always if hiddenCellsButton is _not_ shown) */
+.jp-collapseHeadingButton {
+ display: flex;
+ min-height: var(--jp-cell-collapser-min-height);
+ font-size: var(--jp-code-font-size);
+ position: absolute;
+ background-color: transparent;
+ background-size: 25px;
+ background-repeat: no-repeat;
+ background-position-x: center;
+ background-position-y: top;
+ background-image: var(--jp-icon-caret-down);
+ right: 0;
+ top: 0;
+ bottom: 0;
+}
+
+.jp-collapseHeadingButton.jp-mod-collapsed {
+ background-image: var(--jp-icon-caret-right);
+}
+
+/*
+ set the container font size to match that of content
+ so that the nested collapse buttons have the right size
+*/
+.jp-MarkdownCell .jp-InputPrompt {
+ font-size: var(--jp-content-font-size1);
+}
+
+/*
+ Align collapseHeadingButton with cell top header
+ The font sizes are identical to the ones in packages/rendermime/style/base.css
+*/
+.jp-mod-rendered .jp-collapseHeadingButton[data-heading-level='1'] {
+ font-size: var(--jp-content-font-size5);
+ background-position-y: calc(0.3 * var(--jp-content-font-size5));
+}
+
+.jp-mod-rendered .jp-collapseHeadingButton[data-heading-level='2'] {
+ font-size: var(--jp-content-font-size4);
+ background-position-y: calc(0.3 * var(--jp-content-font-size4));
+}
+
+.jp-mod-rendered .jp-collapseHeadingButton[data-heading-level='3'] {
+ font-size: var(--jp-content-font-size3);
+ background-position-y: calc(0.3 * var(--jp-content-font-size3));
+}
+
+.jp-mod-rendered .jp-collapseHeadingButton[data-heading-level='4'] {
+ font-size: var(--jp-content-font-size2);
+ background-position-y: calc(0.3 * var(--jp-content-font-size2));
+}
+
+.jp-mod-rendered .jp-collapseHeadingButton[data-heading-level='5'] {
+ font-size: var(--jp-content-font-size1);
+ background-position-y: top;
+}
+
+.jp-mod-rendered .jp-collapseHeadingButton[data-heading-level='6'] {
+ font-size: var(--jp-content-font-size0);
+ background-position-y: top;
+}
+
+/* collapseHeadingButton (show only on (hover,active) if hiddenCellsButton is shown) */
+.jp-Notebook.jp-mod-showHiddenCellsButton .jp-collapseHeadingButton {
+ display: none;
+}
+
+.jp-Notebook.jp-mod-showHiddenCellsButton
+ :is(.jp-MarkdownCell:hover, .jp-mod-active)
+ .jp-collapseHeadingButton {
+ display: flex;
+}
+
+/* showHiddenCellsButton (only show if jp-mod-showHiddenCellsButton is set, which
+is a consequence of the showHiddenCellsButton option in Notebook Settings)*/
+.jp-Notebook.jp-mod-showHiddenCellsButton .jp-showHiddenCellsButton {
+ margin-left: calc(var(--jp-cell-prompt-width) + 2 * var(--jp-code-padding));
+ margin-top: var(--jp-code-padding);
+ border: 1px solid var(--jp-border-color2);
+ background-color: var(--jp-border-color3) !important;
+ color: var(--jp-content-font-color0) !important;
+ display: flex;
+}
+
+.jp-Notebook.jp-mod-showHiddenCellsButton .jp-showHiddenCellsButton:hover {
+ background-color: var(--jp-border-color2) !important;
+}
+
+.jp-showHiddenCellsButton {
+ display: none;
+}
+
+/*-----------------------------------------------------------------------------
+| Printing
+|----------------------------------------------------------------------------*/
+
+/*
+Using block instead of flex to allow the use of the break-inside CSS property for
+cell outputs.
+*/
+
+@media print {
+ .jp-Cell-inputWrapper,
+ .jp-Cell-outputWrapper {
+ display: block;
+ }
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/*-----------------------------------------------------------------------------
+| Variables
+|----------------------------------------------------------------------------*/
+
+:root {
+ --jp-notebook-toolbar-padding: 2px 5px 2px 2px;
+}
+
+/*-----------------------------------------------------------------------------
+
+/*-----------------------------------------------------------------------------
+| Styles
+|----------------------------------------------------------------------------*/
+
+.jp-NotebookPanel-toolbar {
+ padding: var(--jp-notebook-toolbar-padding);
+
+ /* disable paint containment from lumino 2.0 default strict CSS containment */
+ contain: style size !important;
+}
+
+.jp-Toolbar-item.jp-Notebook-toolbarCellType .jp-select-wrapper.jp-mod-focused {
+ border: none;
+ box-shadow: none;
+}
+
+.jp-Notebook-toolbarCellTypeDropdown select {
+ height: 24px;
+ font-size: var(--jp-ui-font-size1);
+ line-height: 14px;
+ border-radius: 0;
+ display: block;
+}
+
+.jp-Notebook-toolbarCellTypeDropdown span {
+ top: 5px !important;
+}
+
+.jp-Toolbar-responsive-popup {
+ position: absolute;
+ height: fit-content;
+ display: flex;
+ flex-direction: row;
+ flex-wrap: wrap;
+ justify-content: flex-end;
+ border-bottom: var(--jp-border-width) solid var(--jp-toolbar-border-color);
+ box-shadow: var(--jp-toolbar-box-shadow);
+ background: var(--jp-toolbar-background);
+ min-height: var(--jp-toolbar-micro-height);
+ padding: var(--jp-notebook-toolbar-padding);
+ z-index: 1;
+ right: 0;
+ top: 0;
+}
+
+.jp-Toolbar > .jp-Toolbar-responsive-opener {
+ margin-left: auto;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/*-----------------------------------------------------------------------------
+| Variables
+|----------------------------------------------------------------------------*/
+
+/*-----------------------------------------------------------------------------
+
+/*-----------------------------------------------------------------------------
+| Styles
+|----------------------------------------------------------------------------*/
+
+.jp-Notebook-ExecutionIndicator {
+ position: relative;
+ display: inline-block;
+ height: 100%;
+ z-index: 9997;
+}
+
+.jp-Notebook-ExecutionIndicator-tooltip {
+ visibility: hidden;
+ height: auto;
+ width: max-content;
+ width: -moz-max-content;
+ background-color: var(--jp-layout-color2);
+ color: var(--jp-ui-font-color1);
+ text-align: justify;
+ border-radius: 6px;
+ padding: 0 5px;
+ position: fixed;
+ display: table;
+}
+
+.jp-Notebook-ExecutionIndicator-tooltip.up {
+ transform: translateX(-50%) translateY(-100%) translateY(-32px);
+}
+
+.jp-Notebook-ExecutionIndicator-tooltip.down {
+ transform: translateX(calc(-100% + 16px)) translateY(5px);
+}
+
+.jp-Notebook-ExecutionIndicator-tooltip.hidden {
+ display: none;
+}
+
+.jp-Notebook-ExecutionIndicator:hover .jp-Notebook-ExecutionIndicator-tooltip {
+ visibility: visible;
+}
+
+.jp-Notebook-ExecutionIndicator span {
+ font-size: var(--jp-ui-font-size1);
+ font-family: var(--jp-ui-font-family);
+ color: var(--jp-ui-font-color1);
+ line-height: 24px;
+ display: block;
+}
+
+.jp-Notebook-ExecutionIndicator-progress-bar {
+ display: flex;
+ justify-content: center;
+ height: 100%;
+}
+
+/*
+ * Copyright (c) Jupyter Development Team.
+ * Distributed under the terms of the Modified BSD License.
+ */
+
+/*
+ * Execution indicator
+ */
+.jp-tocItem-content::after {
+ content: '';
+
+ /* Must be identical to form a circle */
+ width: 12px;
+ height: 12px;
+ background: none;
+ border: none;
+ position: absolute;
+ right: 0;
+}
+
+.jp-tocItem-content[data-running='0']::after {
+ border-radius: 50%;
+ border: var(--jp-border-width) solid var(--jp-inverse-layout-color3);
+ background: none;
+}
+
+.jp-tocItem-content[data-running='1']::after {
+ border-radius: 50%;
+ border: var(--jp-border-width) solid var(--jp-inverse-layout-color3);
+ background-color: var(--jp-inverse-layout-color3);
+}
+
+.jp-tocItem-content[data-running='0'],
+.jp-tocItem-content[data-running='1'] {
+ margin-right: 12px;
+}
+
+/*
+ * Copyright (c) Jupyter Development Team.
+ * Distributed under the terms of the Modified BSD License.
+ */
+
+.jp-Notebook-footer {
+ height: 27px;
+ margin-left: calc(
+ var(--jp-cell-prompt-width) + var(--jp-cell-collapser-width) +
+ var(--jp-cell-padding)
+ );
+ width: calc(
+ 100% -
+ (
+ var(--jp-cell-prompt-width) + var(--jp-cell-collapser-width) +
+ var(--jp-cell-padding) + var(--jp-cell-padding)
+ )
+ );
+ border: var(--jp-border-width) solid var(--jp-cell-editor-border-color);
+ color: var(--jp-ui-font-color3);
+ margin-top: 6px;
+ background: none;
+ cursor: pointer;
+}
+
+.jp-Notebook-footer:focus {
+ border-color: var(--jp-cell-editor-active-border-color);
+}
+
+/* For devices that support hovering, hide footer until hover */
+@media (hover: hover) {
+ .jp-Notebook-footer {
+ opacity: 0;
+ }
+
+ .jp-Notebook-footer:focus,
+ .jp-Notebook-footer:hover {
+ opacity: 1;
+ }
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/*-----------------------------------------------------------------------------
+| Imports
+|----------------------------------------------------------------------------*/
+
+/*-----------------------------------------------------------------------------
+| CSS variables
+|----------------------------------------------------------------------------*/
+
+:root {
+ --jp-side-by-side-output-size: 1fr;
+ --jp-side-by-side-resized-cell: var(--jp-side-by-side-output-size);
+ --jp-private-notebook-dragImage-width: 304px;
+ --jp-private-notebook-dragImage-height: 36px;
+ --jp-private-notebook-selected-color: var(--md-blue-400);
+ --jp-private-notebook-active-color: var(--md-green-400);
+}
+
+/*-----------------------------------------------------------------------------
+| Notebook
+|----------------------------------------------------------------------------*/
+
+/* stylelint-disable selector-max-class */
+
+.jp-NotebookPanel {
+ display: block;
+ height: 100%;
+}
+
+.jp-NotebookPanel.jp-Document {
+ min-width: 240px;
+ min-height: 120px;
+}
+
+.jp-Notebook {
+ padding: var(--jp-notebook-padding);
+ outline: none;
+ overflow: auto;
+ background: var(--jp-layout-color0);
+}
+
+.jp-Notebook.jp-mod-scrollPastEnd::after {
+ display: block;
+ content: '';
+ min-height: var(--jp-notebook-scroll-padding);
+}
+
+.jp-MainAreaWidget-ContainStrict .jp-Notebook * {
+ contain: strict;
+}
+
+.jp-Notebook .jp-Cell {
+ overflow: visible;
+}
+
+.jp-Notebook .jp-Cell .jp-InputPrompt {
+ cursor: move;
+}
+
+/*-----------------------------------------------------------------------------
+| Notebook state related styling
+|
+| The notebook and cells each have states, here are the possibilities:
+|
+| - Notebook
+| - Command
+| - Edit
+| - Cell
+| - None
+| - Active (only one can be active)
+| - Selected (the cells actions are applied to)
+| - Multiselected (when multiple selected, the cursor)
+| - No outputs
+|----------------------------------------------------------------------------*/
+
+/* Command or edit modes */
+
+.jp-Notebook .jp-Cell:not(.jp-mod-active) .jp-InputPrompt {
+ opacity: var(--jp-cell-prompt-not-active-opacity);
+ color: var(--jp-cell-prompt-not-active-font-color);
+}
+
+.jp-Notebook .jp-Cell:not(.jp-mod-active) .jp-OutputPrompt {
+ opacity: var(--jp-cell-prompt-not-active-opacity);
+ color: var(--jp-cell-prompt-not-active-font-color);
+}
+
+/* cell is active */
+.jp-Notebook .jp-Cell.jp-mod-active .jp-Collapser {
+ background: var(--jp-brand-color1);
+}
+
+/* cell is dirty */
+.jp-Notebook .jp-Cell.jp-mod-dirty .jp-InputPrompt {
+ color: var(--jp-warn-color1);
+}
+
+.jp-Notebook .jp-Cell.jp-mod-dirty .jp-InputPrompt::before {
+ color: var(--jp-warn-color1);
+ content: '•';
+}
+
+.jp-Notebook .jp-Cell.jp-mod-active.jp-mod-dirty .jp-Collapser {
+ background: var(--jp-warn-color1);
+}
+
+/* collapser is hovered */
+.jp-Notebook .jp-Cell .jp-Collapser:hover {
+ box-shadow: var(--jp-elevation-z2);
+ background: var(--jp-brand-color1);
+ opacity: var(--jp-cell-collapser-not-active-hover-opacity);
+}
+
+/* cell is active and collapser is hovered */
+.jp-Notebook .jp-Cell.jp-mod-active .jp-Collapser:hover {
+ background: var(--jp-brand-color0);
+ opacity: 1;
+}
+
+/* Command mode */
+
+.jp-Notebook.jp-mod-commandMode .jp-Cell.jp-mod-selected {
+ background: var(--jp-notebook-multiselected-color);
+}
+
+.jp-Notebook.jp-mod-commandMode
+ .jp-Cell.jp-mod-active.jp-mod-selected:not(.jp-mod-multiSelected) {
+ background: transparent;
+}
+
+/* Edit mode */
+
+.jp-Notebook.jp-mod-editMode .jp-Cell.jp-mod-active .jp-InputArea-editor {
+ border: var(--jp-border-width) solid var(--jp-cell-editor-active-border-color);
+ box-shadow: var(--jp-input-box-shadow);
+ background-color: var(--jp-cell-editor-active-background);
+}
+
+/*-----------------------------------------------------------------------------
+| Notebook drag and drop
+|----------------------------------------------------------------------------*/
+
+.jp-Notebook-cell.jp-mod-dropSource {
+ opacity: 0.5;
+}
+
+.jp-Notebook-cell.jp-mod-dropTarget,
+.jp-Notebook.jp-mod-commandMode
+ .jp-Notebook-cell.jp-mod-active.jp-mod-selected.jp-mod-dropTarget {
+ border-top-color: var(--jp-private-notebook-selected-color);
+ border-top-style: solid;
+ border-top-width: 2px;
+}
+
+.jp-dragImage {
+ display: block;
+ flex-direction: row;
+ width: var(--jp-private-notebook-dragImage-width);
+ height: var(--jp-private-notebook-dragImage-height);
+ border: var(--jp-border-width) solid var(--jp-cell-editor-border-color);
+ background: var(--jp-cell-editor-background);
+ overflow: visible;
+}
+
+.jp-dragImage-singlePrompt {
+ box-shadow: 2px 2px 4px 0 rgba(0, 0, 0, 0.12);
+}
+
+.jp-dragImage .jp-dragImage-content {
+ flex: 1 1 auto;
+ z-index: 2;
+ font-size: var(--jp-code-font-size);
+ font-family: var(--jp-code-font-family);
+ line-height: var(--jp-code-line-height);
+ padding: var(--jp-code-padding);
+ border: var(--jp-border-width) solid var(--jp-cell-editor-border-color);
+ background: var(--jp-cell-editor-background-color);
+ color: var(--jp-content-font-color3);
+ text-align: left;
+ margin: 4px 4px 4px 0;
+}
+
+.jp-dragImage .jp-dragImage-prompt {
+ flex: 0 0 auto;
+ min-width: 36px;
+ color: var(--jp-cell-inprompt-font-color);
+ padding: var(--jp-code-padding);
+ padding-left: 12px;
+ font-family: var(--jp-cell-prompt-font-family);
+ letter-spacing: var(--jp-cell-prompt-letter-spacing);
+ line-height: 1.9;
+ font-size: var(--jp-code-font-size);
+ border: var(--jp-border-width) solid transparent;
+}
+
+.jp-dragImage-multipleBack {
+ z-index: -1;
+ position: absolute;
+ height: 32px;
+ width: 300px;
+ top: 8px;
+ left: 8px;
+ background: var(--jp-layout-color2);
+ border: var(--jp-border-width) solid var(--jp-input-border-color);
+ box-shadow: 2px 2px 4px 0 rgba(0, 0, 0, 0.12);
+}
+
+/*-----------------------------------------------------------------------------
+| Cell toolbar
+|----------------------------------------------------------------------------*/
+
+.jp-NotebookTools {
+ display: block;
+ min-width: var(--jp-sidebar-min-width);
+ color: var(--jp-ui-font-color1);
+ background: var(--jp-layout-color1);
+
+ /* This is needed so that all font sizing of children done in ems is
+ * relative to this base size */
+ font-size: var(--jp-ui-font-size1);
+ overflow: auto;
+}
+
+.jp-ActiveCellTool {
+ padding: 12px 0;
+ display: flex;
+}
+
+.jp-ActiveCellTool-Content {
+ flex: 1 1 auto;
+}
+
+.jp-ActiveCellTool .jp-ActiveCellTool-CellContent {
+ background: var(--jp-cell-editor-background);
+ border: var(--jp-border-width) solid var(--jp-cell-editor-border-color);
+ border-radius: 0;
+ min-height: 29px;
+}
+
+.jp-ActiveCellTool .jp-InputPrompt {
+ min-width: calc(var(--jp-cell-prompt-width) * 0.75);
+}
+
+.jp-ActiveCellTool-CellContent > pre {
+ padding: 5px 4px;
+ margin: 0;
+ white-space: normal;
+}
+
+.jp-MetadataEditorTool {
+ flex-direction: column;
+ padding: 12px 0;
+}
+
+.jp-RankedPanel > :not(:first-child) {
+ margin-top: 12px;
+}
+
+.jp-KeySelector select.jp-mod-styled {
+ font-size: var(--jp-ui-font-size1);
+ color: var(--jp-ui-font-color0);
+ border: var(--jp-border-width) solid var(--jp-border-color1);
+}
+
+.jp-KeySelector label,
+.jp-MetadataEditorTool label,
+.jp-NumberSetter label {
+ line-height: 1.4;
+}
+
+.jp-NotebookTools .jp-select-wrapper {
+ margin-top: 4px;
+ margin-bottom: 0;
+}
+
+.jp-NumberSetter input {
+ width: 100%;
+ margin-top: 4px;
+}
+
+.jp-NotebookTools .jp-Collapse {
+ margin-top: 16px;
+}
+
+/*-----------------------------------------------------------------------------
+| Presentation Mode (.jp-mod-presentationMode)
+|----------------------------------------------------------------------------*/
+
+.jp-mod-presentationMode .jp-Notebook {
+ --jp-content-font-size1: var(--jp-content-presentation-font-size1);
+ --jp-code-font-size: var(--jp-code-presentation-font-size);
+}
+
+.jp-mod-presentationMode .jp-Notebook .jp-Cell .jp-InputPrompt,
+.jp-mod-presentationMode .jp-Notebook .jp-Cell .jp-OutputPrompt {
+ flex: 0 0 110px;
+}
+
+/*-----------------------------------------------------------------------------
+| Side-by-side Mode (.jp-mod-sideBySide)
+|----------------------------------------------------------------------------*/
+.jp-mod-sideBySide.jp-Notebook .jp-Notebook-cell {
+ margin-top: 3em;
+ margin-bottom: 3em;
+ margin-left: 5%;
+ margin-right: 5%;
+}
+
+.jp-mod-sideBySide.jp-Notebook .jp-CodeCell {
+ display: grid;
+ grid-template-columns: minmax(0, 1fr) min-content minmax(
+ 0,
+ var(--jp-side-by-side-output-size)
+ );
+ grid-template-rows: auto minmax(0, 1fr) auto;
+ grid-template-areas:
+ 'header header header'
+ 'input handle output'
+ 'footer footer footer';
+}
+
+.jp-mod-sideBySide.jp-Notebook .jp-CodeCell.jp-mod-resizedCell {
+ grid-template-columns: minmax(0, 1fr) min-content minmax(
+ 0,
+ var(--jp-side-by-side-resized-cell)
+ );
+}
+
+.jp-mod-sideBySide.jp-Notebook .jp-CodeCell .jp-CellHeader {
+ grid-area: header;
+}
+
+.jp-mod-sideBySide.jp-Notebook .jp-CodeCell .jp-Cell-inputWrapper {
+ grid-area: input;
+}
+
+.jp-mod-sideBySide.jp-Notebook .jp-CodeCell .jp-Cell-outputWrapper {
+ /* overwrite the default margin (no vertical separation needed in side by side move */
+ margin-top: 0;
+ grid-area: output;
+}
+
+.jp-mod-sideBySide.jp-Notebook .jp-CodeCell .jp-CellFooter {
+ grid-area: footer;
+}
+
+.jp-mod-sideBySide.jp-Notebook .jp-CodeCell .jp-CellResizeHandle {
+ grid-area: handle;
+ user-select: none;
+ display: block;
+ height: 100%;
+ cursor: ew-resize;
+ padding: 0 var(--jp-cell-padding);
+}
+
+.jp-mod-sideBySide.jp-Notebook .jp-CodeCell .jp-CellResizeHandle::after {
+ content: '';
+ display: block;
+ background: var(--jp-border-color2);
+ height: 100%;
+ width: 5px;
+}
+
+.jp-mod-sideBySide.jp-Notebook
+ .jp-CodeCell.jp-mod-resizedCell
+ .jp-CellResizeHandle::after {
+ background: var(--jp-border-color0);
+}
+
+.jp-CellResizeHandle {
+ display: none;
+}
+
+/*-----------------------------------------------------------------------------
+| Placeholder
+|----------------------------------------------------------------------------*/
+
+.jp-Cell-Placeholder {
+ padding-left: 55px;
+}
+
+.jp-Cell-Placeholder-wrapper {
+ background: #fff;
+ border: 1px solid;
+ border-color: #e5e6e9 #dfe0e4 #d0d1d5;
+ border-radius: 4px;
+ -webkit-border-radius: 4px;
+ margin: 10px 15px;
+}
+
+.jp-Cell-Placeholder-wrapper-inner {
+ padding: 15px;
+ position: relative;
+}
+
+.jp-Cell-Placeholder-wrapper-body {
+ background-repeat: repeat;
+ background-size: 50% auto;
+}
+
+.jp-Cell-Placeholder-wrapper-body div {
+ background: #f6f7f8;
+ background-image: -webkit-linear-gradient(
+ left,
+ #f6f7f8 0%,
+ #edeef1 20%,
+ #f6f7f8 40%,
+ #f6f7f8 100%
+ );
+ background-repeat: no-repeat;
+ background-size: 800px 104px;
+ height: 104px;
+ position: absolute;
+ right: 15px;
+ left: 15px;
+ top: 15px;
+}
+
+div.jp-Cell-Placeholder-h1 {
+ top: 20px;
+ height: 20px;
+ left: 15px;
+ width: 150px;
+}
+
+div.jp-Cell-Placeholder-h2 {
+ left: 15px;
+ top: 50px;
+ height: 10px;
+ width: 100px;
+}
+
+div.jp-Cell-Placeholder-content-1,
+div.jp-Cell-Placeholder-content-2,
+div.jp-Cell-Placeholder-content-3 {
+ left: 15px;
+ right: 15px;
+ height: 10px;
+}
+
+div.jp-Cell-Placeholder-content-1 {
+ top: 100px;
+}
+
+div.jp-Cell-Placeholder-content-2 {
+ top: 120px;
+}
+
+div.jp-Cell-Placeholder-content-3 {
+ top: 140px;
+}
+
+</style>
+<style type="text/css">
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/*
+The following CSS variables define the main, public API for styling JupyterLab.
+These variables should be used by all plugins wherever possible. In other
+words, plugins should not define custom colors, sizes, etc unless absolutely
+necessary. This enables users to change the visual theme of JupyterLab
+by changing these variables.
+
+Many variables appear in an ordered sequence (0,1,2,3). These sequences
+are designed to work well together, so for example, `--jp-border-color1` should
+be used with `--jp-layout-color1`. The numbers have the following meanings:
+
+* 0: super-primary, reserved for special emphasis
+* 1: primary, most important under normal situations
+* 2: secondary, next most important under normal situations
+* 3: tertiary, next most important under normal situations
+
+Throughout JupyterLab, we are mostly following principles from Google's
+Material Design when selecting colors. We are not, however, following
+all of MD as it is not optimized for dense, information rich UIs.
+*/
+
+:root {
+ /* Elevation
+ *
+ * We style box-shadows using Material Design's idea of elevation. These particular numbers are taken from here:
+ *
+ * https://github.com/material-components/material-components-web
+ * https://material-components-web.appspot.com/elevation.html
+ */
+
+ /* The dark theme shadows need a bit of work, but this will probably also require work on the core layout
+ * colors used in the theme as well. */
+ --jp-shadow-base-lightness: 32;
+ --jp-shadow-umbra-color: rgba(
+ var(--jp-shadow-base-lightness),
+ var(--jp-shadow-base-lightness),
+ var(--jp-shadow-base-lightness),
+ 0.2
+ );
+ --jp-shadow-penumbra-color: rgba(
+ var(--jp-shadow-base-lightness),
+ var(--jp-shadow-base-lightness),
+ var(--jp-shadow-base-lightness),
+ 0.14
+ );
+ --jp-shadow-ambient-color: rgba(
+ var(--jp-shadow-base-lightness),
+ var(--jp-shadow-base-lightness),
+ var(--jp-shadow-base-lightness),
+ 0.12
+ );
+ --jp-elevation-z0: none;
+ --jp-elevation-z1: 0 2px 1px -1px var(--jp-shadow-umbra-color),
+ 0 1px 1px 0 var(--jp-shadow-penumbra-color),
+ 0 1px 3px 0 var(--jp-shadow-ambient-color);
+ --jp-elevation-z2: 0 3px 1px -2px var(--jp-shadow-umbra-color),
+ 0 2px 2px 0 var(--jp-shadow-penumbra-color),
+ 0 1px 5px 0 var(--jp-shadow-ambient-color);
+ --jp-elevation-z4: 0 2px 4px -1px var(--jp-shadow-umbra-color),
+ 0 4px 5px 0 var(--jp-shadow-penumbra-color),
+ 0 1px 10px 0 var(--jp-shadow-ambient-color);
+ --jp-elevation-z6: 0 3px 5px -1px var(--jp-shadow-umbra-color),
+ 0 6px 10px 0 var(--jp-shadow-penumbra-color),
+ 0 1px 18px 0 var(--jp-shadow-ambient-color);
+ --jp-elevation-z8: 0 5px 5px -3px var(--jp-shadow-umbra-color),
+ 0 8px 10px 1px var(--jp-shadow-penumbra-color),
+ 0 3px 14px 2px var(--jp-shadow-ambient-color);
+ --jp-elevation-z12: 0 7px 8px -4px var(--jp-shadow-umbra-color),
+ 0 12px 17px 2px var(--jp-shadow-penumbra-color),
+ 0 5px 22px 4px var(--jp-shadow-ambient-color);
+ --jp-elevation-z16: 0 8px 10px -5px var(--jp-shadow-umbra-color),
+ 0 16px 24px 2px var(--jp-shadow-penumbra-color),
+ 0 6px 30px 5px var(--jp-shadow-ambient-color);
+ --jp-elevation-z20: 0 10px 13px -6px var(--jp-shadow-umbra-color),
+ 0 20px 31px 3px var(--jp-shadow-penumbra-color),
+ 0 8px 38px 7px var(--jp-shadow-ambient-color);
+ --jp-elevation-z24: 0 11px 15px -7px var(--jp-shadow-umbra-color),
+ 0 24px 38px 3px var(--jp-shadow-penumbra-color),
+ 0 9px 46px 8px var(--jp-shadow-ambient-color);
+
+ /* Borders
+ *
+ * The following variables, specify the visual styling of borders in JupyterLab.
+ */
+
+ --jp-border-width: 1px;
+ --jp-border-color0: var(--md-grey-700);
+ --jp-border-color1: var(--md-grey-700);
+ --jp-border-color2: var(--md-grey-800);
+ --jp-border-color3: var(--md-grey-900);
+ --jp-inverse-border-color: var(--md-grey-600);
+ --jp-border-radius: 2px;
+
+ /* UI Fonts
+ *
+ * The UI font CSS variables are used for the typography all of the JupyterLab
+ * user interface elements that are not directly user generated content.
+ *
+ * The font sizing here is done assuming that the body font size of --jp-ui-font-size1
+ * is applied to a parent element. When children elements, such as headings, are sized
+ * in em all things will be computed relative to that body size.
+ */
+
+ --jp-ui-font-scale-factor: 1.2;
+ --jp-ui-font-size0: 0.83333em;
+ --jp-ui-font-size1: 13px; /* Base font size */
+ --jp-ui-font-size2: 1.2em;
+ --jp-ui-font-size3: 1.44em;
+ --jp-ui-font-family: system-ui, -apple-system, blinkmacsystemfont, 'Segoe UI',
+ helvetica, arial, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji',
+ 'Segoe UI Symbol';
+
+ /*
+ * Use these font colors against the corresponding main layout colors.
+ * In a light theme, these go from dark to light.
+ */
+
+ /* Defaults use Material Design specification */
+ --jp-ui-font-color0: rgba(255, 255, 255, 1);
+ --jp-ui-font-color1: rgba(255, 255, 255, 0.87);
+ --jp-ui-font-color2: rgba(255, 255, 255, 0.54);
+ --jp-ui-font-color3: rgba(255, 255, 255, 0.38);
+
+ /*
+ * Use these against the brand/accent/warn/error colors.
+ * These will typically go from light to darker, in both a dark and light theme.
+ */
+
+ --jp-ui-inverse-font-color0: rgba(0, 0, 0, 1);
+ --jp-ui-inverse-font-color1: rgba(0, 0, 0, 0.8);
+ --jp-ui-inverse-font-color2: rgba(0, 0, 0, 0.5);
+ --jp-ui-inverse-font-color3: rgba(0, 0, 0, 0.3);
+
+ /* Content Fonts
+ *
+ * Content font variables are used for typography of user generated content.
+ *
+ * The font sizing here is done assuming that the body font size of --jp-content-font-size1
+ * is applied to a parent element. When children elements, such as headings, are sized
+ * in em all things will be computed relative to that body size.
+ */
+
+ --jp-content-line-height: 1.6;
+ --jp-content-font-scale-factor: 1.2;
+ --jp-content-font-size0: 0.83333em;
+ --jp-content-font-size1: 14px; /* Base font size */
+ --jp-content-font-size2: 1.2em;
+ --jp-content-font-size3: 1.44em;
+ --jp-content-font-size4: 1.728em;
+ --jp-content-font-size5: 2.0736em;
+
+ /* This gives a magnification of about 125% in presentation mode over normal. */
+ --jp-content-presentation-font-size1: 17px;
+ --jp-content-heading-line-height: 1;
+ --jp-content-heading-margin-top: 1.2em;
+ --jp-content-heading-margin-bottom: 0.8em;
+ --jp-content-heading-font-weight: 500;
+
+ /* Defaults use Material Design specification */
+ --jp-content-font-color0: rgba(255, 255, 255, 1);
+ --jp-content-font-color1: rgba(255, 255, 255, 1);
+ --jp-content-font-color2: rgba(255, 255, 255, 0.7);
+ --jp-content-font-color3: rgba(255, 255, 255, 0.5);
+ --jp-content-link-color: var(--md-blue-300);
+ --jp-content-font-family: system-ui, -apple-system, blinkmacsystemfont,
+ 'Segoe UI', helvetica, arial, sans-serif, 'Apple Color Emoji',
+ 'Segoe UI Emoji', 'Segoe UI Symbol';
+
+ /*
+ * Code Fonts
+ *
+ * Code font variables are used for typography of code and other monospaces content.
+ */
+
+ --jp-code-font-size: 13px;
+ --jp-code-line-height: 1.3077; /* 17px for 13px base */
+ --jp-code-padding: 5px; /* 5px for 13px base, codemirror highlighting needs integer px value */
+ --jp-code-font-family-default: menlo, consolas, 'DejaVu Sans Mono', monospace;
+ --jp-code-font-family: var(--jp-code-font-family-default);
+
+ /* This gives a magnification of about 125% in presentation mode over normal. */
+ --jp-code-presentation-font-size: 16px;
+
+ /* may need to tweak cursor width if you change font size */
+ --jp-code-cursor-width0: 1.4px;
+ --jp-code-cursor-width1: 2px;
+ --jp-code-cursor-width2: 4px;
+
+ /* Layout
+ *
+ * The following are the main layout colors use in JupyterLab. In a light
+ * theme these would go from light to dark.
+ */
+
+ --jp-layout-color0: #111;
+ --jp-layout-color1: var(--md-grey-900);
+ --jp-layout-color2: var(--md-grey-800);
+ --jp-layout-color3: var(--md-grey-700);
+ --jp-layout-color4: var(--md-grey-600);
+
+ /* Inverse Layout
+ *
+ * The following are the inverse layout colors use in JupyterLab. In a light
+ * theme these would go from dark to light.
+ */
+
+ --jp-inverse-layout-color0: white;
+ --jp-inverse-layout-color1: white;
+ --jp-inverse-layout-color2: var(--md-grey-200);
+ --jp-inverse-layout-color3: var(--md-grey-400);
+ --jp-inverse-layout-color4: var(--md-grey-600);
+
+ /* Brand/accent */
+
+ --jp-brand-color0: var(--md-blue-700);
+ --jp-brand-color1: var(--md-blue-500);
+ --jp-brand-color2: var(--md-blue-300);
+ --jp-brand-color3: var(--md-blue-100);
+ --jp-brand-color4: var(--md-blue-50);
+ --jp-accent-color0: var(--md-green-700);
+ --jp-accent-color1: var(--md-green-500);
+ --jp-accent-color2: var(--md-green-300);
+ --jp-accent-color3: var(--md-green-100);
+
+ /* State colors (warn, error, success, info) */
+
+ --jp-warn-color0: var(--md-orange-700);
+ --jp-warn-color1: var(--md-orange-500);
+ --jp-warn-color2: var(--md-orange-300);
+ --jp-warn-color3: var(--md-orange-100);
+ --jp-error-color0: var(--md-red-700);
+ --jp-error-color1: var(--md-red-500);
+ --jp-error-color2: var(--md-red-300);
+ --jp-error-color3: var(--md-red-100);
+ --jp-success-color0: var(--md-green-700);
+ --jp-success-color1: var(--md-green-500);
+ --jp-success-color2: var(--md-green-300);
+ --jp-success-color3: var(--md-green-100);
+ --jp-info-color0: var(--md-cyan-700);
+ --jp-info-color1: var(--md-cyan-500);
+ --jp-info-color2: var(--md-cyan-300);
+ --jp-info-color3: var(--md-cyan-100);
+
+ /* Cell specific styles */
+
+ --jp-cell-padding: 5px;
+ --jp-cell-collapser-width: 8px;
+ --jp-cell-collapser-min-height: 20px;
+ --jp-cell-collapser-not-active-hover-opacity: 0.6;
+ --jp-cell-editor-background: var(--jp-layout-color1);
+ --jp-cell-editor-border-color: var(--md-grey-700);
+ --jp-cell-editor-box-shadow: inset 0 0 2px var(--md-blue-300);
+ --jp-cell-editor-active-background: var(--jp-layout-color0);
+ --jp-cell-editor-active-border-color: var(--jp-brand-color1);
+ --jp-cell-prompt-width: 64px;
+ --jp-cell-prompt-font-family: var(--jp-code-font-family-default);
+ --jp-cell-prompt-letter-spacing: 0;
+ --jp-cell-prompt-opacity: 1;
+ --jp-cell-prompt-not-active-opacity: 1;
+ --jp-cell-prompt-not-active-font-color: var(--md-grey-300);
+
+ /* A custom blend of MD grey and blue 600
+ * See https://meyerweb.com/eric/tools/color-blend/#546E7A:1E88E5:5:hex */
+ --jp-cell-inprompt-font-color: #307fc1;
+
+ /* A custom blend of MD grey and orange 600
+ * https://meyerweb.com/eric/tools/color-blend/#546E7A:F4511E:5:hex */
+ --jp-cell-outprompt-font-color: #bf5b3d;
+
+ /* Notebook specific styles */
+
+ --jp-notebook-padding: 10px;
+ --jp-notebook-select-background: var(--jp-layout-color1);
+ --jp-notebook-multiselected-color: rgba(33, 150, 243, 0.24);
+
+ /* The scroll padding is calculated to fill enough space at the bottom of the
+ notebook to show one single-line cell (with appropriate padding) at the top
+ when the notebook is scrolled all the way to the bottom. We also subtract one
+ pixel so that no scrollbar appears if we have just one single-line cell in the
+ notebook. This padding is to enable a 'scroll past end' feature in a notebook.
+ */
+ --jp-notebook-scroll-padding: calc(
+ 100% - var(--jp-code-font-size) * var(--jp-code-line-height) -
+ var(--jp-code-padding) - var(--jp-cell-padding) - 1px
+ );
+
+ /* Rendermime styles */
+
+ --jp-rendermime-error-background: rgba(244, 67, 54, 0.28);
+ --jp-rendermime-table-row-background: var(--md-grey-900);
+ --jp-rendermime-table-row-hover-background: rgba(3, 169, 244, 0.2);
+
+ /* Dialog specific styles */
+
+ --jp-dialog-background: rgba(0, 0, 0, 0.6);
+
+ /* Console specific styles */
+
+ --jp-console-padding: 10px;
+
+ /* Toolbar specific styles */
+
+ --jp-toolbar-border-color: var(--jp-border-color2);
+ --jp-toolbar-micro-height: 8px;
+ --jp-toolbar-background: var(--jp-layout-color1);
+ --jp-toolbar-box-shadow: 0 0 2px 0 rgba(0, 0, 0, 0.8);
+ --jp-toolbar-header-margin: 4px 4px 0 4px;
+ --jp-toolbar-active-background: var(--jp-layout-color0);
+
+ /* Statusbar specific styles */
+
+ --jp-statusbar-height: 24px;
+
+ /* Input field styles */
+
+ --jp-input-box-shadow: inset 0 0 2px var(--md-blue-300);
+ --jp-input-active-background: var(--jp-layout-color0);
+ --jp-input-hover-background: var(--jp-layout-color2);
+ --jp-input-background: var(--md-grey-800);
+ --jp-input-border-color: var(--jp-inverse-border-color);
+ --jp-input-active-border-color: var(--jp-brand-color1);
+ --jp-input-active-box-shadow-color: rgba(19, 124, 189, 0.3);
+
+ /* General editor styles */
+
+ --jp-editor-selected-background: var(--jp-layout-color2);
+ --jp-editor-selected-focused-background: rgba(33, 150, 243, 0.24);
+ --jp-editor-cursor-color: var(--jp-ui-font-color0);
+
+ /* Code mirror specific styles */
+
+ --jp-mirror-editor-keyword-color: var(--md-green-500);
+ --jp-mirror-editor-atom-color: var(--md-blue-300);
+ --jp-mirror-editor-number-color: var(--md-green-400);
+ --jp-mirror-editor-def-color: var(--md-blue-600);
+ --jp-mirror-editor-variable-color: var(--md-grey-300);
+ --jp-mirror-editor-variable-2-color: var(--md-blue-500);
+ --jp-mirror-editor-variable-3-color: var(--md-green-600);
+ --jp-mirror-editor-punctuation-color: var(--md-blue-400);
+ --jp-mirror-editor-property-color: var(--md-blue-400);
+ --jp-mirror-editor-operator-color: #a2f;
+ --jp-mirror-editor-comment-color: #408080;
+ --jp-mirror-editor-string-color: #ff7070;
+ --jp-mirror-editor-string-2-color: var(--md-purple-300);
+ --jp-mirror-editor-meta-color: #a2f;
+ --jp-mirror-editor-qualifier-color: #555;
+ --jp-mirror-editor-builtin-color: var(--md-green-600);
+ --jp-mirror-editor-bracket-color: #997;
+ --jp-mirror-editor-tag-color: var(--md-green-700);
+ --jp-mirror-editor-attribute-color: var(--md-blue-700);
+ --jp-mirror-editor-header-color: var(--md-blue-500);
+ --jp-mirror-editor-quote-color: var(--md-green-300);
+ --jp-mirror-editor-link-color: var(--md-blue-700);
+ --jp-mirror-editor-error-color: #f00;
+ --jp-mirror-editor-hr-color: #999;
+
+ /*
+ RTC user specific colors.
+ These colors are used for the cursor, username in the editor,
+ and the icon of the user.
+ */
+
+ --jp-collaborator-color1: #ad4a00;
+ --jp-collaborator-color2: #7b6a00;
+ --jp-collaborator-color3: #007e00;
+ --jp-collaborator-color4: #008772;
+ --jp-collaborator-color5: #0079b9;
+ --jp-collaborator-color6: #8b45c6;
+ --jp-collaborator-color7: #be208b;
+
+ /* Vega extension styles */
+
+ --jp-vega-background: var(--md-grey-400);
+
+ /* Sidebar-related styles */
+
+ --jp-sidebar-min-width: 250px;
+
+ /* Search-related styles */
+
+ --jp-search-toggle-off-opacity: 0.6;
+ --jp-search-toggle-hover-opacity: 0.8;
+ --jp-search-toggle-on-opacity: 1;
+ --jp-search-selected-match-background-color: rgb(255, 225, 0);
+ --jp-search-selected-match-color: black;
+ --jp-search-unselected-match-background-color: var(
+ --jp-inverse-layout-color0
+ );
+ --jp-search-unselected-match-color: var(--jp-ui-inverse-font-color0);
+
+ /* scrollbar related styles. Supports every browser except Edge. */
+
+ /* colors based on JetBrain's Darcula theme */
+
+ --jp-scrollbar-background-color: #3f4244;
+ --jp-scrollbar-thumb-color: 88, 96, 97; /* need to specify thumb color as an RGB triplet */
+ --jp-scrollbar-endpad: 3px; /* the minimum gap between the thumb and the ends of a scrollbar */
+
+ /* hacks for setting the thumb shape. These do nothing in Firefox */
+
+ --jp-scrollbar-thumb-margin: 3.5px; /* the space in between the sides of the thumb and the track */
+ --jp-scrollbar-thumb-radius: 9px; /* set to a large-ish value for rounded endcaps on the thumb */
+
+ /* Icon colors that work well with light or dark backgrounds */
+ --jp-icon-contrast-color0: var(--md-purple-600);
+ --jp-icon-contrast-color1: var(--md-green-600);
+ --jp-icon-contrast-color2: var(--md-pink-600);
+ --jp-icon-contrast-color3: var(--md-blue-600);
+
+ /* Button colors */
+ --jp-accept-color-normal: var(--md-blue-700);
+ --jp-accept-color-hover: var(--md-blue-800);
+ --jp-accept-color-active: var(--md-blue-900);
+ --jp-warn-color-normal: var(--md-red-700);
+ --jp-warn-color-hover: var(--md-red-800);
+ --jp-warn-color-active: var(--md-red-900);
+ --jp-reject-color-normal: var(--md-grey-600);
+ --jp-reject-color-hover: var(--md-grey-700);
+ --jp-reject-color-active: var(--md-grey-800);
+
+ /* File or activity icons and switch semantic variables */
+ --jp-jupyter-icon-color: #f37626;
+ --jp-notebook-icon-color: #f37626;
+ --jp-json-icon-color: var(--md-orange-500);
+ --jp-console-icon-background-color: var(--md-blue-500);
+ --jp-console-icon-color: white;
+ --jp-terminal-icon-background-color: var(--md-grey-200);
+ --jp-terminal-icon-color: var(--md-grey-800);
+ --jp-text-editor-icon-color: var(--md-grey-200);
+ --jp-inspector-icon-color: var(--md-grey-200);
+ --jp-switch-color: var(--md-grey-400);
+ --jp-switch-true-position-color: var(--md-orange-700);
+}
+</style>
+<style type="text/css">
+/* Force rendering true colors when outputing to pdf */
+* {
+ -webkit-print-color-adjust: exact;
+}
+
+/* Misc */
+a.anchor-link {
+ display: none;
+}
+
+/* Input area styling */
+.jp-InputArea {
+ overflow: hidden;
+}
+
+.jp-InputArea-editor {
+ overflow: hidden;
+}
+
+.cm-editor.cm-s-jupyter .highlight pre {
+/* weird, but --jp-code-padding defined to be 5px but 4px horizontal padding is hardcoded for pre.cm-line */
+ padding: var(--jp-code-padding) 4px;
+ margin: 0;
+
+ font-family: inherit;
+ font-size: inherit;
+ line-height: inherit;
+ color: inherit;
+
+}
+
+.jp-OutputArea-output pre {
+ line-height: inherit;
+ font-family: inherit;
+}
+
+.jp-RenderedText pre {
+ color: var(--jp-content-font-color1);
+ font-size: var(--jp-code-font-size);
+}
+
+/* Hiding the collapser by default */
+.jp-Collapser {
+ display: none;
+}
+
+@page {
+ margin: 0.5in; /* Margin for each printed piece of paper */
+}
+
+@media print {
+ .jp-Cell-inputWrapper,
+ .jp-Cell-outputWrapper {
+ display: block;
+ }
+}
+</style>
+<!-- Load mathjax -->
+<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.7/latest.js?config=TeX-AMS_CHTML-full,Safe"> </script>
+<!-- MathJax configuration -->
+<script type="text/x-mathjax-config">
+ init_mathjax = function() {
+ if (window.MathJax) {
+ // MathJax loaded
+ MathJax.Hub.Config({
+ TeX: {
+ equationNumbers: {
+ autoNumber: "AMS",
+ useLabelIds: true
+ }
+ },
+ tex2jax: {
+ inlineMath: [ ['$','$'], ["\\(","\\)"] ],
+ displayMath: [ ['$$','$$'], ["\\[","\\]"] ],
+ processEscapes: true,
+ processEnvironments: true
+ },
+ displayAlign: 'center',
+ CommonHTML: {
+ linebreaks: {
+ automatic: true
+ }
+ }
+ });
+
+ MathJax.Hub.Queue(["Typeset", MathJax.Hub]);
+ }
+ }
+ init_mathjax();
+ </script>
+<!-- End of mathjax configuration --><script type="module">
+ document.addEventListener("DOMContentLoaded", async () => {
+ const diagrams = document.querySelectorAll(".jp-Mermaid > pre.mermaid");
+ // do not load mermaidjs if not needed
+ if (!diagrams.length) {
+ return;
+ }
+ const mermaid = (await import("https://cdnjs.cloudflare.com/ajax/libs/mermaid/10.7.0/mermaid.esm.min.mjs")).default;
+ const parser = new DOMParser();
+
+ mermaid.initialize({
+ maxTextSize: 100000,
+ maxEdges: 100000,
+ startOnLoad: false,
+ fontFamily: window
+ .getComputedStyle(document.body)
+ .getPropertyValue("--jp-ui-font-family"),
+ theme: document.querySelector("body[data-jp-theme-light='true']")
+ ? "default"
+ : "dark",
+ });
+
+ let _nextMermaidId = 0;
+
+ function makeMermaidImage(svg) {
+ const img = document.createElement("img");
+ const doc = parser.parseFromString(svg, "image/svg+xml");
+ const svgEl = doc.querySelector("svg");
+ const { maxWidth } = svgEl?.style || {};
+ const firstTitle = doc.querySelector("title");
+ const firstDesc = doc.querySelector("desc");
+
+ img.setAttribute("src", `data:image/svg+xml,${encodeURIComponent(svg)}`);
+ if (maxWidth) {
+ img.width = parseInt(maxWidth);
+ }
+ if (firstTitle) {
+ img.setAttribute("alt", firstTitle.textContent);
+ }
+ if (firstDesc) {
+ const caption = document.createElement("figcaption");
+ caption.className = "sr-only";
+ caption.textContent = firstDesc.textContent;
+ return [img, caption];
+ }
+ return [img];
+ }
+
+ async function makeMermaidError(text) {
+ let errorMessage = "";
+ try {
+ await mermaid.parse(text);
+ } catch (err) {
+ errorMessage = `${err}`;
+ }
+
+ const result = document.createElement("details");
+ result.className = 'jp-RenderedMermaid-Details';
+ const summary = document.createElement("summary");
+ summary.className = 'jp-RenderedMermaid-Summary';
+ const pre = document.createElement("pre");
+ const code = document.createElement("code");
+ code.innerText = text;
+ pre.appendChild(code);
+ summary.appendChild(pre);
+ result.appendChild(summary);
+
+ const warning = document.createElement("pre");
+ warning.innerText = errorMessage;
+ result.appendChild(warning);
+ return [result];
+ }
+
+ async function renderOneMarmaid(src) {
+ const id = `jp-mermaid-${_nextMermaidId++}`;
+ const parent = src.parentNode;
+ let raw = src.textContent.trim();
+ const el = document.createElement("div");
+ el.style.visibility = "hidden";
+ document.body.appendChild(el);
+ let results = null;
+ let output = null;
+ try {
+ let { svg } = await mermaid.render(id, raw, el);
+ svg = cleanMermaidSvg(svg);
+ results = makeMermaidImage(svg);
+ output = document.createElement("figure");
+ results.map(output.appendChild, output);
+ } catch (err) {
+ parent.classList.add("jp-mod-warning");
+ results = await makeMermaidError(raw);
+ output = results[0];
+ } finally {
+ el.remove();
+ }
+ parent.classList.add("jp-RenderedMermaid");
+ parent.appendChild(output);
+ }
+
+
+ /**
+ * Post-process to ensure mermaid diagrams contain only valid SVG and XHTML.
+ */
+ function cleanMermaidSvg(svg) {
+ return svg.replace(RE_VOID_ELEMENT, replaceVoidElement);
+ }
+
+
+ /**
+ * A regular expression for all void elements, which may include attributes and
+ * a slash.
+ *
+ * @see https://developer.mozilla.org/en-US/docs/Glossary/Void_element
+ *
+ * Of these, only `<br>` is generated by Mermaid in place of `\n`,
+ * but _any_ "malformed" tag will break the SVG rendering entirely.
+ */
+ const RE_VOID_ELEMENT =
+ /<\s*(area|base|br|col|embed|hr|img|input|link|meta|param|source|track|wbr)\s*([^>]*?)\s*>/gi;
+
+ /**
+ * Ensure a void element is closed with a slash, preserving any attributes.
+ */
+ function replaceVoidElement(match, tag, rest) {
+ rest = rest.trim();
+ if (!rest.endsWith('/')) {
+ rest = `${rest} /`;
+ }
+ return `<${tag} ${rest}>`;
+ }
+
+ void Promise.all([...diagrams].map(renderOneMarmaid));
+ });
+</script>
+<style>
+ .jp-Mermaid:not(.jp-RenderedMermaid) {
+ display: none;
+ }
+
+ .jp-RenderedMermaid {
+ overflow: auto;
+ display: flex;
+ }
+
+ .jp-RenderedMermaid.jp-mod-warning {
+ width: auto;
+ padding: 0.5em;
+ margin-top: 0.5em;
+ border: var(--jp-border-width) solid var(--jp-warn-color2);
+ border-radius: var(--jp-border-radius);
+ color: var(--jp-ui-font-color1);
+ font-size: var(--jp-ui-font-size1);
+ white-space: pre-wrap;
+ word-wrap: break-word;
+ }
+
+ .jp-RenderedMermaid figure {
+ margin: 0;
+ overflow: auto;
+ max-width: 100%;
+ }
+
+ .jp-RenderedMermaid img {
+ max-width: 100%;
+ }
+
+ .jp-RenderedMermaid-Details > pre {
+ margin-top: 1em;
+ }
+
+ .jp-RenderedMermaid-Summary {
+ color: var(--jp-warn-color2);
+ }
+
+ .jp-RenderedMermaid:not(.jp-mod-warning) pre {
+ display: none;
+ }
+
+ .jp-RenderedMermaid-Summary > pre {
+ display: inline-block;
+ white-space: normal;
+ }
+</style>
+<!-- End of mermaid configuration --></head>
+<body class="jp-Notebook" data-jp-theme-light="false" data-jp-theme-name="JupyterLab Dark">
+<main>
+<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=0b397cbb-8db3-40d9-a0a9-27ba0a774021">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown">
+<h2 id="Automatically-creating-new-binhost-directories-when-profile-or-gcc-version-changes">Automatically creating new binhost directories when profile or gcc version changes<a class="anchor-link" href="#Automatically-creating-new-binhost-directories-when-profile-or-gcc-version-changes">¶</a></h2>
+</div>
+</div>
+</div>
+</div>
+<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=97c6e8be-a571-4fea-84c4-b226f03f56c6">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown">
+<p>On Gentoo Linux packages are compiled which is a time and energy consuming.
+To minimise both, I have a binhost to share compiled binaries between devices.
+The issues occurs when gcc major version changes - or a profile bump happens.
+If I do not notice either - problem. Binaries might not be compatible.
+So I wanted to automate a process of detection of those changes and automatically create subfolder for new binaries.
+When investigating I learned a neat trick. For the wise ones this is trivial, for me it was enligtening.
+Here it comes.</p>
+</div>
+</div>
+</div>
+</div>
+<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=2a688afd-5f24-4eab-a1c7-119d372367b5">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown">
+<p>On a regular system, emerge resides here:</p>
+</div>
+</div>
+</div>
+</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs" id="cell-id=b1098db8-2f77-4b56-acef-f58113107dad">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea">
+<div class="jp-InputPrompt jp-InputArea-prompt">In [ ]:</div>
+<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
+<div class="cm-editor cm-s-jupyter">
+<div class="highlight hl-ipython3"><pre><span></span><span class="err">$</span> <span class="n">which</span> <span class="n">emerge</span>
+<span class="o">/</span><span class="n">usr</span><span class="o">/</span><span class="nb">bin</span><span class="o">/</span><span class="n">emerge</span>
+</pre></div>
+</div>
+</div>
+</div>
+</div>
+</div>
+<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=9a1dcd6c-3f8c-455f-9d56-21e5157d0846">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown">
+<p>On my box with binhost:</p>
+</div>
+</div>
+</div>
+</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs" id="cell-id=bcb9918c-20fb-49fd-baaf-b3b63356de5a">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea">
+<div class="jp-InputPrompt jp-InputArea-prompt">In [ ]:</div>
+<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
+<div class="cm-editor cm-s-jupyter">
+<div class="highlight hl-ipython3"><pre><span></span><span class="err">$</span> <span class="n">which</span> <span class="n">emerge</span>
+<span class="o">/</span><span class="n">usr</span><span class="o">/</span><span class="n">local</span><span class="o">/</span><span class="nb">bin</span><span class="o">/</span><span class="n">emerge</span>
+</pre></div>
+</div>
+</div>
+</div>
+</div>
+</div>
+<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=a84cf35c-e744-47c9-9500-d9b8c7d3bfef">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown">
+<p>And here is $PATH:</p>
+</div>
+</div>
+</div>
+</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs" id="cell-id=94092561-ae6b-41eb-831a-71bffcf30e6e">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea">
+<div class="jp-InputPrompt jp-InputArea-prompt">In [ ]:</div>
+<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
+<div class="cm-editor cm-s-jupyter">
+<div class="highlight hl-ipython3"><pre><span></span><span class="err">$</span> <span class="n">echo</span> <span class="err">$</span><span class="n">PATH</span>
+<span class="o">/</span><span class="n">usr</span><span class="o">/</span><span class="n">local</span><span class="o">/</span><span class="n">sbin</span><span class="p">:</span><span class="o">/</span><span class="n">usr</span><span class="o">/</span><span class="n">local</span><span class="o">/</span><span class="nb">bin</span><span class="p">:</span><span class="o">/</span><span class="n">usr</span><span class="o">/</span><span class="nb">bin</span><span class="p">:</span><span class="o">/</span><span class="n">opt</span><span class="o">/</span><span class="nb">bin</span><span class="p">:</span><span class="o">/</span><span class="n">usr</span><span class="o">/</span><span class="n">lib</span><span class="o">/</span><span class="n">llvm</span><span class="o">/</span><span class="mi">18</span><span class="o">/</span><span class="nb">bin</span><span class="p">:</span><span class="o">/</span><span class="n">usr</span><span class="o">/</span><span class="n">lib</span><span class="o">/</span><span class="n">llvm</span><span class="o">/</span><span class="mi">17</span><span class="o">/</span><span class="nb">bin</span>
+</pre></div>
+</div>
+</div>
+</div>
+</div>
+</div>
+<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=eb05de7d-f2f3-4cd3-acc2-769e096a3a5b">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown">
+<p>So we see that on binhost box, there is emerge that resides in location preceeding regular emerge - so it gets called first.
+It contains a shell script as follows:</p>
+</div>
+</div>
+</div>
+</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs" id="cell-id=b9f78265-a1de-47eb-be21-bb66c1ed3bed">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea">
+<div class="jp-InputPrompt jp-InputArea-prompt">In [ ]:</div>
+<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
+<div class="cm-editor cm-s-jupyter">
+<div class="highlight hl-ipython3"><pre><span></span><span class="ch">#!/usr/bin/env bash</span>
+<span class="c1">#</span>
+<span class="c1"># Script checking that binhost path exists before running emerge and</span>
+<span class="c1"># creating it if not exists</span>
+
+<span class="n">PROFILE</span><span class="o">=</span><span class="err">$</span><span class="p">(</span><span class="n">eselect</span> <span class="n">profile</span> <span class="n">show</span><span class="o">|</span><span class="n">sed</span> <span class="o">-</span><span class="n">n</span> <span class="mi">2</span><span class="n">p</span><span class="o">|</span><span class="n">cut</span> <span class="o">-</span><span class="n">d</span> <span class="s1">'/'</span> <span class="o">-</span><span class="n">f4</span><span class="p">)</span>
+<span class="n">GCC_VERSION</span><span class="o">=</span><span class="err">$</span><span class="p">(</span><span class="n">eselect</span> <span class="n">gcc</span> <span class="n">show</span><span class="o">|</span><span class="n">cut</span> <span class="o">-</span><span class="n">d</span> <span class="s1">'-'</span> <span class="o">-</span><span class="n">f5</span><span class="p">)</span>
+<span class="n">BINHOST_DIR</span><span class="o">=</span><span class="s2">"/var/cache/binpkgs/$</span><span class="si">{PROFILE}</span><span class="s2">/gcc-$</span><span class="si">{GCC_VERSION}</span><span class="s2">.x/armv8a"</span>
+
+<span class="k">if</span> <span class="p">[</span> <span class="o">!</span><span class="w"> </span>-d<span class="w"> </span><span class="s2">"</span><span class="si">${</span><span class="nv">BINHOST_DIR</span><span class="si">}</span><span class="s2">"</span><span class="w"> </span><span class="o">]</span><span class="p">;</span><span class="w"> </span><span class="k">then</span>
+ <span class="n">echo</span> <span class="s2">"$</span><span class="si">{BINHOST_DIR}</span><span class="s2"> does not exist, creating"</span>
+ <span class="n">mkdir</span> <span class="o">-</span><span class="n">p</span> <span class="s2">"$</span><span class="si">{BINHOST_DIR}</span><span class="s2">"</span>
+<span class="k">else</span> <span class="n">echo</span> <span class="s2">"Binhost directory $</span><span class="si">{BINHOST_DIR}</span><span class="s2"> exists, proceeding with emerge ..."</span>
+<span class="n">fi</span>
+
+<span class="n">PKGDIR</span><span class="o">=</span><span class="s2">"$</span><span class="si">{BINHOST_DIR}</span><span class="s2">"</span> <span class="o">/</span><span class="n">usr</span><span class="o">/</span><span class="nb">bin</span><span class="o">/</span><span class="n">emerge</span> <span class="s2">"$@"</span>
+</pre></div>
+</div>
+</div>
+</div>
+</div>
+</div>
+<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=d6d085ea-b68f-4220-adaf-00223393e58e">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown">
+<p>So on every profile change subfolder to /var/cache/binpkgs gets created,
+on every gcc major version change, subfolder to /var/cache/binpkgs/<profile> gets created.
+If folder already exists script only prints a message.
+Then it calls /usr/bin/emerge - the regular emerge - with $PKGDIR variable, so binary packages are saved to the correct directory.</profile></p>
+</div>
+</div>
+</div>
+</div>
+<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=1d464645-b7ac-4cbc-b5cc-1bd4bd976f06">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown">
+<p>This is structure of /var/cache/binpkgs:</p>
+</div>
+</div>
+</div>
+</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs" id="cell-id=dee2b348-d16d-4709-a7cd-ac9424934009">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea">
+<div class="jp-InputPrompt jp-InputArea-prompt">In [ ]:</div>
+<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
+<div class="cm-editor cm-s-jupyter">
+<div class="highlight hl-ipython3"><pre><span></span><span class="err">$</span> <span class="n">tree</span> <span class="o">-</span><span class="n">L</span> <span class="mi">3</span> <span class="o">/</span><span class="n">var</span><span class="o">/</span><span class="n">cache</span><span class="o">/</span><span class="n">binpkgs</span><span class="o">/</span>
+<span class="o">/</span><span class="n">var</span><span class="o">/</span><span class="n">cache</span><span class="o">/</span><span class="n">binpkgs</span><span class="o">/</span>
+<span class="err">├──</span> <span class="mf">17.0</span>
+<span class="err">│</span>   <span class="err">└──</span> <span class="n">gcc</span><span class="o">-</span><span class="mf">13.</span><span class="n">x</span>
+<span class="err">│</span>   <span class="err">└──</span> <span class="n">armv8a</span>
+<span class="err">└──</span> <span class="mf">23.0</span>
+ <span class="err">├──</span> <span class="n">gcc</span><span class="o">-</span><span class="mf">13.</span><span class="n">x</span>
+ <span class="err">│</span>   <span class="err">└──</span> <span class="n">armv8a</span>
+ <span class="err">└──</span> <span class="n">gcc</span><span class="o">-</span><span class="mf">14.</span><span class="n">x</span>
+ <span class="err">└──</span> <span class="n">armv8a</span>
+</pre></div>
+</div>
+</div>
+</div>
+</div>
+</div>
+<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=9f8f4a71-9fd1-4678-9cb0-a580c94f4582">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown">
+<p>One less thing to worry about.</p>
+</div>
+</div>
+</div>
+</div>
+</main>
+</body>
+</html>
diff --git a/static/html/creating_fastapi_static_blog.html b/static/html/creating_fastapi_static_blog.html
new file mode 100644
index 0000000..0a13e7f
--- /dev/null
+++ b/static/html/creating_fastapi_static_blog.html
@@ -0,0 +1,8160 @@
+<!DOCTYPE html>
+
+<html lang="en">
+<head><meta charset="utf-8"/>
+<meta content="width=device-width, initial-scale=1.0" name="viewport"/>
+<title>creating_fastapi_static_blog</title><script src="https://cdnjs.cloudflare.com/ajax/libs/require.js/2.1.10/require.min.js"></script>
+<style type="text/css">
+ pre { line-height: 125%; }
+td.linenos .normal { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; }
+span.linenos { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; }
+td.linenos .special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; }
+span.linenos.special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; }
+.highlight .hll { background-color: var(--jp-cell-editor-active-background) }
+.highlight { background: var(--jp-cell-editor-background); color: var(--jp-mirror-editor-variable-color) }
+.highlight .c { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment */
+.highlight .err { color: var(--jp-mirror-editor-error-color) } /* Error */
+.highlight .k { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword */
+.highlight .o { color: var(--jp-mirror-editor-operator-color); font-weight: bold } /* Operator */
+.highlight .p { color: var(--jp-mirror-editor-punctuation-color) } /* Punctuation */
+.highlight .ch { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.Hashbang */
+.highlight .cm { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.Multiline */
+.highlight .cp { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.Preproc */
+.highlight .cpf { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.PreprocFile */
+.highlight .c1 { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.Single */
+.highlight .cs { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.Special */
+.highlight .kc { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Constant */
+.highlight .kd { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Declaration */
+.highlight .kn { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Namespace */
+.highlight .kp { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Pseudo */
+.highlight .kr { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Reserved */
+.highlight .kt { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Type */
+.highlight .m { color: var(--jp-mirror-editor-number-color) } /* Literal.Number */
+.highlight .s { color: var(--jp-mirror-editor-string-color) } /* Literal.String */
+.highlight .ow { color: var(--jp-mirror-editor-operator-color); font-weight: bold } /* Operator.Word */
+.highlight .pm { color: var(--jp-mirror-editor-punctuation-color) } /* Punctuation.Marker */
+.highlight .w { color: var(--jp-mirror-editor-variable-color) } /* Text.Whitespace */
+.highlight .mb { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Bin */
+.highlight .mf { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Float */
+.highlight .mh { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Hex */
+.highlight .mi { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Integer */
+.highlight .mo { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Oct */
+.highlight .sa { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Affix */
+.highlight .sb { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Backtick */
+.highlight .sc { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Char */
+.highlight .dl { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Delimiter */
+.highlight .sd { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Doc */
+.highlight .s2 { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Double */
+.highlight .se { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Escape */
+.highlight .sh { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Heredoc */
+.highlight .si { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Interpol */
+.highlight .sx { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Other */
+.highlight .sr { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Regex */
+.highlight .s1 { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Single */
+.highlight .ss { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Symbol */
+.highlight .il { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Integer.Long */
+ </style>
+<style type="text/css">
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/*
+ * Mozilla scrollbar styling
+ */
+
+/* use standard opaque scrollbars for most nodes */
+[data-jp-theme-scrollbars='true'] {
+ scrollbar-color: rgb(var(--jp-scrollbar-thumb-color))
+ var(--jp-scrollbar-background-color);
+}
+
+/* for code nodes, use a transparent style of scrollbar. These selectors
+ * will match lower in the tree, and so will override the above */
+[data-jp-theme-scrollbars='true'] .CodeMirror-hscrollbar,
+[data-jp-theme-scrollbars='true'] .CodeMirror-vscrollbar {
+ scrollbar-color: rgba(var(--jp-scrollbar-thumb-color), 0.5) transparent;
+}
+
+/* tiny scrollbar */
+
+.jp-scrollbar-tiny {
+ scrollbar-color: rgba(var(--jp-scrollbar-thumb-color), 0.5) transparent;
+ scrollbar-width: thin;
+}
+
+/* tiny scrollbar */
+
+.jp-scrollbar-tiny::-webkit-scrollbar,
+.jp-scrollbar-tiny::-webkit-scrollbar-corner {
+ background-color: transparent;
+ height: 4px;
+ width: 4px;
+}
+
+.jp-scrollbar-tiny::-webkit-scrollbar-thumb {
+ background: rgba(var(--jp-scrollbar-thumb-color), 0.5);
+}
+
+.jp-scrollbar-tiny::-webkit-scrollbar-track:horizontal {
+ border-left: 0 solid transparent;
+ border-right: 0 solid transparent;
+}
+
+.jp-scrollbar-tiny::-webkit-scrollbar-track:vertical {
+ border-top: 0 solid transparent;
+ border-bottom: 0 solid transparent;
+}
+
+/*
+ * Lumino
+ */
+
+.lm-ScrollBar[data-orientation='horizontal'] {
+ min-height: 16px;
+ max-height: 16px;
+ min-width: 45px;
+ border-top: 1px solid #a0a0a0;
+}
+
+.lm-ScrollBar[data-orientation='vertical'] {
+ min-width: 16px;
+ max-width: 16px;
+ min-height: 45px;
+ border-left: 1px solid #a0a0a0;
+}
+
+.lm-ScrollBar-button {
+ background-color: #f0f0f0;
+ background-position: center center;
+ min-height: 15px;
+ max-height: 15px;
+ min-width: 15px;
+ max-width: 15px;
+}
+
+.lm-ScrollBar-button:hover {
+ background-color: #dadada;
+}
+
+.lm-ScrollBar-button.lm-mod-active {
+ background-color: #cdcdcd;
+}
+
+.lm-ScrollBar-track {
+ background: #f0f0f0;
+}
+
+.lm-ScrollBar-thumb {
+ background: #cdcdcd;
+}
+
+.lm-ScrollBar-thumb:hover {
+ background: #bababa;
+}
+
+.lm-ScrollBar-thumb.lm-mod-active {
+ background: #a0a0a0;
+}
+
+.lm-ScrollBar[data-orientation='horizontal'] .lm-ScrollBar-thumb {
+ height: 100%;
+ min-width: 15px;
+ border-left: 1px solid #a0a0a0;
+ border-right: 1px solid #a0a0a0;
+}
+
+.lm-ScrollBar[data-orientation='vertical'] .lm-ScrollBar-thumb {
+ width: 100%;
+ min-height: 15px;
+ border-top: 1px solid #a0a0a0;
+ border-bottom: 1px solid #a0a0a0;
+}
+
+.lm-ScrollBar[data-orientation='horizontal']
+ .lm-ScrollBar-button[data-action='decrement'] {
+ background-image: var(--jp-icon-caret-left);
+ background-size: 17px;
+}
+
+.lm-ScrollBar[data-orientation='horizontal']
+ .lm-ScrollBar-button[data-action='increment'] {
+ background-image: var(--jp-icon-caret-right);
+ background-size: 17px;
+}
+
+.lm-ScrollBar[data-orientation='vertical']
+ .lm-ScrollBar-button[data-action='decrement'] {
+ background-image: var(--jp-icon-caret-up);
+ background-size: 17px;
+}
+
+.lm-ScrollBar[data-orientation='vertical']
+ .lm-ScrollBar-button[data-action='increment'] {
+ background-image: var(--jp-icon-caret-down);
+ background-size: 17px;
+}
+
+/*
+ * Copyright (c) Jupyter Development Team.
+ * Distributed under the terms of the Modified BSD License.
+ */
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Copyright (c) 2014-2017, PhosphorJS Contributors
+|
+| Distributed under the terms of the BSD 3-Clause License.
+|
+| The full license is in the file LICENSE, distributed with this software.
+|----------------------------------------------------------------------------*/
+
+.lm-Widget {
+ box-sizing: border-box;
+ position: relative;
+ overflow: hidden;
+}
+
+.lm-Widget.lm-mod-hidden {
+ display: none !important;
+}
+
+/*
+ * Copyright (c) Jupyter Development Team.
+ * Distributed under the terms of the Modified BSD License.
+ */
+
+.lm-AccordionPanel[data-orientation='horizontal'] > .lm-AccordionPanel-title {
+ /* Title is rotated for horizontal accordion panel using CSS */
+ display: block;
+ transform-origin: top left;
+ transform: rotate(-90deg) translate(-100%);
+}
+
+/*
+ * Copyright (c) Jupyter Development Team.
+ * Distributed under the terms of the Modified BSD License.
+ */
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Copyright (c) 2014-2017, PhosphorJS Contributors
+|
+| Distributed under the terms of the BSD 3-Clause License.
+|
+| The full license is in the file LICENSE, distributed with this software.
+|----------------------------------------------------------------------------*/
+
+.lm-CommandPalette {
+ display: flex;
+ flex-direction: column;
+ -webkit-user-select: none;
+ -moz-user-select: none;
+ -ms-user-select: none;
+ user-select: none;
+}
+
+.lm-CommandPalette-search {
+ flex: 0 0 auto;
+}
+
+.lm-CommandPalette-content {
+ flex: 1 1 auto;
+ margin: 0;
+ padding: 0;
+ min-height: 0;
+ overflow: auto;
+ list-style-type: none;
+}
+
+.lm-CommandPalette-header {
+ overflow: hidden;
+ white-space: nowrap;
+ text-overflow: ellipsis;
+}
+
+.lm-CommandPalette-item {
+ display: flex;
+ flex-direction: row;
+}
+
+.lm-CommandPalette-itemIcon {
+ flex: 0 0 auto;
+}
+
+.lm-CommandPalette-itemContent {
+ flex: 1 1 auto;
+ overflow: hidden;
+}
+
+.lm-CommandPalette-itemShortcut {
+ flex: 0 0 auto;
+}
+
+.lm-CommandPalette-itemLabel {
+ overflow: hidden;
+ white-space: nowrap;
+ text-overflow: ellipsis;
+}
+
+.lm-close-icon {
+ border: 1px solid transparent;
+ background-color: transparent;
+ position: absolute;
+ z-index: 1;
+ right: 3%;
+ top: 0;
+ bottom: 0;
+ margin: auto;
+ padding: 7px 0;
+ display: none;
+ vertical-align: middle;
+ outline: 0;
+ cursor: pointer;
+}
+.lm-close-icon:after {
+ content: 'X';
+ display: block;
+ width: 15px;
+ height: 15px;
+ text-align: center;
+ color: #000;
+ font-weight: normal;
+ font-size: 12px;
+ cursor: pointer;
+}
+
+/*
+ * Copyright (c) Jupyter Development Team.
+ * Distributed under the terms of the Modified BSD License.
+ */
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Copyright (c) 2014-2017, PhosphorJS Contributors
+|
+| Distributed under the terms of the BSD 3-Clause License.
+|
+| The full license is in the file LICENSE, distributed with this software.
+|----------------------------------------------------------------------------*/
+
+.lm-DockPanel {
+ z-index: 0;
+}
+
+.lm-DockPanel-widget {
+ z-index: 0;
+}
+
+.lm-DockPanel-tabBar {
+ z-index: 1;
+}
+
+.lm-DockPanel-handle {
+ z-index: 2;
+}
+
+.lm-DockPanel-handle.lm-mod-hidden {
+ display: none !important;
+}
+
+.lm-DockPanel-handle:after {
+ position: absolute;
+ top: 0;
+ left: 0;
+ width: 100%;
+ height: 100%;
+ content: '';
+}
+
+.lm-DockPanel-handle[data-orientation='horizontal'] {
+ cursor: ew-resize;
+}
+
+.lm-DockPanel-handle[data-orientation='vertical'] {
+ cursor: ns-resize;
+}
+
+.lm-DockPanel-handle[data-orientation='horizontal']:after {
+ left: 50%;
+ min-width: 8px;
+ transform: translateX(-50%);
+}
+
+.lm-DockPanel-handle[data-orientation='vertical']:after {
+ top: 50%;
+ min-height: 8px;
+ transform: translateY(-50%);
+}
+
+.lm-DockPanel-overlay {
+ z-index: 3;
+ box-sizing: border-box;
+ pointer-events: none;
+}
+
+.lm-DockPanel-overlay.lm-mod-hidden {
+ display: none !important;
+}
+
+/*
+ * Copyright (c) Jupyter Development Team.
+ * Distributed under the terms of the Modified BSD License.
+ */
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Copyright (c) 2014-2017, PhosphorJS Contributors
+|
+| Distributed under the terms of the BSD 3-Clause License.
+|
+| The full license is in the file LICENSE, distributed with this software.
+|----------------------------------------------------------------------------*/
+
+.lm-Menu {
+ z-index: 10000;
+ position: absolute;
+ white-space: nowrap;
+ overflow-x: hidden;
+ overflow-y: auto;
+ outline: none;
+ -webkit-user-select: none;
+ -moz-user-select: none;
+ -ms-user-select: none;
+ user-select: none;
+}
+
+.lm-Menu-content {
+ margin: 0;
+ padding: 0;
+ display: table;
+ list-style-type: none;
+}
+
+.lm-Menu-item {
+ display: table-row;
+}
+
+.lm-Menu-item.lm-mod-hidden,
+.lm-Menu-item.lm-mod-collapsed {
+ display: none !important;
+}
+
+.lm-Menu-itemIcon,
+.lm-Menu-itemSubmenuIcon {
+ display: table-cell;
+ text-align: center;
+}
+
+.lm-Menu-itemLabel {
+ display: table-cell;
+ text-align: left;
+}
+
+.lm-Menu-itemShortcut {
+ display: table-cell;
+ text-align: right;
+}
+
+/*
+ * Copyright (c) Jupyter Development Team.
+ * Distributed under the terms of the Modified BSD License.
+ */
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Copyright (c) 2014-2017, PhosphorJS Contributors
+|
+| Distributed under the terms of the BSD 3-Clause License.
+|
+| The full license is in the file LICENSE, distributed with this software.
+|----------------------------------------------------------------------------*/
+
+.lm-MenuBar {
+ outline: none;
+ -webkit-user-select: none;
+ -moz-user-select: none;
+ -ms-user-select: none;
+ user-select: none;
+}
+
+.lm-MenuBar-content {
+ margin: 0;
+ padding: 0;
+ display: flex;
+ flex-direction: row;
+ list-style-type: none;
+}
+
+.lm-MenuBar-item {
+ box-sizing: border-box;
+}
+
+.lm-MenuBar-itemIcon,
+.lm-MenuBar-itemLabel {
+ display: inline-block;
+}
+
+/*
+ * Copyright (c) Jupyter Development Team.
+ * Distributed under the terms of the Modified BSD License.
+ */
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Copyright (c) 2014-2017, PhosphorJS Contributors
+|
+| Distributed under the terms of the BSD 3-Clause License.
+|
+| The full license is in the file LICENSE, distributed with this software.
+|----------------------------------------------------------------------------*/
+
+.lm-ScrollBar {
+ display: flex;
+ -webkit-user-select: none;
+ -moz-user-select: none;
+ -ms-user-select: none;
+ user-select: none;
+}
+
+.lm-ScrollBar[data-orientation='horizontal'] {
+ flex-direction: row;
+}
+
+.lm-ScrollBar[data-orientation='vertical'] {
+ flex-direction: column;
+}
+
+.lm-ScrollBar-button {
+ box-sizing: border-box;
+ flex: 0 0 auto;
+}
+
+.lm-ScrollBar-track {
+ box-sizing: border-box;
+ position: relative;
+ overflow: hidden;
+ flex: 1 1 auto;
+}
+
+.lm-ScrollBar-thumb {
+ box-sizing: border-box;
+ position: absolute;
+}
+
+/*
+ * Copyright (c) Jupyter Development Team.
+ * Distributed under the terms of the Modified BSD License.
+ */
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Copyright (c) 2014-2017, PhosphorJS Contributors
+|
+| Distributed under the terms of the BSD 3-Clause License.
+|
+| The full license is in the file LICENSE, distributed with this software.
+|----------------------------------------------------------------------------*/
+
+.lm-SplitPanel-child {
+ z-index: 0;
+}
+
+.lm-SplitPanel-handle {
+ z-index: 1;
+}
+
+.lm-SplitPanel-handle.lm-mod-hidden {
+ display: none !important;
+}
+
+.lm-SplitPanel-handle:after {
+ position: absolute;
+ top: 0;
+ left: 0;
+ width: 100%;
+ height: 100%;
+ content: '';
+}
+
+.lm-SplitPanel[data-orientation='horizontal'] > .lm-SplitPanel-handle {
+ cursor: ew-resize;
+}
+
+.lm-SplitPanel[data-orientation='vertical'] > .lm-SplitPanel-handle {
+ cursor: ns-resize;
+}
+
+.lm-SplitPanel[data-orientation='horizontal'] > .lm-SplitPanel-handle:after {
+ left: 50%;
+ min-width: 8px;
+ transform: translateX(-50%);
+}
+
+.lm-SplitPanel[data-orientation='vertical'] > .lm-SplitPanel-handle:after {
+ top: 50%;
+ min-height: 8px;
+ transform: translateY(-50%);
+}
+
+/*
+ * Copyright (c) Jupyter Development Team.
+ * Distributed under the terms of the Modified BSD License.
+ */
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Copyright (c) 2014-2017, PhosphorJS Contributors
+|
+| Distributed under the terms of the BSD 3-Clause License.
+|
+| The full license is in the file LICENSE, distributed with this software.
+|----------------------------------------------------------------------------*/
+
+.lm-TabBar {
+ display: flex;
+ -webkit-user-select: none;
+ -moz-user-select: none;
+ -ms-user-select: none;
+ user-select: none;
+}
+
+.lm-TabBar[data-orientation='horizontal'] {
+ flex-direction: row;
+ align-items: flex-end;
+}
+
+.lm-TabBar[data-orientation='vertical'] {
+ flex-direction: column;
+ align-items: flex-end;
+}
+
+.lm-TabBar-content {
+ margin: 0;
+ padding: 0;
+ display: flex;
+ flex: 1 1 auto;
+ list-style-type: none;
+}
+
+.lm-TabBar[data-orientation='horizontal'] > .lm-TabBar-content {
+ flex-direction: row;
+}
+
+.lm-TabBar[data-orientation='vertical'] > .lm-TabBar-content {
+ flex-direction: column;
+}
+
+.lm-TabBar-tab {
+ display: flex;
+ flex-direction: row;
+ box-sizing: border-box;
+ overflow: hidden;
+ touch-action: none; /* Disable native Drag/Drop */
+}
+
+.lm-TabBar-tabIcon,
+.lm-TabBar-tabCloseIcon {
+ flex: 0 0 auto;
+}
+
+.lm-TabBar-tabLabel {
+ flex: 1 1 auto;
+ overflow: hidden;
+ white-space: nowrap;
+}
+
+.lm-TabBar-tabInput {
+ user-select: all;
+ width: 100%;
+ box-sizing: border-box;
+}
+
+.lm-TabBar-tab.lm-mod-hidden {
+ display: none !important;
+}
+
+.lm-TabBar-addButton.lm-mod-hidden {
+ display: none !important;
+}
+
+.lm-TabBar.lm-mod-dragging .lm-TabBar-tab {
+ position: relative;
+}
+
+.lm-TabBar.lm-mod-dragging[data-orientation='horizontal'] .lm-TabBar-tab {
+ left: 0;
+ transition: left 150ms ease;
+}
+
+.lm-TabBar.lm-mod-dragging[data-orientation='vertical'] .lm-TabBar-tab {
+ top: 0;
+ transition: top 150ms ease;
+}
+
+.lm-TabBar.lm-mod-dragging .lm-TabBar-tab.lm-mod-dragging {
+ transition: none;
+}
+
+.lm-TabBar-tabLabel .lm-TabBar-tabInput {
+ user-select: all;
+ width: 100%;
+ box-sizing: border-box;
+ background: inherit;
+}
+
+/*
+ * Copyright (c) Jupyter Development Team.
+ * Distributed under the terms of the Modified BSD License.
+ */
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Copyright (c) 2014-2017, PhosphorJS Contributors
+|
+| Distributed under the terms of the BSD 3-Clause License.
+|
+| The full license is in the file LICENSE, distributed with this software.
+|----------------------------------------------------------------------------*/
+
+.lm-TabPanel-tabBar {
+ z-index: 1;
+}
+
+.lm-TabPanel-stackedPanel {
+ z-index: 0;
+}
+
+/*
+ * Copyright (c) Jupyter Development Team.
+ * Distributed under the terms of the Modified BSD License.
+ */
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Copyright (c) 2014-2017, PhosphorJS Contributors
+|
+| Distributed under the terms of the BSD 3-Clause License.
+|
+| The full license is in the file LICENSE, distributed with this software.
+|----------------------------------------------------------------------------*/
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+.jp-Collapse {
+ display: flex;
+ flex-direction: column;
+ align-items: stretch;
+}
+
+.jp-Collapse-header {
+ padding: 1px 12px;
+ background-color: var(--jp-layout-color1);
+ border-bottom: solid var(--jp-border-width) var(--jp-border-color2);
+ color: var(--jp-ui-font-color1);
+ cursor: pointer;
+ display: flex;
+ align-items: center;
+ font-size: var(--jp-ui-font-size0);
+ font-weight: 600;
+ text-transform: uppercase;
+ user-select: none;
+}
+
+.jp-Collapser-icon {
+ height: 16px;
+}
+
+.jp-Collapse-header-collapsed .jp-Collapser-icon {
+ transform: rotate(-90deg);
+ margin: auto 0;
+}
+
+.jp-Collapser-title {
+ line-height: 25px;
+}
+
+.jp-Collapse-contents {
+ padding: 0 12px;
+ background-color: var(--jp-layout-color1);
+ color: var(--jp-ui-font-color1);
+ overflow: auto;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/* This file was auto-generated by ensureUiComponents() in @jupyterlab/buildutils */
+
+/**
+ * (DEPRECATED) Support for consuming icons as CSS background images
+ */
+
+/* Icons urls */
+
+:root {
+ --jp-icon-add-above: url();
+ --jp-icon-add-below: url();
+ --jp-icon-add: url();
+ --jp-icon-bell: url();
+ --jp-icon-bug-dot: url();
+ --jp-icon-bug: url();
+ --jp-icon-build: url();
+ --jp-icon-caret-down-empty-thin: url();
+ --jp-icon-caret-down-empty: url();
+ --jp-icon-caret-down: url();
+ --jp-icon-caret-left: url();
+ --jp-icon-caret-right: url();
+ --jp-icon-caret-up-empty-thin: url();
+ --jp-icon-caret-up: url();
+ --jp-icon-case-sensitive: url();
+ --jp-icon-check: url();
+ --jp-icon-circle-empty: url();
+ --jp-icon-circle: url();
+ --jp-icon-clear: url();
+ --jp-icon-close: url();
+ --jp-icon-code-check: url();
+ --jp-icon-code: url();
+ --jp-icon-collapse-all: url();
+ --jp-icon-console: url();
+ --jp-icon-copy: url();
+ --jp-icon-copyright: url();
+ --jp-icon-cut: url();
+ --jp-icon-delete: url();
+ --jp-icon-download: url();
+ --jp-icon-duplicate: url();
+ --jp-icon-edit: url();
+ --jp-icon-ellipses: url();
+ --jp-icon-error: url();
+ --jp-icon-expand-all: url();
+ --jp-icon-extension: url();
+ --jp-icon-fast-forward: url();
+ --jp-icon-file-upload: url();
+ --jp-icon-file: url();
+ --jp-icon-filter-dot: url();
+ --jp-icon-filter-list: url();
+ --jp-icon-filter: url();
+ --jp-icon-folder-favorite: url();
+ --jp-icon-folder: url();
+ --jp-icon-home: url();
+ --jp-icon-html5: url();
+ --jp-icon-image: url();
+ --jp-icon-info: url();
+ --jp-icon-inspector: url();
+ --jp-icon-json: url();
+ --jp-icon-julia: url();
+ --jp-icon-jupyter-favicon: url();
+ --jp-icon-jupyter: url();
+ --jp-icon-jupyterlab-wordmark: url();
+ --jp-icon-kernel: url();
+ --jp-icon-keyboard: url();
+ --jp-icon-launch: url();
+ --jp-icon-launcher: url();
+ --jp-icon-line-form: url();
+ --jp-icon-link: url();
+ --jp-icon-list: url();
+ --jp-icon-markdown: url();
+ --jp-icon-move-down: url();
+ --jp-icon-move-up: url();
+ --jp-icon-new-folder: url();
+ --jp-icon-not-trusted: url();
+ --jp-icon-notebook: url();
+ --jp-icon-numbering: url();
+ --jp-icon-offline-bolt: url();
+ --jp-icon-palette: url();
+ --jp-icon-paste: url();
+ --jp-icon-pdf: url();
+ --jp-icon-python: url();
+ --jp-icon-r-kernel: url();
+ --jp-icon-react: url();
+ --jp-icon-redo: url();
+ --jp-icon-refresh: url();
+ --jp-icon-regex: url();
+ --jp-icon-run: url();
+ --jp-icon-running: url();
+ --jp-icon-save: url();
+ --jp-icon-search: url();
+ --jp-icon-settings: url();
+ --jp-icon-share: url();
+ --jp-icon-spreadsheet: url();
+ --jp-icon-stop: url();
+ --jp-icon-tab: url();
+ --jp-icon-table-rows: url();
+ --jp-icon-tag: url();
+ --jp-icon-terminal: url();
+ --jp-icon-text-editor: url();
+ --jp-icon-toc: url();
+ --jp-icon-tree-view: url();
+ --jp-icon-trusted: url();
+ --jp-icon-undo: url();
+ --jp-icon-user: url();
+ --jp-icon-users: url();
+ --jp-icon-vega: url();
+ --jp-icon-word: url();
+ --jp-icon-yaml: url();
+}
+
+/* Icon CSS class declarations */
+
+.jp-AddAboveIcon {
+ background-image: var(--jp-icon-add-above);
+}
+
+.jp-AddBelowIcon {
+ background-image: var(--jp-icon-add-below);
+}
+
+.jp-AddIcon {
+ background-image: var(--jp-icon-add);
+}
+
+.jp-BellIcon {
+ background-image: var(--jp-icon-bell);
+}
+
+.jp-BugDotIcon {
+ background-image: var(--jp-icon-bug-dot);
+}
+
+.jp-BugIcon {
+ background-image: var(--jp-icon-bug);
+}
+
+.jp-BuildIcon {
+ background-image: var(--jp-icon-build);
+}
+
+.jp-CaretDownEmptyIcon {
+ background-image: var(--jp-icon-caret-down-empty);
+}
+
+.jp-CaretDownEmptyThinIcon {
+ background-image: var(--jp-icon-caret-down-empty-thin);
+}
+
+.jp-CaretDownIcon {
+ background-image: var(--jp-icon-caret-down);
+}
+
+.jp-CaretLeftIcon {
+ background-image: var(--jp-icon-caret-left);
+}
+
+.jp-CaretRightIcon {
+ background-image: var(--jp-icon-caret-right);
+}
+
+.jp-CaretUpEmptyThinIcon {
+ background-image: var(--jp-icon-caret-up-empty-thin);
+}
+
+.jp-CaretUpIcon {
+ background-image: var(--jp-icon-caret-up);
+}
+
+.jp-CaseSensitiveIcon {
+ background-image: var(--jp-icon-case-sensitive);
+}
+
+.jp-CheckIcon {
+ background-image: var(--jp-icon-check);
+}
+
+.jp-CircleEmptyIcon {
+ background-image: var(--jp-icon-circle-empty);
+}
+
+.jp-CircleIcon {
+ background-image: var(--jp-icon-circle);
+}
+
+.jp-ClearIcon {
+ background-image: var(--jp-icon-clear);
+}
+
+.jp-CloseIcon {
+ background-image: var(--jp-icon-close);
+}
+
+.jp-CodeCheckIcon {
+ background-image: var(--jp-icon-code-check);
+}
+
+.jp-CodeIcon {
+ background-image: var(--jp-icon-code);
+}
+
+.jp-CollapseAllIcon {
+ background-image: var(--jp-icon-collapse-all);
+}
+
+.jp-ConsoleIcon {
+ background-image: var(--jp-icon-console);
+}
+
+.jp-CopyIcon {
+ background-image: var(--jp-icon-copy);
+}
+
+.jp-CopyrightIcon {
+ background-image: var(--jp-icon-copyright);
+}
+
+.jp-CutIcon {
+ background-image: var(--jp-icon-cut);
+}
+
+.jp-DeleteIcon {
+ background-image: var(--jp-icon-delete);
+}
+
+.jp-DownloadIcon {
+ background-image: var(--jp-icon-download);
+}
+
+.jp-DuplicateIcon {
+ background-image: var(--jp-icon-duplicate);
+}
+
+.jp-EditIcon {
+ background-image: var(--jp-icon-edit);
+}
+
+.jp-EllipsesIcon {
+ background-image: var(--jp-icon-ellipses);
+}
+
+.jp-ErrorIcon {
+ background-image: var(--jp-icon-error);
+}
+
+.jp-ExpandAllIcon {
+ background-image: var(--jp-icon-expand-all);
+}
+
+.jp-ExtensionIcon {
+ background-image: var(--jp-icon-extension);
+}
+
+.jp-FastForwardIcon {
+ background-image: var(--jp-icon-fast-forward);
+}
+
+.jp-FileIcon {
+ background-image: var(--jp-icon-file);
+}
+
+.jp-FileUploadIcon {
+ background-image: var(--jp-icon-file-upload);
+}
+
+.jp-FilterDotIcon {
+ background-image: var(--jp-icon-filter-dot);
+}
+
+.jp-FilterIcon {
+ background-image: var(--jp-icon-filter);
+}
+
+.jp-FilterListIcon {
+ background-image: var(--jp-icon-filter-list);
+}
+
+.jp-FolderFavoriteIcon {
+ background-image: var(--jp-icon-folder-favorite);
+}
+
+.jp-FolderIcon {
+ background-image: var(--jp-icon-folder);
+}
+
+.jp-HomeIcon {
+ background-image: var(--jp-icon-home);
+}
+
+.jp-Html5Icon {
+ background-image: var(--jp-icon-html5);
+}
+
+.jp-ImageIcon {
+ background-image: var(--jp-icon-image);
+}
+
+.jp-InfoIcon {
+ background-image: var(--jp-icon-info);
+}
+
+.jp-InspectorIcon {
+ background-image: var(--jp-icon-inspector);
+}
+
+.jp-JsonIcon {
+ background-image: var(--jp-icon-json);
+}
+
+.jp-JuliaIcon {
+ background-image: var(--jp-icon-julia);
+}
+
+.jp-JupyterFaviconIcon {
+ background-image: var(--jp-icon-jupyter-favicon);
+}
+
+.jp-JupyterIcon {
+ background-image: var(--jp-icon-jupyter);
+}
+
+.jp-JupyterlabWordmarkIcon {
+ background-image: var(--jp-icon-jupyterlab-wordmark);
+}
+
+.jp-KernelIcon {
+ background-image: var(--jp-icon-kernel);
+}
+
+.jp-KeyboardIcon {
+ background-image: var(--jp-icon-keyboard);
+}
+
+.jp-LaunchIcon {
+ background-image: var(--jp-icon-launch);
+}
+
+.jp-LauncherIcon {
+ background-image: var(--jp-icon-launcher);
+}
+
+.jp-LineFormIcon {
+ background-image: var(--jp-icon-line-form);
+}
+
+.jp-LinkIcon {
+ background-image: var(--jp-icon-link);
+}
+
+.jp-ListIcon {
+ background-image: var(--jp-icon-list);
+}
+
+.jp-MarkdownIcon {
+ background-image: var(--jp-icon-markdown);
+}
+
+.jp-MoveDownIcon {
+ background-image: var(--jp-icon-move-down);
+}
+
+.jp-MoveUpIcon {
+ background-image: var(--jp-icon-move-up);
+}
+
+.jp-NewFolderIcon {
+ background-image: var(--jp-icon-new-folder);
+}
+
+.jp-NotTrustedIcon {
+ background-image: var(--jp-icon-not-trusted);
+}
+
+.jp-NotebookIcon {
+ background-image: var(--jp-icon-notebook);
+}
+
+.jp-NumberingIcon {
+ background-image: var(--jp-icon-numbering);
+}
+
+.jp-OfflineBoltIcon {
+ background-image: var(--jp-icon-offline-bolt);
+}
+
+.jp-PaletteIcon {
+ background-image: var(--jp-icon-palette);
+}
+
+.jp-PasteIcon {
+ background-image: var(--jp-icon-paste);
+}
+
+.jp-PdfIcon {
+ background-image: var(--jp-icon-pdf);
+}
+
+.jp-PythonIcon {
+ background-image: var(--jp-icon-python);
+}
+
+.jp-RKernelIcon {
+ background-image: var(--jp-icon-r-kernel);
+}
+
+.jp-ReactIcon {
+ background-image: var(--jp-icon-react);
+}
+
+.jp-RedoIcon {
+ background-image: var(--jp-icon-redo);
+}
+
+.jp-RefreshIcon {
+ background-image: var(--jp-icon-refresh);
+}
+
+.jp-RegexIcon {
+ background-image: var(--jp-icon-regex);
+}
+
+.jp-RunIcon {
+ background-image: var(--jp-icon-run);
+}
+
+.jp-RunningIcon {
+ background-image: var(--jp-icon-running);
+}
+
+.jp-SaveIcon {
+ background-image: var(--jp-icon-save);
+}
+
+.jp-SearchIcon {
+ background-image: var(--jp-icon-search);
+}
+
+.jp-SettingsIcon {
+ background-image: var(--jp-icon-settings);
+}
+
+.jp-ShareIcon {
+ background-image: var(--jp-icon-share);
+}
+
+.jp-SpreadsheetIcon {
+ background-image: var(--jp-icon-spreadsheet);
+}
+
+.jp-StopIcon {
+ background-image: var(--jp-icon-stop);
+}
+
+.jp-TabIcon {
+ background-image: var(--jp-icon-tab);
+}
+
+.jp-TableRowsIcon {
+ background-image: var(--jp-icon-table-rows);
+}
+
+.jp-TagIcon {
+ background-image: var(--jp-icon-tag);
+}
+
+.jp-TerminalIcon {
+ background-image: var(--jp-icon-terminal);
+}
+
+.jp-TextEditorIcon {
+ background-image: var(--jp-icon-text-editor);
+}
+
+.jp-TocIcon {
+ background-image: var(--jp-icon-toc);
+}
+
+.jp-TreeViewIcon {
+ background-image: var(--jp-icon-tree-view);
+}
+
+.jp-TrustedIcon {
+ background-image: var(--jp-icon-trusted);
+}
+
+.jp-UndoIcon {
+ background-image: var(--jp-icon-undo);
+}
+
+.jp-UserIcon {
+ background-image: var(--jp-icon-user);
+}
+
+.jp-UsersIcon {
+ background-image: var(--jp-icon-users);
+}
+
+.jp-VegaIcon {
+ background-image: var(--jp-icon-vega);
+}
+
+.jp-WordIcon {
+ background-image: var(--jp-icon-word);
+}
+
+.jp-YamlIcon {
+ background-image: var(--jp-icon-yaml);
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/**
+ * (DEPRECATED) Support for consuming icons as CSS background images
+ */
+
+.jp-Icon,
+.jp-MaterialIcon {
+ background-position: center;
+ background-repeat: no-repeat;
+ background-size: 16px;
+ min-width: 16px;
+ min-height: 16px;
+}
+
+.jp-Icon-cover {
+ background-position: center;
+ background-repeat: no-repeat;
+ background-size: cover;
+}
+
+/**
+ * (DEPRECATED) Support for specific CSS icon sizes
+ */
+
+.jp-Icon-16 {
+ background-size: 16px;
+ min-width: 16px;
+ min-height: 16px;
+}
+
+.jp-Icon-18 {
+ background-size: 18px;
+ min-width: 18px;
+ min-height: 18px;
+}
+
+.jp-Icon-20 {
+ background-size: 20px;
+ min-width: 20px;
+ min-height: 20px;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+.lm-TabBar .lm-TabBar-addButton {
+ align-items: center;
+ display: flex;
+ padding: 4px;
+ padding-bottom: 5px;
+ margin-right: 1px;
+ background-color: var(--jp-layout-color2);
+}
+
+.lm-TabBar .lm-TabBar-addButton:hover {
+ background-color: var(--jp-layout-color1);
+}
+
+.lm-DockPanel-tabBar .lm-TabBar-tab {
+ width: var(--jp-private-horizontal-tab-width);
+}
+
+.lm-DockPanel-tabBar .lm-TabBar-content {
+ flex: unset;
+}
+
+.lm-DockPanel-tabBar[data-orientation='horizontal'] {
+ flex: 1 1 auto;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/**
+ * Support for icons as inline SVG HTMLElements
+ */
+
+/* recolor the primary elements of an icon */
+.jp-icon0[fill] {
+ fill: var(--jp-inverse-layout-color0);
+}
+
+.jp-icon1[fill] {
+ fill: var(--jp-inverse-layout-color1);
+}
+
+.jp-icon2[fill] {
+ fill: var(--jp-inverse-layout-color2);
+}
+
+.jp-icon3[fill] {
+ fill: var(--jp-inverse-layout-color3);
+}
+
+.jp-icon4[fill] {
+ fill: var(--jp-inverse-layout-color4);
+}
+
+.jp-icon0[stroke] {
+ stroke: var(--jp-inverse-layout-color0);
+}
+
+.jp-icon1[stroke] {
+ stroke: var(--jp-inverse-layout-color1);
+}
+
+.jp-icon2[stroke] {
+ stroke: var(--jp-inverse-layout-color2);
+}
+
+.jp-icon3[stroke] {
+ stroke: var(--jp-inverse-layout-color3);
+}
+
+.jp-icon4[stroke] {
+ stroke: var(--jp-inverse-layout-color4);
+}
+
+/* recolor the accent elements of an icon */
+.jp-icon-accent0[fill] {
+ fill: var(--jp-layout-color0);
+}
+
+.jp-icon-accent1[fill] {
+ fill: var(--jp-layout-color1);
+}
+
+.jp-icon-accent2[fill] {
+ fill: var(--jp-layout-color2);
+}
+
+.jp-icon-accent3[fill] {
+ fill: var(--jp-layout-color3);
+}
+
+.jp-icon-accent4[fill] {
+ fill: var(--jp-layout-color4);
+}
+
+.jp-icon-accent0[stroke] {
+ stroke: var(--jp-layout-color0);
+}
+
+.jp-icon-accent1[stroke] {
+ stroke: var(--jp-layout-color1);
+}
+
+.jp-icon-accent2[stroke] {
+ stroke: var(--jp-layout-color2);
+}
+
+.jp-icon-accent3[stroke] {
+ stroke: var(--jp-layout-color3);
+}
+
+.jp-icon-accent4[stroke] {
+ stroke: var(--jp-layout-color4);
+}
+
+/* set the color of an icon to transparent */
+.jp-icon-none[fill] {
+ fill: none;
+}
+
+.jp-icon-none[stroke] {
+ stroke: none;
+}
+
+/* brand icon colors. Same for light and dark */
+.jp-icon-brand0[fill] {
+ fill: var(--jp-brand-color0);
+}
+
+.jp-icon-brand1[fill] {
+ fill: var(--jp-brand-color1);
+}
+
+.jp-icon-brand2[fill] {
+ fill: var(--jp-brand-color2);
+}
+
+.jp-icon-brand3[fill] {
+ fill: var(--jp-brand-color3);
+}
+
+.jp-icon-brand4[fill] {
+ fill: var(--jp-brand-color4);
+}
+
+.jp-icon-brand0[stroke] {
+ stroke: var(--jp-brand-color0);
+}
+
+.jp-icon-brand1[stroke] {
+ stroke: var(--jp-brand-color1);
+}
+
+.jp-icon-brand2[stroke] {
+ stroke: var(--jp-brand-color2);
+}
+
+.jp-icon-brand3[stroke] {
+ stroke: var(--jp-brand-color3);
+}
+
+.jp-icon-brand4[stroke] {
+ stroke: var(--jp-brand-color4);
+}
+
+/* warn icon colors. Same for light and dark */
+.jp-icon-warn0[fill] {
+ fill: var(--jp-warn-color0);
+}
+
+.jp-icon-warn1[fill] {
+ fill: var(--jp-warn-color1);
+}
+
+.jp-icon-warn2[fill] {
+ fill: var(--jp-warn-color2);
+}
+
+.jp-icon-warn3[fill] {
+ fill: var(--jp-warn-color3);
+}
+
+.jp-icon-warn0[stroke] {
+ stroke: var(--jp-warn-color0);
+}
+
+.jp-icon-warn1[stroke] {
+ stroke: var(--jp-warn-color1);
+}
+
+.jp-icon-warn2[stroke] {
+ stroke: var(--jp-warn-color2);
+}
+
+.jp-icon-warn3[stroke] {
+ stroke: var(--jp-warn-color3);
+}
+
+/* icon colors that contrast well with each other and most backgrounds */
+.jp-icon-contrast0[fill] {
+ fill: var(--jp-icon-contrast-color0);
+}
+
+.jp-icon-contrast1[fill] {
+ fill: var(--jp-icon-contrast-color1);
+}
+
+.jp-icon-contrast2[fill] {
+ fill: var(--jp-icon-contrast-color2);
+}
+
+.jp-icon-contrast3[fill] {
+ fill: var(--jp-icon-contrast-color3);
+}
+
+.jp-icon-contrast0[stroke] {
+ stroke: var(--jp-icon-contrast-color0);
+}
+
+.jp-icon-contrast1[stroke] {
+ stroke: var(--jp-icon-contrast-color1);
+}
+
+.jp-icon-contrast2[stroke] {
+ stroke: var(--jp-icon-contrast-color2);
+}
+
+.jp-icon-contrast3[stroke] {
+ stroke: var(--jp-icon-contrast-color3);
+}
+
+.jp-icon-dot[fill] {
+ fill: var(--jp-warn-color0);
+}
+
+.jp-jupyter-icon-color[fill] {
+ fill: var(--jp-jupyter-icon-color, var(--jp-warn-color0));
+}
+
+.jp-notebook-icon-color[fill] {
+ fill: var(--jp-notebook-icon-color, var(--jp-warn-color0));
+}
+
+.jp-json-icon-color[fill] {
+ fill: var(--jp-json-icon-color, var(--jp-warn-color1));
+}
+
+.jp-console-icon-color[fill] {
+ fill: var(--jp-console-icon-color, white);
+}
+
+.jp-console-icon-background-color[fill] {
+ fill: var(--jp-console-icon-background-color, var(--jp-brand-color1));
+}
+
+.jp-terminal-icon-color[fill] {
+ fill: var(--jp-terminal-icon-color, var(--jp-layout-color2));
+}
+
+.jp-terminal-icon-background-color[fill] {
+ fill: var(
+ --jp-terminal-icon-background-color,
+ var(--jp-inverse-layout-color2)
+ );
+}
+
+.jp-text-editor-icon-color[fill] {
+ fill: var(--jp-text-editor-icon-color, var(--jp-inverse-layout-color3));
+}
+
+.jp-inspector-icon-color[fill] {
+ fill: var(--jp-inspector-icon-color, var(--jp-inverse-layout-color3));
+}
+
+/* CSS for icons in selected filebrowser listing items */
+.jp-DirListing-item.jp-mod-selected .jp-icon-selectable[fill] {
+ fill: #fff;
+}
+
+.jp-DirListing-item.jp-mod-selected .jp-icon-selectable-inverse[fill] {
+ fill: var(--jp-brand-color1);
+}
+
+/* stylelint-disable selector-max-class, selector-max-compound-selectors */
+
+/**
+* TODO: come up with non css-hack solution for showing the busy icon on top
+* of the close icon
+* CSS for complex behavior of close icon of tabs in the main area tabbar
+*/
+.lm-DockPanel-tabBar
+ .lm-TabBar-tab.lm-mod-closable.jp-mod-dirty
+ > .lm-TabBar-tabCloseIcon
+ > :not(:hover)
+ > .jp-icon3[fill] {
+ fill: none;
+}
+
+.lm-DockPanel-tabBar
+ .lm-TabBar-tab.lm-mod-closable.jp-mod-dirty
+ > .lm-TabBar-tabCloseIcon
+ > :not(:hover)
+ > .jp-icon-busy[fill] {
+ fill: var(--jp-inverse-layout-color3);
+}
+
+/* stylelint-enable selector-max-class, selector-max-compound-selectors */
+
+/* CSS for icons in status bar */
+#jp-main-statusbar .jp-mod-selected .jp-icon-selectable[fill] {
+ fill: #fff;
+}
+
+#jp-main-statusbar .jp-mod-selected .jp-icon-selectable-inverse[fill] {
+ fill: var(--jp-brand-color1);
+}
+
+/* special handling for splash icon CSS. While the theme CSS reloads during
+ splash, the splash icon can loose theming. To prevent that, we set a
+ default for its color variable */
+:root {
+ --jp-warn-color0: var(--md-orange-700);
+}
+
+/* not sure what to do with this one, used in filebrowser listing */
+.jp-DragIcon {
+ margin-right: 4px;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/**
+ * Support for alt colors for icons as inline SVG HTMLElements
+ */
+
+/* alt recolor the primary elements of an icon */
+.jp-icon-alt .jp-icon0[fill] {
+ fill: var(--jp-layout-color0);
+}
+
+.jp-icon-alt .jp-icon1[fill] {
+ fill: var(--jp-layout-color1);
+}
+
+.jp-icon-alt .jp-icon2[fill] {
+ fill: var(--jp-layout-color2);
+}
+
+.jp-icon-alt .jp-icon3[fill] {
+ fill: var(--jp-layout-color3);
+}
+
+.jp-icon-alt .jp-icon4[fill] {
+ fill: var(--jp-layout-color4);
+}
+
+.jp-icon-alt .jp-icon0[stroke] {
+ stroke: var(--jp-layout-color0);
+}
+
+.jp-icon-alt .jp-icon1[stroke] {
+ stroke: var(--jp-layout-color1);
+}
+
+.jp-icon-alt .jp-icon2[stroke] {
+ stroke: var(--jp-layout-color2);
+}
+
+.jp-icon-alt .jp-icon3[stroke] {
+ stroke: var(--jp-layout-color3);
+}
+
+.jp-icon-alt .jp-icon4[stroke] {
+ stroke: var(--jp-layout-color4);
+}
+
+/* alt recolor the accent elements of an icon */
+.jp-icon-alt .jp-icon-accent0[fill] {
+ fill: var(--jp-inverse-layout-color0);
+}
+
+.jp-icon-alt .jp-icon-accent1[fill] {
+ fill: var(--jp-inverse-layout-color1);
+}
+
+.jp-icon-alt .jp-icon-accent2[fill] {
+ fill: var(--jp-inverse-layout-color2);
+}
+
+.jp-icon-alt .jp-icon-accent3[fill] {
+ fill: var(--jp-inverse-layout-color3);
+}
+
+.jp-icon-alt .jp-icon-accent4[fill] {
+ fill: var(--jp-inverse-layout-color4);
+}
+
+.jp-icon-alt .jp-icon-accent0[stroke] {
+ stroke: var(--jp-inverse-layout-color0);
+}
+
+.jp-icon-alt .jp-icon-accent1[stroke] {
+ stroke: var(--jp-inverse-layout-color1);
+}
+
+.jp-icon-alt .jp-icon-accent2[stroke] {
+ stroke: var(--jp-inverse-layout-color2);
+}
+
+.jp-icon-alt .jp-icon-accent3[stroke] {
+ stroke: var(--jp-inverse-layout-color3);
+}
+
+.jp-icon-alt .jp-icon-accent4[stroke] {
+ stroke: var(--jp-inverse-layout-color4);
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+.jp-icon-hoverShow:not(:hover) .jp-icon-hoverShow-content {
+ display: none !important;
+}
+
+/**
+ * Support for hover colors for icons as inline SVG HTMLElements
+ */
+
+/**
+ * regular colors
+ */
+
+/* recolor the primary elements of an icon */
+.jp-icon-hover :hover .jp-icon0-hover[fill] {
+ fill: var(--jp-inverse-layout-color0);
+}
+
+.jp-icon-hover :hover .jp-icon1-hover[fill] {
+ fill: var(--jp-inverse-layout-color1);
+}
+
+.jp-icon-hover :hover .jp-icon2-hover[fill] {
+ fill: var(--jp-inverse-layout-color2);
+}
+
+.jp-icon-hover :hover .jp-icon3-hover[fill] {
+ fill: var(--jp-inverse-layout-color3);
+}
+
+.jp-icon-hover :hover .jp-icon4-hover[fill] {
+ fill: var(--jp-inverse-layout-color4);
+}
+
+.jp-icon-hover :hover .jp-icon0-hover[stroke] {
+ stroke: var(--jp-inverse-layout-color0);
+}
+
+.jp-icon-hover :hover .jp-icon1-hover[stroke] {
+ stroke: var(--jp-inverse-layout-color1);
+}
+
+.jp-icon-hover :hover .jp-icon2-hover[stroke] {
+ stroke: var(--jp-inverse-layout-color2);
+}
+
+.jp-icon-hover :hover .jp-icon3-hover[stroke] {
+ stroke: var(--jp-inverse-layout-color3);
+}
+
+.jp-icon-hover :hover .jp-icon4-hover[stroke] {
+ stroke: var(--jp-inverse-layout-color4);
+}
+
+/* recolor the accent elements of an icon */
+.jp-icon-hover :hover .jp-icon-accent0-hover[fill] {
+ fill: var(--jp-layout-color0);
+}
+
+.jp-icon-hover :hover .jp-icon-accent1-hover[fill] {
+ fill: var(--jp-layout-color1);
+}
+
+.jp-icon-hover :hover .jp-icon-accent2-hover[fill] {
+ fill: var(--jp-layout-color2);
+}
+
+.jp-icon-hover :hover .jp-icon-accent3-hover[fill] {
+ fill: var(--jp-layout-color3);
+}
+
+.jp-icon-hover :hover .jp-icon-accent4-hover[fill] {
+ fill: var(--jp-layout-color4);
+}
+
+.jp-icon-hover :hover .jp-icon-accent0-hover[stroke] {
+ stroke: var(--jp-layout-color0);
+}
+
+.jp-icon-hover :hover .jp-icon-accent1-hover[stroke] {
+ stroke: var(--jp-layout-color1);
+}
+
+.jp-icon-hover :hover .jp-icon-accent2-hover[stroke] {
+ stroke: var(--jp-layout-color2);
+}
+
+.jp-icon-hover :hover .jp-icon-accent3-hover[stroke] {
+ stroke: var(--jp-layout-color3);
+}
+
+.jp-icon-hover :hover .jp-icon-accent4-hover[stroke] {
+ stroke: var(--jp-layout-color4);
+}
+
+/* set the color of an icon to transparent */
+.jp-icon-hover :hover .jp-icon-none-hover[fill] {
+ fill: none;
+}
+
+.jp-icon-hover :hover .jp-icon-none-hover[stroke] {
+ stroke: none;
+}
+
+/**
+ * inverse colors
+ */
+
+/* inverse recolor the primary elements of an icon */
+.jp-icon-hover.jp-icon-alt :hover .jp-icon0-hover[fill] {
+ fill: var(--jp-layout-color0);
+}
+
+.jp-icon-hover.jp-icon-alt :hover .jp-icon1-hover[fill] {
+ fill: var(--jp-layout-color1);
+}
+
+.jp-icon-hover.jp-icon-alt :hover .jp-icon2-hover[fill] {
+ fill: var(--jp-layout-color2);
+}
+
+.jp-icon-hover.jp-icon-alt :hover .jp-icon3-hover[fill] {
+ fill: var(--jp-layout-color3);
+}
+
+.jp-icon-hover.jp-icon-alt :hover .jp-icon4-hover[fill] {
+ fill: var(--jp-layout-color4);
+}
+
+.jp-icon-hover.jp-icon-alt :hover .jp-icon0-hover[stroke] {
+ stroke: var(--jp-layout-color0);
+}
+
+.jp-icon-hover.jp-icon-alt :hover .jp-icon1-hover[stroke] {
+ stroke: var(--jp-layout-color1);
+}
+
+.jp-icon-hover.jp-icon-alt :hover .jp-icon2-hover[stroke] {
+ stroke: var(--jp-layout-color2);
+}
+
+.jp-icon-hover.jp-icon-alt :hover .jp-icon3-hover[stroke] {
+ stroke: var(--jp-layout-color3);
+}
+
+.jp-icon-hover.jp-icon-alt :hover .jp-icon4-hover[stroke] {
+ stroke: var(--jp-layout-color4);
+}
+
+/* inverse recolor the accent elements of an icon */
+.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent0-hover[fill] {
+ fill: var(--jp-inverse-layout-color0);
+}
+
+.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent1-hover[fill] {
+ fill: var(--jp-inverse-layout-color1);
+}
+
+.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent2-hover[fill] {
+ fill: var(--jp-inverse-layout-color2);
+}
+
+.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent3-hover[fill] {
+ fill: var(--jp-inverse-layout-color3);
+}
+
+.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent4-hover[fill] {
+ fill: var(--jp-inverse-layout-color4);
+}
+
+.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent0-hover[stroke] {
+ stroke: var(--jp-inverse-layout-color0);
+}
+
+.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent1-hover[stroke] {
+ stroke: var(--jp-inverse-layout-color1);
+}
+
+.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent2-hover[stroke] {
+ stroke: var(--jp-inverse-layout-color2);
+}
+
+.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent3-hover[stroke] {
+ stroke: var(--jp-inverse-layout-color3);
+}
+
+.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent4-hover[stroke] {
+ stroke: var(--jp-inverse-layout-color4);
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+.jp-IFrame {
+ width: 100%;
+ height: 100%;
+}
+
+.jp-IFrame > iframe {
+ border: none;
+}
+
+/*
+When drag events occur, `lm-mod-override-cursor` is added to the body.
+Because iframes steal all cursor events, the following two rules are necessary
+to suppress pointer events while resize drags are occurring. There may be a
+better solution to this problem.
+*/
+body.lm-mod-override-cursor .jp-IFrame {
+ position: relative;
+}
+
+body.lm-mod-override-cursor .jp-IFrame::before {
+ content: '';
+ position: absolute;
+ top: 0;
+ left: 0;
+ right: 0;
+ bottom: 0;
+ background: transparent;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) 2014-2016, Jupyter Development Team.
+|
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+.jp-HoverBox {
+ position: fixed;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+.jp-FormGroup-content fieldset {
+ border: none;
+ padding: 0;
+ min-width: 0;
+ width: 100%;
+}
+
+/* stylelint-disable selector-max-type */
+
+.jp-FormGroup-content fieldset .jp-inputFieldWrapper input,
+.jp-FormGroup-content fieldset .jp-inputFieldWrapper select,
+.jp-FormGroup-content fieldset .jp-inputFieldWrapper textarea {
+ font-size: var(--jp-content-font-size2);
+ border-color: var(--jp-input-border-color);
+ border-style: solid;
+ border-radius: var(--jp-border-radius);
+ border-width: 1px;
+ padding: 6px 8px;
+ background: none;
+ color: var(--jp-ui-font-color0);
+ height: inherit;
+}
+
+.jp-FormGroup-content fieldset input[type='checkbox'] {
+ position: relative;
+ top: 2px;
+ margin-left: 0;
+}
+
+.jp-FormGroup-content button.jp-mod-styled {
+ cursor: pointer;
+}
+
+.jp-FormGroup-content .checkbox label {
+ cursor: pointer;
+ font-size: var(--jp-content-font-size1);
+}
+
+.jp-FormGroup-content .jp-root > fieldset > legend {
+ display: none;
+}
+
+.jp-FormGroup-content .jp-root > fieldset > p {
+ display: none;
+}
+
+/** copy of `input.jp-mod-styled:focus` style */
+.jp-FormGroup-content fieldset input:focus,
+.jp-FormGroup-content fieldset select:focus {
+ -moz-outline-radius: unset;
+ outline: var(--jp-border-width) solid var(--md-blue-500);
+ outline-offset: -1px;
+ box-shadow: inset 0 0 4px var(--md-blue-300);
+}
+
+.jp-FormGroup-content fieldset input:hover:not(:focus),
+.jp-FormGroup-content fieldset select:hover:not(:focus) {
+ background-color: var(--jp-border-color2);
+}
+
+/* stylelint-enable selector-max-type */
+
+.jp-FormGroup-content .checkbox .field-description {
+ /* Disable default description field for checkbox:
+ because other widgets do not have description fields,
+ we add descriptions to each widget on the field level.
+ */
+ display: none;
+}
+
+.jp-FormGroup-content #root__description {
+ display: none;
+}
+
+.jp-FormGroup-content .jp-modifiedIndicator {
+ width: 5px;
+ background-color: var(--jp-brand-color2);
+ margin-top: 0;
+ margin-left: calc(var(--jp-private-settingeditor-modifier-indent) * -1);
+ flex-shrink: 0;
+}
+
+.jp-FormGroup-content .jp-modifiedIndicator.jp-errorIndicator {
+ background-color: var(--jp-error-color0);
+ margin-right: 0.5em;
+}
+
+/* RJSF ARRAY style */
+
+.jp-arrayFieldWrapper legend {
+ font-size: var(--jp-content-font-size2);
+ color: var(--jp-ui-font-color0);
+ flex-basis: 100%;
+ padding: 4px 0;
+ font-weight: var(--jp-content-heading-font-weight);
+ border-bottom: 1px solid var(--jp-border-color2);
+}
+
+.jp-arrayFieldWrapper .field-description {
+ padding: 4px 0;
+ white-space: pre-wrap;
+}
+
+.jp-arrayFieldWrapper .array-item {
+ width: 100%;
+ border: 1px solid var(--jp-border-color2);
+ border-radius: 4px;
+ margin: 4px;
+}
+
+.jp-ArrayOperations {
+ display: flex;
+ margin-left: 8px;
+}
+
+.jp-ArrayOperationsButton {
+ margin: 2px;
+}
+
+.jp-ArrayOperationsButton .jp-icon3[fill] {
+ fill: var(--jp-ui-font-color0);
+}
+
+button.jp-ArrayOperationsButton.jp-mod-styled:disabled {
+ cursor: not-allowed;
+ opacity: 0.5;
+}
+
+/* RJSF form validation error */
+
+.jp-FormGroup-content .validationErrors {
+ color: var(--jp-error-color0);
+}
+
+/* Hide panel level error as duplicated the field level error */
+.jp-FormGroup-content .panel.errors {
+ display: none;
+}
+
+/* RJSF normal content (settings-editor) */
+
+.jp-FormGroup-contentNormal {
+ display: flex;
+ align-items: center;
+ flex-wrap: wrap;
+}
+
+.jp-FormGroup-contentNormal .jp-FormGroup-contentItem {
+ margin-left: 7px;
+ color: var(--jp-ui-font-color0);
+}
+
+.jp-FormGroup-contentNormal .jp-FormGroup-description {
+ flex-basis: 100%;
+ padding: 4px 7px;
+}
+
+.jp-FormGroup-contentNormal .jp-FormGroup-default {
+ flex-basis: 100%;
+ padding: 4px 7px;
+}
+
+.jp-FormGroup-contentNormal .jp-FormGroup-fieldLabel {
+ font-size: var(--jp-content-font-size1);
+ font-weight: normal;
+ min-width: 120px;
+}
+
+.jp-FormGroup-contentNormal fieldset:not(:first-child) {
+ margin-left: 7px;
+}
+
+.jp-FormGroup-contentNormal .field-array-of-string .array-item {
+ /* Display `jp-ArrayOperations` buttons side-by-side with content except
+ for small screens where flex-wrap will place them one below the other.
+ */
+ display: flex;
+ align-items: center;
+ flex-wrap: wrap;
+}
+
+.jp-FormGroup-contentNormal .jp-objectFieldWrapper .form-group {
+ padding: 2px 8px 2px var(--jp-private-settingeditor-modifier-indent);
+ margin-top: 2px;
+}
+
+/* RJSF compact content (metadata-form) */
+
+.jp-FormGroup-content.jp-FormGroup-contentCompact {
+ width: 100%;
+}
+
+.jp-FormGroup-contentCompact .form-group {
+ display: flex;
+ padding: 0.5em 0.2em 0.5em 0;
+}
+
+.jp-FormGroup-contentCompact
+ .jp-FormGroup-compactTitle
+ .jp-FormGroup-description {
+ font-size: var(--jp-ui-font-size1);
+ color: var(--jp-ui-font-color2);
+}
+
+.jp-FormGroup-contentCompact .jp-FormGroup-fieldLabel {
+ padding-bottom: 0.3em;
+}
+
+.jp-FormGroup-contentCompact .jp-inputFieldWrapper .form-control {
+ width: 100%;
+ box-sizing: border-box;
+}
+
+.jp-FormGroup-contentCompact .jp-arrayFieldWrapper .jp-FormGroup-compactTitle {
+ padding-bottom: 7px;
+}
+
+.jp-FormGroup-contentCompact
+ .jp-objectFieldWrapper
+ .jp-objectFieldWrapper
+ .form-group {
+ padding: 2px 8px 2px var(--jp-private-settingeditor-modifier-indent);
+ margin-top: 2px;
+}
+
+.jp-FormGroup-contentCompact ul.error-detail {
+ margin-block-start: 0.5em;
+ margin-block-end: 0.5em;
+ padding-inline-start: 1em;
+}
+
+/*
+ * Copyright (c) Jupyter Development Team.
+ * Distributed under the terms of the Modified BSD License.
+ */
+
+.jp-SidePanel {
+ display: flex;
+ flex-direction: column;
+ min-width: var(--jp-sidebar-min-width);
+ overflow-y: auto;
+ color: var(--jp-ui-font-color1);
+ background: var(--jp-layout-color1);
+ font-size: var(--jp-ui-font-size1);
+}
+
+.jp-SidePanel-header {
+ flex: 0 0 auto;
+ display: flex;
+ border-bottom: var(--jp-border-width) solid var(--jp-border-color2);
+ font-size: var(--jp-ui-font-size0);
+ font-weight: 600;
+ letter-spacing: 1px;
+ margin: 0;
+ padding: 2px;
+ text-transform: uppercase;
+}
+
+.jp-SidePanel-toolbar {
+ flex: 0 0 auto;
+}
+
+.jp-SidePanel-content {
+ flex: 1 1 auto;
+}
+
+.jp-SidePanel-toolbar,
+.jp-AccordionPanel-toolbar {
+ height: var(--jp-private-toolbar-height);
+}
+
+.jp-SidePanel-toolbar.jp-Toolbar-micro {
+ display: none;
+}
+
+.lm-AccordionPanel .jp-AccordionPanel-title {
+ box-sizing: border-box;
+ line-height: 25px;
+ margin: 0;
+ display: flex;
+ align-items: center;
+ background: var(--jp-layout-color1);
+ color: var(--jp-ui-font-color1);
+ border-bottom: var(--jp-border-width) solid var(--jp-toolbar-border-color);
+ box-shadow: var(--jp-toolbar-box-shadow);
+ font-size: var(--jp-ui-font-size0);
+}
+
+.jp-AccordionPanel-title {
+ cursor: pointer;
+ user-select: none;
+ -moz-user-select: none;
+ -webkit-user-select: none;
+ text-transform: uppercase;
+}
+
+.lm-AccordionPanel[data-orientation='horizontal'] > .jp-AccordionPanel-title {
+ /* Title is rotated for horizontal accordion panel using CSS */
+ display: block;
+ transform-origin: top left;
+ transform: rotate(-90deg) translate(-100%);
+}
+
+.jp-AccordionPanel-title .lm-AccordionPanel-titleLabel {
+ user-select: none;
+ text-overflow: ellipsis;
+ white-space: nowrap;
+ overflow: hidden;
+}
+
+.jp-AccordionPanel-title .lm-AccordionPanel-titleCollapser {
+ transform: rotate(-90deg);
+ margin: auto 0;
+ height: 16px;
+}
+
+.jp-AccordionPanel-title.lm-mod-expanded .lm-AccordionPanel-titleCollapser {
+ transform: rotate(0deg);
+}
+
+.lm-AccordionPanel .jp-AccordionPanel-toolbar {
+ background: none;
+ box-shadow: none;
+ border: none;
+ margin-left: auto;
+}
+
+.lm-AccordionPanel .lm-SplitPanel-handle:hover {
+ background: var(--jp-layout-color3);
+}
+
+.jp-text-truncated {
+ overflow: hidden;
+ text-overflow: ellipsis;
+ white-space: nowrap;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) 2017, Jupyter Development Team.
+|
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+.jp-Spinner {
+ position: absolute;
+ display: flex;
+ justify-content: center;
+ align-items: center;
+ z-index: 10;
+ left: 0;
+ top: 0;
+ width: 100%;
+ height: 100%;
+ background: var(--jp-layout-color0);
+ outline: none;
+}
+
+.jp-SpinnerContent {
+ font-size: 10px;
+ margin: 50px auto;
+ text-indent: -9999em;
+ width: 3em;
+ height: 3em;
+ border-radius: 50%;
+ background: var(--jp-brand-color3);
+ background: linear-gradient(
+ to right,
+ #f37626 10%,
+ rgba(255, 255, 255, 0) 42%
+ );
+ position: relative;
+ animation: load3 1s infinite linear, fadeIn 1s;
+}
+
+.jp-SpinnerContent::before {
+ width: 50%;
+ height: 50%;
+ background: #f37626;
+ border-radius: 100% 0 0;
+ position: absolute;
+ top: 0;
+ left: 0;
+ content: '';
+}
+
+.jp-SpinnerContent::after {
+ background: var(--jp-layout-color0);
+ width: 75%;
+ height: 75%;
+ border-radius: 50%;
+ content: '';
+ margin: auto;
+ position: absolute;
+ top: 0;
+ left: 0;
+ bottom: 0;
+ right: 0;
+}
+
+@keyframes fadeIn {
+ 0% {
+ opacity: 0;
+ }
+
+ 100% {
+ opacity: 1;
+ }
+}
+
+@keyframes load3 {
+ 0% {
+ transform: rotate(0deg);
+ }
+
+ 100% {
+ transform: rotate(360deg);
+ }
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) 2014-2017, Jupyter Development Team.
+|
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+button.jp-mod-styled {
+ font-size: var(--jp-ui-font-size1);
+ color: var(--jp-ui-font-color0);
+ border: none;
+ box-sizing: border-box;
+ text-align: center;
+ line-height: 32px;
+ height: 32px;
+ padding: 0 12px;
+ letter-spacing: 0.8px;
+ outline: none;
+ appearance: none;
+ -webkit-appearance: none;
+ -moz-appearance: none;
+}
+
+input.jp-mod-styled {
+ background: var(--jp-input-background);
+ height: 28px;
+ box-sizing: border-box;
+ border: var(--jp-border-width) solid var(--jp-border-color1);
+ padding-left: 7px;
+ padding-right: 7px;
+ font-size: var(--jp-ui-font-size2);
+ color: var(--jp-ui-font-color0);
+ outline: none;
+ appearance: none;
+ -webkit-appearance: none;
+ -moz-appearance: none;
+}
+
+input[type='checkbox'].jp-mod-styled {
+ appearance: checkbox;
+ -webkit-appearance: checkbox;
+ -moz-appearance: checkbox;
+ height: auto;
+}
+
+input.jp-mod-styled:focus {
+ border: var(--jp-border-width) solid var(--md-blue-500);
+ box-shadow: inset 0 0 4px var(--md-blue-300);
+}
+
+.jp-select-wrapper {
+ display: flex;
+ position: relative;
+ flex-direction: column;
+ padding: 1px;
+ background-color: var(--jp-layout-color1);
+ box-sizing: border-box;
+ margin-bottom: 12px;
+}
+
+.jp-select-wrapper:not(.multiple) {
+ height: 28px;
+}
+
+.jp-select-wrapper.jp-mod-focused select.jp-mod-styled {
+ border: var(--jp-border-width) solid var(--jp-input-active-border-color);
+ box-shadow: var(--jp-input-box-shadow);
+ background-color: var(--jp-input-active-background);
+}
+
+select.jp-mod-styled:hover {
+ cursor: pointer;
+ color: var(--jp-ui-font-color0);
+ background-color: var(--jp-input-hover-background);
+ box-shadow: inset 0 0 1px rgba(0, 0, 0, 0.5);
+}
+
+select.jp-mod-styled {
+ flex: 1 1 auto;
+ width: 100%;
+ font-size: var(--jp-ui-font-size2);
+ background: var(--jp-input-background);
+ color: var(--jp-ui-font-color0);
+ padding: 0 25px 0 8px;
+ border: var(--jp-border-width) solid var(--jp-input-border-color);
+ border-radius: 0;
+ outline: none;
+ appearance: none;
+ -webkit-appearance: none;
+ -moz-appearance: none;
+}
+
+select.jp-mod-styled:not([multiple]) {
+ height: 32px;
+}
+
+select.jp-mod-styled[multiple] {
+ max-height: 200px;
+ overflow-y: auto;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+.jp-switch {
+ display: flex;
+ align-items: center;
+ padding-left: 4px;
+ padding-right: 4px;
+ font-size: var(--jp-ui-font-size1);
+ background-color: transparent;
+ color: var(--jp-ui-font-color1);
+ border: none;
+ height: 20px;
+}
+
+.jp-switch:hover {
+ background-color: var(--jp-layout-color2);
+}
+
+.jp-switch-label {
+ margin-right: 5px;
+ font-family: var(--jp-ui-font-family);
+}
+
+.jp-switch-track {
+ cursor: pointer;
+ background-color: var(--jp-switch-color, var(--jp-border-color1));
+ -webkit-transition: 0.4s;
+ transition: 0.4s;
+ border-radius: 34px;
+ height: 16px;
+ width: 35px;
+ position: relative;
+}
+
+.jp-switch-track::before {
+ content: '';
+ position: absolute;
+ height: 10px;
+ width: 10px;
+ margin: 3px;
+ left: 0;
+ background-color: var(--jp-ui-inverse-font-color1);
+ -webkit-transition: 0.4s;
+ transition: 0.4s;
+ border-radius: 50%;
+}
+
+.jp-switch[aria-checked='true'] .jp-switch-track {
+ background-color: var(--jp-switch-true-position-color, var(--jp-warn-color0));
+}
+
+.jp-switch[aria-checked='true'] .jp-switch-track::before {
+ /* track width (35) - margins (3 + 3) - thumb width (10) */
+ left: 19px;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) 2014-2016, Jupyter Development Team.
+|
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+:root {
+ --jp-private-toolbar-height: calc(
+ 28px + var(--jp-border-width)
+ ); /* leave 28px for content */
+}
+
+.jp-Toolbar {
+ color: var(--jp-ui-font-color1);
+ flex: 0 0 auto;
+ display: flex;
+ flex-direction: row;
+ border-bottom: var(--jp-border-width) solid var(--jp-toolbar-border-color);
+ box-shadow: var(--jp-toolbar-box-shadow);
+ background: var(--jp-toolbar-background);
+ min-height: var(--jp-toolbar-micro-height);
+ padding: 2px;
+ z-index: 8;
+ overflow-x: hidden;
+}
+
+/* Toolbar items */
+
+.jp-Toolbar > .jp-Toolbar-item.jp-Toolbar-spacer {
+ flex-grow: 1;
+ flex-shrink: 1;
+}
+
+.jp-Toolbar-item.jp-Toolbar-kernelStatus {
+ display: inline-block;
+ width: 32px;
+ background-repeat: no-repeat;
+ background-position: center;
+ background-size: 16px;
+}
+
+.jp-Toolbar > .jp-Toolbar-item {
+ flex: 0 0 auto;
+ display: flex;
+ padding-left: 1px;
+ padding-right: 1px;
+ font-size: var(--jp-ui-font-size1);
+ line-height: var(--jp-private-toolbar-height);
+ height: 100%;
+}
+
+/* Toolbar buttons */
+
+/* This is the div we use to wrap the react component into a Widget */
+div.jp-ToolbarButton {
+ color: transparent;
+ border: none;
+ box-sizing: border-box;
+ outline: none;
+ appearance: none;
+ -webkit-appearance: none;
+ -moz-appearance: none;
+ padding: 0;
+ margin: 0;
+}
+
+button.jp-ToolbarButtonComponent {
+ background: var(--jp-layout-color1);
+ border: none;
+ box-sizing: border-box;
+ outline: none;
+ appearance: none;
+ -webkit-appearance: none;
+ -moz-appearance: none;
+ padding: 0 6px;
+ margin: 0;
+ height: 24px;
+ border-radius: var(--jp-border-radius);
+ display: flex;
+ align-items: center;
+ text-align: center;
+ font-size: 14px;
+ min-width: unset;
+ min-height: unset;
+}
+
+button.jp-ToolbarButtonComponent:disabled {
+ opacity: 0.4;
+}
+
+button.jp-ToolbarButtonComponent > span {
+ padding: 0;
+ flex: 0 0 auto;
+}
+
+button.jp-ToolbarButtonComponent .jp-ToolbarButtonComponent-label {
+ font-size: var(--jp-ui-font-size1);
+ line-height: 100%;
+ padding-left: 2px;
+ color: var(--jp-ui-font-color1);
+ font-family: var(--jp-ui-font-family);
+}
+
+#jp-main-dock-panel[data-mode='single-document']
+ .jp-MainAreaWidget
+ > .jp-Toolbar.jp-Toolbar-micro {
+ padding: 0;
+ min-height: 0;
+}
+
+#jp-main-dock-panel[data-mode='single-document']
+ .jp-MainAreaWidget
+ > .jp-Toolbar {
+ border: none;
+ box-shadow: none;
+}
+
+/*
+ * Copyright (c) Jupyter Development Team.
+ * Distributed under the terms of the Modified BSD License.
+ */
+
+.jp-WindowedPanel-outer {
+ position: relative;
+ overflow-y: auto;
+}
+
+.jp-WindowedPanel-inner {
+ position: relative;
+}
+
+.jp-WindowedPanel-window {
+ position: absolute;
+ left: 0;
+ right: 0;
+ overflow: visible;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/* Sibling imports */
+
+body {
+ color: var(--jp-ui-font-color1);
+ font-size: var(--jp-ui-font-size1);
+}
+
+/* Disable native link decoration styles everywhere outside of dialog boxes */
+a {
+ text-decoration: unset;
+ color: unset;
+}
+
+a:hover {
+ text-decoration: unset;
+ color: unset;
+}
+
+/* Accessibility for links inside dialog box text */
+.jp-Dialog-content a {
+ text-decoration: revert;
+ color: var(--jp-content-link-color);
+}
+
+.jp-Dialog-content a:hover {
+ text-decoration: revert;
+}
+
+/* Styles for ui-components */
+.jp-Button {
+ color: var(--jp-ui-font-color2);
+ border-radius: var(--jp-border-radius);
+ padding: 0 12px;
+ font-size: var(--jp-ui-font-size1);
+
+ /* Copy from blueprint 3 */
+ display: inline-flex;
+ flex-direction: row;
+ border: none;
+ cursor: pointer;
+ align-items: center;
+ justify-content: center;
+ text-align: left;
+ vertical-align: middle;
+ min-height: 30px;
+ min-width: 30px;
+}
+
+.jp-Button:disabled {
+ cursor: not-allowed;
+}
+
+.jp-Button:empty {
+ padding: 0 !important;
+}
+
+.jp-Button.jp-mod-small {
+ min-height: 24px;
+ min-width: 24px;
+ font-size: 12px;
+ padding: 0 7px;
+}
+
+/* Use our own theme for hover styles */
+.jp-Button.jp-mod-minimal:hover {
+ background-color: var(--jp-layout-color2);
+}
+
+.jp-Button.jp-mod-minimal {
+ background: none;
+}
+
+.jp-InputGroup {
+ display: block;
+ position: relative;
+}
+
+.jp-InputGroup input {
+ box-sizing: border-box;
+ border: none;
+ border-radius: 0;
+ background-color: transparent;
+ color: var(--jp-ui-font-color0);
+ box-shadow: inset 0 0 0 var(--jp-border-width) var(--jp-input-border-color);
+ padding-bottom: 0;
+ padding-top: 0;
+ padding-left: 10px;
+ padding-right: 28px;
+ position: relative;
+ width: 100%;
+ -webkit-appearance: none;
+ -moz-appearance: none;
+ appearance: none;
+ font-size: 14px;
+ font-weight: 400;
+ height: 30px;
+ line-height: 30px;
+ outline: none;
+ vertical-align: middle;
+}
+
+.jp-InputGroup input:focus {
+ box-shadow: inset 0 0 0 var(--jp-border-width)
+ var(--jp-input-active-box-shadow-color),
+ inset 0 0 0 3px var(--jp-input-active-box-shadow-color);
+}
+
+.jp-InputGroup input:disabled {
+ cursor: not-allowed;
+ resize: block;
+ background-color: var(--jp-layout-color2);
+ color: var(--jp-ui-font-color2);
+}
+
+.jp-InputGroup input:disabled ~ span {
+ cursor: not-allowed;
+ color: var(--jp-ui-font-color2);
+}
+
+.jp-InputGroup input::placeholder,
+input::placeholder {
+ color: var(--jp-ui-font-color2);
+}
+
+.jp-InputGroupAction {
+ position: absolute;
+ bottom: 1px;
+ right: 0;
+ padding: 6px;
+}
+
+.jp-HTMLSelect.jp-DefaultStyle select {
+ background-color: initial;
+ border: none;
+ border-radius: 0;
+ box-shadow: none;
+ color: var(--jp-ui-font-color0);
+ display: block;
+ font-size: var(--jp-ui-font-size1);
+ font-family: var(--jp-ui-font-family);
+ height: 24px;
+ line-height: 14px;
+ padding: 0 25px 0 10px;
+ text-align: left;
+ -moz-appearance: none;
+ -webkit-appearance: none;
+}
+
+.jp-HTMLSelect.jp-DefaultStyle select:disabled {
+ background-color: var(--jp-layout-color2);
+ color: var(--jp-ui-font-color2);
+ cursor: not-allowed;
+ resize: block;
+}
+
+.jp-HTMLSelect.jp-DefaultStyle select:disabled ~ span {
+ cursor: not-allowed;
+}
+
+/* Use our own theme for hover and option styles */
+/* stylelint-disable-next-line selector-max-type */
+.jp-HTMLSelect.jp-DefaultStyle select:hover,
+.jp-HTMLSelect.jp-DefaultStyle select > option {
+ background-color: var(--jp-layout-color2);
+ color: var(--jp-ui-font-color0);
+}
+
+select {
+ box-sizing: border-box;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/*-----------------------------------------------------------------------------
+| Styles
+|----------------------------------------------------------------------------*/
+
+.jp-StatusBar-Widget {
+ display: flex;
+ align-items: center;
+ background: var(--jp-layout-color2);
+ min-height: var(--jp-statusbar-height);
+ justify-content: space-between;
+ padding: 0 10px;
+}
+
+.jp-StatusBar-Left {
+ display: flex;
+ align-items: center;
+ flex-direction: row;
+}
+
+.jp-StatusBar-Middle {
+ display: flex;
+ align-items: center;
+}
+
+.jp-StatusBar-Right {
+ display: flex;
+ align-items: center;
+ flex-direction: row-reverse;
+}
+
+.jp-StatusBar-Item {
+ max-height: var(--jp-statusbar-height);
+ margin: 0 2px;
+ height: var(--jp-statusbar-height);
+ white-space: nowrap;
+ text-overflow: ellipsis;
+ color: var(--jp-ui-font-color1);
+ padding: 0 6px;
+}
+
+.jp-mod-highlighted:hover {
+ background-color: var(--jp-layout-color3);
+}
+
+.jp-mod-clicked {
+ background-color: var(--jp-brand-color1);
+}
+
+.jp-mod-clicked:hover {
+ background-color: var(--jp-brand-color0);
+}
+
+.jp-mod-clicked .jp-StatusBar-TextItem {
+ color: var(--jp-ui-inverse-font-color1);
+}
+
+.jp-StatusBar-HoverItem {
+ box-shadow: '0px 4px 4px rgba(0, 0, 0, 0.25)';
+}
+
+.jp-StatusBar-TextItem {
+ font-size: var(--jp-ui-font-size1);
+ font-family: var(--jp-ui-font-family);
+ line-height: 24px;
+ color: var(--jp-ui-font-color1);
+}
+
+.jp-StatusBar-GroupItem {
+ display: flex;
+ align-items: center;
+ flex-direction: row;
+}
+
+.jp-Statusbar-ProgressCircle svg {
+ display: block;
+ margin: 0 auto;
+ width: 16px;
+ height: 24px;
+ align-self: normal;
+}
+
+.jp-Statusbar-ProgressCircle path {
+ fill: var(--jp-inverse-layout-color3);
+}
+
+.jp-Statusbar-ProgressBar-progress-bar {
+ height: 10px;
+ width: 100px;
+ border: solid 0.25px var(--jp-brand-color2);
+ border-radius: 3px;
+ overflow: hidden;
+ align-self: center;
+}
+
+.jp-Statusbar-ProgressBar-progress-bar > div {
+ background-color: var(--jp-brand-color2);
+ background-image: linear-gradient(
+ -45deg,
+ rgba(255, 255, 255, 0.2) 25%,
+ transparent 25%,
+ transparent 50%,
+ rgba(255, 255, 255, 0.2) 50%,
+ rgba(255, 255, 255, 0.2) 75%,
+ transparent 75%,
+ transparent
+ );
+ background-size: 40px 40px;
+ float: left;
+ width: 0%;
+ height: 100%;
+ font-size: 12px;
+ line-height: 14px;
+ color: #fff;
+ text-align: center;
+ animation: jp-Statusbar-ExecutionTime-progress-bar 2s linear infinite;
+}
+
+.jp-Statusbar-ProgressBar-progress-bar p {
+ color: var(--jp-ui-font-color1);
+ font-family: var(--jp-ui-font-family);
+ font-size: var(--jp-ui-font-size1);
+ line-height: 10px;
+ width: 100px;
+}
+
+@keyframes jp-Statusbar-ExecutionTime-progress-bar {
+ 0% {
+ background-position: 0 0;
+ }
+
+ 100% {
+ background-position: 40px 40px;
+ }
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/*-----------------------------------------------------------------------------
+| Variables
+|----------------------------------------------------------------------------*/
+
+:root {
+ --jp-private-commandpalette-search-height: 28px;
+}
+
+/*-----------------------------------------------------------------------------
+| Overall styles
+|----------------------------------------------------------------------------*/
+
+.lm-CommandPalette {
+ padding-bottom: 0;
+ color: var(--jp-ui-font-color1);
+ background: var(--jp-layout-color1);
+
+ /* This is needed so that all font sizing of children done in ems is
+ * relative to this base size */
+ font-size: var(--jp-ui-font-size1);
+}
+
+/*-----------------------------------------------------------------------------
+| Modal variant
+|----------------------------------------------------------------------------*/
+
+.jp-ModalCommandPalette {
+ position: absolute;
+ z-index: 10000;
+ top: 38px;
+ left: 30%;
+ margin: 0;
+ padding: 4px;
+ width: 40%;
+ box-shadow: var(--jp-elevation-z4);
+ border-radius: 4px;
+ background: var(--jp-layout-color0);
+}
+
+.jp-ModalCommandPalette .lm-CommandPalette {
+ max-height: 40vh;
+}
+
+.jp-ModalCommandPalette .lm-CommandPalette .lm-close-icon::after {
+ display: none;
+}
+
+.jp-ModalCommandPalette .lm-CommandPalette .lm-CommandPalette-header {
+ display: none;
+}
+
+.jp-ModalCommandPalette .lm-CommandPalette .lm-CommandPalette-item {
+ margin-left: 4px;
+ margin-right: 4px;
+}
+
+.jp-ModalCommandPalette
+ .lm-CommandPalette
+ .lm-CommandPalette-item.lm-mod-disabled {
+ display: none;
+}
+
+/*-----------------------------------------------------------------------------
+| Search
+|----------------------------------------------------------------------------*/
+
+.lm-CommandPalette-search {
+ padding: 4px;
+ background-color: var(--jp-layout-color1);
+ z-index: 2;
+}
+
+.lm-CommandPalette-wrapper {
+ overflow: overlay;
+ padding: 0 9px;
+ background-color: var(--jp-input-active-background);
+ height: 30px;
+ box-shadow: inset 0 0 0 var(--jp-border-width) var(--jp-input-border-color);
+}
+
+.lm-CommandPalette.lm-mod-focused .lm-CommandPalette-wrapper {
+ box-shadow: inset 0 0 0 1px var(--jp-input-active-box-shadow-color),
+ inset 0 0 0 3px var(--jp-input-active-box-shadow-color);
+}
+
+.jp-SearchIconGroup {
+ color: white;
+ background-color: var(--jp-brand-color1);
+ position: absolute;
+ top: 4px;
+ right: 4px;
+ padding: 5px 5px 1px;
+}
+
+.jp-SearchIconGroup svg {
+ height: 20px;
+ width: 20px;
+}
+
+.jp-SearchIconGroup .jp-icon3[fill] {
+ fill: var(--jp-layout-color0);
+}
+
+.lm-CommandPalette-input {
+ background: transparent;
+ width: calc(100% - 18px);
+ float: left;
+ border: none;
+ outline: none;
+ font-size: var(--jp-ui-font-size1);
+ color: var(--jp-ui-font-color0);
+ line-height: var(--jp-private-commandpalette-search-height);
+}
+
+.lm-CommandPalette-input::-webkit-input-placeholder,
+.lm-CommandPalette-input::-moz-placeholder,
+.lm-CommandPalette-input:-ms-input-placeholder {
+ color: var(--jp-ui-font-color2);
+ font-size: var(--jp-ui-font-size1);
+}
+
+/*-----------------------------------------------------------------------------
+| Results
+|----------------------------------------------------------------------------*/
+
+.lm-CommandPalette-header:first-child {
+ margin-top: 0;
+}
+
+.lm-CommandPalette-header {
+ border-bottom: solid var(--jp-border-width) var(--jp-border-color2);
+ color: var(--jp-ui-font-color1);
+ cursor: pointer;
+ display: flex;
+ font-size: var(--jp-ui-font-size0);
+ font-weight: 600;
+ letter-spacing: 1px;
+ margin-top: 8px;
+ padding: 8px 0 8px 12px;
+ text-transform: uppercase;
+}
+
+.lm-CommandPalette-header.lm-mod-active {
+ background: var(--jp-layout-color2);
+}
+
+.lm-CommandPalette-header > mark {
+ background-color: transparent;
+ font-weight: bold;
+ color: var(--jp-ui-font-color1);
+}
+
+.lm-CommandPalette-item {
+ padding: 4px 12px 4px 4px;
+ color: var(--jp-ui-font-color1);
+ font-size: var(--jp-ui-font-size1);
+ font-weight: 400;
+ display: flex;
+}
+
+.lm-CommandPalette-item.lm-mod-disabled {
+ color: var(--jp-ui-font-color2);
+}
+
+.lm-CommandPalette-item.lm-mod-active {
+ color: var(--jp-ui-inverse-font-color1);
+ background: var(--jp-brand-color1);
+}
+
+.lm-CommandPalette-item.lm-mod-active .lm-CommandPalette-itemLabel > mark {
+ color: var(--jp-ui-inverse-font-color0);
+}
+
+.lm-CommandPalette-item.lm-mod-active .jp-icon-selectable[fill] {
+ fill: var(--jp-layout-color0);
+}
+
+.lm-CommandPalette-item.lm-mod-active:hover:not(.lm-mod-disabled) {
+ color: var(--jp-ui-inverse-font-color1);
+ background: var(--jp-brand-color1);
+}
+
+.lm-CommandPalette-item:hover:not(.lm-mod-active):not(.lm-mod-disabled) {
+ background: var(--jp-layout-color2);
+}
+
+.lm-CommandPalette-itemContent {
+ overflow: hidden;
+}
+
+.lm-CommandPalette-itemLabel > mark {
+ color: var(--jp-ui-font-color0);
+ background-color: transparent;
+ font-weight: bold;
+}
+
+.lm-CommandPalette-item.lm-mod-disabled mark {
+ color: var(--jp-ui-font-color2);
+}
+
+.lm-CommandPalette-item .lm-CommandPalette-itemIcon {
+ margin: 0 4px 0 0;
+ position: relative;
+ width: 16px;
+ top: 2px;
+ flex: 0 0 auto;
+}
+
+.lm-CommandPalette-item.lm-mod-disabled .lm-CommandPalette-itemIcon {
+ opacity: 0.6;
+}
+
+.lm-CommandPalette-item .lm-CommandPalette-itemShortcut {
+ flex: 0 0 auto;
+}
+
+.lm-CommandPalette-itemCaption {
+ display: none;
+}
+
+.lm-CommandPalette-content {
+ background-color: var(--jp-layout-color1);
+}
+
+.lm-CommandPalette-content:empty::after {
+ content: 'No results';
+ margin: auto;
+ margin-top: 20px;
+ width: 100px;
+ display: block;
+ font-size: var(--jp-ui-font-size2);
+ font-family: var(--jp-ui-font-family);
+ font-weight: lighter;
+}
+
+.lm-CommandPalette-emptyMessage {
+ text-align: center;
+ margin-top: 24px;
+ line-height: 1.32;
+ padding: 0 8px;
+ color: var(--jp-content-font-color3);
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) 2014-2017, Jupyter Development Team.
+|
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+.jp-Dialog {
+ position: absolute;
+ z-index: 10000;
+ display: flex;
+ flex-direction: column;
+ align-items: center;
+ justify-content: center;
+ top: 0;
+ left: 0;
+ margin: 0;
+ padding: 0;
+ width: 100%;
+ height: 100%;
+ background: var(--jp-dialog-background);
+}
+
+.jp-Dialog-content {
+ display: flex;
+ flex-direction: column;
+ margin-left: auto;
+ margin-right: auto;
+ background: var(--jp-layout-color1);
+ padding: 24px 24px 12px;
+ min-width: 300px;
+ min-height: 150px;
+ max-width: 1000px;
+ max-height: 500px;
+ box-sizing: border-box;
+ box-shadow: var(--jp-elevation-z20);
+ word-wrap: break-word;
+ border-radius: var(--jp-border-radius);
+
+ /* This is needed so that all font sizing of children done in ems is
+ * relative to this base size */
+ font-size: var(--jp-ui-font-size1);
+ color: var(--jp-ui-font-color1);
+ resize: both;
+}
+
+.jp-Dialog-content.jp-Dialog-content-small {
+ max-width: 500px;
+}
+
+.jp-Dialog-button {
+ overflow: visible;
+}
+
+button.jp-Dialog-button:focus {
+ outline: 1px solid var(--jp-brand-color1);
+ outline-offset: 4px;
+ -moz-outline-radius: 0;
+}
+
+button.jp-Dialog-button:focus::-moz-focus-inner {
+ border: 0;
+}
+
+button.jp-Dialog-button.jp-mod-styled.jp-mod-accept:focus,
+button.jp-Dialog-button.jp-mod-styled.jp-mod-warn:focus,
+button.jp-Dialog-button.jp-mod-styled.jp-mod-reject:focus {
+ outline-offset: 4px;
+ -moz-outline-radius: 0;
+}
+
+button.jp-Dialog-button.jp-mod-styled.jp-mod-accept:focus {
+ outline: 1px solid var(--jp-accept-color-normal, var(--jp-brand-color1));
+}
+
+button.jp-Dialog-button.jp-mod-styled.jp-mod-warn:focus {
+ outline: 1px solid var(--jp-warn-color-normal, var(--jp-error-color1));
+}
+
+button.jp-Dialog-button.jp-mod-styled.jp-mod-reject:focus {
+ outline: 1px solid var(--jp-reject-color-normal, var(--md-grey-600));
+}
+
+button.jp-Dialog-close-button {
+ padding: 0;
+ height: 100%;
+ min-width: unset;
+ min-height: unset;
+}
+
+.jp-Dialog-header {
+ display: flex;
+ justify-content: space-between;
+ flex: 0 0 auto;
+ padding-bottom: 12px;
+ font-size: var(--jp-ui-font-size3);
+ font-weight: 400;
+ color: var(--jp-ui-font-color1);
+}
+
+.jp-Dialog-body {
+ display: flex;
+ flex-direction: column;
+ flex: 1 1 auto;
+ font-size: var(--jp-ui-font-size1);
+ background: var(--jp-layout-color1);
+ color: var(--jp-ui-font-color1);
+ overflow: auto;
+}
+
+.jp-Dialog-footer {
+ display: flex;
+ flex-direction: row;
+ justify-content: flex-end;
+ align-items: center;
+ flex: 0 0 auto;
+ margin-left: -12px;
+ margin-right: -12px;
+ padding: 12px;
+}
+
+.jp-Dialog-checkbox {
+ padding-right: 5px;
+}
+
+.jp-Dialog-checkbox > input:focus-visible {
+ outline: 1px solid var(--jp-input-active-border-color);
+ outline-offset: 1px;
+}
+
+.jp-Dialog-spacer {
+ flex: 1 1 auto;
+}
+
+.jp-Dialog-title {
+ overflow: hidden;
+ white-space: nowrap;
+ text-overflow: ellipsis;
+}
+
+.jp-Dialog-body > .jp-select-wrapper {
+ width: 100%;
+}
+
+.jp-Dialog-body > button {
+ padding: 0 16px;
+}
+
+.jp-Dialog-body > label {
+ line-height: 1.4;
+ color: var(--jp-ui-font-color0);
+}
+
+.jp-Dialog-button.jp-mod-styled:not(:last-child) {
+ margin-right: 12px;
+}
+
+/*
+ * Copyright (c) Jupyter Development Team.
+ * Distributed under the terms of the Modified BSD License.
+ */
+
+.jp-Input-Boolean-Dialog {
+ flex-direction: row-reverse;
+ align-items: end;
+ width: 100%;
+}
+
+.jp-Input-Boolean-Dialog > label {
+ flex: 1 1 auto;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) 2014-2016, Jupyter Development Team.
+|
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+.jp-MainAreaWidget > :focus {
+ outline: none;
+}
+
+.jp-MainAreaWidget .jp-MainAreaWidget-error {
+ padding: 6px;
+}
+
+.jp-MainAreaWidget .jp-MainAreaWidget-error > pre {
+ width: auto;
+ padding: 10px;
+ background: var(--jp-error-color3);
+ border: var(--jp-border-width) solid var(--jp-error-color1);
+ border-radius: var(--jp-border-radius);
+ color: var(--jp-ui-font-color1);
+ font-size: var(--jp-ui-font-size1);
+ white-space: pre-wrap;
+ word-wrap: break-word;
+}
+
+/*
+ * Copyright (c) Jupyter Development Team.
+ * Distributed under the terms of the Modified BSD License.
+ */
+
+/**
+ * google-material-color v1.2.6
+ * https://github.com/danlevan/google-material-color
+ */
+:root {
+ --md-red-50: #ffebee;
+ --md-red-100: #ffcdd2;
+ --md-red-200: #ef9a9a;
+ --md-red-300: #e57373;
+ --md-red-400: #ef5350;
+ --md-red-500: #f44336;
+ --md-red-600: #e53935;
+ --md-red-700: #d32f2f;
+ --md-red-800: #c62828;
+ --md-red-900: #b71c1c;
+ --md-red-A100: #ff8a80;
+ --md-red-A200: #ff5252;
+ --md-red-A400: #ff1744;
+ --md-red-A700: #d50000;
+ --md-pink-50: #fce4ec;
+ --md-pink-100: #f8bbd0;
+ --md-pink-200: #f48fb1;
+ --md-pink-300: #f06292;
+ --md-pink-400: #ec407a;
+ --md-pink-500: #e91e63;
+ --md-pink-600: #d81b60;
+ --md-pink-700: #c2185b;
+ --md-pink-800: #ad1457;
+ --md-pink-900: #880e4f;
+ --md-pink-A100: #ff80ab;
+ --md-pink-A200: #ff4081;
+ --md-pink-A400: #f50057;
+ --md-pink-A700: #c51162;
+ --md-purple-50: #f3e5f5;
+ --md-purple-100: #e1bee7;
+ --md-purple-200: #ce93d8;
+ --md-purple-300: #ba68c8;
+ --md-purple-400: #ab47bc;
+ --md-purple-500: #9c27b0;
+ --md-purple-600: #8e24aa;
+ --md-purple-700: #7b1fa2;
+ --md-purple-800: #6a1b9a;
+ --md-purple-900: #4a148c;
+ --md-purple-A100: #ea80fc;
+ --md-purple-A200: #e040fb;
+ --md-purple-A400: #d500f9;
+ --md-purple-A700: #a0f;
+ --md-deep-purple-50: #ede7f6;
+ --md-deep-purple-100: #d1c4e9;
+ --md-deep-purple-200: #b39ddb;
+ --md-deep-purple-300: #9575cd;
+ --md-deep-purple-400: #7e57c2;
+ --md-deep-purple-500: #673ab7;
+ --md-deep-purple-600: #5e35b1;
+ --md-deep-purple-700: #512da8;
+ --md-deep-purple-800: #4527a0;
+ --md-deep-purple-900: #311b92;
+ --md-deep-purple-A100: #b388ff;
+ --md-deep-purple-A200: #7c4dff;
+ --md-deep-purple-A400: #651fff;
+ --md-deep-purple-A700: #6200ea;
+ --md-indigo-50: #e8eaf6;
+ --md-indigo-100: #c5cae9;
+ --md-indigo-200: #9fa8da;
+ --md-indigo-300: #7986cb;
+ --md-indigo-400: #5c6bc0;
+ --md-indigo-500: #3f51b5;
+ --md-indigo-600: #3949ab;
+ --md-indigo-700: #303f9f;
+ --md-indigo-800: #283593;
+ --md-indigo-900: #1a237e;
+ --md-indigo-A100: #8c9eff;
+ --md-indigo-A200: #536dfe;
+ --md-indigo-A400: #3d5afe;
+ --md-indigo-A700: #304ffe;
+ --md-blue-50: #e3f2fd;
+ --md-blue-100: #bbdefb;
+ --md-blue-200: #90caf9;
+ --md-blue-300: #64b5f6;
+ --md-blue-400: #42a5f5;
+ --md-blue-500: #2196f3;
+ --md-blue-600: #1e88e5;
+ --md-blue-700: #1976d2;
+ --md-blue-800: #1565c0;
+ --md-blue-900: #0d47a1;
+ --md-blue-A100: #82b1ff;
+ --md-blue-A200: #448aff;
+ --md-blue-A400: #2979ff;
+ --md-blue-A700: #2962ff;
+ --md-light-blue-50: #e1f5fe;
+ --md-light-blue-100: #b3e5fc;
+ --md-light-blue-200: #81d4fa;
+ --md-light-blue-300: #4fc3f7;
+ --md-light-blue-400: #29b6f6;
+ --md-light-blue-500: #03a9f4;
+ --md-light-blue-600: #039be5;
+ --md-light-blue-700: #0288d1;
+ --md-light-blue-800: #0277bd;
+ --md-light-blue-900: #01579b;
+ --md-light-blue-A100: #80d8ff;
+ --md-light-blue-A200: #40c4ff;
+ --md-light-blue-A400: #00b0ff;
+ --md-light-blue-A700: #0091ea;
+ --md-cyan-50: #e0f7fa;
+ --md-cyan-100: #b2ebf2;
+ --md-cyan-200: #80deea;
+ --md-cyan-300: #4dd0e1;
+ --md-cyan-400: #26c6da;
+ --md-cyan-500: #00bcd4;
+ --md-cyan-600: #00acc1;
+ --md-cyan-700: #0097a7;
+ --md-cyan-800: #00838f;
+ --md-cyan-900: #006064;
+ --md-cyan-A100: #84ffff;
+ --md-cyan-A200: #18ffff;
+ --md-cyan-A400: #00e5ff;
+ --md-cyan-A700: #00b8d4;
+ --md-teal-50: #e0f2f1;
+ --md-teal-100: #b2dfdb;
+ --md-teal-200: #80cbc4;
+ --md-teal-300: #4db6ac;
+ --md-teal-400: #26a69a;
+ --md-teal-500: #009688;
+ --md-teal-600: #00897b;
+ --md-teal-700: #00796b;
+ --md-teal-800: #00695c;
+ --md-teal-900: #004d40;
+ --md-teal-A100: #a7ffeb;
+ --md-teal-A200: #64ffda;
+ --md-teal-A400: #1de9b6;
+ --md-teal-A700: #00bfa5;
+ --md-green-50: #e8f5e9;
+ --md-green-100: #c8e6c9;
+ --md-green-200: #a5d6a7;
+ --md-green-300: #81c784;
+ --md-green-400: #66bb6a;
+ --md-green-500: #4caf50;
+ --md-green-600: #43a047;
+ --md-green-700: #388e3c;
+ --md-green-800: #2e7d32;
+ --md-green-900: #1b5e20;
+ --md-green-A100: #b9f6ca;
+ --md-green-A200: #69f0ae;
+ --md-green-A400: #00e676;
+ --md-green-A700: #00c853;
+ --md-light-green-50: #f1f8e9;
+ --md-light-green-100: #dcedc8;
+ --md-light-green-200: #c5e1a5;
+ --md-light-green-300: #aed581;
+ --md-light-green-400: #9ccc65;
+ --md-light-green-500: #8bc34a;
+ --md-light-green-600: #7cb342;
+ --md-light-green-700: #689f38;
+ --md-light-green-800: #558b2f;
+ --md-light-green-900: #33691e;
+ --md-light-green-A100: #ccff90;
+ --md-light-green-A200: #b2ff59;
+ --md-light-green-A400: #76ff03;
+ --md-light-green-A700: #64dd17;
+ --md-lime-50: #f9fbe7;
+ --md-lime-100: #f0f4c3;
+ --md-lime-200: #e6ee9c;
+ --md-lime-300: #dce775;
+ --md-lime-400: #d4e157;
+ --md-lime-500: #cddc39;
+ --md-lime-600: #c0ca33;
+ --md-lime-700: #afb42b;
+ --md-lime-800: #9e9d24;
+ --md-lime-900: #827717;
+ --md-lime-A100: #f4ff81;
+ --md-lime-A200: #eeff41;
+ --md-lime-A400: #c6ff00;
+ --md-lime-A700: #aeea00;
+ --md-yellow-50: #fffde7;
+ --md-yellow-100: #fff9c4;
+ --md-yellow-200: #fff59d;
+ --md-yellow-300: #fff176;
+ --md-yellow-400: #ffee58;
+ --md-yellow-500: #ffeb3b;
+ --md-yellow-600: #fdd835;
+ --md-yellow-700: #fbc02d;
+ --md-yellow-800: #f9a825;
+ --md-yellow-900: #f57f17;
+ --md-yellow-A100: #ffff8d;
+ --md-yellow-A200: #ff0;
+ --md-yellow-A400: #ffea00;
+ --md-yellow-A700: #ffd600;
+ --md-amber-50: #fff8e1;
+ --md-amber-100: #ffecb3;
+ --md-amber-200: #ffe082;
+ --md-amber-300: #ffd54f;
+ --md-amber-400: #ffca28;
+ --md-amber-500: #ffc107;
+ --md-amber-600: #ffb300;
+ --md-amber-700: #ffa000;
+ --md-amber-800: #ff8f00;
+ --md-amber-900: #ff6f00;
+ --md-amber-A100: #ffe57f;
+ --md-amber-A200: #ffd740;
+ --md-amber-A400: #ffc400;
+ --md-amber-A700: #ffab00;
+ --md-orange-50: #fff3e0;
+ --md-orange-100: #ffe0b2;
+ --md-orange-200: #ffcc80;
+ --md-orange-300: #ffb74d;
+ --md-orange-400: #ffa726;
+ --md-orange-500: #ff9800;
+ --md-orange-600: #fb8c00;
+ --md-orange-700: #f57c00;
+ --md-orange-800: #ef6c00;
+ --md-orange-900: #e65100;
+ --md-orange-A100: #ffd180;
+ --md-orange-A200: #ffab40;
+ --md-orange-A400: #ff9100;
+ --md-orange-A700: #ff6d00;
+ --md-deep-orange-50: #fbe9e7;
+ --md-deep-orange-100: #ffccbc;
+ --md-deep-orange-200: #ffab91;
+ --md-deep-orange-300: #ff8a65;
+ --md-deep-orange-400: #ff7043;
+ --md-deep-orange-500: #ff5722;
+ --md-deep-orange-600: #f4511e;
+ --md-deep-orange-700: #e64a19;
+ --md-deep-orange-800: #d84315;
+ --md-deep-orange-900: #bf360c;
+ --md-deep-orange-A100: #ff9e80;
+ --md-deep-orange-A200: #ff6e40;
+ --md-deep-orange-A400: #ff3d00;
+ --md-deep-orange-A700: #dd2c00;
+ --md-brown-50: #efebe9;
+ --md-brown-100: #d7ccc8;
+ --md-brown-200: #bcaaa4;
+ --md-brown-300: #a1887f;
+ --md-brown-400: #8d6e63;
+ --md-brown-500: #795548;
+ --md-brown-600: #6d4c41;
+ --md-brown-700: #5d4037;
+ --md-brown-800: #4e342e;
+ --md-brown-900: #3e2723;
+ --md-grey-50: #fafafa;
+ --md-grey-100: #f5f5f5;
+ --md-grey-200: #eee;
+ --md-grey-300: #e0e0e0;
+ --md-grey-400: #bdbdbd;
+ --md-grey-500: #9e9e9e;
+ --md-grey-600: #757575;
+ --md-grey-700: #616161;
+ --md-grey-800: #424242;
+ --md-grey-900: #212121;
+ --md-blue-grey-50: #eceff1;
+ --md-blue-grey-100: #cfd8dc;
+ --md-blue-grey-200: #b0bec5;
+ --md-blue-grey-300: #90a4ae;
+ --md-blue-grey-400: #78909c;
+ --md-blue-grey-500: #607d8b;
+ --md-blue-grey-600: #546e7a;
+ --md-blue-grey-700: #455a64;
+ --md-blue-grey-800: #37474f;
+ --md-blue-grey-900: #263238;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) 2014-2017, Jupyter Development Team.
+|
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/*-----------------------------------------------------------------------------
+| RenderedText
+|----------------------------------------------------------------------------*/
+
+:root {
+ /* This is the padding value to fill the gaps between lines containing spans with background color. */
+ --jp-private-code-span-padding: calc(
+ (var(--jp-code-line-height) - 1) * var(--jp-code-font-size) / 2
+ );
+}
+
+.jp-RenderedText {
+ text-align: left;
+ padding-left: var(--jp-code-padding);
+ line-height: var(--jp-code-line-height);
+ font-family: var(--jp-code-font-family);
+}
+
+.jp-RenderedText pre,
+.jp-RenderedJavaScript pre,
+.jp-RenderedHTMLCommon pre {
+ color: var(--jp-content-font-color1);
+ font-size: var(--jp-code-font-size);
+ border: none;
+ margin: 0;
+ padding: 0;
+}
+
+.jp-RenderedText pre a:link {
+ text-decoration: none;
+ color: var(--jp-content-link-color);
+}
+
+.jp-RenderedText pre a:hover {
+ text-decoration: underline;
+ color: var(--jp-content-link-color);
+}
+
+.jp-RenderedText pre a:visited {
+ text-decoration: none;
+ color: var(--jp-content-link-color);
+}
+
+/* console foregrounds and backgrounds */
+.jp-RenderedText pre .ansi-black-fg {
+ color: #3e424d;
+}
+
+.jp-RenderedText pre .ansi-red-fg {
+ color: #e75c58;
+}
+
+.jp-RenderedText pre .ansi-green-fg {
+ color: #00a250;
+}
+
+.jp-RenderedText pre .ansi-yellow-fg {
+ color: #ddb62b;
+}
+
+.jp-RenderedText pre .ansi-blue-fg {
+ color: #208ffb;
+}
+
+.jp-RenderedText pre .ansi-magenta-fg {
+ color: #d160c4;
+}
+
+.jp-RenderedText pre .ansi-cyan-fg {
+ color: #60c6c8;
+}
+
+.jp-RenderedText pre .ansi-white-fg {
+ color: #c5c1b4;
+}
+
+.jp-RenderedText pre .ansi-black-bg {
+ background-color: #3e424d;
+ padding: var(--jp-private-code-span-padding) 0;
+}
+
+.jp-RenderedText pre .ansi-red-bg {
+ background-color: #e75c58;
+ padding: var(--jp-private-code-span-padding) 0;
+}
+
+.jp-RenderedText pre .ansi-green-bg {
+ background-color: #00a250;
+ padding: var(--jp-private-code-span-padding) 0;
+}
+
+.jp-RenderedText pre .ansi-yellow-bg {
+ background-color: #ddb62b;
+ padding: var(--jp-private-code-span-padding) 0;
+}
+
+.jp-RenderedText pre .ansi-blue-bg {
+ background-color: #208ffb;
+ padding: var(--jp-private-code-span-padding) 0;
+}
+
+.jp-RenderedText pre .ansi-magenta-bg {
+ background-color: #d160c4;
+ padding: var(--jp-private-code-span-padding) 0;
+}
+
+.jp-RenderedText pre .ansi-cyan-bg {
+ background-color: #60c6c8;
+ padding: var(--jp-private-code-span-padding) 0;
+}
+
+.jp-RenderedText pre .ansi-white-bg {
+ background-color: #c5c1b4;
+ padding: var(--jp-private-code-span-padding) 0;
+}
+
+.jp-RenderedText pre .ansi-black-intense-fg {
+ color: #282c36;
+}
+
+.jp-RenderedText pre .ansi-red-intense-fg {
+ color: #b22b31;
+}
+
+.jp-RenderedText pre .ansi-green-intense-fg {
+ color: #007427;
+}
+
+.jp-RenderedText pre .ansi-yellow-intense-fg {
+ color: #b27d12;
+}
+
+.jp-RenderedText pre .ansi-blue-intense-fg {
+ color: #0065ca;
+}
+
+.jp-RenderedText pre .ansi-magenta-intense-fg {
+ color: #a03196;
+}
+
+.jp-RenderedText pre .ansi-cyan-intense-fg {
+ color: #258f8f;
+}
+
+.jp-RenderedText pre .ansi-white-intense-fg {
+ color: #a1a6b2;
+}
+
+.jp-RenderedText pre .ansi-black-intense-bg {
+ background-color: #282c36;
+ padding: var(--jp-private-code-span-padding) 0;
+}
+
+.jp-RenderedText pre .ansi-red-intense-bg {
+ background-color: #b22b31;
+ padding: var(--jp-private-code-span-padding) 0;
+}
+
+.jp-RenderedText pre .ansi-green-intense-bg {
+ background-color: #007427;
+ padding: var(--jp-private-code-span-padding) 0;
+}
+
+.jp-RenderedText pre .ansi-yellow-intense-bg {
+ background-color: #b27d12;
+ padding: var(--jp-private-code-span-padding) 0;
+}
+
+.jp-RenderedText pre .ansi-blue-intense-bg {
+ background-color: #0065ca;
+ padding: var(--jp-private-code-span-padding) 0;
+}
+
+.jp-RenderedText pre .ansi-magenta-intense-bg {
+ background-color: #a03196;
+ padding: var(--jp-private-code-span-padding) 0;
+}
+
+.jp-RenderedText pre .ansi-cyan-intense-bg {
+ background-color: #258f8f;
+ padding: var(--jp-private-code-span-padding) 0;
+}
+
+.jp-RenderedText pre .ansi-white-intense-bg {
+ background-color: #a1a6b2;
+ padding: var(--jp-private-code-span-padding) 0;
+}
+
+.jp-RenderedText pre .ansi-default-inverse-fg {
+ color: var(--jp-ui-inverse-font-color0);
+}
+
+.jp-RenderedText pre .ansi-default-inverse-bg {
+ background-color: var(--jp-inverse-layout-color0);
+ padding: var(--jp-private-code-span-padding) 0;
+}
+
+.jp-RenderedText pre .ansi-bold {
+ font-weight: bold;
+}
+
+.jp-RenderedText pre .ansi-underline {
+ text-decoration: underline;
+}
+
+.jp-RenderedText[data-mime-type='application/vnd.jupyter.stderr'] {
+ background: var(--jp-rendermime-error-background);
+ padding-top: var(--jp-code-padding);
+}
+
+/*-----------------------------------------------------------------------------
+| RenderedLatex
+|----------------------------------------------------------------------------*/
+
+.jp-RenderedLatex {
+ color: var(--jp-content-font-color1);
+ font-size: var(--jp-content-font-size1);
+ line-height: var(--jp-content-line-height);
+}
+
+/* Left-justify outputs.*/
+.jp-OutputArea-output.jp-RenderedLatex {
+ padding: var(--jp-code-padding);
+ text-align: left;
+}
+
+/*-----------------------------------------------------------------------------
+| RenderedHTML
+|----------------------------------------------------------------------------*/
+
+.jp-RenderedHTMLCommon {
+ color: var(--jp-content-font-color1);
+ font-family: var(--jp-content-font-family);
+ font-size: var(--jp-content-font-size1);
+ line-height: var(--jp-content-line-height);
+
+ /* Give a bit more R padding on Markdown text to keep line lengths reasonable */
+ padding-right: 20px;
+}
+
+.jp-RenderedHTMLCommon em {
+ font-style: italic;
+}
+
+.jp-RenderedHTMLCommon strong {
+ font-weight: bold;
+}
+
+.jp-RenderedHTMLCommon u {
+ text-decoration: underline;
+}
+
+.jp-RenderedHTMLCommon a:link {
+ text-decoration: none;
+ color: var(--jp-content-link-color);
+}
+
+.jp-RenderedHTMLCommon a:hover {
+ text-decoration: underline;
+ color: var(--jp-content-link-color);
+}
+
+.jp-RenderedHTMLCommon a:visited {
+ text-decoration: none;
+ color: var(--jp-content-link-color);
+}
+
+/* Headings */
+
+.jp-RenderedHTMLCommon h1,
+.jp-RenderedHTMLCommon h2,
+.jp-RenderedHTMLCommon h3,
+.jp-RenderedHTMLCommon h4,
+.jp-RenderedHTMLCommon h5,
+.jp-RenderedHTMLCommon h6 {
+ line-height: var(--jp-content-heading-line-height);
+ font-weight: var(--jp-content-heading-font-weight);
+ font-style: normal;
+ margin: var(--jp-content-heading-margin-top) 0
+ var(--jp-content-heading-margin-bottom) 0;
+}
+
+.jp-RenderedHTMLCommon h1:first-child,
+.jp-RenderedHTMLCommon h2:first-child,
+.jp-RenderedHTMLCommon h3:first-child,
+.jp-RenderedHTMLCommon h4:first-child,
+.jp-RenderedHTMLCommon h5:first-child,
+.jp-RenderedHTMLCommon h6:first-child {
+ margin-top: calc(0.5 * var(--jp-content-heading-margin-top));
+}
+
+.jp-RenderedHTMLCommon h1:last-child,
+.jp-RenderedHTMLCommon h2:last-child,
+.jp-RenderedHTMLCommon h3:last-child,
+.jp-RenderedHTMLCommon h4:last-child,
+.jp-RenderedHTMLCommon h5:last-child,
+.jp-RenderedHTMLCommon h6:last-child {
+ margin-bottom: calc(0.5 * var(--jp-content-heading-margin-bottom));
+}
+
+.jp-RenderedHTMLCommon h1 {
+ font-size: var(--jp-content-font-size5);
+}
+
+.jp-RenderedHTMLCommon h2 {
+ font-size: var(--jp-content-font-size4);
+}
+
+.jp-RenderedHTMLCommon h3 {
+ font-size: var(--jp-content-font-size3);
+}
+
+.jp-RenderedHTMLCommon h4 {
+ font-size: var(--jp-content-font-size2);
+}
+
+.jp-RenderedHTMLCommon h5 {
+ font-size: var(--jp-content-font-size1);
+}
+
+.jp-RenderedHTMLCommon h6 {
+ font-size: var(--jp-content-font-size0);
+}
+
+/* Lists */
+
+/* stylelint-disable selector-max-type, selector-max-compound-selectors */
+
+.jp-RenderedHTMLCommon ul:not(.list-inline),
+.jp-RenderedHTMLCommon ol:not(.list-inline) {
+ padding-left: 2em;
+}
+
+.jp-RenderedHTMLCommon ul {
+ list-style: disc;
+}
+
+.jp-RenderedHTMLCommon ul ul {
+ list-style: square;
+}
+
+.jp-RenderedHTMLCommon ul ul ul {
+ list-style: circle;
+}
+
+.jp-RenderedHTMLCommon ol {
+ list-style: decimal;
+}
+
+.jp-RenderedHTMLCommon ol ol {
+ list-style: upper-alpha;
+}
+
+.jp-RenderedHTMLCommon ol ol ol {
+ list-style: lower-alpha;
+}
+
+.jp-RenderedHTMLCommon ol ol ol ol {
+ list-style: lower-roman;
+}
+
+.jp-RenderedHTMLCommon ol ol ol ol ol {
+ list-style: decimal;
+}
+
+.jp-RenderedHTMLCommon ol,
+.jp-RenderedHTMLCommon ul {
+ margin-bottom: 1em;
+}
+
+.jp-RenderedHTMLCommon ul ul,
+.jp-RenderedHTMLCommon ul ol,
+.jp-RenderedHTMLCommon ol ul,
+.jp-RenderedHTMLCommon ol ol {
+ margin-bottom: 0;
+}
+
+/* stylelint-enable selector-max-type, selector-max-compound-selectors */
+
+.jp-RenderedHTMLCommon hr {
+ color: var(--jp-border-color2);
+ background-color: var(--jp-border-color1);
+ margin-top: 1em;
+ margin-bottom: 1em;
+}
+
+.jp-RenderedHTMLCommon > pre {
+ margin: 1.5em 2em;
+}
+
+.jp-RenderedHTMLCommon pre,
+.jp-RenderedHTMLCommon code {
+ border: 0;
+ background-color: var(--jp-layout-color0);
+ color: var(--jp-content-font-color1);
+ font-family: var(--jp-code-font-family);
+ font-size: inherit;
+ line-height: var(--jp-code-line-height);
+ padding: 0;
+ white-space: pre-wrap;
+}
+
+.jp-RenderedHTMLCommon :not(pre) > code {
+ background-color: var(--jp-layout-color2);
+ padding: 1px 5px;
+}
+
+/* Tables */
+
+.jp-RenderedHTMLCommon table {
+ border-collapse: collapse;
+ border-spacing: 0;
+ border: none;
+ color: var(--jp-ui-font-color1);
+ font-size: var(--jp-ui-font-size1);
+ table-layout: fixed;
+ margin-left: auto;
+ margin-bottom: 1em;
+ margin-right: auto;
+}
+
+.jp-RenderedHTMLCommon thead {
+ border-bottom: var(--jp-border-width) solid var(--jp-border-color1);
+ vertical-align: bottom;
+}
+
+.jp-RenderedHTMLCommon td,
+.jp-RenderedHTMLCommon th,
+.jp-RenderedHTMLCommon tr {
+ vertical-align: middle;
+ padding: 0.5em;
+ line-height: normal;
+ white-space: normal;
+ max-width: none;
+ border: none;
+}
+
+.jp-RenderedMarkdown.jp-RenderedHTMLCommon td,
+.jp-RenderedMarkdown.jp-RenderedHTMLCommon th {
+ max-width: none;
+}
+
+:not(.jp-RenderedMarkdown).jp-RenderedHTMLCommon td,
+:not(.jp-RenderedMarkdown).jp-RenderedHTMLCommon th,
+:not(.jp-RenderedMarkdown).jp-RenderedHTMLCommon tr {
+ text-align: right;
+}
+
+.jp-RenderedHTMLCommon th {
+ font-weight: bold;
+}
+
+.jp-RenderedHTMLCommon tbody tr:nth-child(odd) {
+ background: var(--jp-layout-color0);
+}
+
+.jp-RenderedHTMLCommon tbody tr:nth-child(even) {
+ background: var(--jp-rendermime-table-row-background);
+}
+
+.jp-RenderedHTMLCommon tbody tr:hover {
+ background: var(--jp-rendermime-table-row-hover-background);
+}
+
+.jp-RenderedHTMLCommon p {
+ text-align: left;
+ margin: 0;
+ margin-bottom: 1em;
+}
+
+.jp-RenderedHTMLCommon img {
+ -moz-force-broken-image-icon: 1;
+}
+
+/* Restrict to direct children as other images could be nested in other content. */
+.jp-RenderedHTMLCommon > img {
+ display: block;
+ margin-left: 0;
+ margin-right: 0;
+ margin-bottom: 1em;
+}
+
+/* Change color behind transparent images if they need it... */
+[data-jp-theme-light='false'] .jp-RenderedImage img.jp-needs-light-background {
+ background-color: var(--jp-inverse-layout-color1);
+}
+
+[data-jp-theme-light='true'] .jp-RenderedImage img.jp-needs-dark-background {
+ background-color: var(--jp-inverse-layout-color1);
+}
+
+.jp-RenderedHTMLCommon img,
+.jp-RenderedImage img,
+.jp-RenderedHTMLCommon svg,
+.jp-RenderedSVG svg {
+ max-width: 100%;
+ height: auto;
+}
+
+.jp-RenderedHTMLCommon img.jp-mod-unconfined,
+.jp-RenderedImage img.jp-mod-unconfined,
+.jp-RenderedHTMLCommon svg.jp-mod-unconfined,
+.jp-RenderedSVG svg.jp-mod-unconfined {
+ max-width: none;
+}
+
+.jp-RenderedHTMLCommon .alert {
+ padding: var(--jp-notebook-padding);
+ border: var(--jp-border-width) solid transparent;
+ border-radius: var(--jp-border-radius);
+ margin-bottom: 1em;
+}
+
+.jp-RenderedHTMLCommon .alert-info {
+ color: var(--jp-info-color0);
+ background-color: var(--jp-info-color3);
+ border-color: var(--jp-info-color2);
+}
+
+.jp-RenderedHTMLCommon .alert-info hr {
+ border-color: var(--jp-info-color3);
+}
+
+.jp-RenderedHTMLCommon .alert-info > p:last-child,
+.jp-RenderedHTMLCommon .alert-info > ul:last-child {
+ margin-bottom: 0;
+}
+
+.jp-RenderedHTMLCommon .alert-warning {
+ color: var(--jp-warn-color0);
+ background-color: var(--jp-warn-color3);
+ border-color: var(--jp-warn-color2);
+}
+
+.jp-RenderedHTMLCommon .alert-warning hr {
+ border-color: var(--jp-warn-color3);
+}
+
+.jp-RenderedHTMLCommon .alert-warning > p:last-child,
+.jp-RenderedHTMLCommon .alert-warning > ul:last-child {
+ margin-bottom: 0;
+}
+
+.jp-RenderedHTMLCommon .alert-success {
+ color: var(--jp-success-color0);
+ background-color: var(--jp-success-color3);
+ border-color: var(--jp-success-color2);
+}
+
+.jp-RenderedHTMLCommon .alert-success hr {
+ border-color: var(--jp-success-color3);
+}
+
+.jp-RenderedHTMLCommon .alert-success > p:last-child,
+.jp-RenderedHTMLCommon .alert-success > ul:last-child {
+ margin-bottom: 0;
+}
+
+.jp-RenderedHTMLCommon .alert-danger {
+ color: var(--jp-error-color0);
+ background-color: var(--jp-error-color3);
+ border-color: var(--jp-error-color2);
+}
+
+.jp-RenderedHTMLCommon .alert-danger hr {
+ border-color: var(--jp-error-color3);
+}
+
+.jp-RenderedHTMLCommon .alert-danger > p:last-child,
+.jp-RenderedHTMLCommon .alert-danger > ul:last-child {
+ margin-bottom: 0;
+}
+
+.jp-RenderedHTMLCommon blockquote {
+ margin: 1em 2em;
+ padding: 0 1em;
+ border-left: 5px solid var(--jp-border-color2);
+}
+
+a.jp-InternalAnchorLink {
+ visibility: hidden;
+ margin-left: 8px;
+ color: var(--md-blue-800);
+}
+
+h1:hover .jp-InternalAnchorLink,
+h2:hover .jp-InternalAnchorLink,
+h3:hover .jp-InternalAnchorLink,
+h4:hover .jp-InternalAnchorLink,
+h5:hover .jp-InternalAnchorLink,
+h6:hover .jp-InternalAnchorLink {
+ visibility: visible;
+}
+
+.jp-RenderedHTMLCommon kbd {
+ background-color: var(--jp-rendermime-table-row-background);
+ border: 1px solid var(--jp-border-color0);
+ border-bottom-color: var(--jp-border-color2);
+ border-radius: 3px;
+ box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.25);
+ display: inline-block;
+ font-size: var(--jp-ui-font-size0);
+ line-height: 1em;
+ padding: 0.2em 0.5em;
+}
+
+/* Most direct children of .jp-RenderedHTMLCommon have a margin-bottom of 1.0.
+ * At the bottom of cells this is a bit too much as there is also spacing
+ * between cells. Going all the way to 0 gets too tight between markdown and
+ * code cells.
+ */
+.jp-RenderedHTMLCommon > *:last-child {
+ margin-bottom: 0.5em;
+}
+
+/*
+ * Copyright (c) Jupyter Development Team.
+ * Distributed under the terms of the Modified BSD License.
+ */
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Copyright (c) 2014-2017, PhosphorJS Contributors
+|
+| Distributed under the terms of the BSD 3-Clause License.
+|
+| The full license is in the file LICENSE, distributed with this software.
+|----------------------------------------------------------------------------*/
+
+.lm-cursor-backdrop {
+ position: fixed;
+ width: 200px;
+ height: 200px;
+ margin-top: -100px;
+ margin-left: -100px;
+ will-change: transform;
+ z-index: 100;
+}
+
+.lm-mod-drag-image {
+ will-change: transform;
+}
+
+/*
+ * Copyright (c) Jupyter Development Team.
+ * Distributed under the terms of the Modified BSD License.
+ */
+
+.jp-lineFormSearch {
+ padding: 4px 12px;
+ background-color: var(--jp-layout-color2);
+ box-shadow: var(--jp-toolbar-box-shadow);
+ z-index: 2;
+ font-size: var(--jp-ui-font-size1);
+}
+
+.jp-lineFormCaption {
+ font-size: var(--jp-ui-font-size0);
+ line-height: var(--jp-ui-font-size1);
+ margin-top: 4px;
+ color: var(--jp-ui-font-color0);
+}
+
+.jp-baseLineForm {
+ border: none;
+ border-radius: 0;
+ position: absolute;
+ background-size: 16px;
+ background-repeat: no-repeat;
+ background-position: center;
+ outline: none;
+}
+
+.jp-lineFormButtonContainer {
+ top: 4px;
+ right: 8px;
+ height: 24px;
+ padding: 0 12px;
+ width: 12px;
+}
+
+.jp-lineFormButtonIcon {
+ top: 0;
+ right: 0;
+ background-color: var(--jp-brand-color1);
+ height: 100%;
+ width: 100%;
+ box-sizing: border-box;
+ padding: 4px 6px;
+}
+
+.jp-lineFormButton {
+ top: 0;
+ right: 0;
+ background-color: transparent;
+ height: 100%;
+ width: 100%;
+ box-sizing: border-box;
+}
+
+.jp-lineFormWrapper {
+ overflow: hidden;
+ padding: 0 8px;
+ border: 1px solid var(--jp-border-color0);
+ background-color: var(--jp-input-active-background);
+ height: 22px;
+}
+
+.jp-lineFormWrapperFocusWithin {
+ border: var(--jp-border-width) solid var(--md-blue-500);
+ box-shadow: inset 0 0 4px var(--md-blue-300);
+}
+
+.jp-lineFormInput {
+ background: transparent;
+ width: 200px;
+ height: 100%;
+ border: none;
+ outline: none;
+ color: var(--jp-ui-font-color0);
+ line-height: 28px;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) 2014-2016, Jupyter Development Team.
+|
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+.jp-JSONEditor {
+ display: flex;
+ flex-direction: column;
+ width: 100%;
+}
+
+.jp-JSONEditor-host {
+ flex: 1 1 auto;
+ border: var(--jp-border-width) solid var(--jp-input-border-color);
+ border-radius: 0;
+ background: var(--jp-layout-color0);
+ min-height: 50px;
+ padding: 1px;
+}
+
+.jp-JSONEditor.jp-mod-error .jp-JSONEditor-host {
+ border-color: red;
+ outline-color: red;
+}
+
+.jp-JSONEditor-header {
+ display: flex;
+ flex: 1 0 auto;
+ padding: 0 0 0 12px;
+}
+
+.jp-JSONEditor-header label {
+ flex: 0 0 auto;
+}
+
+.jp-JSONEditor-commitButton {
+ height: 16px;
+ width: 16px;
+ background-size: 18px;
+ background-repeat: no-repeat;
+ background-position: center;
+}
+
+.jp-JSONEditor-host.jp-mod-focused {
+ background-color: var(--jp-input-active-background);
+ border: 1px solid var(--jp-input-active-border-color);
+ box-shadow: var(--jp-input-box-shadow);
+}
+
+.jp-Editor.jp-mod-dropTarget {
+ border: var(--jp-border-width) solid var(--jp-input-active-border-color);
+ box-shadow: var(--jp-input-box-shadow);
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+.jp-DocumentSearch-input {
+ border: none;
+ outline: none;
+ color: var(--jp-ui-font-color0);
+ font-size: var(--jp-ui-font-size1);
+ background-color: var(--jp-layout-color0);
+ font-family: var(--jp-ui-font-family);
+ padding: 2px 1px;
+ resize: none;
+}
+
+.jp-DocumentSearch-overlay {
+ position: absolute;
+ background-color: var(--jp-toolbar-background);
+ border-bottom: var(--jp-border-width) solid var(--jp-toolbar-border-color);
+ border-left: var(--jp-border-width) solid var(--jp-toolbar-border-color);
+ top: 0;
+ right: 0;
+ z-index: 7;
+ min-width: 405px;
+ padding: 2px;
+ font-size: var(--jp-ui-font-size1);
+
+ --jp-private-document-search-button-height: 20px;
+}
+
+.jp-DocumentSearch-overlay button {
+ background-color: var(--jp-toolbar-background);
+ outline: 0;
+}
+
+.jp-DocumentSearch-overlay button:hover {
+ background-color: var(--jp-layout-color2);
+}
+
+.jp-DocumentSearch-overlay button:active {
+ background-color: var(--jp-layout-color3);
+}
+
+.jp-DocumentSearch-overlay-row {
+ display: flex;
+ align-items: center;
+ margin-bottom: 2px;
+}
+
+.jp-DocumentSearch-button-content {
+ display: inline-block;
+ cursor: pointer;
+ box-sizing: border-box;
+ width: 100%;
+ height: 100%;
+}
+
+.jp-DocumentSearch-button-content svg {
+ width: 100%;
+ height: 100%;
+}
+
+.jp-DocumentSearch-input-wrapper {
+ border: var(--jp-border-width) solid var(--jp-border-color0);
+ display: flex;
+ background-color: var(--jp-layout-color0);
+ margin: 2px;
+}
+
+.jp-DocumentSearch-input-wrapper:focus-within {
+ border-color: var(--jp-cell-editor-active-border-color);
+}
+
+.jp-DocumentSearch-toggle-wrapper,
+.jp-DocumentSearch-button-wrapper {
+ all: initial;
+ overflow: hidden;
+ display: inline-block;
+ border: none;
+ box-sizing: border-box;
+}
+
+.jp-DocumentSearch-toggle-wrapper {
+ width: 14px;
+ height: 14px;
+}
+
+.jp-DocumentSearch-button-wrapper {
+ width: var(--jp-private-document-search-button-height);
+ height: var(--jp-private-document-search-button-height);
+}
+
+.jp-DocumentSearch-toggle-wrapper:focus,
+.jp-DocumentSearch-button-wrapper:focus {
+ outline: var(--jp-border-width) solid
+ var(--jp-cell-editor-active-border-color);
+ outline-offset: -1px;
+}
+
+.jp-DocumentSearch-toggle-wrapper,
+.jp-DocumentSearch-button-wrapper,
+.jp-DocumentSearch-button-content:focus {
+ outline: none;
+}
+
+.jp-DocumentSearch-toggle-placeholder {
+ width: 5px;
+}
+
+.jp-DocumentSearch-input-button::before {
+ display: block;
+ padding-top: 100%;
+}
+
+.jp-DocumentSearch-input-button-off {
+ opacity: var(--jp-search-toggle-off-opacity);
+}
+
+.jp-DocumentSearch-input-button-off:hover {
+ opacity: var(--jp-search-toggle-hover-opacity);
+}
+
+.jp-DocumentSearch-input-button-on {
+ opacity: var(--jp-search-toggle-on-opacity);
+}
+
+.jp-DocumentSearch-index-counter {
+ padding-left: 10px;
+ padding-right: 10px;
+ user-select: none;
+ min-width: 35px;
+ display: inline-block;
+}
+
+.jp-DocumentSearch-up-down-wrapper {
+ display: inline-block;
+ padding-right: 2px;
+ margin-left: auto;
+ white-space: nowrap;
+}
+
+.jp-DocumentSearch-spacer {
+ margin-left: auto;
+}
+
+.jp-DocumentSearch-up-down-wrapper button {
+ outline: 0;
+ border: none;
+ width: var(--jp-private-document-search-button-height);
+ height: var(--jp-private-document-search-button-height);
+ vertical-align: middle;
+ margin: 1px 5px 2px;
+}
+
+.jp-DocumentSearch-up-down-button:hover {
+ background-color: var(--jp-layout-color2);
+}
+
+.jp-DocumentSearch-up-down-button:active {
+ background-color: var(--jp-layout-color3);
+}
+
+.jp-DocumentSearch-filter-button {
+ border-radius: var(--jp-border-radius);
+}
+
+.jp-DocumentSearch-filter-button:hover {
+ background-color: var(--jp-layout-color2);
+}
+
+.jp-DocumentSearch-filter-button-enabled {
+ background-color: var(--jp-layout-color2);
+}
+
+.jp-DocumentSearch-filter-button-enabled:hover {
+ background-color: var(--jp-layout-color3);
+}
+
+.jp-DocumentSearch-search-options {
+ padding: 0 8px;
+ margin-left: 3px;
+ width: 100%;
+ display: grid;
+ justify-content: start;
+ grid-template-columns: 1fr 1fr;
+ align-items: center;
+ justify-items: stretch;
+}
+
+.jp-DocumentSearch-search-filter-disabled {
+ color: var(--jp-ui-font-color2);
+}
+
+.jp-DocumentSearch-search-filter {
+ display: flex;
+ align-items: center;
+ user-select: none;
+}
+
+.jp-DocumentSearch-regex-error {
+ color: var(--jp-error-color0);
+}
+
+.jp-DocumentSearch-replace-button-wrapper {
+ overflow: hidden;
+ display: inline-block;
+ box-sizing: border-box;
+ border: var(--jp-border-width) solid var(--jp-border-color0);
+ margin: auto 2px;
+ padding: 1px 4px;
+ height: calc(var(--jp-private-document-search-button-height) + 2px);
+}
+
+.jp-DocumentSearch-replace-button-wrapper:focus {
+ border: var(--jp-border-width) solid var(--jp-cell-editor-active-border-color);
+}
+
+.jp-DocumentSearch-replace-button {
+ display: inline-block;
+ text-align: center;
+ cursor: pointer;
+ box-sizing: border-box;
+ color: var(--jp-ui-font-color1);
+
+ /* height - 2 * (padding of wrapper) */
+ line-height: calc(var(--jp-private-document-search-button-height) - 2px);
+ width: 100%;
+ height: 100%;
+}
+
+.jp-DocumentSearch-replace-button:focus {
+ outline: none;
+}
+
+.jp-DocumentSearch-replace-wrapper-class {
+ margin-left: 14px;
+ display: flex;
+}
+
+.jp-DocumentSearch-replace-toggle {
+ border: none;
+ background-color: var(--jp-toolbar-background);
+ border-radius: var(--jp-border-radius);
+}
+
+.jp-DocumentSearch-replace-toggle:hover {
+ background-color: var(--jp-layout-color2);
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+.cm-editor {
+ line-height: var(--jp-code-line-height);
+ font-size: var(--jp-code-font-size);
+ font-family: var(--jp-code-font-family);
+ border: 0;
+ border-radius: 0;
+ height: auto;
+
+ /* Changed to auto to autogrow */
+}
+
+.cm-editor pre {
+ padding: 0 var(--jp-code-padding);
+}
+
+.jp-CodeMirrorEditor[data-type='inline'] .cm-dialog {
+ background-color: var(--jp-layout-color0);
+ color: var(--jp-content-font-color1);
+}
+
+.jp-CodeMirrorEditor {
+ cursor: text;
+}
+
+/* When zoomed out 67% and 33% on a screen of 1440 width x 900 height */
+@media screen and (min-width: 2138px) and (max-width: 4319px) {
+ .jp-CodeMirrorEditor[data-type='inline'] .cm-cursor {
+ border-left: var(--jp-code-cursor-width1) solid
+ var(--jp-editor-cursor-color);
+ }
+}
+
+/* When zoomed out less than 33% */
+@media screen and (min-width: 4320px) {
+ .jp-CodeMirrorEditor[data-type='inline'] .cm-cursor {
+ border-left: var(--jp-code-cursor-width2) solid
+ var(--jp-editor-cursor-color);
+ }
+}
+
+.cm-editor.jp-mod-readOnly .cm-cursor {
+ display: none;
+}
+
+.jp-CollaboratorCursor {
+ border-left: 5px solid transparent;
+ border-right: 5px solid transparent;
+ border-top: none;
+ border-bottom: 3px solid;
+ background-clip: content-box;
+ margin-left: -5px;
+ margin-right: -5px;
+}
+
+.cm-searching,
+.cm-searching span {
+ /* `.cm-searching span`: we need to override syntax highlighting */
+ background-color: var(--jp-search-unselected-match-background-color);
+ color: var(--jp-search-unselected-match-color);
+}
+
+.cm-searching::selection,
+.cm-searching span::selection {
+ background-color: var(--jp-search-unselected-match-background-color);
+ color: var(--jp-search-unselected-match-color);
+}
+
+.jp-current-match > .cm-searching,
+.jp-current-match > .cm-searching span,
+.cm-searching > .jp-current-match,
+.cm-searching > .jp-current-match span {
+ background-color: var(--jp-search-selected-match-background-color);
+ color: var(--jp-search-selected-match-color);
+}
+
+.jp-current-match > .cm-searching::selection,
+.cm-searching > .jp-current-match::selection,
+.jp-current-match > .cm-searching span::selection {
+ background-color: var(--jp-search-selected-match-background-color);
+ color: var(--jp-search-selected-match-color);
+}
+
+.cm-trailingspace {
+ background-image: url();
+ background-position: center left;
+ background-repeat: repeat-x;
+}
+
+.jp-CollaboratorCursor-hover {
+ position: absolute;
+ z-index: 1;
+ transform: translateX(-50%);
+ color: white;
+ border-radius: 3px;
+ padding-left: 4px;
+ padding-right: 4px;
+ padding-top: 1px;
+ padding-bottom: 1px;
+ text-align: center;
+ font-size: var(--jp-ui-font-size1);
+ white-space: nowrap;
+}
+
+.jp-CodeMirror-ruler {
+ border-left: 1px dashed var(--jp-border-color2);
+}
+
+/* Styles for shared cursors (remote cursor locations and selected ranges) */
+.jp-CodeMirrorEditor .cm-ySelectionCaret {
+ position: relative;
+ border-left: 1px solid black;
+ margin-left: -1px;
+ margin-right: -1px;
+ box-sizing: border-box;
+}
+
+.jp-CodeMirrorEditor .cm-ySelectionCaret > .cm-ySelectionInfo {
+ white-space: nowrap;
+ position: absolute;
+ top: -1.15em;
+ padding-bottom: 0.05em;
+ left: -1px;
+ font-size: 0.95em;
+ font-family: var(--jp-ui-font-family);
+ font-weight: bold;
+ line-height: normal;
+ user-select: none;
+ color: white;
+ padding-left: 2px;
+ padding-right: 2px;
+ z-index: 101;
+ transition: opacity 0.3s ease-in-out;
+}
+
+.jp-CodeMirrorEditor .cm-ySelectionInfo {
+ transition-delay: 0.7s;
+ opacity: 0;
+}
+
+.jp-CodeMirrorEditor .cm-ySelectionCaret:hover > .cm-ySelectionInfo {
+ opacity: 1;
+ transition-delay: 0s;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+.jp-MimeDocument {
+ outline: none;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/*-----------------------------------------------------------------------------
+| Variables
+|----------------------------------------------------------------------------*/
+
+:root {
+ --jp-private-filebrowser-button-height: 28px;
+ --jp-private-filebrowser-button-width: 48px;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+.jp-FileBrowser .jp-SidePanel-content {
+ display: flex;
+ flex-direction: column;
+}
+
+.jp-FileBrowser-toolbar.jp-Toolbar {
+ flex-wrap: wrap;
+ row-gap: 12px;
+ border-bottom: none;
+ height: auto;
+ margin: 8px 12px 0;
+ box-shadow: none;
+ padding: 0;
+ justify-content: flex-start;
+}
+
+.jp-FileBrowser-Panel {
+ flex: 1 1 auto;
+ display: flex;
+ flex-direction: column;
+}
+
+.jp-BreadCrumbs {
+ flex: 0 0 auto;
+ margin: 8px 12px;
+}
+
+.jp-BreadCrumbs-item {
+ margin: 0 2px;
+ padding: 0 2px;
+ border-radius: var(--jp-border-radius);
+ cursor: pointer;
+}
+
+.jp-BreadCrumbs-item:hover {
+ background-color: var(--jp-layout-color2);
+}
+
+.jp-BreadCrumbs-item:first-child {
+ margin-left: 0;
+}
+
+.jp-BreadCrumbs-item.jp-mod-dropTarget {
+ background-color: var(--jp-brand-color2);
+ opacity: 0.7;
+}
+
+/*-----------------------------------------------------------------------------
+| Buttons
+|----------------------------------------------------------------------------*/
+
+.jp-FileBrowser-toolbar > .jp-Toolbar-item {
+ flex: 0 0 auto;
+ padding-left: 0;
+ padding-right: 2px;
+ align-items: center;
+ height: unset;
+}
+
+.jp-FileBrowser-toolbar > .jp-Toolbar-item .jp-ToolbarButtonComponent {
+ width: 40px;
+}
+
+/*-----------------------------------------------------------------------------
+| Other styles
+|----------------------------------------------------------------------------*/
+
+.jp-FileDialog.jp-mod-conflict input {
+ color: var(--jp-error-color1);
+}
+
+.jp-FileDialog .jp-new-name-title {
+ margin-top: 12px;
+}
+
+.jp-LastModified-hidden {
+ display: none;
+}
+
+.jp-FileSize-hidden {
+ display: none;
+}
+
+.jp-FileBrowser .lm-AccordionPanel > h3:first-child {
+ display: none;
+}
+
+/*-----------------------------------------------------------------------------
+| DirListing
+|----------------------------------------------------------------------------*/
+
+.jp-DirListing {
+ flex: 1 1 auto;
+ display: flex;
+ flex-direction: column;
+ outline: 0;
+}
+
+.jp-DirListing-header {
+ flex: 0 0 auto;
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ overflow: hidden;
+ border-top: var(--jp-border-width) solid var(--jp-border-color2);
+ border-bottom: var(--jp-border-width) solid var(--jp-border-color1);
+ box-shadow: var(--jp-toolbar-box-shadow);
+ z-index: 2;
+}
+
+.jp-DirListing-headerItem {
+ padding: 4px 12px 2px;
+ font-weight: 500;
+}
+
+.jp-DirListing-headerItem:hover {
+ background: var(--jp-layout-color2);
+}
+
+.jp-DirListing-headerItem.jp-id-name {
+ flex: 1 0 84px;
+}
+
+.jp-DirListing-headerItem.jp-id-modified {
+ flex: 0 0 112px;
+ border-left: var(--jp-border-width) solid var(--jp-border-color2);
+ text-align: right;
+}
+
+.jp-DirListing-headerItem.jp-id-filesize {
+ flex: 0 0 75px;
+ border-left: var(--jp-border-width) solid var(--jp-border-color2);
+ text-align: right;
+}
+
+.jp-id-narrow {
+ display: none;
+ flex: 0 0 5px;
+ padding: 4px;
+ border-left: var(--jp-border-width) solid var(--jp-border-color2);
+ text-align: right;
+ color: var(--jp-border-color2);
+}
+
+.jp-DirListing-narrow .jp-id-narrow {
+ display: block;
+}
+
+.jp-DirListing-narrow .jp-id-modified,
+.jp-DirListing-narrow .jp-DirListing-itemModified {
+ display: none;
+}
+
+.jp-DirListing-headerItem.jp-mod-selected {
+ font-weight: 600;
+}
+
+/* increase specificity to override bundled default */
+.jp-DirListing-content {
+ flex: 1 1 auto;
+ margin: 0;
+ padding: 0;
+ list-style-type: none;
+ overflow: auto;
+ background-color: var(--jp-layout-color1);
+}
+
+.jp-DirListing-content mark {
+ color: var(--jp-ui-font-color0);
+ background-color: transparent;
+ font-weight: bold;
+}
+
+.jp-DirListing-content .jp-DirListing-item.jp-mod-selected mark {
+ color: var(--jp-ui-inverse-font-color0);
+}
+
+/* Style the directory listing content when a user drops a file to upload */
+.jp-DirListing.jp-mod-native-drop .jp-DirListing-content {
+ outline: 5px dashed rgba(128, 128, 128, 0.5);
+ outline-offset: -10px;
+ cursor: copy;
+}
+
+.jp-DirListing-item {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ padding: 4px 12px;
+ -webkit-user-select: none;
+ -moz-user-select: none;
+ -ms-user-select: none;
+ user-select: none;
+}
+
+.jp-DirListing-checkboxWrapper {
+ /* Increases hit area of checkbox. */
+ padding: 4px;
+}
+
+.jp-DirListing-header
+ .jp-DirListing-checkboxWrapper
+ + .jp-DirListing-headerItem {
+ padding-left: 4px;
+}
+
+.jp-DirListing-content .jp-DirListing-checkboxWrapper {
+ position: relative;
+ left: -4px;
+ margin: -4px 0 -4px -8px;
+}
+
+.jp-DirListing-checkboxWrapper.jp-mod-visible {
+ visibility: visible;
+}
+
+/* For devices that support hovering, hide checkboxes until hovered, selected...
+*/
+@media (hover: hover) {
+ .jp-DirListing-checkboxWrapper {
+ visibility: hidden;
+ }
+
+ .jp-DirListing-item:hover .jp-DirListing-checkboxWrapper,
+ .jp-DirListing-item.jp-mod-selected .jp-DirListing-checkboxWrapper {
+ visibility: visible;
+ }
+}
+
+.jp-DirListing-item[data-is-dot] {
+ opacity: 75%;
+}
+
+.jp-DirListing-item.jp-mod-selected {
+ color: var(--jp-ui-inverse-font-color1);
+ background: var(--jp-brand-color1);
+}
+
+.jp-DirListing-item.jp-mod-dropTarget {
+ background: var(--jp-brand-color3);
+}
+
+.jp-DirListing-item:hover:not(.jp-mod-selected) {
+ background: var(--jp-layout-color2);
+}
+
+.jp-DirListing-itemIcon {
+ flex: 0 0 20px;
+ margin-right: 4px;
+}
+
+.jp-DirListing-itemText {
+ flex: 1 0 64px;
+ white-space: nowrap;
+ overflow: hidden;
+ text-overflow: ellipsis;
+ user-select: none;
+}
+
+.jp-DirListing-itemText:focus {
+ outline-width: 2px;
+ outline-color: var(--jp-inverse-layout-color1);
+ outline-style: solid;
+ outline-offset: 1px;
+}
+
+.jp-DirListing-item.jp-mod-selected .jp-DirListing-itemText:focus {
+ outline-color: var(--jp-layout-color1);
+}
+
+.jp-DirListing-itemModified {
+ flex: 0 0 125px;
+ text-align: right;
+}
+
+.jp-DirListing-itemFileSize {
+ flex: 0 0 90px;
+ text-align: right;
+}
+
+.jp-DirListing-editor {
+ flex: 1 0 64px;
+ outline: none;
+ border: none;
+ color: var(--jp-ui-font-color1);
+ background-color: var(--jp-layout-color1);
+}
+
+.jp-DirListing-item.jp-mod-running .jp-DirListing-itemIcon::before {
+ color: var(--jp-success-color1);
+ content: '\25CF';
+ font-size: 8px;
+ position: absolute;
+ left: -8px;
+}
+
+.jp-DirListing-item.jp-mod-running.jp-mod-selected
+ .jp-DirListing-itemIcon::before {
+ color: var(--jp-ui-inverse-font-color1);
+}
+
+.jp-DirListing-item.lm-mod-drag-image,
+.jp-DirListing-item.jp-mod-selected.lm-mod-drag-image {
+ font-size: var(--jp-ui-font-size1);
+ padding-left: 4px;
+ margin-left: 4px;
+ width: 160px;
+ background-color: var(--jp-ui-inverse-font-color2);
+ box-shadow: var(--jp-elevation-z2);
+ border-radius: 0;
+ color: var(--jp-ui-font-color1);
+ transform: translateX(-40%) translateY(-58%);
+}
+
+.jp-Document {
+ min-width: 120px;
+ min-height: 120px;
+ outline: none;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/*-----------------------------------------------------------------------------
+| Main OutputArea
+| OutputArea has a list of Outputs
+|----------------------------------------------------------------------------*/
+
+.jp-OutputArea {
+ overflow-y: auto;
+}
+
+.jp-OutputArea-child {
+ display: table;
+ table-layout: fixed;
+ width: 100%;
+ overflow: hidden;
+}
+
+.jp-OutputPrompt {
+ width: var(--jp-cell-prompt-width);
+ color: var(--jp-cell-outprompt-font-color);
+ font-family: var(--jp-cell-prompt-font-family);
+ padding: var(--jp-code-padding);
+ letter-spacing: var(--jp-cell-prompt-letter-spacing);
+ line-height: var(--jp-code-line-height);
+ font-size: var(--jp-code-font-size);
+ border: var(--jp-border-width) solid transparent;
+ opacity: var(--jp-cell-prompt-opacity);
+
+ /* Right align prompt text, don't wrap to handle large prompt numbers */
+ text-align: right;
+ white-space: nowrap;
+ overflow: hidden;
+ text-overflow: ellipsis;
+
+ /* Disable text selection */
+ -webkit-user-select: none;
+ -moz-user-select: none;
+ -ms-user-select: none;
+ user-select: none;
+}
+
+.jp-OutputArea-prompt {
+ display: table-cell;
+ vertical-align: top;
+}
+
+.jp-OutputArea-output {
+ display: table-cell;
+ width: 100%;
+ height: auto;
+ overflow: auto;
+ user-select: text;
+ -moz-user-select: text;
+ -webkit-user-select: text;
+ -ms-user-select: text;
+}
+
+.jp-OutputArea .jp-RenderedText {
+ padding-left: 1ch;
+}
+
+/**
+ * Prompt overlay.
+ */
+
+.jp-OutputArea-promptOverlay {
+ position: absolute;
+ top: 0;
+ width: var(--jp-cell-prompt-width);
+ height: 100%;
+ opacity: 0.5;
+}
+
+.jp-OutputArea-promptOverlay:hover {
+ background: var(--jp-layout-color2);
+ box-shadow: inset 0 0 1px var(--jp-inverse-layout-color0);
+ cursor: zoom-out;
+}
+
+.jp-mod-outputsScrolled .jp-OutputArea-promptOverlay:hover {
+ cursor: zoom-in;
+}
+
+/**
+ * Isolated output.
+ */
+.jp-OutputArea-output.jp-mod-isolated {
+ width: 100%;
+ display: block;
+}
+
+/*
+When drag events occur, `lm-mod-override-cursor` is added to the body.
+Because iframes steal all cursor events, the following two rules are necessary
+to suppress pointer events while resize drags are occurring. There may be a
+better solution to this problem.
+*/
+body.lm-mod-override-cursor .jp-OutputArea-output.jp-mod-isolated {
+ position: relative;
+}
+
+body.lm-mod-override-cursor .jp-OutputArea-output.jp-mod-isolated::before {
+ content: '';
+ position: absolute;
+ top: 0;
+ left: 0;
+ right: 0;
+ bottom: 0;
+ background: transparent;
+}
+
+/* pre */
+
+.jp-OutputArea-output pre {
+ border: none;
+ margin: 0;
+ padding: 0;
+ overflow-x: auto;
+ overflow-y: auto;
+ word-break: break-all;
+ word-wrap: break-word;
+ white-space: pre-wrap;
+}
+
+/* tables */
+
+.jp-OutputArea-output.jp-RenderedHTMLCommon table {
+ margin-left: 0;
+ margin-right: 0;
+}
+
+/* description lists */
+
+.jp-OutputArea-output dl,
+.jp-OutputArea-output dt,
+.jp-OutputArea-output dd {
+ display: block;
+}
+
+.jp-OutputArea-output dl {
+ width: 100%;
+ overflow: hidden;
+ padding: 0;
+ margin: 0;
+}
+
+.jp-OutputArea-output dt {
+ font-weight: bold;
+ float: left;
+ width: 20%;
+ padding: 0;
+ margin: 0;
+}
+
+.jp-OutputArea-output dd {
+ float: left;
+ width: 80%;
+ padding: 0;
+ margin: 0;
+}
+
+.jp-TrimmedOutputs pre {
+ background: var(--jp-layout-color3);
+ font-size: calc(var(--jp-code-font-size) * 1.4);
+ text-align: center;
+ text-transform: uppercase;
+}
+
+/* Hide the gutter in case of
+ * - nested output areas (e.g. in the case of output widgets)
+ * - mirrored output areas
+ */
+.jp-OutputArea .jp-OutputArea .jp-OutputArea-prompt {
+ display: none;
+}
+
+/* Hide empty lines in the output area, for instance due to cleared widgets */
+.jp-OutputArea-prompt:empty {
+ padding: 0;
+ border: 0;
+}
+
+/*-----------------------------------------------------------------------------
+| executeResult is added to any Output-result for the display of the object
+| returned by a cell
+|----------------------------------------------------------------------------*/
+
+.jp-OutputArea-output.jp-OutputArea-executeResult {
+ margin-left: 0;
+ width: 100%;
+}
+
+/* Text output with the Out[] prompt needs a top padding to match the
+ * alignment of the Out[] prompt itself.
+ */
+.jp-OutputArea-executeResult .jp-RenderedText.jp-OutputArea-output {
+ padding-top: var(--jp-code-padding);
+ border-top: var(--jp-border-width) solid transparent;
+}
+
+/*-----------------------------------------------------------------------------
+| The Stdin output
+|----------------------------------------------------------------------------*/
+
+.jp-Stdin-prompt {
+ color: var(--jp-content-font-color0);
+ padding-right: var(--jp-code-padding);
+ vertical-align: baseline;
+ flex: 0 0 auto;
+}
+
+.jp-Stdin-input {
+ font-family: var(--jp-code-font-family);
+ font-size: inherit;
+ color: inherit;
+ background-color: inherit;
+ width: 42%;
+ min-width: 200px;
+
+ /* make sure input baseline aligns with prompt */
+ vertical-align: baseline;
+
+ /* padding + margin = 0.5em between prompt and cursor */
+ padding: 0 0.25em;
+ margin: 0 0.25em;
+ flex: 0 0 70%;
+}
+
+.jp-Stdin-input::placeholder {
+ opacity: 0;
+}
+
+.jp-Stdin-input:focus {
+ box-shadow: none;
+}
+
+.jp-Stdin-input:focus::placeholder {
+ opacity: 1;
+}
+
+/*-----------------------------------------------------------------------------
+| Output Area View
+|----------------------------------------------------------------------------*/
+
+.jp-LinkedOutputView .jp-OutputArea {
+ height: 100%;
+ display: block;
+}
+
+.jp-LinkedOutputView .jp-OutputArea-output:only-child {
+ height: 100%;
+}
+
+/*-----------------------------------------------------------------------------
+| Printing
+|----------------------------------------------------------------------------*/
+
+@media print {
+ .jp-OutputArea-child {
+ break-inside: avoid-page;
+ }
+}
+
+/*-----------------------------------------------------------------------------
+| Mobile
+|----------------------------------------------------------------------------*/
+@media only screen and (max-width: 760px) {
+ .jp-OutputPrompt {
+ display: table-row;
+ text-align: left;
+ }
+
+ .jp-OutputArea-child .jp-OutputArea-output {
+ display: table-row;
+ margin-left: var(--jp-notebook-padding);
+ }
+}
+
+/* Trimmed outputs warning */
+.jp-TrimmedOutputs > a {
+ margin: 10px;
+ text-decoration: none;
+ cursor: pointer;
+}
+
+.jp-TrimmedOutputs > a:hover {
+ text-decoration: none;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/*-----------------------------------------------------------------------------
+| Table of Contents
+|----------------------------------------------------------------------------*/
+
+:root {
+ --jp-private-toc-active-width: 4px;
+}
+
+.jp-TableOfContents {
+ display: flex;
+ flex-direction: column;
+ background: var(--jp-layout-color1);
+ color: var(--jp-ui-font-color1);
+ font-size: var(--jp-ui-font-size1);
+ height: 100%;
+}
+
+.jp-TableOfContents-placeholder {
+ text-align: center;
+}
+
+.jp-TableOfContents-placeholderContent {
+ color: var(--jp-content-font-color2);
+ padding: 8px;
+}
+
+.jp-TableOfContents-placeholderContent > h3 {
+ margin-bottom: var(--jp-content-heading-margin-bottom);
+}
+
+.jp-TableOfContents .jp-SidePanel-content {
+ overflow-y: auto;
+}
+
+.jp-TableOfContents-tree {
+ margin: 4px;
+}
+
+.jp-TableOfContents ol {
+ list-style-type: none;
+}
+
+/* stylelint-disable-next-line selector-max-type */
+.jp-TableOfContents li > ol {
+ /* Align left border with triangle icon center */
+ padding-left: 11px;
+}
+
+.jp-TableOfContents-content {
+ /* left margin for the active heading indicator */
+ margin: 0 0 0 var(--jp-private-toc-active-width);
+ padding: 0;
+ background-color: var(--jp-layout-color1);
+}
+
+.jp-tocItem {
+ -webkit-user-select: none;
+ -moz-user-select: none;
+ -ms-user-select: none;
+ user-select: none;
+}
+
+.jp-tocItem-heading {
+ display: flex;
+ cursor: pointer;
+}
+
+.jp-tocItem-heading:hover {
+ background-color: var(--jp-layout-color2);
+}
+
+.jp-tocItem-content {
+ display: block;
+ padding: 4px 0;
+ white-space: nowrap;
+ text-overflow: ellipsis;
+ overflow-x: hidden;
+}
+
+.jp-tocItem-collapser {
+ height: 20px;
+ margin: 2px 2px 0;
+ padding: 0;
+ background: none;
+ border: none;
+ cursor: pointer;
+}
+
+.jp-tocItem-collapser:hover {
+ background-color: var(--jp-layout-color3);
+}
+
+/* Active heading indicator */
+
+.jp-tocItem-heading::before {
+ content: ' ';
+ background: transparent;
+ width: var(--jp-private-toc-active-width);
+ height: 24px;
+ position: absolute;
+ left: 0;
+ border-radius: var(--jp-border-radius);
+}
+
+.jp-tocItem-heading.jp-tocItem-active::before {
+ background-color: var(--jp-brand-color1);
+}
+
+.jp-tocItem-heading:hover.jp-tocItem-active::before {
+ background: var(--jp-brand-color0);
+ opacity: 1;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+.jp-Collapser {
+ flex: 0 0 var(--jp-cell-collapser-width);
+ padding: 0;
+ margin: 0;
+ border: none;
+ outline: none;
+ background: transparent;
+ border-radius: var(--jp-border-radius);
+ opacity: 1;
+}
+
+.jp-Collapser-child {
+ display: block;
+ width: 100%;
+ box-sizing: border-box;
+
+ /* height: 100% doesn't work because the height of its parent is computed from content */
+ position: absolute;
+ top: 0;
+ bottom: 0;
+}
+
+/*-----------------------------------------------------------------------------
+| Printing
+|----------------------------------------------------------------------------*/
+
+/*
+Hiding collapsers in print mode.
+
+Note: input and output wrappers have "display: block" propery in print mode.
+*/
+
+@media print {
+ .jp-Collapser {
+ display: none;
+ }
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/*-----------------------------------------------------------------------------
+| Header/Footer
+|----------------------------------------------------------------------------*/
+
+/* Hidden by zero height by default */
+.jp-CellHeader,
+.jp-CellFooter {
+ height: 0;
+ width: 100%;
+ padding: 0;
+ margin: 0;
+ border: none;
+ outline: none;
+ background: transparent;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/*-----------------------------------------------------------------------------
+| Input
+|----------------------------------------------------------------------------*/
+
+/* All input areas */
+.jp-InputArea {
+ display: table;
+ table-layout: fixed;
+ width: 100%;
+ overflow: hidden;
+}
+
+.jp-InputArea-editor {
+ display: table-cell;
+ overflow: hidden;
+ vertical-align: top;
+
+ /* This is the non-active, default styling */
+ border: var(--jp-border-width) solid var(--jp-cell-editor-border-color);
+ border-radius: 0;
+ background: var(--jp-cell-editor-background);
+}
+
+.jp-InputPrompt {
+ display: table-cell;
+ vertical-align: top;
+ width: var(--jp-cell-prompt-width);
+ color: var(--jp-cell-inprompt-font-color);
+ font-family: var(--jp-cell-prompt-font-family);
+ padding: var(--jp-code-padding);
+ letter-spacing: var(--jp-cell-prompt-letter-spacing);
+ opacity: var(--jp-cell-prompt-opacity);
+ line-height: var(--jp-code-line-height);
+ font-size: var(--jp-code-font-size);
+ border: var(--jp-border-width) solid transparent;
+
+ /* Right align prompt text, don't wrap to handle large prompt numbers */
+ text-align: right;
+ white-space: nowrap;
+ overflow: hidden;
+ text-overflow: ellipsis;
+
+ /* Disable text selection */
+ -webkit-user-select: none;
+ -moz-user-select: none;
+ -ms-user-select: none;
+ user-select: none;
+}
+
+/*-----------------------------------------------------------------------------
+| Mobile
+|----------------------------------------------------------------------------*/
+@media only screen and (max-width: 760px) {
+ .jp-InputArea-editor {
+ display: table-row;
+ margin-left: var(--jp-notebook-padding);
+ }
+
+ .jp-InputPrompt {
+ display: table-row;
+ text-align: left;
+ }
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/*-----------------------------------------------------------------------------
+| Placeholder
+|----------------------------------------------------------------------------*/
+
+.jp-Placeholder {
+ display: table;
+ table-layout: fixed;
+ width: 100%;
+}
+
+.jp-Placeholder-prompt {
+ display: table-cell;
+ box-sizing: border-box;
+}
+
+.jp-Placeholder-content {
+ display: table-cell;
+ padding: 4px 6px;
+ border: 1px solid transparent;
+ border-radius: 0;
+ background: none;
+ box-sizing: border-box;
+ cursor: pointer;
+}
+
+.jp-Placeholder-contentContainer {
+ display: flex;
+}
+
+.jp-Placeholder-content:hover,
+.jp-InputPlaceholder > .jp-Placeholder-content:hover {
+ border-color: var(--jp-layout-color3);
+}
+
+.jp-Placeholder-content .jp-MoreHorizIcon {
+ width: 32px;
+ height: 16px;
+ border: 1px solid transparent;
+ border-radius: var(--jp-border-radius);
+}
+
+.jp-Placeholder-content .jp-MoreHorizIcon:hover {
+ border: 1px solid var(--jp-border-color1);
+ box-shadow: 0 0 2px 0 rgba(0, 0, 0, 0.25);
+ background-color: var(--jp-layout-color0);
+}
+
+.jp-PlaceholderText {
+ white-space: nowrap;
+ overflow-x: hidden;
+ color: var(--jp-inverse-layout-color3);
+ font-family: var(--jp-code-font-family);
+}
+
+.jp-InputPlaceholder > .jp-Placeholder-content {
+ border-color: var(--jp-cell-editor-border-color);
+ background: var(--jp-cell-editor-background);
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/*-----------------------------------------------------------------------------
+| Private CSS variables
+|----------------------------------------------------------------------------*/
+
+:root {
+ --jp-private-cell-scrolling-output-offset: 5px;
+}
+
+/*-----------------------------------------------------------------------------
+| Cell
+|----------------------------------------------------------------------------*/
+
+.jp-Cell {
+ padding: var(--jp-cell-padding);
+ margin: 0;
+ border: none;
+ outline: none;
+ background: transparent;
+}
+
+/*-----------------------------------------------------------------------------
+| Common input/output
+|----------------------------------------------------------------------------*/
+
+.jp-Cell-inputWrapper,
+.jp-Cell-outputWrapper {
+ display: flex;
+ flex-direction: row;
+ padding: 0;
+ margin: 0;
+
+ /* Added to reveal the box-shadow on the input and output collapsers. */
+ overflow: visible;
+}
+
+/* Only input/output areas inside cells */
+.jp-Cell-inputArea,
+.jp-Cell-outputArea {
+ flex: 1 1 auto;
+}
+
+/*-----------------------------------------------------------------------------
+| Collapser
+|----------------------------------------------------------------------------*/
+
+/* Make the output collapser disappear when there is not output, but do so
+ * in a manner that leaves it in the layout and preserves its width.
+ */
+.jp-Cell.jp-mod-noOutputs .jp-Cell-outputCollapser {
+ border: none !important;
+ background: transparent !important;
+}
+
+.jp-Cell:not(.jp-mod-noOutputs) .jp-Cell-outputCollapser {
+ min-height: var(--jp-cell-collapser-min-height);
+}
+
+/*-----------------------------------------------------------------------------
+| Output
+|----------------------------------------------------------------------------*/
+
+/* Put a space between input and output when there IS output */
+.jp-Cell:not(.jp-mod-noOutputs) .jp-Cell-outputWrapper {
+ margin-top: 5px;
+}
+
+.jp-CodeCell.jp-mod-outputsScrolled .jp-Cell-outputArea {
+ overflow-y: auto;
+ max-height: 24em;
+ margin-left: var(--jp-private-cell-scrolling-output-offset);
+ resize: vertical;
+}
+
+.jp-CodeCell.jp-mod-outputsScrolled .jp-Cell-outputArea[style*='height'] {
+ max-height: unset;
+}
+
+.jp-CodeCell.jp-mod-outputsScrolled .jp-Cell-outputArea::after {
+ content: ' ';
+ box-shadow: inset 0 0 6px 2px rgb(0 0 0 / 30%);
+ width: 100%;
+ height: 100%;
+ position: sticky;
+ bottom: 0;
+ top: 0;
+ margin-top: -50%;
+ float: left;
+ display: block;
+ pointer-events: none;
+}
+
+.jp-CodeCell.jp-mod-outputsScrolled .jp-OutputArea-child {
+ padding-top: 6px;
+}
+
+.jp-CodeCell.jp-mod-outputsScrolled .jp-OutputArea-prompt {
+ width: calc(
+ var(--jp-cell-prompt-width) - var(--jp-private-cell-scrolling-output-offset)
+ );
+}
+
+.jp-CodeCell.jp-mod-outputsScrolled .jp-OutputArea-promptOverlay {
+ left: calc(-1 * var(--jp-private-cell-scrolling-output-offset));
+}
+
+/*-----------------------------------------------------------------------------
+| CodeCell
+|----------------------------------------------------------------------------*/
+
+/*-----------------------------------------------------------------------------
+| MarkdownCell
+|----------------------------------------------------------------------------*/
+
+.jp-MarkdownOutput {
+ display: table-cell;
+ width: 100%;
+ margin-top: 0;
+ margin-bottom: 0;
+ padding-left: var(--jp-code-padding);
+}
+
+.jp-MarkdownOutput.jp-RenderedHTMLCommon {
+ overflow: auto;
+}
+
+/* collapseHeadingButton (show always if hiddenCellsButton is _not_ shown) */
+.jp-collapseHeadingButton {
+ display: flex;
+ min-height: var(--jp-cell-collapser-min-height);
+ font-size: var(--jp-code-font-size);
+ position: absolute;
+ background-color: transparent;
+ background-size: 25px;
+ background-repeat: no-repeat;
+ background-position-x: center;
+ background-position-y: top;
+ background-image: var(--jp-icon-caret-down);
+ right: 0;
+ top: 0;
+ bottom: 0;
+}
+
+.jp-collapseHeadingButton.jp-mod-collapsed {
+ background-image: var(--jp-icon-caret-right);
+}
+
+/*
+ set the container font size to match that of content
+ so that the nested collapse buttons have the right size
+*/
+.jp-MarkdownCell .jp-InputPrompt {
+ font-size: var(--jp-content-font-size1);
+}
+
+/*
+ Align collapseHeadingButton with cell top header
+ The font sizes are identical to the ones in packages/rendermime/style/base.css
+*/
+.jp-mod-rendered .jp-collapseHeadingButton[data-heading-level='1'] {
+ font-size: var(--jp-content-font-size5);
+ background-position-y: calc(0.3 * var(--jp-content-font-size5));
+}
+
+.jp-mod-rendered .jp-collapseHeadingButton[data-heading-level='2'] {
+ font-size: var(--jp-content-font-size4);
+ background-position-y: calc(0.3 * var(--jp-content-font-size4));
+}
+
+.jp-mod-rendered .jp-collapseHeadingButton[data-heading-level='3'] {
+ font-size: var(--jp-content-font-size3);
+ background-position-y: calc(0.3 * var(--jp-content-font-size3));
+}
+
+.jp-mod-rendered .jp-collapseHeadingButton[data-heading-level='4'] {
+ font-size: var(--jp-content-font-size2);
+ background-position-y: calc(0.3 * var(--jp-content-font-size2));
+}
+
+.jp-mod-rendered .jp-collapseHeadingButton[data-heading-level='5'] {
+ font-size: var(--jp-content-font-size1);
+ background-position-y: top;
+}
+
+.jp-mod-rendered .jp-collapseHeadingButton[data-heading-level='6'] {
+ font-size: var(--jp-content-font-size0);
+ background-position-y: top;
+}
+
+/* collapseHeadingButton (show only on (hover,active) if hiddenCellsButton is shown) */
+.jp-Notebook.jp-mod-showHiddenCellsButton .jp-collapseHeadingButton {
+ display: none;
+}
+
+.jp-Notebook.jp-mod-showHiddenCellsButton
+ :is(.jp-MarkdownCell:hover, .jp-mod-active)
+ .jp-collapseHeadingButton {
+ display: flex;
+}
+
+/* showHiddenCellsButton (only show if jp-mod-showHiddenCellsButton is set, which
+is a consequence of the showHiddenCellsButton option in Notebook Settings)*/
+.jp-Notebook.jp-mod-showHiddenCellsButton .jp-showHiddenCellsButton {
+ margin-left: calc(var(--jp-cell-prompt-width) + 2 * var(--jp-code-padding));
+ margin-top: var(--jp-code-padding);
+ border: 1px solid var(--jp-border-color2);
+ background-color: var(--jp-border-color3) !important;
+ color: var(--jp-content-font-color0) !important;
+ display: flex;
+}
+
+.jp-Notebook.jp-mod-showHiddenCellsButton .jp-showHiddenCellsButton:hover {
+ background-color: var(--jp-border-color2) !important;
+}
+
+.jp-showHiddenCellsButton {
+ display: none;
+}
+
+/*-----------------------------------------------------------------------------
+| Printing
+|----------------------------------------------------------------------------*/
+
+/*
+Using block instead of flex to allow the use of the break-inside CSS property for
+cell outputs.
+*/
+
+@media print {
+ .jp-Cell-inputWrapper,
+ .jp-Cell-outputWrapper {
+ display: block;
+ }
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/*-----------------------------------------------------------------------------
+| Variables
+|----------------------------------------------------------------------------*/
+
+:root {
+ --jp-notebook-toolbar-padding: 2px 5px 2px 2px;
+}
+
+/*-----------------------------------------------------------------------------
+
+/*-----------------------------------------------------------------------------
+| Styles
+|----------------------------------------------------------------------------*/
+
+.jp-NotebookPanel-toolbar {
+ padding: var(--jp-notebook-toolbar-padding);
+
+ /* disable paint containment from lumino 2.0 default strict CSS containment */
+ contain: style size !important;
+}
+
+.jp-Toolbar-item.jp-Notebook-toolbarCellType .jp-select-wrapper.jp-mod-focused {
+ border: none;
+ box-shadow: none;
+}
+
+.jp-Notebook-toolbarCellTypeDropdown select {
+ height: 24px;
+ font-size: var(--jp-ui-font-size1);
+ line-height: 14px;
+ border-radius: 0;
+ display: block;
+}
+
+.jp-Notebook-toolbarCellTypeDropdown span {
+ top: 5px !important;
+}
+
+.jp-Toolbar-responsive-popup {
+ position: absolute;
+ height: fit-content;
+ display: flex;
+ flex-direction: row;
+ flex-wrap: wrap;
+ justify-content: flex-end;
+ border-bottom: var(--jp-border-width) solid var(--jp-toolbar-border-color);
+ box-shadow: var(--jp-toolbar-box-shadow);
+ background: var(--jp-toolbar-background);
+ min-height: var(--jp-toolbar-micro-height);
+ padding: var(--jp-notebook-toolbar-padding);
+ z-index: 1;
+ right: 0;
+ top: 0;
+}
+
+.jp-Toolbar > .jp-Toolbar-responsive-opener {
+ margin-left: auto;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/*-----------------------------------------------------------------------------
+| Variables
+|----------------------------------------------------------------------------*/
+
+/*-----------------------------------------------------------------------------
+
+/*-----------------------------------------------------------------------------
+| Styles
+|----------------------------------------------------------------------------*/
+
+.jp-Notebook-ExecutionIndicator {
+ position: relative;
+ display: inline-block;
+ height: 100%;
+ z-index: 9997;
+}
+
+.jp-Notebook-ExecutionIndicator-tooltip {
+ visibility: hidden;
+ height: auto;
+ width: max-content;
+ width: -moz-max-content;
+ background-color: var(--jp-layout-color2);
+ color: var(--jp-ui-font-color1);
+ text-align: justify;
+ border-radius: 6px;
+ padding: 0 5px;
+ position: fixed;
+ display: table;
+}
+
+.jp-Notebook-ExecutionIndicator-tooltip.up {
+ transform: translateX(-50%) translateY(-100%) translateY(-32px);
+}
+
+.jp-Notebook-ExecutionIndicator-tooltip.down {
+ transform: translateX(calc(-100% + 16px)) translateY(5px);
+}
+
+.jp-Notebook-ExecutionIndicator-tooltip.hidden {
+ display: none;
+}
+
+.jp-Notebook-ExecutionIndicator:hover .jp-Notebook-ExecutionIndicator-tooltip {
+ visibility: visible;
+}
+
+.jp-Notebook-ExecutionIndicator span {
+ font-size: var(--jp-ui-font-size1);
+ font-family: var(--jp-ui-font-family);
+ color: var(--jp-ui-font-color1);
+ line-height: 24px;
+ display: block;
+}
+
+.jp-Notebook-ExecutionIndicator-progress-bar {
+ display: flex;
+ justify-content: center;
+ height: 100%;
+}
+
+/*
+ * Copyright (c) Jupyter Development Team.
+ * Distributed under the terms of the Modified BSD License.
+ */
+
+/*
+ * Execution indicator
+ */
+.jp-tocItem-content::after {
+ content: '';
+
+ /* Must be identical to form a circle */
+ width: 12px;
+ height: 12px;
+ background: none;
+ border: none;
+ position: absolute;
+ right: 0;
+}
+
+.jp-tocItem-content[data-running='0']::after {
+ border-radius: 50%;
+ border: var(--jp-border-width) solid var(--jp-inverse-layout-color3);
+ background: none;
+}
+
+.jp-tocItem-content[data-running='1']::after {
+ border-radius: 50%;
+ border: var(--jp-border-width) solid var(--jp-inverse-layout-color3);
+ background-color: var(--jp-inverse-layout-color3);
+}
+
+.jp-tocItem-content[data-running='0'],
+.jp-tocItem-content[data-running='1'] {
+ margin-right: 12px;
+}
+
+/*
+ * Copyright (c) Jupyter Development Team.
+ * Distributed under the terms of the Modified BSD License.
+ */
+
+.jp-Notebook-footer {
+ height: 27px;
+ margin-left: calc(
+ var(--jp-cell-prompt-width) + var(--jp-cell-collapser-width) +
+ var(--jp-cell-padding)
+ );
+ width: calc(
+ 100% -
+ (
+ var(--jp-cell-prompt-width) + var(--jp-cell-collapser-width) +
+ var(--jp-cell-padding) + var(--jp-cell-padding)
+ )
+ );
+ border: var(--jp-border-width) solid var(--jp-cell-editor-border-color);
+ color: var(--jp-ui-font-color3);
+ margin-top: 6px;
+ background: none;
+ cursor: pointer;
+}
+
+.jp-Notebook-footer:focus {
+ border-color: var(--jp-cell-editor-active-border-color);
+}
+
+/* For devices that support hovering, hide footer until hover */
+@media (hover: hover) {
+ .jp-Notebook-footer {
+ opacity: 0;
+ }
+
+ .jp-Notebook-footer:focus,
+ .jp-Notebook-footer:hover {
+ opacity: 1;
+ }
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/*-----------------------------------------------------------------------------
+| Imports
+|----------------------------------------------------------------------------*/
+
+/*-----------------------------------------------------------------------------
+| CSS variables
+|----------------------------------------------------------------------------*/
+
+:root {
+ --jp-side-by-side-output-size: 1fr;
+ --jp-side-by-side-resized-cell: var(--jp-side-by-side-output-size);
+ --jp-private-notebook-dragImage-width: 304px;
+ --jp-private-notebook-dragImage-height: 36px;
+ --jp-private-notebook-selected-color: var(--md-blue-400);
+ --jp-private-notebook-active-color: var(--md-green-400);
+}
+
+/*-----------------------------------------------------------------------------
+| Notebook
+|----------------------------------------------------------------------------*/
+
+/* stylelint-disable selector-max-class */
+
+.jp-NotebookPanel {
+ display: block;
+ height: 100%;
+}
+
+.jp-NotebookPanel.jp-Document {
+ min-width: 240px;
+ min-height: 120px;
+}
+
+.jp-Notebook {
+ padding: var(--jp-notebook-padding);
+ outline: none;
+ overflow: auto;
+ background: var(--jp-layout-color0);
+}
+
+.jp-Notebook.jp-mod-scrollPastEnd::after {
+ display: block;
+ content: '';
+ min-height: var(--jp-notebook-scroll-padding);
+}
+
+.jp-MainAreaWidget-ContainStrict .jp-Notebook * {
+ contain: strict;
+}
+
+.jp-Notebook .jp-Cell {
+ overflow: visible;
+}
+
+.jp-Notebook .jp-Cell .jp-InputPrompt {
+ cursor: move;
+}
+
+/*-----------------------------------------------------------------------------
+| Notebook state related styling
+|
+| The notebook and cells each have states, here are the possibilities:
+|
+| - Notebook
+| - Command
+| - Edit
+| - Cell
+| - None
+| - Active (only one can be active)
+| - Selected (the cells actions are applied to)
+| - Multiselected (when multiple selected, the cursor)
+| - No outputs
+|----------------------------------------------------------------------------*/
+
+/* Command or edit modes */
+
+.jp-Notebook .jp-Cell:not(.jp-mod-active) .jp-InputPrompt {
+ opacity: var(--jp-cell-prompt-not-active-opacity);
+ color: var(--jp-cell-prompt-not-active-font-color);
+}
+
+.jp-Notebook .jp-Cell:not(.jp-mod-active) .jp-OutputPrompt {
+ opacity: var(--jp-cell-prompt-not-active-opacity);
+ color: var(--jp-cell-prompt-not-active-font-color);
+}
+
+/* cell is active */
+.jp-Notebook .jp-Cell.jp-mod-active .jp-Collapser {
+ background: var(--jp-brand-color1);
+}
+
+/* cell is dirty */
+.jp-Notebook .jp-Cell.jp-mod-dirty .jp-InputPrompt {
+ color: var(--jp-warn-color1);
+}
+
+.jp-Notebook .jp-Cell.jp-mod-dirty .jp-InputPrompt::before {
+ color: var(--jp-warn-color1);
+ content: '•';
+}
+
+.jp-Notebook .jp-Cell.jp-mod-active.jp-mod-dirty .jp-Collapser {
+ background: var(--jp-warn-color1);
+}
+
+/* collapser is hovered */
+.jp-Notebook .jp-Cell .jp-Collapser:hover {
+ box-shadow: var(--jp-elevation-z2);
+ background: var(--jp-brand-color1);
+ opacity: var(--jp-cell-collapser-not-active-hover-opacity);
+}
+
+/* cell is active and collapser is hovered */
+.jp-Notebook .jp-Cell.jp-mod-active .jp-Collapser:hover {
+ background: var(--jp-brand-color0);
+ opacity: 1;
+}
+
+/* Command mode */
+
+.jp-Notebook.jp-mod-commandMode .jp-Cell.jp-mod-selected {
+ background: var(--jp-notebook-multiselected-color);
+}
+
+.jp-Notebook.jp-mod-commandMode
+ .jp-Cell.jp-mod-active.jp-mod-selected:not(.jp-mod-multiSelected) {
+ background: transparent;
+}
+
+/* Edit mode */
+
+.jp-Notebook.jp-mod-editMode .jp-Cell.jp-mod-active .jp-InputArea-editor {
+ border: var(--jp-border-width) solid var(--jp-cell-editor-active-border-color);
+ box-shadow: var(--jp-input-box-shadow);
+ background-color: var(--jp-cell-editor-active-background);
+}
+
+/*-----------------------------------------------------------------------------
+| Notebook drag and drop
+|----------------------------------------------------------------------------*/
+
+.jp-Notebook-cell.jp-mod-dropSource {
+ opacity: 0.5;
+}
+
+.jp-Notebook-cell.jp-mod-dropTarget,
+.jp-Notebook.jp-mod-commandMode
+ .jp-Notebook-cell.jp-mod-active.jp-mod-selected.jp-mod-dropTarget {
+ border-top-color: var(--jp-private-notebook-selected-color);
+ border-top-style: solid;
+ border-top-width: 2px;
+}
+
+.jp-dragImage {
+ display: block;
+ flex-direction: row;
+ width: var(--jp-private-notebook-dragImage-width);
+ height: var(--jp-private-notebook-dragImage-height);
+ border: var(--jp-border-width) solid var(--jp-cell-editor-border-color);
+ background: var(--jp-cell-editor-background);
+ overflow: visible;
+}
+
+.jp-dragImage-singlePrompt {
+ box-shadow: 2px 2px 4px 0 rgba(0, 0, 0, 0.12);
+}
+
+.jp-dragImage .jp-dragImage-content {
+ flex: 1 1 auto;
+ z-index: 2;
+ font-size: var(--jp-code-font-size);
+ font-family: var(--jp-code-font-family);
+ line-height: var(--jp-code-line-height);
+ padding: var(--jp-code-padding);
+ border: var(--jp-border-width) solid var(--jp-cell-editor-border-color);
+ background: var(--jp-cell-editor-background-color);
+ color: var(--jp-content-font-color3);
+ text-align: left;
+ margin: 4px 4px 4px 0;
+}
+
+.jp-dragImage .jp-dragImage-prompt {
+ flex: 0 0 auto;
+ min-width: 36px;
+ color: var(--jp-cell-inprompt-font-color);
+ padding: var(--jp-code-padding);
+ padding-left: 12px;
+ font-family: var(--jp-cell-prompt-font-family);
+ letter-spacing: var(--jp-cell-prompt-letter-spacing);
+ line-height: 1.9;
+ font-size: var(--jp-code-font-size);
+ border: var(--jp-border-width) solid transparent;
+}
+
+.jp-dragImage-multipleBack {
+ z-index: -1;
+ position: absolute;
+ height: 32px;
+ width: 300px;
+ top: 8px;
+ left: 8px;
+ background: var(--jp-layout-color2);
+ border: var(--jp-border-width) solid var(--jp-input-border-color);
+ box-shadow: 2px 2px 4px 0 rgba(0, 0, 0, 0.12);
+}
+
+/*-----------------------------------------------------------------------------
+| Cell toolbar
+|----------------------------------------------------------------------------*/
+
+.jp-NotebookTools {
+ display: block;
+ min-width: var(--jp-sidebar-min-width);
+ color: var(--jp-ui-font-color1);
+ background: var(--jp-layout-color1);
+
+ /* This is needed so that all font sizing of children done in ems is
+ * relative to this base size */
+ font-size: var(--jp-ui-font-size1);
+ overflow: auto;
+}
+
+.jp-ActiveCellTool {
+ padding: 12px 0;
+ display: flex;
+}
+
+.jp-ActiveCellTool-Content {
+ flex: 1 1 auto;
+}
+
+.jp-ActiveCellTool .jp-ActiveCellTool-CellContent {
+ background: var(--jp-cell-editor-background);
+ border: var(--jp-border-width) solid var(--jp-cell-editor-border-color);
+ border-radius: 0;
+ min-height: 29px;
+}
+
+.jp-ActiveCellTool .jp-InputPrompt {
+ min-width: calc(var(--jp-cell-prompt-width) * 0.75);
+}
+
+.jp-ActiveCellTool-CellContent > pre {
+ padding: 5px 4px;
+ margin: 0;
+ white-space: normal;
+}
+
+.jp-MetadataEditorTool {
+ flex-direction: column;
+ padding: 12px 0;
+}
+
+.jp-RankedPanel > :not(:first-child) {
+ margin-top: 12px;
+}
+
+.jp-KeySelector select.jp-mod-styled {
+ font-size: var(--jp-ui-font-size1);
+ color: var(--jp-ui-font-color0);
+ border: var(--jp-border-width) solid var(--jp-border-color1);
+}
+
+.jp-KeySelector label,
+.jp-MetadataEditorTool label,
+.jp-NumberSetter label {
+ line-height: 1.4;
+}
+
+.jp-NotebookTools .jp-select-wrapper {
+ margin-top: 4px;
+ margin-bottom: 0;
+}
+
+.jp-NumberSetter input {
+ width: 100%;
+ margin-top: 4px;
+}
+
+.jp-NotebookTools .jp-Collapse {
+ margin-top: 16px;
+}
+
+/*-----------------------------------------------------------------------------
+| Presentation Mode (.jp-mod-presentationMode)
+|----------------------------------------------------------------------------*/
+
+.jp-mod-presentationMode .jp-Notebook {
+ --jp-content-font-size1: var(--jp-content-presentation-font-size1);
+ --jp-code-font-size: var(--jp-code-presentation-font-size);
+}
+
+.jp-mod-presentationMode .jp-Notebook .jp-Cell .jp-InputPrompt,
+.jp-mod-presentationMode .jp-Notebook .jp-Cell .jp-OutputPrompt {
+ flex: 0 0 110px;
+}
+
+/*-----------------------------------------------------------------------------
+| Side-by-side Mode (.jp-mod-sideBySide)
+|----------------------------------------------------------------------------*/
+.jp-mod-sideBySide.jp-Notebook .jp-Notebook-cell {
+ margin-top: 3em;
+ margin-bottom: 3em;
+ margin-left: 5%;
+ margin-right: 5%;
+}
+
+.jp-mod-sideBySide.jp-Notebook .jp-CodeCell {
+ display: grid;
+ grid-template-columns: minmax(0, 1fr) min-content minmax(
+ 0,
+ var(--jp-side-by-side-output-size)
+ );
+ grid-template-rows: auto minmax(0, 1fr) auto;
+ grid-template-areas:
+ 'header header header'
+ 'input handle output'
+ 'footer footer footer';
+}
+
+.jp-mod-sideBySide.jp-Notebook .jp-CodeCell.jp-mod-resizedCell {
+ grid-template-columns: minmax(0, 1fr) min-content minmax(
+ 0,
+ var(--jp-side-by-side-resized-cell)
+ );
+}
+
+.jp-mod-sideBySide.jp-Notebook .jp-CodeCell .jp-CellHeader {
+ grid-area: header;
+}
+
+.jp-mod-sideBySide.jp-Notebook .jp-CodeCell .jp-Cell-inputWrapper {
+ grid-area: input;
+}
+
+.jp-mod-sideBySide.jp-Notebook .jp-CodeCell .jp-Cell-outputWrapper {
+ /* overwrite the default margin (no vertical separation needed in side by side move */
+ margin-top: 0;
+ grid-area: output;
+}
+
+.jp-mod-sideBySide.jp-Notebook .jp-CodeCell .jp-CellFooter {
+ grid-area: footer;
+}
+
+.jp-mod-sideBySide.jp-Notebook .jp-CodeCell .jp-CellResizeHandle {
+ grid-area: handle;
+ user-select: none;
+ display: block;
+ height: 100%;
+ cursor: ew-resize;
+ padding: 0 var(--jp-cell-padding);
+}
+
+.jp-mod-sideBySide.jp-Notebook .jp-CodeCell .jp-CellResizeHandle::after {
+ content: '';
+ display: block;
+ background: var(--jp-border-color2);
+ height: 100%;
+ width: 5px;
+}
+
+.jp-mod-sideBySide.jp-Notebook
+ .jp-CodeCell.jp-mod-resizedCell
+ .jp-CellResizeHandle::after {
+ background: var(--jp-border-color0);
+}
+
+.jp-CellResizeHandle {
+ display: none;
+}
+
+/*-----------------------------------------------------------------------------
+| Placeholder
+|----------------------------------------------------------------------------*/
+
+.jp-Cell-Placeholder {
+ padding-left: 55px;
+}
+
+.jp-Cell-Placeholder-wrapper {
+ background: #fff;
+ border: 1px solid;
+ border-color: #e5e6e9 #dfe0e4 #d0d1d5;
+ border-radius: 4px;
+ -webkit-border-radius: 4px;
+ margin: 10px 15px;
+}
+
+.jp-Cell-Placeholder-wrapper-inner {
+ padding: 15px;
+ position: relative;
+}
+
+.jp-Cell-Placeholder-wrapper-body {
+ background-repeat: repeat;
+ background-size: 50% auto;
+}
+
+.jp-Cell-Placeholder-wrapper-body div {
+ background: #f6f7f8;
+ background-image: -webkit-linear-gradient(
+ left,
+ #f6f7f8 0%,
+ #edeef1 20%,
+ #f6f7f8 40%,
+ #f6f7f8 100%
+ );
+ background-repeat: no-repeat;
+ background-size: 800px 104px;
+ height: 104px;
+ position: absolute;
+ right: 15px;
+ left: 15px;
+ top: 15px;
+}
+
+div.jp-Cell-Placeholder-h1 {
+ top: 20px;
+ height: 20px;
+ left: 15px;
+ width: 150px;
+}
+
+div.jp-Cell-Placeholder-h2 {
+ left: 15px;
+ top: 50px;
+ height: 10px;
+ width: 100px;
+}
+
+div.jp-Cell-Placeholder-content-1,
+div.jp-Cell-Placeholder-content-2,
+div.jp-Cell-Placeholder-content-3 {
+ left: 15px;
+ right: 15px;
+ height: 10px;
+}
+
+div.jp-Cell-Placeholder-content-1 {
+ top: 100px;
+}
+
+div.jp-Cell-Placeholder-content-2 {
+ top: 120px;
+}
+
+div.jp-Cell-Placeholder-content-3 {
+ top: 140px;
+}
+
+</style>
+<style type="text/css">
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/*
+The following CSS variables define the main, public API for styling JupyterLab.
+These variables should be used by all plugins wherever possible. In other
+words, plugins should not define custom colors, sizes, etc unless absolutely
+necessary. This enables users to change the visual theme of JupyterLab
+by changing these variables.
+
+Many variables appear in an ordered sequence (0,1,2,3). These sequences
+are designed to work well together, so for example, `--jp-border-color1` should
+be used with `--jp-layout-color1`. The numbers have the following meanings:
+
+* 0: super-primary, reserved for special emphasis
+* 1: primary, most important under normal situations
+* 2: secondary, next most important under normal situations
+* 3: tertiary, next most important under normal situations
+
+Throughout JupyterLab, we are mostly following principles from Google's
+Material Design when selecting colors. We are not, however, following
+all of MD as it is not optimized for dense, information rich UIs.
+*/
+
+:root {
+ /* Elevation
+ *
+ * We style box-shadows using Material Design's idea of elevation. These particular numbers are taken from here:
+ *
+ * https://github.com/material-components/material-components-web
+ * https://material-components-web.appspot.com/elevation.html
+ */
+
+ /* The dark theme shadows need a bit of work, but this will probably also require work on the core layout
+ * colors used in the theme as well. */
+ --jp-shadow-base-lightness: 32;
+ --jp-shadow-umbra-color: rgba(
+ var(--jp-shadow-base-lightness),
+ var(--jp-shadow-base-lightness),
+ var(--jp-shadow-base-lightness),
+ 0.2
+ );
+ --jp-shadow-penumbra-color: rgba(
+ var(--jp-shadow-base-lightness),
+ var(--jp-shadow-base-lightness),
+ var(--jp-shadow-base-lightness),
+ 0.14
+ );
+ --jp-shadow-ambient-color: rgba(
+ var(--jp-shadow-base-lightness),
+ var(--jp-shadow-base-lightness),
+ var(--jp-shadow-base-lightness),
+ 0.12
+ );
+ --jp-elevation-z0: none;
+ --jp-elevation-z1: 0 2px 1px -1px var(--jp-shadow-umbra-color),
+ 0 1px 1px 0 var(--jp-shadow-penumbra-color),
+ 0 1px 3px 0 var(--jp-shadow-ambient-color);
+ --jp-elevation-z2: 0 3px 1px -2px var(--jp-shadow-umbra-color),
+ 0 2px 2px 0 var(--jp-shadow-penumbra-color),
+ 0 1px 5px 0 var(--jp-shadow-ambient-color);
+ --jp-elevation-z4: 0 2px 4px -1px var(--jp-shadow-umbra-color),
+ 0 4px 5px 0 var(--jp-shadow-penumbra-color),
+ 0 1px 10px 0 var(--jp-shadow-ambient-color);
+ --jp-elevation-z6: 0 3px 5px -1px var(--jp-shadow-umbra-color),
+ 0 6px 10px 0 var(--jp-shadow-penumbra-color),
+ 0 1px 18px 0 var(--jp-shadow-ambient-color);
+ --jp-elevation-z8: 0 5px 5px -3px var(--jp-shadow-umbra-color),
+ 0 8px 10px 1px var(--jp-shadow-penumbra-color),
+ 0 3px 14px 2px var(--jp-shadow-ambient-color);
+ --jp-elevation-z12: 0 7px 8px -4px var(--jp-shadow-umbra-color),
+ 0 12px 17px 2px var(--jp-shadow-penumbra-color),
+ 0 5px 22px 4px var(--jp-shadow-ambient-color);
+ --jp-elevation-z16: 0 8px 10px -5px var(--jp-shadow-umbra-color),
+ 0 16px 24px 2px var(--jp-shadow-penumbra-color),
+ 0 6px 30px 5px var(--jp-shadow-ambient-color);
+ --jp-elevation-z20: 0 10px 13px -6px var(--jp-shadow-umbra-color),
+ 0 20px 31px 3px var(--jp-shadow-penumbra-color),
+ 0 8px 38px 7px var(--jp-shadow-ambient-color);
+ --jp-elevation-z24: 0 11px 15px -7px var(--jp-shadow-umbra-color),
+ 0 24px 38px 3px var(--jp-shadow-penumbra-color),
+ 0 9px 46px 8px var(--jp-shadow-ambient-color);
+
+ /* Borders
+ *
+ * The following variables, specify the visual styling of borders in JupyterLab.
+ */
+
+ --jp-border-width: 1px;
+ --jp-border-color0: var(--md-grey-700);
+ --jp-border-color1: var(--md-grey-700);
+ --jp-border-color2: var(--md-grey-800);
+ --jp-border-color3: var(--md-grey-900);
+ --jp-inverse-border-color: var(--md-grey-600);
+ --jp-border-radius: 2px;
+
+ /* UI Fonts
+ *
+ * The UI font CSS variables are used for the typography all of the JupyterLab
+ * user interface elements that are not directly user generated content.
+ *
+ * The font sizing here is done assuming that the body font size of --jp-ui-font-size1
+ * is applied to a parent element. When children elements, such as headings, are sized
+ * in em all things will be computed relative to that body size.
+ */
+
+ --jp-ui-font-scale-factor: 1.2;
+ --jp-ui-font-size0: 0.83333em;
+ --jp-ui-font-size1: 13px; /* Base font size */
+ --jp-ui-font-size2: 1.2em;
+ --jp-ui-font-size3: 1.44em;
+ --jp-ui-font-family: system-ui, -apple-system, blinkmacsystemfont, 'Segoe UI',
+ helvetica, arial, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji',
+ 'Segoe UI Symbol';
+
+ /*
+ * Use these font colors against the corresponding main layout colors.
+ * In a light theme, these go from dark to light.
+ */
+
+ /* Defaults use Material Design specification */
+ --jp-ui-font-color0: rgba(255, 255, 255, 1);
+ --jp-ui-font-color1: rgba(255, 255, 255, 0.87);
+ --jp-ui-font-color2: rgba(255, 255, 255, 0.54);
+ --jp-ui-font-color3: rgba(255, 255, 255, 0.38);
+
+ /*
+ * Use these against the brand/accent/warn/error colors.
+ * These will typically go from light to darker, in both a dark and light theme.
+ */
+
+ --jp-ui-inverse-font-color0: rgba(0, 0, 0, 1);
+ --jp-ui-inverse-font-color1: rgba(0, 0, 0, 0.8);
+ --jp-ui-inverse-font-color2: rgba(0, 0, 0, 0.5);
+ --jp-ui-inverse-font-color3: rgba(0, 0, 0, 0.3);
+
+ /* Content Fonts
+ *
+ * Content font variables are used for typography of user generated content.
+ *
+ * The font sizing here is done assuming that the body font size of --jp-content-font-size1
+ * is applied to a parent element. When children elements, such as headings, are sized
+ * in em all things will be computed relative to that body size.
+ */
+
+ --jp-content-line-height: 1.6;
+ --jp-content-font-scale-factor: 1.2;
+ --jp-content-font-size0: 0.83333em;
+ --jp-content-font-size1: 14px; /* Base font size */
+ --jp-content-font-size2: 1.2em;
+ --jp-content-font-size3: 1.44em;
+ --jp-content-font-size4: 1.728em;
+ --jp-content-font-size5: 2.0736em;
+
+ /* This gives a magnification of about 125% in presentation mode over normal. */
+ --jp-content-presentation-font-size1: 17px;
+ --jp-content-heading-line-height: 1;
+ --jp-content-heading-margin-top: 1.2em;
+ --jp-content-heading-margin-bottom: 0.8em;
+ --jp-content-heading-font-weight: 500;
+
+ /* Defaults use Material Design specification */
+ --jp-content-font-color0: rgba(255, 255, 255, 1);
+ --jp-content-font-color1: rgba(255, 255, 255, 1);
+ --jp-content-font-color2: rgba(255, 255, 255, 0.7);
+ --jp-content-font-color3: rgba(255, 255, 255, 0.5);
+ --jp-content-link-color: var(--md-blue-300);
+ --jp-content-font-family: system-ui, -apple-system, blinkmacsystemfont,
+ 'Segoe UI', helvetica, arial, sans-serif, 'Apple Color Emoji',
+ 'Segoe UI Emoji', 'Segoe UI Symbol';
+
+ /*
+ * Code Fonts
+ *
+ * Code font variables are used for typography of code and other monospaces content.
+ */
+
+ --jp-code-font-size: 13px;
+ --jp-code-line-height: 1.3077; /* 17px for 13px base */
+ --jp-code-padding: 5px; /* 5px for 13px base, codemirror highlighting needs integer px value */
+ --jp-code-font-family-default: menlo, consolas, 'DejaVu Sans Mono', monospace;
+ --jp-code-font-family: var(--jp-code-font-family-default);
+
+ /* This gives a magnification of about 125% in presentation mode over normal. */
+ --jp-code-presentation-font-size: 16px;
+
+ /* may need to tweak cursor width if you change font size */
+ --jp-code-cursor-width0: 1.4px;
+ --jp-code-cursor-width1: 2px;
+ --jp-code-cursor-width2: 4px;
+
+ /* Layout
+ *
+ * The following are the main layout colors use in JupyterLab. In a light
+ * theme these would go from light to dark.
+ */
+
+ --jp-layout-color0: #111;
+ --jp-layout-color1: var(--md-grey-900);
+ --jp-layout-color2: var(--md-grey-800);
+ --jp-layout-color3: var(--md-grey-700);
+ --jp-layout-color4: var(--md-grey-600);
+
+ /* Inverse Layout
+ *
+ * The following are the inverse layout colors use in JupyterLab. In a light
+ * theme these would go from dark to light.
+ */
+
+ --jp-inverse-layout-color0: white;
+ --jp-inverse-layout-color1: white;
+ --jp-inverse-layout-color2: var(--md-grey-200);
+ --jp-inverse-layout-color3: var(--md-grey-400);
+ --jp-inverse-layout-color4: var(--md-grey-600);
+
+ /* Brand/accent */
+
+ --jp-brand-color0: var(--md-blue-700);
+ --jp-brand-color1: var(--md-blue-500);
+ --jp-brand-color2: var(--md-blue-300);
+ --jp-brand-color3: var(--md-blue-100);
+ --jp-brand-color4: var(--md-blue-50);
+ --jp-accent-color0: var(--md-green-700);
+ --jp-accent-color1: var(--md-green-500);
+ --jp-accent-color2: var(--md-green-300);
+ --jp-accent-color3: var(--md-green-100);
+
+ /* State colors (warn, error, success, info) */
+
+ --jp-warn-color0: var(--md-orange-700);
+ --jp-warn-color1: var(--md-orange-500);
+ --jp-warn-color2: var(--md-orange-300);
+ --jp-warn-color3: var(--md-orange-100);
+ --jp-error-color0: var(--md-red-700);
+ --jp-error-color1: var(--md-red-500);
+ --jp-error-color2: var(--md-red-300);
+ --jp-error-color3: var(--md-red-100);
+ --jp-success-color0: var(--md-green-700);
+ --jp-success-color1: var(--md-green-500);
+ --jp-success-color2: var(--md-green-300);
+ --jp-success-color3: var(--md-green-100);
+ --jp-info-color0: var(--md-cyan-700);
+ --jp-info-color1: var(--md-cyan-500);
+ --jp-info-color2: var(--md-cyan-300);
+ --jp-info-color3: var(--md-cyan-100);
+
+ /* Cell specific styles */
+
+ --jp-cell-padding: 5px;
+ --jp-cell-collapser-width: 8px;
+ --jp-cell-collapser-min-height: 20px;
+ --jp-cell-collapser-not-active-hover-opacity: 0.6;
+ --jp-cell-editor-background: var(--jp-layout-color1);
+ --jp-cell-editor-border-color: var(--md-grey-700);
+ --jp-cell-editor-box-shadow: inset 0 0 2px var(--md-blue-300);
+ --jp-cell-editor-active-background: var(--jp-layout-color0);
+ --jp-cell-editor-active-border-color: var(--jp-brand-color1);
+ --jp-cell-prompt-width: 64px;
+ --jp-cell-prompt-font-family: var(--jp-code-font-family-default);
+ --jp-cell-prompt-letter-spacing: 0;
+ --jp-cell-prompt-opacity: 1;
+ --jp-cell-prompt-not-active-opacity: 1;
+ --jp-cell-prompt-not-active-font-color: var(--md-grey-300);
+
+ /* A custom blend of MD grey and blue 600
+ * See https://meyerweb.com/eric/tools/color-blend/#546E7A:1E88E5:5:hex */
+ --jp-cell-inprompt-font-color: #307fc1;
+
+ /* A custom blend of MD grey and orange 600
+ * https://meyerweb.com/eric/tools/color-blend/#546E7A:F4511E:5:hex */
+ --jp-cell-outprompt-font-color: #bf5b3d;
+
+ /* Notebook specific styles */
+
+ --jp-notebook-padding: 10px;
+ --jp-notebook-select-background: var(--jp-layout-color1);
+ --jp-notebook-multiselected-color: rgba(33, 150, 243, 0.24);
+
+ /* The scroll padding is calculated to fill enough space at the bottom of the
+ notebook to show one single-line cell (with appropriate padding) at the top
+ when the notebook is scrolled all the way to the bottom. We also subtract one
+ pixel so that no scrollbar appears if we have just one single-line cell in the
+ notebook. This padding is to enable a 'scroll past end' feature in a notebook.
+ */
+ --jp-notebook-scroll-padding: calc(
+ 100% - var(--jp-code-font-size) * var(--jp-code-line-height) -
+ var(--jp-code-padding) - var(--jp-cell-padding) - 1px
+ );
+
+ /* Rendermime styles */
+
+ --jp-rendermime-error-background: rgba(244, 67, 54, 0.28);
+ --jp-rendermime-table-row-background: var(--md-grey-900);
+ --jp-rendermime-table-row-hover-background: rgba(3, 169, 244, 0.2);
+
+ /* Dialog specific styles */
+
+ --jp-dialog-background: rgba(0, 0, 0, 0.6);
+
+ /* Console specific styles */
+
+ --jp-console-padding: 10px;
+
+ /* Toolbar specific styles */
+
+ --jp-toolbar-border-color: var(--jp-border-color2);
+ --jp-toolbar-micro-height: 8px;
+ --jp-toolbar-background: var(--jp-layout-color1);
+ --jp-toolbar-box-shadow: 0 0 2px 0 rgba(0, 0, 0, 0.8);
+ --jp-toolbar-header-margin: 4px 4px 0 4px;
+ --jp-toolbar-active-background: var(--jp-layout-color0);
+
+ /* Statusbar specific styles */
+
+ --jp-statusbar-height: 24px;
+
+ /* Input field styles */
+
+ --jp-input-box-shadow: inset 0 0 2px var(--md-blue-300);
+ --jp-input-active-background: var(--jp-layout-color0);
+ --jp-input-hover-background: var(--jp-layout-color2);
+ --jp-input-background: var(--md-grey-800);
+ --jp-input-border-color: var(--jp-inverse-border-color);
+ --jp-input-active-border-color: var(--jp-brand-color1);
+ --jp-input-active-box-shadow-color: rgba(19, 124, 189, 0.3);
+
+ /* General editor styles */
+
+ --jp-editor-selected-background: var(--jp-layout-color2);
+ --jp-editor-selected-focused-background: rgba(33, 150, 243, 0.24);
+ --jp-editor-cursor-color: var(--jp-ui-font-color0);
+
+ /* Code mirror specific styles */
+
+ --jp-mirror-editor-keyword-color: var(--md-green-500);
+ --jp-mirror-editor-atom-color: var(--md-blue-300);
+ --jp-mirror-editor-number-color: var(--md-green-400);
+ --jp-mirror-editor-def-color: var(--md-blue-600);
+ --jp-mirror-editor-variable-color: var(--md-grey-300);
+ --jp-mirror-editor-variable-2-color: var(--md-blue-500);
+ --jp-mirror-editor-variable-3-color: var(--md-green-600);
+ --jp-mirror-editor-punctuation-color: var(--md-blue-400);
+ --jp-mirror-editor-property-color: var(--md-blue-400);
+ --jp-mirror-editor-operator-color: #a2f;
+ --jp-mirror-editor-comment-color: #408080;
+ --jp-mirror-editor-string-color: #ff7070;
+ --jp-mirror-editor-string-2-color: var(--md-purple-300);
+ --jp-mirror-editor-meta-color: #a2f;
+ --jp-mirror-editor-qualifier-color: #555;
+ --jp-mirror-editor-builtin-color: var(--md-green-600);
+ --jp-mirror-editor-bracket-color: #997;
+ --jp-mirror-editor-tag-color: var(--md-green-700);
+ --jp-mirror-editor-attribute-color: var(--md-blue-700);
+ --jp-mirror-editor-header-color: var(--md-blue-500);
+ --jp-mirror-editor-quote-color: var(--md-green-300);
+ --jp-mirror-editor-link-color: var(--md-blue-700);
+ --jp-mirror-editor-error-color: #f00;
+ --jp-mirror-editor-hr-color: #999;
+
+ /*
+ RTC user specific colors.
+ These colors are used for the cursor, username in the editor,
+ and the icon of the user.
+ */
+
+ --jp-collaborator-color1: #ad4a00;
+ --jp-collaborator-color2: #7b6a00;
+ --jp-collaborator-color3: #007e00;
+ --jp-collaborator-color4: #008772;
+ --jp-collaborator-color5: #0079b9;
+ --jp-collaborator-color6: #8b45c6;
+ --jp-collaborator-color7: #be208b;
+
+ /* Vega extension styles */
+
+ --jp-vega-background: var(--md-grey-400);
+
+ /* Sidebar-related styles */
+
+ --jp-sidebar-min-width: 250px;
+
+ /* Search-related styles */
+
+ --jp-search-toggle-off-opacity: 0.6;
+ --jp-search-toggle-hover-opacity: 0.8;
+ --jp-search-toggle-on-opacity: 1;
+ --jp-search-selected-match-background-color: rgb(255, 225, 0);
+ --jp-search-selected-match-color: black;
+ --jp-search-unselected-match-background-color: var(
+ --jp-inverse-layout-color0
+ );
+ --jp-search-unselected-match-color: var(--jp-ui-inverse-font-color0);
+
+ /* scrollbar related styles. Supports every browser except Edge. */
+
+ /* colors based on JetBrain's Darcula theme */
+
+ --jp-scrollbar-background-color: #3f4244;
+ --jp-scrollbar-thumb-color: 88, 96, 97; /* need to specify thumb color as an RGB triplet */
+ --jp-scrollbar-endpad: 3px; /* the minimum gap between the thumb and the ends of a scrollbar */
+
+ /* hacks for setting the thumb shape. These do nothing in Firefox */
+
+ --jp-scrollbar-thumb-margin: 3.5px; /* the space in between the sides of the thumb and the track */
+ --jp-scrollbar-thumb-radius: 9px; /* set to a large-ish value for rounded endcaps on the thumb */
+
+ /* Icon colors that work well with light or dark backgrounds */
+ --jp-icon-contrast-color0: var(--md-purple-600);
+ --jp-icon-contrast-color1: var(--md-green-600);
+ --jp-icon-contrast-color2: var(--md-pink-600);
+ --jp-icon-contrast-color3: var(--md-blue-600);
+
+ /* Button colors */
+ --jp-accept-color-normal: var(--md-blue-700);
+ --jp-accept-color-hover: var(--md-blue-800);
+ --jp-accept-color-active: var(--md-blue-900);
+ --jp-warn-color-normal: var(--md-red-700);
+ --jp-warn-color-hover: var(--md-red-800);
+ --jp-warn-color-active: var(--md-red-900);
+ --jp-reject-color-normal: var(--md-grey-600);
+ --jp-reject-color-hover: var(--md-grey-700);
+ --jp-reject-color-active: var(--md-grey-800);
+
+ /* File or activity icons and switch semantic variables */
+ --jp-jupyter-icon-color: #f37626;
+ --jp-notebook-icon-color: #f37626;
+ --jp-json-icon-color: var(--md-orange-500);
+ --jp-console-icon-background-color: var(--md-blue-500);
+ --jp-console-icon-color: white;
+ --jp-terminal-icon-background-color: var(--md-grey-200);
+ --jp-terminal-icon-color: var(--md-grey-800);
+ --jp-text-editor-icon-color: var(--md-grey-200);
+ --jp-inspector-icon-color: var(--md-grey-200);
+ --jp-switch-color: var(--md-grey-400);
+ --jp-switch-true-position-color: var(--md-orange-700);
+}
+</style>
+<style type="text/css">
+/* Force rendering true colors when outputing to pdf */
+* {
+ -webkit-print-color-adjust: exact;
+}
+
+/* Misc */
+a.anchor-link {
+ display: none;
+}
+
+/* Input area styling */
+.jp-InputArea {
+ overflow: hidden;
+}
+
+.jp-InputArea-editor {
+ overflow: hidden;
+}
+
+.cm-editor.cm-s-jupyter .highlight pre {
+/* weird, but --jp-code-padding defined to be 5px but 4px horizontal padding is hardcoded for pre.cm-line */
+ padding: var(--jp-code-padding) 4px;
+ margin: 0;
+
+ font-family: inherit;
+ font-size: inherit;
+ line-height: inherit;
+ color: inherit;
+
+}
+
+.jp-OutputArea-output pre {
+ line-height: inherit;
+ font-family: inherit;
+}
+
+.jp-RenderedText pre {
+ color: var(--jp-content-font-color1);
+ font-size: var(--jp-code-font-size);
+}
+
+/* Hiding the collapser by default */
+.jp-Collapser {
+ display: none;
+}
+
+@page {
+ margin: 0.5in; /* Margin for each printed piece of paper */
+}
+
+@media print {
+ .jp-Cell-inputWrapper,
+ .jp-Cell-outputWrapper {
+ display: block;
+ }
+}
+</style>
+<!-- Load mathjax -->
+<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.7/latest.js?config=TeX-AMS_CHTML-full,Safe"> </script>
+<!-- MathJax configuration -->
+<script type="text/x-mathjax-config">
+ init_mathjax = function() {
+ if (window.MathJax) {
+ // MathJax loaded
+ MathJax.Hub.Config({
+ TeX: {
+ equationNumbers: {
+ autoNumber: "AMS",
+ useLabelIds: true
+ }
+ },
+ tex2jax: {
+ inlineMath: [ ['$','$'], ["\\(","\\)"] ],
+ displayMath: [ ['$$','$$'], ["\\[","\\]"] ],
+ processEscapes: true,
+ processEnvironments: true
+ },
+ displayAlign: 'center',
+ CommonHTML: {
+ linebreaks: {
+ automatic: true
+ }
+ }
+ });
+
+ MathJax.Hub.Queue(["Typeset", MathJax.Hub]);
+ }
+ }
+ init_mathjax();
+ </script>
+<!-- End of mathjax configuration --><script type="module">
+ document.addEventListener("DOMContentLoaded", async () => {
+ const diagrams = document.querySelectorAll(".jp-Mermaid > pre.mermaid");
+ // do not load mermaidjs if not needed
+ if (!diagrams.length) {
+ return;
+ }
+ const mermaid = (await import("https://cdnjs.cloudflare.com/ajax/libs/mermaid/10.7.0/mermaid.esm.min.mjs")).default;
+ const parser = new DOMParser();
+
+ mermaid.initialize({
+ maxTextSize: 100000,
+ maxEdges: 100000,
+ startOnLoad: false,
+ fontFamily: window
+ .getComputedStyle(document.body)
+ .getPropertyValue("--jp-ui-font-family"),
+ theme: document.querySelector("body[data-jp-theme-light='true']")
+ ? "default"
+ : "dark",
+ });
+
+ let _nextMermaidId = 0;
+
+ function makeMermaidImage(svg) {
+ const img = document.createElement("img");
+ const doc = parser.parseFromString(svg, "image/svg+xml");
+ const svgEl = doc.querySelector("svg");
+ const { maxWidth } = svgEl?.style || {};
+ const firstTitle = doc.querySelector("title");
+ const firstDesc = doc.querySelector("desc");
+
+ img.setAttribute("src", `data:image/svg+xml,${encodeURIComponent(svg)}`);
+ if (maxWidth) {
+ img.width = parseInt(maxWidth);
+ }
+ if (firstTitle) {
+ img.setAttribute("alt", firstTitle.textContent);
+ }
+ if (firstDesc) {
+ const caption = document.createElement("figcaption");
+ caption.className = "sr-only";
+ caption.textContent = firstDesc.textContent;
+ return [img, caption];
+ }
+ return [img];
+ }
+
+ async function makeMermaidError(text) {
+ let errorMessage = "";
+ try {
+ await mermaid.parse(text);
+ } catch (err) {
+ errorMessage = `${err}`;
+ }
+
+ const result = document.createElement("details");
+ result.className = 'jp-RenderedMermaid-Details';
+ const summary = document.createElement("summary");
+ summary.className = 'jp-RenderedMermaid-Summary';
+ const pre = document.createElement("pre");
+ const code = document.createElement("code");
+ code.innerText = text;
+ pre.appendChild(code);
+ summary.appendChild(pre);
+ result.appendChild(summary);
+
+ const warning = document.createElement("pre");
+ warning.innerText = errorMessage;
+ result.appendChild(warning);
+ return [result];
+ }
+
+ async function renderOneMarmaid(src) {
+ const id = `jp-mermaid-${_nextMermaidId++}`;
+ const parent = src.parentNode;
+ let raw = src.textContent.trim();
+ const el = document.createElement("div");
+ el.style.visibility = "hidden";
+ document.body.appendChild(el);
+ let results = null;
+ let output = null;
+ try {
+ let { svg } = await mermaid.render(id, raw, el);
+ svg = cleanMermaidSvg(svg);
+ results = makeMermaidImage(svg);
+ output = document.createElement("figure");
+ results.map(output.appendChild, output);
+ } catch (err) {
+ parent.classList.add("jp-mod-warning");
+ results = await makeMermaidError(raw);
+ output = results[0];
+ } finally {
+ el.remove();
+ }
+ parent.classList.add("jp-RenderedMermaid");
+ parent.appendChild(output);
+ }
+
+
+ /**
+ * Post-process to ensure mermaid diagrams contain only valid SVG and XHTML.
+ */
+ function cleanMermaidSvg(svg) {
+ return svg.replace(RE_VOID_ELEMENT, replaceVoidElement);
+ }
+
+
+ /**
+ * A regular expression for all void elements, which may include attributes and
+ * a slash.
+ *
+ * @see https://developer.mozilla.org/en-US/docs/Glossary/Void_element
+ *
+ * Of these, only `<br>` is generated by Mermaid in place of `\n`,
+ * but _any_ "malformed" tag will break the SVG rendering entirely.
+ */
+ const RE_VOID_ELEMENT =
+ /<\s*(area|base|br|col|embed|hr|img|input|link|meta|param|source|track|wbr)\s*([^>]*?)\s*>/gi;
+
+ /**
+ * Ensure a void element is closed with a slash, preserving any attributes.
+ */
+ function replaceVoidElement(match, tag, rest) {
+ rest = rest.trim();
+ if (!rest.endsWith('/')) {
+ rest = `${rest} /`;
+ }
+ return `<${tag} ${rest}>`;
+ }
+
+ void Promise.all([...diagrams].map(renderOneMarmaid));
+ });
+</script>
+<style>
+ .jp-Mermaid:not(.jp-RenderedMermaid) {
+ display: none;
+ }
+
+ .jp-RenderedMermaid {
+ overflow: auto;
+ display: flex;
+ }
+
+ .jp-RenderedMermaid.jp-mod-warning {
+ width: auto;
+ padding: 0.5em;
+ margin-top: 0.5em;
+ border: var(--jp-border-width) solid var(--jp-warn-color2);
+ border-radius: var(--jp-border-radius);
+ color: var(--jp-ui-font-color1);
+ font-size: var(--jp-ui-font-size1);
+ white-space: pre-wrap;
+ word-wrap: break-word;
+ }
+
+ .jp-RenderedMermaid figure {
+ margin: 0;
+ overflow: auto;
+ max-width: 100%;
+ }
+
+ .jp-RenderedMermaid img {
+ max-width: 100%;
+ }
+
+ .jp-RenderedMermaid-Details > pre {
+ margin-top: 1em;
+ }
+
+ .jp-RenderedMermaid-Summary {
+ color: var(--jp-warn-color2);
+ }
+
+ .jp-RenderedMermaid:not(.jp-mod-warning) pre {
+ display: none;
+ }
+
+ .jp-RenderedMermaid-Summary > pre {
+ display: inline-block;
+ white-space: normal;
+ }
+</style>
+<!-- End of mermaid configuration --></head>
+<body class="jp-Notebook" data-jp-theme-light="false" data-jp-theme-name="JupyterLab Dark">
+<main>
+<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=d745c9ae-31f8-47e5-83df-42c0a39e700e">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown">
+<h1 id="Setting-up-FastAPI-with-Uvicorn-and-Openrc-to-serve-Jupyter-Notebook-generated-html-files.">Setting up FastAPI with Uvicorn and Openrc to serve Jupyter Notebook generated html files.<a class="anchor-link" href="#Setting-up-FastAPI-with-Uvicorn-and-Openrc-to-serve-Jupyter-Notebook-generated-html-files.">¶</a></h1>
+</div>
+</div>
+</div>
+</div>
+<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=5dec85d7-1ac2-4bdd-a5c4-40dc8ec80c1f">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown">
+<h2 id="Prerequisites:">Prerequisites:<a class="anchor-link" href="#Prerequisites:">¶</a></h2><ul>
+<li>system with openrc</li>
+<li>fastapi</li>
+<li>uvicorn</li>
+<li>jupyter notebook (optional)</li>
+<li>nginx</li>
+</ul>
+</div>
+</div>
+</div>
+</div>
+<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=3d5a9177-1fcd-4bc6-97dd-f85c712e8a9e">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown">
+<h2 id="Creating-FastAPI-application">Creating FastAPI application<a class="anchor-link" href="#Creating-FastAPI-application">¶</a></h2>
+</div>
+</div>
+</div>
+</div>
+<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=6f2751d9-cdfe-417e-8a30-8768e2fd828e">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown">
+<p>Create a directory for project and enter it:</p>
+</div>
+</div>
+</div>
+</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs" id="cell-id=58fe2a08-afb0-400b-a8a2-063da88a2559">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea">
+<div class="jp-InputPrompt jp-InputArea-prompt">In [ ]:</div>
+<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
+<div class="cm-editor cm-s-jupyter">
+<div class="highlight hl-ipython3"><pre><span></span><span class="err">$</span> <span class="n">mkdir</span> <span class="o">-</span><span class="n">p</span> <span class="o">~/</span><span class="n">Fastapi_blog</span><span class="o">/</span><span class="n">static</span> <span class="o">&amp;&amp;</span> <span class="n">cd</span> <span class="o">~/</span><span class="n">Fastapi_blog</span>
+</pre></div>
+</div>
+</div>
+</div>
+</div>
+</div>
+<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=2ad52653-7f16-489f-8a4b-e2fd08f90d05">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown">
+<p>Create a file containing code and html template folder and template for the main page:</p>
+</div>
+</div>
+</div>
+</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs" id="cell-id=27e461b5-279f-4143-ac69-5ef61b75e6af">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea">
+<div class="jp-InputPrompt jp-InputArea-prompt">In [ ]:</div>
+<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
+<div class="cm-editor cm-s-jupyter">
+<div class="highlight hl-ipython3"><pre><span></span><span class="err">$</span> <span class="n">touch</span> <span class="n">main</span><span class="o">.</span><span class="n">py</span>
+<span class="err">$</span> <span class="n">mkdir</span> <span class="n">templates</span>
+<span class="err">$</span> <span class="n">touch</span> <span class="n">templates</span><span class="o">/</span><span class="n">main_page</span><span class="o">.</span><span class="n">html</span>
+</pre></div>
+</div>
+</div>
+</div>
+</div>
+</div>
+<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=9c3d9c08-81ea-43b0-bea8-8486adb06d85">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown">
+<p>main_page.html can be really minimal:</p>
+</div>
+</div>
+</div>
+</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs" id="cell-id=e6a61c2c-708e-462d-b487-0ddd23b5e08a">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea">
+<div class="jp-InputPrompt jp-InputArea-prompt">In [ ]:</div>
+<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
+<div class="cm-editor cm-s-jupyter">
+<div class="highlight hl-ipython3"><pre><span></span><span class="o">&lt;</span><span class="n">html</span><span class="o">&gt;</span>
+<span class="o">&lt;</span><span class="n">body</span><span class="o">&gt;</span>
+ <span class="o">&lt;</span><span class="n">h1</span><span class="o">&gt;</span><span class="n">List</span> <span class="n">of</span> <span class="n">articles</span><span class="o">&lt;/</span><span class="n">h1</span><span class="o">&gt;</span>
+ <span class="o">&lt;</span><span class="n">h2</span><span class="o">&gt;</span><span class="n">Number</span> <span class="n">of</span> <span class="n">posts</span><span class="p">:</span> <span class="p">{{</span> <span class="n">files</span><span class="o">|</span><span class="n">length</span> <span class="p">}}</span><span class="o">&lt;/</span><span class="n">h2</span><span class="o">&gt;</span>
+ <span class="p">{</span><span class="o">%</span> <span class="k">if</span> <span class="n">files</span> <span class="o">%</span><span class="p">}</span>
+ <span class="p">{</span><span class="o">%</span> <span class="k">for</span> <span class="n">item</span> <span class="ow">in</span> <span class="n">files</span> <span class="o">%</span><span class="p">}</span>
+ <span class="o">&lt;</span><span class="n">a</span> <span class="n">href</span><span class="o">=</span><span class="s2">"static/html/{{ item }}"</span><span class="o">&gt;</span><span class="p">{{</span> <span class="n">item</span> <span class="p">}}</span><span class="o">&lt;/</span><span class="n">a</span><span class="o">&gt;&lt;</span><span class="n">br</span><span class="o">&gt;</span>
+ <span class="p">{</span><span class="o">%</span> <span class="n">endfor</span> <span class="o">%</span><span class="p">}</span>
+ <span class="p">{</span><span class="o">%</span> <span class="n">endif</span> <span class="o">%</span><span class="p">}</span>
+<span class="o">&lt;/</span><span class="n">body</span><span class="o">&gt;</span>
+<span class="o">&lt;/</span><span class="n">html</span><span class="o">&gt;</span>
+</pre></div>
+</div>
+</div>
+</div>
+</div>
+</div>
+<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=b15b4217-9343-4c73-aa44-f069f6d5e776">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown">
+<p>Create basic FastAPI application serving static files at '/'. I want that as I'll be serving if from behind Nginx reverse proxy. Prefix will be set with Nginx conf file</p>
+</div>
+</div>
+</div>
+</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs" id="cell-id=90f95ae9-4079-440e-9f40-2889541cb727">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea">
+<div class="jp-InputPrompt jp-InputArea-prompt">In [ ]:</div>
+<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
+<div class="cm-editor cm-s-jupyter">
+<div class="highlight hl-ipython3"><pre><span></span><span class="ch">#!/usr/bin/env python</span>
+
+<span class="sd">"""</span>
+<span class="sd">FastAPI site serving static html files.</span>
+<span class="sd">"""</span>
+
+<span class="kn">from</span> <span class="nn">os</span> <span class="kn">import</span> <span class="n">listdir</span>
+<span class="kn">from</span> <span class="nn">fastapi</span> <span class="kn">import</span> <span class="n">FastAPI</span>
+<span class="kn">from</span> <span class="nn">fastapi.staticfiles</span> <span class="kn">import</span> <span class="n">StaticFiles</span>
+<span class="kn">from</span> <span class="nn">fastapi</span> <span class="kn">import</span> <span class="n">FastAPI</span><span class="p">,</span> <span class="n">Request</span>
+<span class="kn">from</span> <span class="nn">fastapi.staticfiles</span> <span class="kn">import</span> <span class="n">StaticFiles</span>
+<span class="kn">from</span> <span class="nn">fastapi.templating</span> <span class="kn">import</span> <span class="n">Jinja2Templates</span>
+
+
+<span class="n">ARTICLES</span> <span class="o">=</span> <span class="s1">'static/html'</span>
+<span class="n">templates</span> <span class="o">=</span> <span class="n">Jinja2Templates</span><span class="p">(</span><span class="n">directory</span><span class="o">=</span><span class="s2">"templates"</span><span class="p">)</span>
+<span class="n">LIST_OF_ARTICLES</span> <span class="o">=</span> <span class="p">[</span><span class="n">i</span> <span class="k">for</span> <span class="n">i</span> <span class="ow">in</span> <span class="n">listdir</span><span class="p">(</span><span class="n">ARTICLES</span><span class="p">)</span> <span class="k">if</span> <span class="n">i</span><span class="o">.</span><span class="n">endswith</span><span class="p">(</span><span class="s1">'.html'</span><span class="p">)]</span>
+
+<span class="n">app</span> <span class="o">=</span> <span class="n">FastAPI</span><span class="p">()</span>
+
+<span class="n">app</span><span class="o">.</span><span class="n">mount</span><span class="p">(</span><span class="s2">"/"</span><span class="p">,</span> <span class="n">StaticFiles</span><span class="p">(</span><span class="n">directory</span><span class="o">=</span><span class="s2">"static"</span><span class="p">,</span> <span class="n">html</span><span class="o">=</span><span class="kc">True</span><span class="p">),</span> <span class="n">name</span><span class="o">=</span><span class="s2">"static"</span><span class="p">)</span>
+
+
+<span class="nd">@app</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s2">"/"</span><span class="p">)</span>
+<span class="k">async</span> <span class="k">def</span> <span class="nf">main_page</span><span class="p">(</span><span class="n">request</span><span class="p">:</span> <span class="n">Request</span><span class="p">):</span>
+<span class="w"> </span><span class="sd">"""Generate main page"""</span>
+ <span class="k">return</span> <span class="n">templates</span><span class="o">.</span><span class="n">TemplateResponse</span><span class="p">(</span>
+ <span class="s2">"main_page.html"</span><span class="p">,</span> <span class="p">{</span>
+ <span class="s2">"request"</span><span class="p">:</span> <span class="n">request</span><span class="p">,</span>
+ <span class="s2">"files"</span><span class="p">:</span> <span class="n">LIST_OF_ARTICLES</span><span class="p">,</span>
+ <span class="s2">"static"</span><span class="p">:</span> <span class="n">ARTICLES</span><span class="p">,</span>
+ <span class="p">}</span>
+ <span class="p">)</span>
+
+
+<span class="k">if</span> <span class="vm">__name__</span> <span class="o">==</span> <span class="s2">"__main__"</span><span class="p">:</span>
+ <span class="n">uvicorn</span><span class="o">.</span><span class="n">run</span><span class="p">(</span>
+ <span class="n">app</span><span class="p">,</span>
+ <span class="n">port</span><span class="o">=</span><span class="mi">8000</span><span class="p">,</span>
+ <span class="n">host</span><span class="o">=</span><span class="s1">'127.0.0.1'</span><span class="p">,</span>
+ <span class="n">log_level</span><span class="o">=</span><span class="s2">"info"</span><span class="p">,</span>
+ <span class="c1"># uds="/run/tech_blog.sock", &lt;- uncomment if you want Unix socket</span>
+ <span class="p">)</span>
+</pre></div>
+</div>
+</div>
+</div>
+</div>
+</div>
+<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=0def2ab2-e037-4997-b472-59784554d12f">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown">
+<p>Test run:</p>
+</div>
+</div>
+</div>
+</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs" id="cell-id=7e4b78e2-9412-40a0-ad23-b1ebdc32b34d">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea">
+<div class="jp-InputPrompt jp-InputArea-prompt">In [ ]:</div>
+<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
+<div class="cm-editor cm-s-jupyter">
+<div class="highlight hl-ipython3"><pre><span></span><span class="err">$</span> <span class="n">uvicorn</span> <span class="n">main</span><span class="p">:</span><span class="n">app</span> <span class="o">--</span><span class="n">reload</span>
+</pre></div>
+</div>
+</div>
+</div>
+</div>
+</div>
+<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=1ff45780-0f1a-4f8a-a50d-7c52ad08f52d">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown">
+<p>If we try to run it as regular user with 'uds="/run/tech_blog.sock"' line uncommented we should get permission denied error as we don't have rights to create files in /run.</p>
+<p>In browser, take a peek at <a href="http://localhost:8000">http://localhost:8000</a> and you should already see something.</p>
+<p>Create a file with a test html code:</p>
+</div>
+</div>
+</div>
+</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs" id="cell-id=f2cb8101-4914-494e-9c6e-222cd9cdb148">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea">
+<div class="jp-InputPrompt jp-InputArea-prompt">In [ ]:</div>
+<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
+<div class="cm-editor cm-s-jupyter">
+<div class="highlight hl-ipython3"><pre><span></span><span class="err">$</span> <span class="n">touch</span> <span class="n">static</span><span class="o">/</span><span class="n">test</span><span class="o">.</span><span class="n">html</span>
+</pre></div>
+</div>
+</div>
+</div>
+</div>
+</div>
+<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=0496d679-15a2-4610-815b-9e1b57285ebf">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown">
+<p>Put this in it:</p>
+</div>
+</div>
+</div>
+</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs" id="cell-id=3db82cd2-3f9f-4c74-b98b-2cf1b19dd353">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea">
+<div class="jp-InputPrompt jp-InputArea-prompt">In [ ]:</div>
+<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
+<div class="cm-editor cm-s-jupyter">
+<div class="highlight hl-ipython3"><pre><span></span><span class="o">&lt;</span><span class="n">html</span><span class="o">&gt;</span>
+<span class="o">&lt;</span><span class="n">body</span><span class="o">&gt;</span>
+
+<span class="o">&lt;</span><span class="n">h1</span><span class="o">&gt;</span><span class="n">Fun</span> <span class="n">stuff</span> <span class="n">comming</span> <span class="n">up</span><span class="o">&lt;/</span><span class="n">h1</span><span class="o">&gt;</span>
+<span class="o">&lt;</span><span class="n">p</span><span class="o">&gt;</span><span class="n">Bob</span><span class="s1">'s your uncle!&lt;/p&gt;</span>
+
+<span class="o">&lt;/</span><span class="n">body</span><span class="o">&gt;</span>
+<span class="o">&lt;/</span><span class="n">html</span><span class="o">&gt;</span>
+</pre></div>
+</div>
+</div>
+</div>
+</div>
+</div>
+<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=fd3b37dc-e3d3-48a0-a496-7f0060bc69c0">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown">
+<p>Visit <a href="http://localhost:8000/">http://localhost:8000/</a>
+You should see the main page with test article and you should be able to navigate to the article clicking the link.</p>
+</div>
+</div>
+</div>
+</div>
+<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=cba92c27-c741-4959-88c5-b9790de7eddf">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown">
+<h2 id="Jupyter-side-note">Jupyter side note<a class="anchor-link" href="#Jupyter-side-note">¶</a></h2>
+</div>
+</div>
+</div>
+</div>
+<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=f7fefa06-9d13-4793-8bb6-3f96f2171f25">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown">
+<p>To write stuff with Jupyter Notebook start it up:</p>
+</div>
+</div>
+</div>
+</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs" id="cell-id=f7eadb7f-e811-4bee-a8d7-68c68ec9f9ca">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea">
+<div class="jp-InputPrompt jp-InputArea-prompt">In [ ]:</div>
+<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
+<div class="cm-editor cm-s-jupyter">
+<div class="highlight hl-ipython3"><pre><span></span><span class="err">$</span> <span class="n">jupyter</span><span class="o">-</span><span class="n">notebook</span>
+</pre></div>
+</div>
+</div>
+</div>
+</div>
+</div>
+<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=d0ce0f2c-e633-4974-8ed4-1f4b3a021d6a">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown">
+<p>In browser a new tab with jupyter notebook should have started. Write your fun stuff. Save it. If you don't want to execute cell content convert to html with:</p>
+</div>
+</div>
+</div>
+</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs" id="cell-id=7a4da315-d47b-4bec-8b17-f2cbf494f4d4">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea">
+<div class="jp-InputPrompt jp-InputArea-prompt">In [ ]:</div>
+<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
+<div class="cm-editor cm-s-jupyter">
+<div class="highlight hl-ipython3"><pre><span></span><span class="err">$</span> <span class="n">jupyter</span> <span class="n">nbconvert</span> <span class="o">--</span><span class="n">to</span> <span class="n">html</span> <span class="o">&lt;</span><span class="n">path</span> <span class="n">to</span> <span class="n">your</span> <span class="n">file</span><span class="o">&gt;</span>
+</pre></div>
+</div>
+</div>
+</div>
+</div>
+</div>
+<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=80c327c4-d985-47d6-94fa-10e8e5b7d2b4">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown">
+<p>If you want to execute cell content convert with:</p>
+</div>
+</div>
+</div>
+</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs" id="cell-id=54af67cd-0d26-4373-9647-8943dec2f4ab">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea">
+<div class="jp-InputPrompt jp-InputArea-prompt">In [ ]:</div>
+<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
+<div class="cm-editor cm-s-jupyter">
+<div class="highlight hl-ipython3"><pre><span></span><span class="err">$</span> <span class="n">jupyter</span> <span class="n">nbconvert</span> <span class="o">--</span><span class="n">execute</span> <span class="o">--</span><span class="n">to</span> <span class="n">html</span> <span class="o">&lt;</span><span class="n">path</span> <span class="n">to</span> <span class="n">your</span> <span class="n">file</span><span class="o">&gt;</span>
+</pre></div>
+</div>
+</div>
+</div>
+</div>
+</div>
+<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=f8653115-4f64-40a7-9d72-0e088a607a07">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown">
+<p>Want to change theme to dark?</p>
+</div>
+</div>
+</div>
+</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs" id="cell-id=52d5866b-813d-4ef3-9886-c775e1c67d5b">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea">
+<div class="jp-InputPrompt jp-InputArea-prompt">In [ ]:</div>
+<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
+<div class="cm-editor cm-s-jupyter">
+<div class="highlight hl-ipython3"><pre><span></span><span class="err">$</span> <span class="n">jupyter</span> <span class="n">nbconvert</span> <span class="o">--</span><span class="n">execute</span> <span class="o">--</span><span class="n">to</span> <span class="n">html</span> <span class="o">&lt;</span><span class="n">path</span> <span class="n">to</span> <span class="n">your</span> <span class="n">file</span><span class="o">&gt;</span> <span class="o">--</span><span class="n">HTMLExporter</span><span class="o">.</span><span class="n">theme</span><span class="o">=</span><span class="n">dark</span>
+</pre></div>
+</div>
+</div>
+</div>
+</div>
+</div>
+<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=e73f69fc-6c8a-4617-90bd-a0e788b89756">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown">
+<p>Now put it in your <code>static</code> folder. It will be served by your FastAPI application.</p>
+</div>
+</div>
+</div>
+</div>
+<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=c56ef398-9f2e-4253-bc37-22b5926b8c7c">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown">
+<h2 id="Bash-script">Bash script<a class="anchor-link" href="#Bash-script">¶</a></h2>
+</div>
+</div>
+</div>
+</div>
+<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=f37aba78-c09b-4807-ba02-c72f48b9dba5">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown">
+<p>In order to run our python script with Openrc first we need to create a Bash script:</p>
+</div>
+</div>
+</div>
+</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs" id="cell-id=6f4052ac-f582-47fa-b702-34f1341dec88">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea">
+<div class="jp-InputPrompt jp-InputArea-prompt">In [ ]:</div>
+<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
+<div class="cm-editor cm-s-jupyter">
+<div class="highlight hl-ipython3"><pre><span></span><span class="ch">#!/usr/bin/env bash</span>
+
+<span class="n">cd</span> <span class="o">/</span><span class="n">home</span><span class="o">/</span><span class="n">discordia</span><span class="o">/</span><span class="n">Fastapi_blog</span> <span class="o">||</span> <span class="n">exit</span> <span class="c1"># If your login is different, change home directory name.</span>
+<span class="n">exec</span> <span class="n">python</span> <span class="n">main</span><span class="o">.</span><span class="n">py</span>
+</pre></div>
+</div>
+</div>
+</div>
+</div>
+</div>
+<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=dedf511e-f6fd-4c41-8b02-a2eb25e9604a">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown">
+<p>Save it (here as fastapi_blog.sh) as a root user to /usr/local/bin and make executable:</p>
+</div>
+</div>
+</div>
+</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs" id="cell-id=7c6e7b2d-33a3-4305-917b-c24155a648f2">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea">
+<div class="jp-InputPrompt jp-InputArea-prompt">In [ ]:</div>
+<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
+<div class="cm-editor cm-s-jupyter">
+<div class="highlight hl-ipython3"><pre><span></span><span class="c1"># chmod ugo+x /usr/local/bin/fastapi_blog.sh</span>
+</pre></div>
+</div>
+</div>
+</div>
+</div>
+</div>
+<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=1bf1a799-25b0-4008-b1d2-1a555cef79c5">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown">
+<h2 id="Openrc-service-file">Openrc service file<a class="anchor-link" href="#Openrc-service-file">¶</a></h2>
+</div>
+</div>
+</div>
+</div>
+<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=43794484-8e10-400d-a598-d1acefd455ee">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown">
+<p>Now create a minimal service file</p>
+</div>
+</div>
+</div>
+</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs" id="cell-id=f14c6b71-3f1f-4dd8-b62d-d79721a8d6fe">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea">
+<div class="jp-InputPrompt jp-InputArea-prompt">In [ ]:</div>
+<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
+<div class="cm-editor cm-s-jupyter">
+<div class="highlight hl-ipython3"><pre><span></span><span class="ch">#!/sbin/openrc-run</span>
+
+<span class="n">supervisor</span><span class="o">=</span><span class="n">supervise</span><span class="o">-</span><span class="n">daemon</span>
+<span class="n">command</span><span class="o">=</span><span class="s2">"/usr/local/bin/fastapi_blog.sh"</span>
+<span class="n">pidfile</span><span class="o">=</span><span class="s2">"/run/$</span><span class="si">{RC_SVCNAME}</span><span class="s2">.pid"</span>
+<span class="n">command_args</span><span class="o">=</span><span class="s2">"-p $</span><span class="si">{pidfile}</span><span class="s2">"</span>
+<span class="n">command_background</span><span class="o">=</span><span class="kc">True</span>
+</pre></div>
+</div>
+</div>
+</div>
+</div>
+</div>
+<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=8982eef9-a095-4b57-b0a6-5d59ac12be78">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown">
+<p>Save it as a root user in /etc/init.d and make executable:</p>
+</div>
+</div>
+</div>
+</div>
+<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=6336a60f-6e8a-489b-8bc8-9b9e6f8e02fc">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown">
+<p>Save it as a root user in /etc/init.d and make executable:</p>
+</div>
+</div>
+</div>
+</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs" id="cell-id=445a5744-8e71-4104-8601-ad444ca0f9c1">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea">
+<div class="jp-InputPrompt jp-InputArea-prompt">In [ ]:</div>
+<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
+<div class="cm-editor cm-s-jupyter">
+<div class="highlight hl-ipython3"><pre><span></span><span class="c1"># chmod ugo+x /etc/init.d/fastapi_blog</span>
+</pre></div>
+</div>
+</div>
+</div>
+</div>
+</div>
+<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=0985e123-559c-4f9b-8bfc-7f75e9251756">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown">
+<p>You should be able to start/restart/stop it normally:</p>
+</div>
+</div>
+</div>
+</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs" id="cell-id=c856613b-8541-43e4-b7e0-1d0f2a4a6d22">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea">
+<div class="jp-InputPrompt jp-InputArea-prompt">In [ ]:</div>
+<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
+<div class="cm-editor cm-s-jupyter">
+<div class="highlight hl-ipython3"><pre><span></span><span class="c1"># rc-service fastapi_blog start</span>
+<span class="c1"># rc-service fastapi_blog restart</span>
+<span class="c1"># rc-service fastapi_blog stop</span>
+</pre></div>
+</div>
+</div>
+</div>
+</div>
+</div>
+<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=719552bc-b736-41db-939c-6a1010ca9557">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown">
+<p>If you're using Unix socket, check for existence of /run/fastapi_blog.sock.
+Else navigate to <a href="http://127.0.0.1:8000/test.html">http://127.0.0.1:8000/test.html</a> to see page is indeed there.</p>
+</div>
+</div>
+</div>
+</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs" id="cell-id=b8f408bf-120c-4adf-8e8b-3dc019a015ae">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea">
+<div class="jp-InputPrompt jp-InputArea-prompt">In [ ]:</div>
+<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
+<div class="cm-editor cm-s-jupyter">
+<div class="highlight hl-ipython3"><pre><span></span><span class="err">$</span> <span class="n">ps</span> <span class="n">aux</span> <span class="o">|</span> <span class="n">grep</span> <span class="s2">"python main.py"</span>
+</pre></div>
+</div>
+</div>
+</div>
+</div>
+</div>
+<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=13c17523-3603-4b8a-b8a2-563ae6dc27d5">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown">
+<p>You want to see only one 'python main.py'.
+At first I did not use exec which resulted in lingering processess. You don't want that.</p>
+<p>Now you can plug it in to your preffered proxy server using either a unix socket or a TCP socket.</p>
+</div>
+</div>
+</div>
+</div>
+<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=3134cb86-be0f-456c-b755-cd4f43ef2810">
+<div class="jp-Cell-inputWrapper" tabindex="0">
+<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser">
+</div>
+<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown">
+<p>If you're using unix socket, check for existence of /run/fastapi_blog.sock, else either use lsof to see what's using port 8000 or navigate to <a href="http://127.0.0.1:8000/test.html">http://127.0.0.1:8000/test.html</a></p>
+</div>
+</div>
+</div>
+</div>
+</main>
+</body>
+</html>