*,
*::before,
*::after {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

:root {
    color-scheme: light;
    --light-color: rgb(246, 245, 244);
    --dark-color: rgb(13, 13, 13);

    --fg: var(--dark-color);
    --bg: var(--light-color);

    --default-font-size: 1rem;
    --default-border-radius: 4px;

    --spacing-large: 5rem;
    --spacing-double: calc(var(--default-font-size) * 2);
}

[data-theme="dark"] {
    color-scheme: dark;
    --light-color: rgb(230, 230, 230);
    --dark-color: rgb(43, 45, 49);

    --fg: var(--light-color);
    --bg: var(--dark-color);
}

body {
    display: flex;
    flex-direction: column;
    align-items: center;
    min-height: 100dvh;
    font-family: system-ui, sans-serif;
    line-height: 1.5;
    color: var(--fg);
    background-color: var(--bg);
    padding: 1.5rem;
}

a[href^="http"]::after {
    content: url('data:image/svg+xml;utf8,<svg width="16" height="16" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg"><path d="M8.00008 5.00005L19.0001 5.00005V16L17.0001 16L17.0001 8.41426L7.00008 18.4143L5.58586 17L15.5859 7.00005L8.00008 7.00005L8.00008 5.00005Z" fill="%238F8F8F" /></svg>');
    display: inline-block;
    position: relative;
    top: 0.2em;
    margin-block: -5px;
}

h2,
h3,
h4 {
    margin-top: 2.5em;
    margin-bottom: 0.5em;
    line-height: 1.25;
}

h2:first-child {
    margin-top: 0;
}

footer h2 {
    font-size: var(--default-font-size);
}

img {
    display: block;
    max-width: 100%;
    margin-block: var(--default-font-size);
    /* margin-inline: auto; */
    border: 1px solid rgba(0, 0, 0, 0.4);
    border-radius: 4px;
}

p {
    margin-block: var(--default-font-size);
    overflow-wrap: break-word;
    hyphens: auto;
}

ul {
    padding-left: 1.25rem;
    line-height: 1.75;
}

#ukraine-banner {
    order: -1;
    font-size: smaller;

    & p {
        margin-block: 0;
    }

    & p::before {
        content: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 36 36"><path fill="%23005BBB" d="M32 5H4C1.791 5 0 6.791 0 9v9h36V9c0-2.209-1.791-4-4-4z"/><path fill="%23FFD500" d="M36 27c0 2.209-1.791 4-4 4H4c-2.209 0-4-1.791-4-4v-9h36v9z"/></svg>');
        display: inline-block;
        position: relative;
        width: 1em;
        height: 1em;
        top: 0.15em;
        margin-right: 0.5em;
    }
}

#wrapper {
    margin-inline: auto;

    & main {
        margin-block: var(--spacing-large);
    }
}

#logo {
    display: flex;
    margin-top: var(--spacing-large);

    & h1 {
        --padding: 0.2rem;
        display: inline-block;
        font-size: calc(var(--default-font-size) * 1.5);
        line-height: 1;
        color: var(--bg);
        background-color: var(--fg);
        border-color: transparent;
        border-radius: var(--default-border-radius);
        padding: var(--padding);
        margin-left: calc(var(--padding) * -1);
    }
}

button#theme-switch {
    display: flex;
    align-items: center;
    color: var(--fg);
    background-color: var(--bg);
    border-radius: var(--default-border-radius);
    border-color: transparent;
    padding: 4px;
    margin-left: .5rem;

    @media (hover: hover) {
        &:hover {
            color: var(--bg);
            background-color: var(--fg);
            cursor: pointer;
        }
    }
}

.code {
    font-family: monospace;
    padding: 1rem;
    color: #dde;
    background-color: #222;
    border-radius: 4px;
    white-space: pre-wrap;
    word-break: break-all;
}

code:not(pre code) {
    color: #dde;
    background-color: #333;
    padding: 0.3em;
    border-radius: var(--default-border-radius);
}

[data-theme="dark"] code:not(pre code) {
    background-color: #222;
}

@media (min-width: 800px) {

    /* center visually vertical for small content */
    body::before {
        content: '';
        flex-grow: 1;
    }

    body::after {
        content: '';
        flex-grow: 2.5;
    }
}