﻿@import url('open-iconic/font/css/open-iconic-bootstrap.min.css');

@charset "utf-8";

h1, h3 {
    font-weight: 600
}

:root {
    --primary-hex: #002f5d;
    --secondary-hex: #6c6c6c;
    --light-grey: #eee;
    --dark-grey: #222;
    --black: #000;
    --white: #fff;
    --green: #448600;
    --red: #e00;
    --gold: #8C7300;
    --s24green: #86bc24;
    --modal-header-color: var(--primary-hex);
    --button-color: var(--primary-hex);
    --link-color: var(--primary-hex);
    --modal-border-color: #0000002d
}

body {
    font-size: 1rem;
    font-family: sans-serif;
    color: var(--black)
}

main {
    padding-top: 8em
}

h1 {
    font-size: 2rem;
    margin: .75rem 0 .5rem;
    color: var(--primary-hex)
}

.modal-header h2, h2 {
    font-size: 1.5rem
}

h3 {
    font-size: 1.33rem
}

ul a {
    color: var(--link-color)
}

    ul a:hover {
        text-decoration: none
    }

.fl-left {
    float: left
}

.error {
    display: block;
    color: var(--red)
}

h1:focus {
    outline: none;
}

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

.loginForm {
    display: flex;
    justify-content: center;
    margin-top: 10em;
}

.login-body {
    width: 25em;
}

.login-footer {
    display: flex;
    justify-content: flex-end;
}

p#verifyLoginMessage {
    color: red;
}

a#queueLink,
a#tenantLink,
a#logFileLink {
    text-decoration: none;
}

#editApiKeyInput {
    display: none;
}

.formAddQueue {
    margin-top: 1em;
}

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

.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."
    }

.btn-generate {
    color: #002f5d;
    border-color: #002f5d;
    border-radius: 0;
}

    .btn-generate:hover {
        background-color: #002f5d;
        color: white;
        border-color: #002f5d;
    }

.btn-edit {
    background-color: var(--button-color);
    border: 1px solid var(--button-color);
    color: var(--white);
    border-radius: unset
}

    .btn-edit:hover, .btn-edit:focus {
        background-color: var(--white);
        color: var(--button-color);
        text-decoration: none !important;
        border: 1px solid var(--button-color)
    }

.btn-delete {
    background-color: var(--red);
    border: 1px solid var(--red);
    color: var(--white);
    border-radius: unset
}

    .btn-delete:hover, .btn-delete:focus {
        background-color: var(--white);
        color: var(--red);
        text-decoration: none !important;
        border: 1px solid var(--red)
    }

.btn-modal-close {
    color: white;
    background: transparent;
    border: none;
}

    .btn-modal-close:hover {
        color: var(--red);
    }

.settingsContainer {
    max-width: 100%;
    margin-top: 3em;
    padding: 0;
}

#settingsTable td {
    border: 1px solid black;
}

.adminAddedModal {
    max-width: 50%;
}

.btn-disabled {
    visibility: hidden;
}

footer.col-lg-10, main.col-lg-10 {
    width: calc(100% - 17.5rem)
}

a code {
    color: var(--primary-hex);
    border-bottom: 1px solid var(--primary-hex)
}

    a code:hover {
        border-bottom: 1px solid transparent
    }

#loading {
    right: 0;
    position: absolute
}

header {
    top: 0;
    transition: top .5s ease-in-out
}

#sidebarMenu, footer {
    bottom: 0;
    z-index: 100
}

header.navbar {
    background-color: var(--white);
}

#sidebarMenu {
    position: fixed;
    top: 0;
    left: 0;
    padding: 83px 0 0;
    box-shadow: inset -1px 0 0 rgba(0,0,0,.1)
}

.navbar-brand, .navbar-toggler:focus {
    box-shadow: unset
}

.navbar-dark .navbar-toggler {
    color: var(--primary-hex);
}

#sidebarMenu .nav-link {
    font-weight: 500;
    color: var(--black);
    padding: .5rem
}

    #sidebarMenu .nav-link .feather {
        color: var(--secondary-hex);
        width: 25px;
        height: 18px
    }

    #sidebarMenu .nav-link.active, #sidebarMenu .nav-link:hover {
        color: var(--link-color);
        font-weight: 700
    }

        #sidebarMenu .nav-link.active .feather, #sidebarMenu .nav-link:hover .feather {
            color: inherit
        }

.sidebar-heading {
    font-size: .75rem
}

.sidebar-sticky {
    overflow-x: hidden;
    overflow-y: auto
}

input, input#create-views-button, select {
    overflow: hidden;
    text-overflow: ellipsis
}

.navbar-toggler {
    top: .85rem;
    right: 1rem;
    font-size: 1.5rem;
    color: var(--primary-hex);
}

.navbar-logout {
    flex-direction: row-reverse;
    margin-right: 24px
}

.navbar-nav {
    flex-direction: row-reverse;
    margin-right: 24px
}

    .navbar-nav .nav-item {
        margin-left: 1rem
    }

        .navbar-nav .nav-item i {
            font-style: normal;
            margin-right: .5em
        }

.nav-item:first-of-type {
    padding-top: 0.3rem !important;
}

.nav-item {
    font-size: 1rem !important;
    padding-bottom: 0.01rem !important;
}

.navbar-brand {
    padding-top: 1rem;
    padding-bottom: 1rem;
    background-color: inherit;
    height: 4.5rem;
}

.navbar-brand img {
    height: 2.5rem;
}

#sidebarMenu, .navbar-brand {
    width: 17.5rem
}

.navbar .nav-link:focus, .navbar .nav-link:hover {
    color: var(--link-color);
    text-decoration: underline
}

.navbar a:not(.btn-primary) {
    color: var(--black)
}

input, select {
    padding: .5rem .33rem .25rem;
    border: 1px solid var(--modal-border-color);
    background-color: var(--white)
}

    select:not(select[multiple=multiple]) {
        -webkit-appearance: none;
        -moz-appearance: none;
        appearance: none;
        background-image: url('data:image/svg+xml;charset=US-ASCII,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 276.7 153" enable-background="new 0 0 276.7 153"><style>.arrow{fill:%23002f5d}</style><path class="arrow" d="M276.7 0H0l138.2 153z" /></svg>');
        background-position: right 5px center;
        background-repeat: no-repeat;
        background-size: auto 17.5%;
        border-radius: 0
    }

    select[multiple=multiple] {
        appearance: none;
        padding: 0
    }

        select[multiple=multiple] option {
            padding: .5rem .25rem .25rem
        }

            select[multiple=multiple] option:checked {
                background-color: var(--light-grey);
                font-weight: 600
            }


.btn-primary {
    background-color: var(--button-color);
    border: 1px solid var(--button-color);
    color: var(--white);
    border-radius: unset
}

    .btn-primary:focus, .btn-primary:hover {
        background-color: var(--white);
        color: var(--button-color);
        text-decoration: none !important;
        border: 1px solid var(--button-color)
    }

.btn:focus-visible {
    color: var(--white) !important;
    background-color: var(--button-color);
    border-color: var(--modal-border-color);
    box-shadow: unset;
    outline: var(--button-color) dashed 2px;
    outline-offset: 1px
}

.btn-check:checked + .btn, .btn.active, .btn.show, .btn:first-child:active, :not(.btn-check) + .btn:active {
    color: var(--bs-btn-active-color);
    background-color: var(--s24green);
    border-color: var(--modal-border-color);
    outline: var(--button-color) dashed 2px;
    outline-offset: 1px
}

.fa-icon {
    font-family: 'Font Awesome 5 Pro',sans-serif
}

input[type=checkbox], input[type=radio] {
    -webkit-appearance: none;
    appearance: none;
    background-color: var(--white);
    margin: 0;
    font: inherit;
    color: currentColor;
    width: 1.2rem;
    height: 1rem;
    border: .1rem solid currentColor;
    border-radius: 0;
    transform: translateY(-.05rem);
    display: inline-grid;
    place-content: center;
    padding: 0
}

    input[type=checkbox]:checked::before, input[type=radio]:checked::before {
        transform: scale(1.5)
    }

    a:focus, input:focus, input[type=checkbox]:focus, input[type=radio]:focus, select:focus {
        outline: currentColor dashed 2px;
        outline-offset: 1px
    }

    input[type=checkbox]::before, input[type=radio]::before {
        content: "";
        width: .5rem;
        height: .5rem;
        transform: scale(0);
        transition: 120ms transform ease-in-out;
        background-color: CanvasText
    }

    input[type=checkbox]::before {
        clip-path: polygon(14% 44%,0 65%,50% 100%,100% 16%,80% 0,43% 62%);
        transform-origin: center;
        box-shadow: inset 1em 1em var(--button-color)
    }

.form-control:focus-within {
    color: var(--button-color)
}

[disabled=disabled] {
    border-style: hidden;
    color: var(--black)
}

.modal-header {
    background-color: var(--modal-header-color);
    color: var(--white);
    border-bottom: unset;
    padding-top: .6rem;
    padding-bottom: .25rem;
    hyphens: auto
}

    .modal-header, .modal-header:first-child {
        border-radius: 9px 9px 0 0
    }

        .modal-header.loading {
            padding-right: 3.33em
        }

.modal-content {
    border-radius: 0.8rem;
}

.modal .input, .modal .input-standard, .modal .select-standard {
    width: 77%
}

.modal .input-long, .input-long {
    width: 99%;
}

.modal .input-short {
    width: 33%
}

.modal label {
    width: 45%;
    hyphens: auto
}

.modal label.approvedInput {
    width: 14%;
}

.modal ul ul label {
    width: 90% !important
}

.ul-errors {
    background-color: var(--red)
}

.ul-warnings {
    background-color: var(--gold)
}

.ul-notices {
    background-color: var(--green)
}

code {
    color: var(--black)
}

.container-fluid {
    height: 100vh;
    --bs-gutter-x: 1.5rem;
    --bs-gutter-y: 0;
    width: 100%;
    padding-right: calc(var(--bs-gutter-x) * .5);
    padding-left: calc(var(--bs-gutter-x) * .5);
    margin-right: auto;
    margin-left: auto;
}

div.main-row {
    padding-bottom: 7em !important;
}

footer {
    transition: bottom .5s ease-in-out;
    position: fixed;
    bottom: 0;
    right: 0;
    left: 0;
    z-index:100;
    background-color: var(--dark-grey);
    color: var(--white);
    height: auto;
    display: block;
    box-shadow: 0 -.5rem 1rem rgba(var(--bs-body-color-rgb),.15);
    padding-right: 1rem !important;
    padding-left: 1rem !important;
}

    footer .container {
        max-width: 100%;
        padding: 0
    }

    footer p {
        margin-bottom: 0
    }

@media (max-width: 1199.98px) {
    footer.col-lg-10, main.col-lg-10 {
        width: calc(100% - 15rem)
    }

    #sidebarMenu, .navbar-brand {
        width: 15rem
    }

    main {
        padding-top: 62px
    }

    #sidebarMenu {
        padding-top: 77px
    }

    .modal .input-short {
        width: 53%
    }

}

@media (max-width: 767.98px) {
    header {
        max-width: 100%;
    }

    .container-fluid {
        width: 100%;
    }

    #sidebarMenu, footer.col-lg-10, main.col-lg-10 {
        width: 100%
    }

    main {
        padding-top: 110px
    }

    #sidebarMenu {
        padding-top: 125px
    }

    .navbar-nav {
        width: 100%;
        margin-bottom: 1rem
    }

    .navbar-brand {
        padding-bottom: 1rem;
        width: 15rem
    }

    .navbar-logout form {
        display: inline-block;
        margin-right: 5rem;
    }

    footer {
        flex-shrink: 0;
        max-width: 100%
    }

}

@media (max-width: 599.98px) {
    #login-form input.input-standard, .modal .input-standard:not(.label-radio-group), .modal .select-standard {
        width: 100%
    }

    .modal .input, .modal .input-short {
        width: 66%
    }

    .modal label:not(.label-radio-title) {
        width: 100%
    }

    .btn-group {
        margin-top: .5rem
    }

    [disabled=disabled] {
        padding: 0
    }

}