:root {
    --primary-color: #282a2e;
    --secondary-color: #1d1f21;
    --topic-color: lightblue;
    --bluetext-color: #a039ff;
    --peetext-color: #bebe33;
    --border-color: #242424;
    --error-color: purple;
    --text-color: #c5c8c6;
    --secondary-text-color: #40dba0;
    --border-width: 0.05em;
    --border-type: solid;
    --link-color: #2c7d31;
    --post-link-valid-color: #2c7d31;
    --post-link-unloaded-color: #a039ff;
    --post-link-invalid-color: #e74c3c;
    --edge-padding: 2%;
    --animation-speed: 200ms;
    --border-radius: 0.3em;
}

body {
    width: 100%;
    height: 100vh;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
    background-color: var(--secondary-color);
    color: var(--text-color);
}

.horizontal-center {
    margin: 0;
    padding: 0;
    width: 100%;
    height: min-content;
    display: flex;
    flex-direction: row;
    justify-content: space-around;
}

.container {
    background-color: var(--primary-color);
    margin: 0;
    padding: 0;
    width: min-content;
    height: min-content;
    display: flex;
    flex-direction: column;
    justify-content: center;
    border: var(--border-width) var(--border-type) var(--border-color);
    border-radius: var(--border-radius) var(--border-radius) var(--border-radius) var(--border-radius);
}

.container h1 {
    white-space: nowrap;
    margin-inline: 0.75em;
}

.container form {
    padding: 0;
    margin-inline: 1.5em;
    margin-bottom: 1.5em;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

form * {
    margin-block: 0.2em;
}

.text-input {
    resize: none;
    box-sizing: border-box;
    width: 100%;
    height: 100%;
    border: var(--border-width) var(--border-type) var(--border-color);
    background-color: var(--secondary-color);
    color: var(--text-color);
}

form select {
    background-color: var(--secondary-color);
    color: var(--text-color);
    border: var(--border-width) var(--border-type) var(--border-color);
    padding-inline: 0.4em;
    padding-block: 0.2em;
}

form button {
    background-color: var(--secondary-color);
    color: var(--text-color);
    border: var(--border-width) var(--border-type) var(--border-color);
    padding-inline: 0.4em;
    padding-block: 0.2em;
}

#audio {
    accent-color: var(--text-color);
    background-color: var(--text-color);
}

.audio-checkbox {
    display: flex;
    justify-content: center
}

.submit {
    display: flex;
    flex-direction: row;
}

.loader {
    border: 0.2em solid var(--link-color);
    /* Light grey */
    border-top: 0.2em solid var(--text-color);
    /* Blue */
    border-radius: 50%;
    width: 0.6em;
    height: 0.6em;
    margin-block: 0.35em;
    margin-inline: 0.3em;
    animation: spin 2s linear infinite;
}

@keyframes spin {
    0% {
        transform: rotate(0deg);
    }

    100% {
        transform: rotate(360deg);
    }
}

#error-popup {
    position: fixed;
    background-color: var(--primary-color);
    color: var(--error-color);
    border: var(--border-width) var(--border-type) var(--border-color);
    border-radius: var(--border-radius) var(--border-radius) var(--border-radius) var(--border-radius);
    width: 50vw;
    text-align: center;
    bottom: 5%;
    align-self: center;
}

#error-popup span {
    padding-block: 0.5em;
    padding-inline: 0.2em;
}

#error-topbar {
    width: 100%;
    height: 100%;
    border-bottom: var(--border-width) var(--border-type) var(--border-color);
    display: flex;
    justify-content: space-between;
    padding-block: 0.1em;
}

#error-topbar #error-title {
    margin: 0;
    padding: 0;
    margin-inline: 0.2em;
}

#error-topbar #close-error-popup {
    margin: 0;
    padding: 0;
    margin-inline: 0.2em;
    width: 1.5em;
    height: 1.5em;
    color: var(--error-color);
    background-color: var(--secondary-color);
    border: var(--border-width) var(--border-type) var(--border-color);
}