:root {
    --theme-color: #19974E;
    --theme-color-light: #74C495;
    --shadow-color: #000000d6;
    --shadow: drop-shadow(5px 5px var(--shadow-color));
}

html {
    height: 100vh;
    background-image: linear-gradient(rgb(0 0 0 / 50%), rgb(0 0 0 / 50%)), url('/staticImages/heroImage.webp');
    background-position: center;
    background-size: cover;
    overflow: auto; 
}

body {
    height: 100%;
    overflow: auto;
    background: none;
    backdrop-filter: blur(2px);
}

body,
html {
    font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
}

main {
    overflow: auto;
}

.text-theme {
    color:var(--theme-color);
}

.bg-theme {
    background: var(--theme-color);
}

.fold {
    position: relative; 
    padding-right: 0 !important;
    margin-right: var(--fold-width);
    height: 100%;
}

.fold::after,
.fold::before {
    content: '';
    width: var(--fold-width);
    position: absolute;
    transform: translateX(100%);
    box-shadow: white -2px 0px 0 0;
}

.fold::before {
    height: var(--fold-width);
    inset: 0 0 auto auto;
    border: #e8e8e8 solid calc(var(--fold-width) / 2);
    border-top-color: transparent;
    border-right-color: transparent;
}

.fold::after {
    content: '';
    background: white;
    inset: var(--fold-width) 0 0 auto;
}





#app {
    gap: 20px;
    display: grid;
    grid-template-areas:
        'nav'
        'aside'
        'content';
    grid-template-columns: 1fr;
    grid-template-rows: auto auto 1fr;
}



#app > header {
    grid-area: nav;
    background: white;
}

#app > aside {
    grid-area: aside;
    overflow-y: auto;
    overflow-x: hidden;
    position: relative;
}


#app > aside > * {
    --fold-width: 30px;
    background: white;
    width: calc(100% - 30px);
    padding: 1.5rem;
}

.floating-button {
    position: sticky;
    bottom: 0;
    z-index: 1;
    border-bottom: white solid 1.2em
}

.floating-button::before {
    background: linear-gradient(to bottom, #0000, white 50%);
    content: '';
    width: 100%;
    height: 1.5em;
    display: block;
}

#app > main {
    grid-area: content;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 0 15px;
}



#app > *:not(main) {
    filter: var(--shadow);
}

#app > :is(header, aside) {
    border-left: var(--theme-color) solid 15px;
}







/* medium */
@media screen and (min-width: 768px) {
    #app {
        max-height: 100%;
        gap: 20px;
        grid-template-areas:
            'nav content'
            'aside content';
        grid-template-columns: 1fr 3fr;
        grid-template-rows: auto 1fr;
        height: 100%;
    }

    body {
        padding: 10px 0;
    }

    #app > main {
        margin-top: 0;
        margin-right: 30px;
        padding: 0;
    }
}


input {
    position: relative;
}
/*
*::-webkit-calendar-picker-indicator {
    position: absolute;
    top: 20px;
    padding: 50% 15px;
    right: 0px;
    transform: translateY(-50%);
    font-size: 1.2rem;
}*/

input[type="date"]::-webkit-calendar-picker-indicator {
    position: absolute;
    top: 20px;
    padding: 50% 15px;
    right: 0px;
    transform: translateY(-50%);
    font-size: 1.2rem;
}





 

/*
    blazor styles
*/

h1:focus {
    outline: none;
}

a, .btn-link {
    color: #0071c1;
}

.btn-primary {
    color: #fff;
    background-color: #1b6ec2;
    border-color: #1861ac;
}

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
  box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem #258cfb;
}

.content {
    padding-top: 1.1rem;
}

.valid.modified:not([type=checkbox]) {
    outline: 1px solid #26b050;
}

.invalid {
    outline: 1px solid red;
}

.validation-message {
    color: red;
}

#blazor-error-ui {
    background: lightyellow;
    bottom: 0;
    box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2);
    display: none;
    left: 0;
    padding: 0.6rem 1.25rem 0.7rem 1.25rem;
    position: fixed;
    width: 100%;
    z-index: 1000;
}

    #blazor-error-ui .dismiss {
        cursor: pointer;
        position: absolute;
        right: 0.75rem;
        top: 0.5rem;
    }

.blazor-error-boundary {
    background: url() no-repeat 1rem/1.8rem, #b32121;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
}

    .blazor-error-boundary::after {
        content: "An error has occurred."
    }
