:root {
    /* Light theme (Catppuccin Latte) */
    --bg-primary: #eff1f5;
    --text-primary: #313244;
    --text-bright: #181825;
    --text-secondary: #444763;
    --text-muted: #6c6f85;
    --text-dark: #8c8fa1;
    --text-darker: #9ca0b0;
    --link: #1e66f5; /* Blue */
    --link-visited: #7287fd; /* Lavender */
    --heading-secondary: #7287fd; /* Lavender */
    --border: #dce0e8;
    --border-table: #acb0be;
    --tag-bg: #ccd0da;
}

@media (prefers-color-scheme: dark) {
    :root {
        /* Dark theme (Catppuccin Mocha) */
        --bg-primary: #1e1e2e;
        --text-primary: #d5dbf0;
        --text-bright: #f0f0ff;
        --text-secondary: #cad3f5;
        --text-muted: #cdd6f4;
        --text-dark: #585b70;
        --text-darker: #4c4f69;
        --link: #89b4fa; /* Blue */
        --link-visited: #b4befe; /* Lavender */
        --heading-secondary: #b4befe; /* Lavender */
        --border: #181825;
        --border-table: #45475a;
        --tag-bg: #45475a;
    }
}

html, body {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    background-color: var(--bg-primary);
    color: var(--text-primary);
    font-family: system-ui, sans-serif;
    line-height: 1.6;
    text-wrap: pretty;
    padding: 1rem 2.5rem;
    max-width: 60rem;
    margin: 0 auto;
}

a {
    color: var(--link);
}

a:visited {
    color: var(--link-visited);
}

th, td {
    border-color: var(--border);
}

h1 {
    color: var(--text-bright);
}

h2 {
    color: var(--heading-secondary);
    margin-top: 3rem;
}

h3 {
    margin-top: 2rem;
    color: var(--text-secondary);
}

h2 + h3 {
    margin-top: 0;
}

h4, h5, h6 {
    color: var(--text-secondary);
}

header h1 {
    font-size: 1.2em;
    margin-left: -1.6rem;
}

header h1 a {
    text-decoration: none;
    color: var(--text-dark);
}

header h1 a:visited {
    color: var(--text-darker);
}

header h1 span {
    display: inline-block;
    width: 1.5rem;
    margin-right: 0.1rem;
}

main > p:first-of-type {
    color: var(--text-bright);
}

img {
    max-width: 100%;
    height: auto;
}

pre {
    line-height: 125%;
    padding: 0.75rem;
    overflow-x: auto;
    font-family: ui-monospace, 'Cascadia Code', 'Source Code Pro', Menlo, Consolas, 'DejaVu Sans Mono', monospace;
}

dl {
    display: grid;
    grid-template-columns: max-content auto;
    column-gap: 1em;
    row-gap: 0.25em;
}

dt {
    font-weight: bold;
    grid-column: 1;
    text-align: right;
}

dd {
    margin: 0;
    grid-column: 2;
}

table {
    border-collapse: collapse;
    border-spacing: 0;
    border:  1px solid var(--border-table);
}

th, td {
    padding: 0.35rem 0.45rem;
    border: 1px solid var(--border-table);
}

blockquote {
    color: var(--text-dark);
    border-left: 2px solid var(--text-dark);
    margin-left: 0;
    padding-left: 1rem;
    font-style: italic;
}

/* HOMEPAGE */

main.index > ul {
    padding-left: 0;
}

main.index ul {
    list-style-type: none;
}

main.index li {
    margin-bottom: 1rem;
}

.page-header {
    display: flex;
    align-items: center;
    gap: 6px;
}

.tag {
    font-size: 0.6rem;
    padding: 0.1rem 0.2rem;
    background-color: var(--tag-bg);
    color: var(--text-bright);
    border-radius: 4px;
    text-transform: uppercase;
}

main.index h3 {
    color: var(--text-muted);
}

.directory-info {
    color: var(--text-bright);
    border-left: 2px solid #cba6f7;
    padding-left: 1rem;
}

.directory-info p {
    margin: 1.5rem 0;
}

.page-description {
    font-size: 0.9rem;
    margin: 0 0 1.5rem 0;
}

/* PYGMENTS */

pre {
    line-height: 125%;
}

td.linenos, span.linenos, td.linenos .special, span.linenos.special {
    padding-left: 5px;
    padding-right: 5px;
}

:root {
}

/* Light theme (default) */
pre { background-color: #e6e9ef; border: 1px solid #ccd0da; }
td.linenos .normal { color: #4c4f69; background-color: #e6e9ef; }
span.linenos { color: #4c4f69; background-color: #e6e9ef; }
td.linenos .special { color: #4c4f69; background-color: #e6e9ef; }
span.linenos.special { color: #4c4f69; background-color: #e6e9ef; }
.hll { background-color: #ccd0da }
.c { color: #8c8fa1 } /* Comment */
.err { color: #4c4f69 } /* Error */
.g { color: #4c4f69 } /* Generic */
.k { color: #8839ef } /* Keyword */
.l { color: #4c4f69 } /* Literal */
.n { color: #4c4f69 } /* Name */
.o { color: #179299 } /* Operator */
.x { color: #4c4f69 } /* Other */
.p { color: #8c8fa1 } /* Punctuation */
.ch { color: #8c8fa1 } /* Comment.Hashbang */
.cm { color: #8c8fa1 } /* Comment.Multiline */
.cp { color: #ea76cb } /* Comment.Preproc */
.cpf { color: #8c8fa1 } /* Comment.PreprocFile */
.c1 { color: #8c8fa1 } /* Comment.Single */
.cs { color: #8c8fa1 } /* Comment.Special */
.gd { color: #d20f39 } /* Generic.Deleted */
.ge { color: #4c4f69; text-decoration: underline } /* Generic.Emph */
.ges { color: #4c4f69 } /* Generic.EmphStrong */
.gr { color: #4c4f69 } /* Generic.Error */
.gh { color: #4c4f69; font-weight: bold } /* Generic.Heading */
.gi { color: #4c4f69; font-weight: bold } /* Generic.Inserted */
.go { color: #6c6f85 } /* Generic.Output */
.gp { color: #6c6f85 } /* Generic.Prompt */
.gs { color: #4c4f69 } /* Generic.Strong */
.gu { color: #4c4f69; font-weight: bold } /* Generic.Subheading */
.gt { color: #4c4f69 } /* Generic.Traceback */
.kc { color: #8839ef } /* Keyword.Constant */
.kd { color: #8839ef; font-style: italic } /* Keyword.Declaration */
.kn { color: #8839ef } /* Keyword.Namespace */
.kp { color: #ea76cb } /* Keyword.Pseudo */
.kr { color: #8839ef } /* Keyword.Reserved */
.kt { color: #df8e1d } /* Keyword.Type */
.ld { color: #4c4f69 } /* Literal.Date */
.m { color: #fe640b } /* Literal.Number */
.s { color: #40a02b } /* Literal.String */
.na { color: #40a02b } /* Name.Attribute */
/*.nb { color: #d20f39; font-style: italic } !* Name.Builtin *!*/
.nc { color: #df8e1d } /* Name.Class */
.no { color: #4c4f69 } /* Name.Constant */
.nd { color: #4c4f69 } /* Name.Decorator */
.ni { color: #4c4f69 } /* Name.Entity */
.ne { color: #df8e1d } /* Name.Exception */
.nf { color: #1e66f5 } /* Name.Function */
.nl { color: #179299; font-style: italic } /* Name.Label */
.nn { color: #4c4f69 } /* Name.Namespace */
.nx { color: #4c4f69 } /* Name.Other */
.py { color: #4c4f69 } /* Name.Property */
.nt { color: #1e66f5 } /* Name.Tag */
.nv { color: #4c4f69; font-style: italic } /* Name.Variable */
.ow { color: #8839ef } /* Operator.Word */
.pm { color: #8c8fa1 } /* Punctuation.Marker */
.w { color: #4c4f69 } /* Text.Whitespace */
.mb { color: #fe640b } /* Literal.Number.Bin */
.mf { color: #fe640b } /* Literal.Number.Float */
.mh { color: #fe640b } /* Literal.Number.Hex */
.mi { color: #fe640b } /* Literal.Number.Integer */
.mo { color: #fe640b } /* Literal.Number.Oct */
.sa { color: #40a02b } /* Literal.String.Affix */
.sb { color: #40a02b } /* Literal.String.Backtick */
.sc { color: #40a02b } /* Literal.String.Char */
.dl { color: #40a02b } /* Literal.String.Delimiter */
.sd { color: #40a02b } /* Literal.String.Doc */
.s2 { color: #40a02b } /* Literal.String.Double */
.se { color: #ea76cb } /* Literal.String.Escape */
.sh { color: #40a02b } /* Literal.String.Heredoc */
.si { color: #40a02b } /* Literal.String.Interpol */
.sx { color: #40a02b } /* Literal.String.Other */
.sr { color: #ea76cb } /* Literal.String.Regex */
.s1 { color: #40a02b } /* Literal.String.Single */
.ss { color: #d20f39 } /* Literal.String.Symbol */
.bp { color: #d20f39; font-style: italic } /* Name.Builtin.Pseudo */
.fm { color: #1e66f5 } /* Name.Function.Magic */
.vc { color: #df8e1d; font-style: italic } /* Name.Variable.Class */
.vg { color: #4c4f69; font-style: italic } /* Name.Variable.Global */
.vi { color: #4c4f69; font-style: italic } /* Name.Variable.Instance */
.vm { color: #4c4f69; font-style: italic } /* Name.Variable.Magic */
.il { color: #fe640b } /* Literal.Number.Integer.Long */

._sp { color: #8c8fa1 } /* Smidge Prefix */
._sf { color: #6c6f85 } /* Smidge Frontmatter */
._st { color: #7287fd } /* Smidge Title */
._sc { color: #1e66f5 } /* Smidge Component */
._ss { color: #4c4f69 } /* Smidge Step */
._si { color: #4c4f69 } /* Smidge Ingredient */

@media (prefers-color-scheme: dark) {
    pre { background-color: #181825; border: 1px solid #313244; }
    td.linenos .normal { color: #cdd6f4; background-color: #181825; }
    span.linenos { color: #cdd6f4; background-color: #181825; }
    td.linenos .special { color: #cdd6f4; background-color: #181825; }
    span.linenos.special { color: #cdd6f4; background-color: #181825; }
    .hll { background-color: #313244 }
    .c { color: #9399B2 } /* Comment */
    .err { color: #CDD6F4 } /* Error */
    .g { color: #CDD6F4 } /* Generic */
    .k { color: #CBA6F7 } /* Keyword */
    .l { color: #CDD6F4 } /* Literal */
    .n { color: #CDD6F4 } /* Name */
    .o { color: #89DCEB } /* Operator */
    .x { color: #CDD6F4 } /* Other */
    .p { color: #9399B2 } /* Punctuation */
    .ch { color: #9399B2 } /* Comment.Hashbang */
    .cm { color: #9399B2 } /* Comment.Multiline */
    .cp { color: #F5C2E7 } /* Comment.Preproc */
    .cpf { color: #9399B2 } /* Comment.PreprocFile */
    .c1 { color: #9399B2 } /* Comment.Single */
    .cs { color: #9399B2 } /* Comment.Special */
    .gd { color: #F38BA8 } /* Generic.Deleted */
    .ge { color: #CDD6F4; text-decoration: underline } /* Generic.Emph */
    .ges { color: #CDD6F4 } /* Generic.EmphStrong */
    .gr { color: #CDD6F4 } /* Generic.Error */
    .gh { color: #CDD6F4; font-weight: bold } /* Generic.Heading */
    .gi { color: #CDD6F4; font-weight: bold } /* Generic.Inserted */
    .go { color: #6C7086 } /* Generic.Output */
    .gp { color: #6C7086 } /* Generic.Prompt */
    .gs { color: #CDD6F4 } /* Generic.Strong */
    .gu { color: #CDD6F4; font-weight: bold } /* Generic.Subheading */
    .gt { color: #CDD6F4 } /* Generic.Traceback */
    .kc { color: #CBA6F7 } /* Keyword.Constant */
    .kd { color: #CBA6F7; font-style: italic } /* Keyword.Declaration */
    .kn { color: #CBA6F7 } /* Keyword.Namespace */
    .kp { color: #F5C2E7 } /* Keyword.Pseudo */
    .kr { color: #CBA6F7 } /* Keyword.Reserved */
    .kt { color: #F9E2AF } /* Keyword.Type */
    .ld { color: #CDD6F4 } /* Literal.Date */
    .m { color: #FAB387 } /* Literal.Number */
    .s { color: #A6E3A1 } /* Literal.String */
    .na { color: #A6E3A1 } /* Name.Attribute */
    /*.nb { color: #F38BA8; font-style: italic } !* Name.Builtin *!*/
    .nc { color: #F9E2AF } /* Name.Class */
    .no { color: #CDD6F4 } /* Name.Constant */
    .nd { color: #CDD6F4 } /* Name.Decorator */
    .ni { color: #CDD6F4 } /* Name.Entity */
    .ne { color: #F9E2AF } /* Name.Exception */
    .nf { color: #89B4FA } /* Name.Function */
    .nl { color: #94E2D5; font-style: italic } /* Name.Label */
    .nn { color: #CDD6F4 } /* Name.Namespace */
    .nx { color: #CDD6F4 } /* Name.Other */
    .py { color: #CDD6F4 } /* Name.Property */
    .nt { color: #89B4FA } /* Name.Tag */
    .nv { color: #CDD6F4; font-style: italic } /* Name.Variable */
    .ow { color: #CBA6F7 } /* Operator.Word */
    .pm { color: #9399B2 } /* Punctuation.Marker */
    .w { color: #CDD6F4 } /* Text.Whitespace */
    .mb { color: #FAB387 } /* Literal.Number.Bin */
    .mf { color: #FAB387 } /* Literal.Number.Float */
    .mh { color: #FAB387 } /* Literal.Number.Hex */
    .mi { color: #FAB387 } /* Literal.Number.Integer */
    .mo { color: #FAB387 } /* Literal.Number.Oct */
    .sa { color: #A6E3A1 } /* Literal.String.Affix */
    .sb { color: #A6E3A1 } /* Literal.String.Backtick */
    .sc { color: #A6E3A1 } /* Literal.String.Char */
    .dl { color: #A6E3A1 } /* Literal.String.Delimiter */
    .sd { color: #A6E3A1 } /* Literal.String.Doc */
    .s2 { color: #A6E3A1 } /* Literal.String.Double */
    .se { color: #F5C2E7 } /* Literal.String.Escape */
    .sh { color: #A6E3A1 } /* Literal.String.Heredoc */
    .si { color: #A6E3A1 } /* Literal.String.Interpol */
    .sx { color: #A6E3A1 } /* Literal.String.Other */
    .sr { color: #F5C2E7 } /* Literal.String.Regex */
    .s1 { color: #A6E3A1 } /* Literal.String.Single */
    .ss { color: #F38BA8 } /* Literal.String.Symbol */
    .bp { color: #F38BA8; font-style: italic } /* Name.Builtin.Pseudo */
    .fm { color: #89B4FA } /* Name.Function.Magic */
    .vc { color: #F9E2AF; font-style: italic } /* Name.Variable.Class */
    .vg { color: #CDD6F4; font-style: italic } /* Name.Variable.Global */
    .vi { color: #CDD6F4; font-style: italic } /* Name.Variable.Instance */
    .vm { color: #CDD6F4; font-style: italic } /* Name.Variable.Magic */
    .il { color: #FAB387 } /* Literal.Number.Integer.Long */

    ._sp { color: #9399B2 } /* Smidge Prefix */
    ._sf { color: #6C7086 } /* Smidge Frontmatter */
    ._st { color: #B4BEFE } /* Smidge Title */
    ._sc { color: #89B4FA } /* Smidge Component */
    ._ss { color: #CDD6F4 } /* Smidge Step */
    ._si { color: #CDD6F4 } /* Smidge Ingredient */
}