html, body {
    font-family: system-ui, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
    padding: 0;
    margin: 0;
    scroll-padding-top: 4rem;
}

.header {
    /*background: #fafafa;*/
}

.main {
    margin: 1rem auto;
    padding: 1rem;
    width: fit-content;
    max-width: 100%;
    box-sizing: border-box;
}

.sidebar {
    display: none;
}

.mobile-nav-container {
    border: 1px solid;
    border-radius: 4px;
    position: sticky;
    top: 1rem;
    background: Canvas;
    max-height: calc(100vh - 2rem);
    overflow-y: auto;
    box-shadow: 0 0 1px 4px white;
}

.mobile-nav-container summary {
    padding: .5rem 1rem;
}

.mobile-nav {
    padding: 0 1rem;
    line-height: 1.5;
    font-size: .875rem;
}

.mobile-nav ul {
    padding-left: 0;
    list-style-type: none;
}

.mobile-nav ul ul {
    padding-left: 1rem;
}

.mobile-nav a {
    text-decoration: none;
    color: LinkText;
}

.mobile-nav > ul > li {
    margin-bottom: .75rem;
}

.content {
    line-height: 1.375;
    max-width: 80ch;
}

h2 {
    margin-top: 2.5rem;
    border-bottom: 1px solid;
    padding-bottom: .5rem;
}

.content p code {
    background: #fafafa;
    border: 1px solid #f0f0f0;
    padding: 2px;
    border-radius: 3px;
}

blockquote {
    margin: 0;
    margin-bottom: 1rem;
    border: 1px solid;
    padding: 0 1rem;
}

blockquote cite {
    font-style: italic;
}

blockquote cite a {
    font-style: normal;
}

.content pre:not(.shiki) {
    background: #fafafa;
    border-top: 1px solid gray;
    border-bottom: 1px solid gray;
    padding: .5rem 0;
    overflow-y: auto;
}

/* for more shiki styles see shiki.css */
pre.shiki {
    padding: 1rem;
}

.footer {
    /*background: #fafafa;*/
}

table {
    border-collapse: collapse;
    border-spacing: 0;
}

table th {
    text-align: match-parent;
}

table th, table td {
    padding: .25rem;
    border-bottom: 1px solid gray;
}

@media screen and (min-width: 760px) {
    html, body {
        scroll-padding-top: 1rem;
    }

    .main {
        display: flex;
        flex-direction: row;
        gap: 3rem;
    }

    .sidebar {
        display: block;
    }

    .sidebar-nav {
        position: sticky;
        top: 1rem;
        line-height: 1.5;
        font-size: .875rem;
    }

    .sidebar-nav ul {
        padding-left: 0;
        list-style-type: none;
    }

    .sidebar-nav ul ul {
        padding-left: 1rem;
    }

    .sidebar-nav a {
        text-decoration: none;
        color: LinkText;
    }

    .sidebar-nav > ul > li {
        margin-bottom: .75rem;
    }

    .mobile-nav-container {
        display: none;
    }

    .content {
        flex: 4;
    }

    blockquote {
        margin: 1rem;
    }
}
/* See https://www.npmjs.com/package/remark-shiki-twoslash#plugin-setup */

pre.shiki {
    overflow-x: auto;
}

pre.shiki:hover .dim {
    opacity: 1;
}

pre.shiki div.dim {
    opacity: 0.5;
}

pre.shiki div.dim,
pre.shiki div.highlight {
    margin: 0;
    padding: 0;
}

pre.shiki div.highlight {
    opacity: 1;
    background-color: #f1f8ff;
}

pre.shiki div.line {
    min-height: 1rem;
}

/** Don't show the language identifiers */
pre.shiki .language-id {
    display: none;
}

/* Visually differentiates twoslash code samples  */
pre.twoslash {
    border-color: #719af4;
}

/** When you mouse over the pre, show the underlines */
pre.twoslash:hover data-lsp {
    border-color: #747474;
}

/** The tooltip-like which provides the LSP response */
pre.twoslash data-lsp:hover::before {
    content: attr(lsp);
    position: absolute;
    transform: translate(0, 1rem);

    background-color: #3f3f3f;
    color: #fff;
    text-align: left;
    padding: 5px 8px;
    border-radius: 2px;
    font-family: "JetBrains Mono", Menlo, Monaco, Consolas, Courier New, monospace;
    font-size: 14px;
    white-space: pre-wrap;
    z-index: 100;
}

pre .code-container {
    overflow: auto;
}

/* The try button */
pre .code-container>a {
    position: absolute;
    right: 8px;
    bottom: 8px;
    border-radius: 4px;
    border: 1px solid #719af4;
    padding: 0 8px;
    color: #719af4;
    text-decoration: none;
    opacity: 0;
    transition-timing-function: ease;
    transition: opacity 0.3s;
}

/* Respect no animations */
@media (prefers-reduced-motion: reduce) {
    pre .code-container>a {
        transition: none;
    }
}

pre .code-container>a:hover {
    color: white;
    background-color: #719af4;
}

pre .code-container:hover a {
    opacity: 1;
}

pre code {
    font-size: 15px;
    font-family: "JetBrains Mono", Menlo, Monaco, Consolas, Courier New, monospace;
    ;
    white-space: pre;
    -webkit-overflow-scrolling: touch;
}

pre code a {
    text-decoration: none;
}

pre data-err {
    /* Extracted from VS Code */
    background: url("data:image/svg+xml,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%206%203'%20enable-background%3D'new%200%200%206%203'%20height%3D'3'%20width%3D'6'%3E%3Cg%20fill%3D'%23c94824'%3E%3Cpolygon%20points%3D'5.5%2C0%202.5%2C3%201.1%2C3%204.1%2C0'%2F%3E%3Cpolygon%20points%3D'4%2C0%206%2C2%206%2C0.6%205.4%2C0'%2F%3E%3Cpolygon%20points%3D'0%2C2%201%2C3%202.4%2C3%200%2C0.6'%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E") repeat-x bottom left;
    padding-bottom: 3px;
}

pre .query {
    margin-bottom: 10px;
    color: #137998;
    display: inline-block;
}

/* In order to have the 'popped out' style design and to not break the layout
  /* we need to place a fake and un-selectable copy of the error which _isn't_ broken out
  /* behind the actual error message.

  /* This sections keeps both of those two in in sync  */

pre .error,
pre .error-behind {
    /* margin-left: -14px; daniel changed */
    margin-top: 8px;
    margin-bottom: 4px;
    padding: 6px;
    padding-left: 14px;
    /* width: calc(100% - 20px); daniel changed */
    white-space: pre-wrap;
    display: block;
}

pre .error {
    /* position: absolute; daniel changed */
    background-color: #fee;
    border-left: 2px solid #bf1818;
    /* Give the space to the error code */
    display: flex;
    align-items: center;
    color: black;
}

pre .error .code {
    display: none;
}

pre .error-behind {
    display: none; /* daniel changed */
    user-select: none;
    visibility: transparent;
    color: #fee;
}

/* Queries */
pre .arrow {
    /* Transparent background */
    background-color: #eee;
    position: relative;
    top: -7px;
    margin-left: 0.1rem;
    /* Edges */
    border-left: 1px solid #eee;
    border-top: 1px solid #eee;
    transform: translateY(25%) rotate(45deg);
    /* Size */
    height: 8px;
    width: 8px;
}

pre .popover {
    margin-bottom: 10px;
    background-color: #eee;
    display: inline-block;
    padding: 0 0.5rem 0.3rem;
    margin-top: 10px;
    border-radius: 3px;
}

/* Completion */
pre .inline-completions ul.dropdown {
    display: inline-block;
    position: absolute;
    width: 240px;
    background-color: gainsboro;
    color: grey;
    padding-top: 4px;
    font-family: var(--code-font);
    font-size: 0.8rem;
    margin: 0;
    padding: 0;
    border-left: 4px solid #4b9edd;
}

pre .inline-completions ul.dropdown::before {
    background-color: #4b9edd;
    width: 2px;
    position: absolute;
    top: -1.2rem;
    left: -3px;
    content: " ";
}

pre .inline-completions ul.dropdown li {
    overflow-x: hidden;
    padding-left: 4px;
    margin-bottom: 4px;
}

pre .inline-completions ul.dropdown li.deprecated {
    text-decoration: line-through;
}

pre .inline-completions ul.dropdown li span.result-found {
    color: #4b9edd;
}

pre .inline-completions ul.dropdown li span.result {
    width: 100px;
    color: black;
    display: inline-block;
}

.dark-theme .markdown pre {
    background-color: #d8d8d8;
    border-color: #ddd;
    filter: invert(98%) hue-rotate(180deg);
}

data-lsp {
    /* Ensures there's no 1px jump when the hover happens */
    border-bottom: 1px dotted transparent;
    /* Fades in unobtrusively */
    transition-timing-function: ease;
    transition: border-color 0.3s;
}

/* Respect people's wishes to not have animations */
@media (prefers-reduced-motion: reduce) {
    data-lsp {
        transition: none;
    }
}

/** Annotations support, providing a tool for meta commentary */
.tag-container {
    position: relative;
}

.tag-container .twoslash-annotation {
    position: absolute;
    font-family: "JetBrains Mono", Menlo, Monaco, Consolas, Courier New, monospace;
    right: -10px;
    /** Default annotation text to 200px */
    width: 200px;
    color: #187abf;
    background-color: #fcf3d9 bb;
}

.tag-container .twoslash-annotation p {
    text-align: left;
    font-size: 0.8rem;
    line-height: 0.9rem;
}

.tag-container .twoslash-annotation svg {
    float: left;
    margin-left: -44px;
}

.tag-container .twoslash-annotation.left {
    right: auto;
    left: -200px;
}

.tag-container .twoslash-annotation.left svg {
    float: right;
    margin-right: -5px;
}

/** Support for showing console log/warn/errors inline */
pre .logger {
    display: flex;
    align-items: center;
    color: black;
    padding: 6px;
    padding-left: 8px;
    width: calc(100% - 19px);
    white-space: pre-wrap;
}

pre .logger svg {
    margin-right: 9px;
}

pre .logger.error-log {
    background-color: #fee;
    border-left: 2px solid #bf1818;
}

pre .logger.warn-log {
    background-color: #ffe;
    border-left: 2px solid #eae662;
}

pre .logger.log-log {
    background-color: #e9e9e9;
    border-left: 2px solid #ababab;
}

pre .logger.log-log svg {
    margin-left: 6px;
    margin-right: 9px;
}
