:root {
    --color-purple: #42268c;
    --color-purple-light: #715ca9;
    --color-purple-lighter: #a485f5;
    --color-purple-lightest: #ECE6FD;
    --color-green: #247b85;
    --color-green-light: #ccf1f5;
    --color-green-lighter: #e6eeef;
    --color-pink: #7900eb;
    --color-white: #fff;
    --color-black: #212b32;
    --color-positive: #00c767;
    --color-negative: #e33258;
    --color-red-dark: #b90034;
    --color-red: #f70354;
    --color-red-light: #ffaab7;
    --grid-width: 258px;
    --grid-height: 144px;
}

/* https://www.joshwcomeau.com/css/custom-css-reset/ */
*, *::before, *::after {
    box-sizing: border-box;
}

* {
    margin: 0;
}

body {
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
    accent-color: var(--color-purple);
}

img, picture, video, canvas, svg {
    display: block;
    max-width: 100%;
}

input, button, textarea, select {
    font: inherit;
}

p, h1, h2, h3, h4, h5, h6 {
    overflow-wrap: break-word;
}

p {
    text-wrap: pretty;
}

h1, h2, h3, h4, h5, h6 {
    text-wrap: balance;
}

#root, #__next {
    isolation: isolate;
}

/* Main styles */

html,
body {
    font-family: Poppins, sans-serif;
    font-size: 15px;
    font-style: normal;
    font-weight: 300;
    letter-spacing: 0;
    color: var(--color-black);
}

#app.container {
    display: grid;
    min-height: 100vh;
    width: 100%;
    grid-template-columns: 1fr;
    grid-template-rows: min-content min-content 1fr min-content;
    grid-template-areas: "nav"
        "main"
        "footer";

    >header {
        grid-area: header;
        display: none;
        grid-template-columns: 1fr;
        background-color: var(--color-purple);
        color: var(--color-white);
        padding: 1.75rem 1.5rem;
        text-align: center;

        a {
            color: inherit;
        }
    }

    &:not(.aside)>aside {
        display: none;
    }

    &.aside {
        grid-template-columns: 1fr;
        grid-template-areas: "nav"
            "main"
            "aside"
            "footer";
    }

    >nav {

        grid-area: nav;
        background-color: var(--color-green);
        display: flex;
        flex-direction: column;
        justify-content: space-between;

        >ul {
            list-style-type: none;
            padding: 0;
            margin: 0;

            >li {
                >a {
                    cursor: pointer;
                    color: var(--color-white);
                    background-color: var(--color-green);
                    font-size: 16px;
                    font-style: normal;
                    font-weight: 700;
                    text-decoration: none;
                    padding: .5rem .75rem;
                    display: block;

                }

                >.sidebar-item-toggle {
                    float: right;
                    border: 0;
                    margin: 0.5rem;
                    background-color: var(--color-green);
                    color: var(--color-white);
                }

                &.active,
                &:hover {
                    >a {
                        color: var(--color-green);
                        background-color: var(--color-green-light);
                    }

                    >ul>li>a {
                        color: var(--color-green);
                        background-color: var(--color-green-lighter);
                    }
                }

                >form {

                    button {
                        cursor: pointer;
                        color: var(--color-white);
                        background-color: var(--color-green);
                        font-size: 16px;
                        font-style: normal;
                        font-weight: 700;
                        text-decoration: none;
                        padding: .5rem .75rem;
                        display: block;
                        border: none;
                        width: 100%;
                        text-align: left;

                        &:hover {
                            color: var(--color-green);
                            background-color: var(--color-green-light);
                        }
                    }
                }

                >ul {
                    list-style-type: none;
                    padding: 0;
                    margin: 0;

                    >li {
                        >a {
                            cursor: pointer;
                            color: var(--color-white);
                            background-color: var(--color-green);
                            font-size: 14px;
                            font-style: normal;
                            font-weight: 700;
                            text-decoration: none;
                            padding: .5rem 1.875rem;
                            display: block;

                            &:hover {
                                color: var(--color-green);
                                background-color: var(--color-green-lighter);
                                text-decoration: underline;
                            }
                        }
                    }
                }
            }
        }

        >ul.main {
            flex-grow: 2;
        }

        a.main-logo {
            width: 100%;
            height: 100%;
            padding: 0.25rem;
            display: flex;
            flex-direction: column;
            background-color: var(--color-white);
            max-height: var(--grid-height);
            text-decoration: none;
            color: inherit;
            place-content: center;

            >h1 {
                margin: 0 auto;
                max-width: 217px;
                font-size: 1.1rem;
                text-align: center;
            }

            >img {
                margin: 0 auto;
                max-width: 217px;
            }
        }
    }

    >main {
        grid-area: main;

        >header {
            margin-top: 0.5rem;
            margin-bottom: 1.5rem;
        }
    }

    >main, >aside {
        display: flex;
        flex-direction: column;
        padding: 0.75rem;

        p, h1, h2, h3, h4, h5, h6 {
            max-width: 65ch;
            line-height: 1.5;
        }

        section#content {
            display: flex;
            flex-direction: column;
            gap: 0.75rem;
        }
    }

    >footer {
        grid-area: footer;
        background-color: var(--color-pink);
        color: var(--color-white);
        display: flex;
        flex-direction: column;
        justify-content: center;
        font-size: 0.8rem;
        row-gap: 1.25rem;
        padding-bottom: 1.75rem;
        padding-top: 1.75rem;
        font-size: 14px;

        >* {
            margin: 0 auto;
            max-width: 83.75rem;
            width: calc(100% - 3rem);
        }

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

@media (min-width: 768px) {
    #app.container {
        grid-template-columns: var(--grid-width) 1fr;
        grid-template-rows: var(--grid-height) 1fr min-content;
        grid-template-areas: "nav main"
            "nav main"
            "nav footer";

        >nav {
            max-height: 100vh;
            position: sticky;
            top: 0;
        }

        >header {
            place-items: center;
        }

        &.aside {
            grid-template-columns: var(--grid-width) 1fr var(--grid-width);
            grid-template-rows: var(--grid-height) 1fr min-content;
            grid-template-areas: "nav main aside"
                "nav main aside"
                "nav footer footer";

            >aside {
                padding-left: 0;
            }
        }
    }
}

.table-wrapper.sticky {
    max-width: calc(100vw - calc(calc(var(--grid-width) * 1) + 1.5rem));
    overflow-y: scroll;

    &.aside {
        max-width: calc(100vw - calc(calc(var(--grid-width) * 2) + 1.5rem));
    }

    >table.table {
        >tbody>tr>td:first-of-type {
            position: sticky;
            left: 0;
            z-index: 1;
            background-color: var(--background-color-full);
            text-wrap: balance;

            a {
                color: inherit;
            }
        }

        &.striped {
            >tbody>tr:nth-child(odd)>td:first-of-type {
                --background-color-full: var(--base-background-color);
            }

            >tbody>tr:nth-child(even)>td:first-of-type {
                --background-color-full: var(--striped-background-color);
            }
        }
    }
}


table.table {
    border-collapse: collapse;
    width: 100%;
    margin-bottom: 1.75rem;
    --base-background-color: var(--color-white);
    --striped-background-color: var(--color-green-lighter);
    --background-color: var(--base-background-color);
    --background-color-full: var(--background-color);
    /* font-size: 0.95rem; */

    th, td {
        padding: 0.5rem;
        vertical-align: top;
        text-align: left;
        background-color: var(--background-color);
        color: var(--color-black);

        a:not([class]) {
            color: inherit;
        }

        &:has(table) {
            padding: 0;
        }

        table.table {
            margin-bottom: 0;
            --background-color: var(--background-color);

            &.striped {
                tbody tr:nth-child(even) {
                    --background-color: var(--base-background-color);
                }

                tbody tr:nth-child(odd) {
                    --background-color: var(--striped-background-color);
                }
            }
        }

        &.small-width {
            min-width: 20ch;
        }

        &.medium-width {
            min-width: 26ch;
        }

        &.big-width {
            min-width: 40ch;
        }

        &.tl {
            text-align: left;
        }

        &.tr {
            text-align: right;
        }

        &.tc {
            text-align: center;
        }
    }

    thead th {
        background-color: var(--color-green);
        color: var(--color-white);
    }

    &.striped {
        >tbody>tr:nth-child(even) {
            --background-color: var(--base-background-color);
        }

        >tbody>tr:nth-child(odd) {
            --background-color: var(--striped-background-color);
        }
    }

    &.bordered {
        >tbody>tr>td {
            border-top: 1px solid var(--striped-background-color);
        }
    }

    tbody tr.border>td {
        border-top: 3px solid var(--striped-background-color);
    }

    tbody tr.positive>td {
        --background-color: rgba(from var(--color-positive) r g b / 0.4);
        --background-color-full: rgba(from var(--color-positive) r g b / 0.8);
    }

    tbody tr.negative>td {
        --background-color: var(--color-negative);
        color: var(--color-white);

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

tr.funder-year.current {
    --base-background-color: var(--color-purple-lightest);
    --striped-background-color: var(--color-purple-lightest);

    >td:first-of-type {
        border-left: 3px solid var(--color-purple);
    }
}

ul.tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    list-style-type: none;
    padding: 0;
    margin: 0;

    >li {
        background-color: var(--color-green-light);
        color: var(--color-green);
        font-size: 0.8rem;
        font-weight: 700;
        padding: 0.25rem 0.5rem;

        &:has(label) {

            &:has(input:checked) {
                background-color: var(--color-positive);
                color: var(--color-white);
            }

            >label {
                cursor: pointer;

                input[type="checkbox"] {
                    display: none;
                }
            }
        }

        &.action {
            padding: 0.25rem 0.5rem;
            background-color: transparent;
        }
    }
}

.notes {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(35ch, 1fr));
    gap: 1rem;
    list-style: none;
    padding: 0;
    font-size: 0.95rem;

    >.note, >li {
        background-color: var(--color-green-lighter);
        border-radius: 0.5rem;
        position: relative;
        padding-left: 1rem;
        padding-right: 1rem;
        padding-bottom: 1rem;

        &:has(>footer) {
            padding-bottom: 0;
        }

        >header,
        >footer {
            font-weight: 600;
            margin-left: -1rem;
            margin-right: -1rem;
            margin-bottom: 1rem;
            padding-left: 1rem;
            padding-right: 1rem;
            padding-top: 0.6rem;
            padding-bottom: 0.6rem;
            background-color: var(--color-green);
            border-radius: 0.5rem 0.5rem 0 0;
            color: var(--color-white);
        }

        >footer {
            margin-top: 1rem;
            margin-bottom: 0;
            border-radius: 0 0 0.5rem 0.5rem;
            background-color: var(--color-green-light);
            color: var(--color-green);

            &:has(a),
            &:has(select) {
                padding: 0;

                >a:last-child,
                >select:last-child {
                    border-radius: 0 0 0.5rem 0.5rem;
                }

                >a:not(:last-child),
                >select:not(:last-child) {
                    border-bottom: 1px solid var(--color-green-light);
                }

                >a {
                    display: block;
                    padding-left: 1rem;
                    padding-right: 1rem;
                    padding-top: 0.6rem;
                    padding-bottom: 0.6rem;
                }

                >select {
                    max-width: 100%;
                    width: 100%;
                    background-color: var(--color-green);
                    color: var(--color-white);
                    border: 0;
                    display: block;
                    padding-left: 1rem;
                    padding-right: 1rem;
                    padding-top: 0.6rem;
                    padding-bottom: 0.6rem;
                    filter: drop-shadow(0 0 0.15rem var(--color-green));

                    &:hover {
                        color: var(--color-green);
                        background-color: var(--color-green-light);
                    }

                    optgroup,
                    option {
                        background-color: var(--color-white);
                        color: var(--color-black);
                    }
                }
            }
        }

        &.positive {
            color: var(--color-black);
            background-color: var(--color-positive);

            >header {
                color: var(--color-black);
                background-color: var(--color-positive);
            }
        }

        &.negative {
            color: var(--color-white);
            background-color: var(--color-negative);

            >header {
                color: var(--color-white);
                background-color: var(--color-negative);
            }
        }
    }

    &.status {
        grid-template-columns: repeat(auto-fill, minmax(20ch, 1fr));

        >.note, >li {

            text-align: center;
            display: grid;
            grid-template-rows: min-content 1fr min-content;
            grid-template-columns: 1fr;
            align-items: center;
            justify-content: space-between;
            font-size: 1.1rem;

            >header,
            >footer {
                font-size: 0.95rem;
            }
        }
    }

}

.button, form.filters button, form.filters input[type=submit] {
    cursor: pointer;
    color: var(--color-white);
    background-color: var(--color-green);
    font-size: 16px;
    font-style: normal;
    font-weight: 700;
    text-decoration: none;
    padding: .5rem .75rem;
    display: block;
    border: 0;
    filter: drop-shadow(0 0 0.15rem var(--color-green));
    text-align: center;

    &.w-100 {
        width: 100%;
    }

    &:hover {
        color: var(--color-green);
        background-color: var(--color-green-light);
    }

    &.red {
        background-color: var(--color-red-dark);
        filter: drop-shadow(0 0 0.25rem var(--color-red-dark));
        color: var(--color-red-light);

        &:hover {
            color: var(--color-red);
            background-color: var(--color-red-light);
        }
    }
}

.lead {
    font-size: 1.25rem;
    font-weight: 400;
    line-height: 1.5;
    margin-bottom: 1.75rem;
}

form.filters {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    font-size: 0.95rem;

    label {
        font-weight: 600;
    }

    input, select {
        max-width: 100%;
        background-color: var(--color-white);
        border: 1px solid var(--color-green);
    }

    >div {
        display: flex;
        flex-direction: column;
        gap: 0.2rem;
    }

}

.b {
    font-weight: 700;
}

.underline {
    text-decoration: underline;
}

details>summary {
    cursor: pointer;
}

.flex-column {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.flex-row {
    display: flex;
    flex-direction: row;
    gap: 0.5rem;
}

.grid-row {
    display: grid;
    gap: 0.5rem;
    grid-auto-flow: column;
    width: 100%;
}


.tl {
    text-align: left;
}

.tr {
    text-align: right;
}

.tc {
    text-align: center;
}

ul.pagination {
    list-style-type: none;
    padding: 0;
    margin: 0;
    display: flex;
    gap: 0.5rem;
    font-size: 0.95rem;
    justify-content: center;

    >li {
        display: block;

        >a {
            display: block;
            padding: 0.5em 0.75em;
            background-color: var(--color-green-light);
            color: var(--color-black);
            text-decoration: none;

            &:hover {
                background-color: var(--color-green-lighter);
            }
        }

        &.active {
            font-weight: 700;

            >a {
                background-color: var(--color-green);
                color: var(--color-white);
            }
        }

        &:not(:has(a)) {
            padding: 0.5em 0.75em;
        }
    }
}

.funder-year-edit {
    max-width: 16ch;
    width: 100%;
    text-align: right;
}

textarea.funder-year-edit {
    max-width: 100%;
    text-align: left;
}

.progress-grid {
    width: 100%;
    display: grid;
    grid-template-columns: max-content 3fr max-content;
    grid-gap: 1em;
    align-items: center;

    meter {
        width: 100%;
        -moz-appearance: none;
        -webkit-appearance: none;
        appearance: none;
        height: 2em;
        background: none;
        background-color: var(--color-green-lighter);
    }

    meter::-webkit-meter-bar {
        background: none;
        background-color: var(--color-green-lighter);
        height: 2em;
    }

    /* meter::-webkit-meter-optimum-value,
    meter::-moz-meter-bar {
        background: none;
        background-color: var(--color-positive);
        height: 2em;
    } */

    &.border {
        meter {
            border: 1px solid var(--color-purple);
        }

        meter::-webkit-meter-bar {
            border: 1px solid var(--color-purple);
        }
    }
}

/* material symbols */
.material-symbols-outlined {
    font-variation-settings:
        'FILL'0,
        'wght'400,
        'GRAD'0,
        'opsz'24
}

.negative {
    color: var(--color-negative);
}

.positive {
    color: var(--color-positive);
}

data.number {
    font-variant-numeric: tabular-nums;
    font-family: 'Outfit', 'Courier New', Courier, monospace;
}

.md-grid {
    display: grid;
    grid-template-columns: 1fr minmax(65ch, 1fr) 1fr;
    gap: 1rem;

    >.toc-wrapper {
        grid-column: 1 / 2;

        >.toc {
            position: sticky;
            top: 1rem;
            padding: 1rem;
            max-width: 35ch;
            background-color: var(--color-green-lighter);

            ul {
                padding-left: 1rem;
            }
        }
    }

    >.md {
        grid-column: 2 / 3;
    }
}

.md {
    font-size: 1.15rem;
    max-width: 65ch;
    margin-left: auto;
    margin-right: auto;

    * {
        margin-top: 0.75em;
        margin-bottom: 0.75em;
    }

    blockquote {
        margin-top: 0.75em;
        margin-bottom: 0.75em;
        font-style: italic;
        margin-left: 0;
        margin-right: 0;
        padding-left: 1.5rem;
        border-left: 3px solid var(--color-green-light);
    }

    pre {
        padding: 1rem;
        background-color: var(--color-green-lighter);
        border-radius: 0.5rem;
        overflow-x: auto;

        > code {
            background-color: transparent;
            color: inherit;
        }
    }

    code {
        padding: 0.2rem;
        background-color: var(--color-green);
        color: var(--color-white);
        border-radius: 0.5rem;
        overflow-x: auto;
    }

    img {
        padding: 1rem;
        box-shadow: rgba(100, 100, 111, 0.2) 0px 7px 29px 0px;
    }

    table {
        margin-top: 0.75rem;
        margin-bottom: 0.75rem;
        border-collapse: collapse;

        th {
            text-align: left;
            text-wrap: balance;
        }

        td, th {
            padding: 0.5rem;
            vertical-align: top;
        }

        tr:nth-child(odd)>td {
            background-color: var(--color-green-lighter);
        }

        tr:nth-child(even)>td {
            background-color: var(--color-green-lightest);
        }
    }
}

ul.messages {
    list-style-type: none;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    padding-left: 0;
    margin-bottom: 1rem;

    >li.message {
        --bg-color: var(--color-green-light);
        --color: var(--color-green);
        --border-color: var(--color);
        display: block;
        padding: 8px 12px;
        border-radius: 5px;
        background-color: var(--bg-color);
        color: var(--color);
        border: solid 2px var(--border-color);
        width: 100%;

        &.success {
            --bg-color: var(--color-positive);
            --color: var(--color-white);
            --border-color: var(--bg-color);
        }

        &.warning {
            --bg-color: var(--color-red-light);
            --color: var(--color-red-dark);
        }

        &.error {
            --bg-color: var(--color-red-dark);
            --color: var(--color-white);
            --border-color: var(--bg-color);
        }
    }
}