/**
* Responsive modifiers
* inspired by Tailwind CSS (https://tailwindcss.com)
*
* For example class="hidden sm:block" means "hidden on small screens and shown on larger screens".
*
* Breakpoints:
* sm: 640px;
* md: 768px;
* lg: 1024px;
* xl: 1280px;
*/

.hidden {
    display: none;
}

.block {
    display: block;
}

.inline-block {
    display: inline-block;
}

.flex {
    display: flex;
}

@media (min-width: 640px) {
    .sm\:hidden {
        display: none;
    }

    .sm\:block {
        display: block;
    }

    .sm\:inline-block {
        display: inline-block;
    }

    .sm\:flex {
        display: flex;
    }
}

@media (min-width: 768px) {
    .md\:hidden {
        display: none;
    }

    .md\:block {
        display: block;
    }

    .md\:inline-block {
        display: inline-block;
    }

    .md\:flex {
        display: flex;
    }
}

@media (min-width: 1024px) {
    .lg\:hidden {
        display: none;
    }

    .lg\:block {
        display: block;
    }

    .lg\:inline-block {
        display: inline-block;
    }

    .lg\:flex {
        display: flex;
    }
}

@media (min-width: 1280px) {
    .xl\:hidden {
        display: none;
    }

    .xl\:block {
        display: block;
    }

    .xl\:inline-block {
        display: inline-block;
    }

    .xl\:flex {
        display: flex;
    }
}

.hover\:bg-light-grey:hover {
    background-color: var(--color-light-grey);
}

.focus\:outline-none:focus {
    outline: none;
}

.focus-within\:error:focus-within {
    outline: 1px solid var(--color-dark-red);
    box-shadow: 0 0 0 3px rgba(179, 58, 43, 0.5);
}

.focus-within\:success:focus-within {
    outline: 1px solid var(--color-light-green);
    box-shadow: 0 0 0 3px rgba(143, 181, 91, 0.5);
}

.focus-within\:warning:focus-within {
    outline: 1px solid var(--color-yellow);
    box-shadow: 0 0 0 3px rgba(242, 184, 46, 0.5);
}

.focus-within\:input:focus-within {
    outline: 1px solid var(--color-beige--30-darker);
    box-shadow: 0 0 0 3px rgba(173, 129, 91, 0.5);
}

form .fieldErrorText {
    color: var(--color-dark-red);
    font-size: 1em;
    margin-top: 0.25em;
    line-height: 1.5em;
}

label {
    line-height: 1.5em;
    font-weight: 500;
    font-size: 1em;
    cursor: pointer;
}

input {
    border-radius: 5px;
    border: 1px solid rgba(0, 0, 0, 0.2);
    box-sizing: border-box;
    padding: 0.5em 0.75em;
    font-size: 1em;
    box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
}

input.error {
    border: 1px solid var(--color-dark-red);
    color: var(--color-dark-red--30-darker);
    background: var(--color-dark-red--90-lighter);
}

select {
    border-radius: 5px;
    border: 1px solid rgba(0, 0, 0, 0.2);
    box-sizing: border-box;
    padding: 0.5em 0.75em;
    font-size: 1em;
    box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
}

select.error {
    border: 1px solid var(--color-dark-red);
    color: var(--color-dark-red--30-darker);
}

.errorAlert {
    position: relative;
    padding: .75rem 1.25rem;
    margin-bottom: 1rem;
    border: 1px solid var(--color-dark-red);
    border-radius: .25rem;
    color: var(--color-dark-red--30-darker);
    background-color: var(--color-dark-red--90-lighter);
}

.errorAlert a {
    font-weight: bold;
    color: var(--color-dark-red--30-darker);
}

textarea {
    border-radius: 5px;
    border: 1px solid rgba(0, 0, 0, 0.2);
    box-sizing: border-box;
    padding: 0.5em 0.75em;
    font-size: 1em;
    box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
}

textarea.error {
    border: 1px solid var(--color-dark-red);
    background: var(--color-dark-red--90-lighter);
}

a:focus, input:focus, select:focus, textarea:focus, button:focus, input[type="checkbox"]:focus, input[type="radio"]:focus, label:focus {
    outline: 1px solid var(--color-beige--30-darker);
    box-shadow: 0 0 0 3px rgba(173, 129, 91, 0.5);
}

:target::before {
    content: "";
    display: block;
    height: 60px; /* fixed header height*/
    margin: -60px 0 0; /* negative fixed header height */
}


html {
    scroll-behavior: smooth;
}

body {
    background-color: white;
    margin: 0;
    padding: 0;
}

h1 {
    margin-top: 10px;
    margin-bottom: 2px;
}

h2 {
    margin-top: 20px;
    margin-bottom: 15px;
}

h3 {
    margin-top: 10px;
    margin-bottom: 6px;
}

p {
    margin: 10px 0;
}
