/* Global CSS variables */

* {
    font-family: "Comfortaa", sans-serif !important;
    font-weight: 500 !important;
}

.background {
    position: fixed;
    inset: 0;

    /* Dark gradient base */
    background: radial-gradient(circle at top, #1b1b1b, #0a0a0a);

    overflow: hidden;
}

.background::before {
    content: "";
    position: absolute;
    inset: 0;

    /* Tiny SVG noise pattern */
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.25'/%3E%3C/svg%3E");

    opacity: 0.08;
    mix-blend-mode: soft-light;
    pointer-events: none;
}

body {
    background-color: transparent;
}

:root {
    margin: 0;
    min-height: 100vh;

    background:
        radial-gradient(circle, rgba(255, 255, 255, 0.03) 1px, transparent 1px),
        linear-gradient(180deg, #111, #050505);
    background-size:
        4px 4px,
        cover;

    /* Scale down the entire site because picocss uses huge size. */
    --pico-font-size: 1rem !important;

    /* Make the nav not soo tall. */
    --pico-nav-element-spacing-vertical: 0.75rem;

    --pico-border-radius: 1.5rem !important;

    --pico-muted-border-color: #303030 !important;

    --pico-card-box-shadow: transparent !important;

    --pico-blockquote-border-color: currentColor;

    --kaos-icon-padding: 0.75em;
    /*--pico-nav-element-spacing-horizontal: 0.25rem; */
    --kaos-margin-top-main: 4rem;

    --doc-border-radius-sm: 0.5rem;
    --doc-border-radius-md: 0.925rem;
    --doc-border-radius-lg: 2rem;

    /* Dark/Light Mode Independant */
    --kaos-card-background-color-main-menu: var(--pico-primary);
    --kaos-card-foreground-color-main-menu: white;
}

.card-main-menu {
    background-color: var(--kaos-card-background-color-main-menu);
}
.card-main-menu * {
    color: var(kaos-card-foreground-color-main-menu);
}

.card-map {
    background-color: var(--kaos-card-background-color-map);
}
.card-map * {
    color: var(--kaos-card-foreground-color-map);
}

.card-gray {
    background-color: var(--kaos-card-background-color-gray);
}
.card-gray * {
    color: var(--kaos-card-foreground-color-gray);
}

.card-blue {
    background-color: var(--kaos-card-background-color-blue);
}
.card-blue * {
    color: var(--kaos-card-foreground-color-blue);
}

.card-pink {
    background-color: var(--kaos-card-background-color-pink);
}
.card-pink * {
    color: var(--kaos-card-foreground-color-pink);
}

.card-purple {
    background-color: var(--kaos-card-background-color-purple);
}
.card-purple * {
    color: var(--kaos-card-foreground-color-purple);
}

.card-green {
    background-color: var(--kaos-card-background-color-green);
}
.card-green * {
    color: var(--kaos-card-foreground-color-green);
}

/* Can be forced with data-theme="light" */
[data-theme="light"],
:root:not([data-theme="dark"]),
:host:not([data-theme="dark"]) {
    background:
        radial-gradient(circle, rgba(255, 255, 255, 0.03) 1px, transparent 1px),
        linear-gradient(180deg, #fff, #eee);
    background-size:
        4px 4px,
        cover;

    --kaos-header-background-color: #f0f2f6;
    --kaos-footer-background-color: var(--kaos-header-background-color);
    --pico-header-background: rgba(255, 255, 255, 0.8);
    --pico-header-border-color: transparent;

    --kaos-logo-circle-fill: rgb(0, 0, 0);
    --kaos-logo-circle-stroke: rgb(0, 0, 0);
    --kaos-logo-glyph-stroke: rgb(255, 255, 255);

    /* Card Colors - Light Mode */

    --kaos-card-background-color-map: #eeeeee;
    --kaos-card-foreground-color-map: #cccccc;

    --kaos-card-background-color-gray: #f9f9f9;
    --kaos-card-foreground-color-gray: #686868;

    --kaos-card-background-color-blue: rgb(239 244 255);
    --kaos-card-foreground-color-blue: #2abdff;

    --kaos-card-background-color-pink: #feedfd;
    --kaos-card-foreground-color-pink: #ff37c7;

    --kaos-card-background-color-purple: #eee8fe;
    --kaos-card-foreground-color-purple: #8251fb;

    --kaos-card-background-color-green: #f1fbf9;
    --kaos-card-foreground-color-green: #02c3a0;
}

/* Orange color for dark color scheme (Auto) */
/* Automatically enabled if user has Dark mode enabled */
@media only screen and (prefers-color-scheme: dark) {
    :root:not([data-theme]),
    :host:not([data-theme]) {
        background:
            radial-gradient(
                circle,
                rgba(255, 255, 255, 0.03) 1px,
                transparent 1px
            ),
            linear-gradient(180deg, #111, #050505);
        background-size:
            4px 4px,
            cover;

        --kaos-header-background-color: rgba(19, 19, 19, 0.9) !important;
        --kaos-footer-background-color: transparent;
        --pico-header-background: rgba(0, 0, 0, 0.9);
        --pico-header-border-color: rgba(1, 1, 1, 0.9);

        /* Card Colors */

        --pico-card-background-color: rgba(252, 114, 255, 0.12) !important;
        --pico-card-background-color: rgb(31, 31, 31) !important;

        --kaos-card-background-color-map: #1f1f1f;
        --kaos-card-foreground-color-map: #2f2f2f;

        --kaos-card-background-color-gray: #1f1f1f;
        --kaos-card-foreground-color-gray: #b1b1b1;

        --kaos-card-background-color-blue: #131f31;
        --kaos-card-foreground-color-blue: #2abdff;

        --kaos-card-background-color-pink: #311f31;
        --kaos-card-foreground-color-pink: #ff37c7;

        --kaos-card-background-color-purple: #1c1922;
        --kaos-card-foreground-color-purple: #8251fb;

        --kaos-card-background-color-green: #191f1d;
        --kaos-card-foreground-color-green: #02c3a0;
    }
}

/* Orange color for dark color scheme (Forced) */
/* Enabled if forced with data-theme="dark" */
[data-theme="dark"] {
    background:
        radial-gradient(circle, rgba(255, 255, 255, 0.03) 1px, transparent 1px),
        linear-gradient(180deg, #111, #050505);
    background-size:
        4px 4px,
        cover;

    --kaos-header-background-color: rgba(19, 19, 19, 0.9) !important;
    --kaos-footer-background-color: transparent;
    --pico-header-background: rgba(0, 0, 0, 0.9);
    --pico-header-border-color: rgba(1, 1, 1, 0.9);

    --kaos-logo-circle-fill: rgb(255, 255, 255);
    --kaos-logo-circle-stroke: rgb(255, 255, 255);
    --kaos-logo-glyph-stroke: rgb(0, 0, 0);

    /* Card Colors */

    --pico-card-background-color: rgba(252, 114, 255, 0.12) !important;
    --pico-card-background-color: rgb(31, 31, 31) !important;

    --kaos-card-background-color-map: #1f1f1f;
    --kaos-card-foreground-color-map: #2f2f2f;

    --kaos-card-background-color-gray: #1f1f1f;
    --kaos-card-foreground-color-gray: #b1b1b1;

    --kaos-card-background-color-blue: #131f31;
    --kaos-card-foreground-color-blue: #2abdff;

    --kaos-card-background-color-pink: #311f31;
    --kaos-card-foreground-color-pink: #ff37c7;

    --kaos-card-background-color-purple: #1c1922;
    --kaos-card-foreground-color-purple: #8251fb;

    --kaos-card-background-color-green: #191f1d;
    --kaos-card-foreground-color-green: #02c3a0;
}

/* ------------ */

/**
 * Overflow auto
 */
.overflow-auto {
    overflow: auto;
}

details.hide-arrow > summary::after {
    display: none;
    content: none;
}

body > header {
    z-index: 999;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 9;
    /*height: 65px;*/
    margin-top: auto;
    margin-left: auto;
    margin-right: auto;
    padding: 0px;
    padding-left: 16px;
    padding-right: 16px;
    background-color: var(--kaos-header-background-color);
    background-color: transparent !important;
}

body > header.is-fixed-above-lg {
    z-index: 999;
    /*position: sticky;*/
    position: fixed;
    transition:
        border-top-color 0.4s ease-in-out,
        box-shadow 0.4s ease-in-out;
}

body > header.is-fixed-above-lg.is-fixed {
    z-index: 999;
    border-bottom: 1px solid var(--pico-muted-border-color);
    box-shadow: var(--pico-box-shadow);
    background-color: var(--kaos-header-background-color);
    -webkit-backdrop-filter: blur(1rem);
    backdrop-filter: blur(1rem);
}

body > header nav .separator:before {
    display: block;
    height: 1.125rem;
    margin-inline: var(--pico-nav-element-spacing-horizontal);
    border-left: var(--pico-border-width) solid
        var(--pico-form-element-border-color);
    content: "";
}

main.page .grid hgroup > * + * {
    margin-top: 0.5rem !important;
}

main.page .grid hgroup.text-center {
    text-align: center !important;
}

main.page .grid.kaos-bordered > div {
    margin-bottom: var(--pico-block-spacing-vertical) !important;
    padding: var(--pico-block-spacing-vertical)
        var(--pico-block-spacing-horizontal) !important;
    border-radius: var(--pico-border-radius) !important;
    background: var(--pico-card-background-color) !important;
    box-shadow: var(--pico-card-box-shadow) !important;
}

.kaos-content-header {
    margin-bottom: var(--pico-block-spacing-vertical) !important;
    padding: var(--pico-block-spacing-vertical)
        var(--pico-block-spacing-horizontal) !important;
    border-radius: var(--pico-border-radius) !important;
    background: var(--pico-card-background-color) !important;
    box-shadow: var(--pico-card-box-shadow) !important;
}

.kaos-content-header .kaos-label {
    flex-shrink: 0;
    margin-bottom: 0px;
}

/* Push down the main so it isn't under the fixed header. */
main {
    margin-top: var(--kaos-margin-top-main);
}

summary.outline.no-after::after {
    display: none;
}

.loading-blur-overlay {
    position: fixed;
    inset: 0;
    z-index: 9999;
    backdrop-filter: var(--pico-modal-overlay-backdrop-filter);
    background: rgba(0, 0, 0, 0.2);
    z-index: 9999;
    pointer-events: none;
    opacity: 0;
    transition: var(--pico-transition);
    /* Spinner */
    display: flex;
    justify-content: center;
    align-items: center;
}

.loading-blur-overlay.visible {
    opacity: 1;
    pointer-events: auto;
}

/* Pages */

.page {
    max-width: 960px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 1rem;
    padding-right: 1rem;
}

/* Footer */

.reverse-collapse {
    display: grid;
    grid-template-columns: 1fr 1fr;
}

@media (max-width: 768px) {
    .reverse-collapse {
        grid-template-columns: 1fr;
    }

    .reverse-collapse > :first-child {
        order: 2;
    }

    .reverse-collapse > :nth-child(2) {
        order: 1;
    }
}

/* Footer */

body > footer {
    padding-left: 16px;
    padding-right: 16px;
    background-color: var(--kaos-footer-background-color);
}

/* Global */
.kaos-text-center {
    text-align: center;
}

/* Navigation */

body > header > nav ul li.hide-before-sm {
    display: block;
}

body > header > nav ul li.show-after-lg {
    display: none;
}

@media (max-width: 575px) {
    body > header > nav ul li.hide-before-sm {
        display: none;
    }

    body > header > nav ul li.show-after-lg {
        display: block;
    }
}

.kaos-container-main-menu {
    position: fixed;
    z-index: 99;
    display: none;
    width: 250px;
}

/* Hero */
.kaos-hero {
    max-width: 500px;
    margin: auto;
    text-align: center;
    display: grid;
    grid-template-columns: 1fr;
    row-gap: 12px;
    justify-items: center;
    margin-bottom: 0;
}
