:root {
    --text-color: black;
    --message-background-color: yellow;
    --background-color: white;
    --text-background-color: #e8b5ff;
    --element-background-color: #ec8dff;
    --hard-color: black;
    --soft-color: grey;

    --outer-width: min(1000px, 90vw);
    --inner-width: min(500px, 75%)
}

.messages {
    padding: 0;
    
    & .message {
        list-style: none;
        background-color: var(--message-background-color);
        padding: 4px;
        width: fit-content;
        margin: 2px 0px;
    }
}

body {
    margin: 0 auto;
    padding: 0px 0px 24px 0px;
    width: var(--outer-width);
    background-color: var(--background-color);
}

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

    & h1 {
        text-decoration: underline;
    }
}

nav {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;

    background-color: var(--element-background-color);
    border: 1px solid var(--hard-color);

    padding: 0px 12px;
    border-radius: 6px;

    & div ul {
        display: flex;
        padding: 0;
        gap: 8px;
    }

    & li {
        list-style: none;
        background-color: var(--text-background-color);
        border: 1px solid var(--soft-color);

        padding: 6px;
        border-radius: 12px;
    }
}

.form {
    display: flex;
    flex-direction: column;
    gap: 6px;
    
    margin: 0 auto;
    width: var(--inner-width);

    & input[type="submit"] {
        margin-top: 8px;
    }
}

input[type="submit"] {
    background-color: var(--text-background-color);
}

.file-upload {
    padding: 8px;
    border-radius: 12px;
    width: fit-content;

    background-color: var(--element-background-color);
    border: 1px solid var(--soft-color);
}
