:root {
    --gfMain: #177706;
    --gfMid: #024b2b;
    --gfDark: #01321c;
    --gfLight: rgb(212, 230, 201);
    --gfStatic: #efefef;
    --gfOffBlack: #354034;

    --block-size: 18vmin;
}

html, body {
    font-family: sans-serif, Arial, Helvetica, Verdana;
}

input:-internal-autofill-selected {
    background-color: #cde2d9 !important;
}

input::placeholder, textarea::placeholder, select:required:invalid {
    color: rgb(134, 182, 105) !important;
    font-family: Tahoma, Verdana, Arial, Helvetica, sans-serif;
    font-size: 1rem !important;
}

option[value=""][disabled] {
    display: none;
}
option {
    color: #000000;
}

h1:focus {
    outline: none;
}

a, .btn-link {
    color: var(--gfMain);
}

a.infoShell {
    text-decoration: none;
    color: #3c3c3c;
    font-family: "Arial", "Tahoma", "Helvetica";
}

.text-bg-primary {
    background-color: var(--gfMain) !important;
}

.badge-main {
    background-color: var(--gfMain);
    border: 1px solid var(--gfMain);
}

.badge-darkGrey {
    background-color: var(--gfOffBlack);
    border: 1px solid var(--gfOffBlack);
}

.badge-midGreen {
    background-color: var(--gfMid);
    border: 1px solid var(--gfMid);
}

.badge-lightGrey {
    background-color: var(--gfStatic);
    border: 1px solid var(--gfStatic);
}

.badge-inverted {
    background-color: var(--gfStatic);
    color: var(--gfMain);
    border: 1px solid var(--gfMain);
}

.badge-gold {
    background-color: goldenrod !important;
}

.badge-header-placeholder {
    background-color: var(--gfLight);
    color: var(--gfLight);
}

.circular-badge {
    display: inline-block;
    padding: 0;
    width: 2rem;
    height: 2rem;
    text-align: center;
    line-height: 2rem;
    border-radius: 50%;
    font-size: .75rem;
    font-weight: 700;
    vertical-align: baseline;
}

.circular-badge-small {
    display: inline-block;
    padding: 0;
    width: 1.25rem;
    height: 1.25rem;
    text-align: center;
    line-height: 1.25rem;
    border-radius: 50%;
    font-size: .6rem;
    font-weight: 600;
    vertical-align: top;
}

.grid-text {
    font-size: .875rem;
}

.bg-primary {
    background-color: var(--gfMain) !important;
}

.text-primary {
    color: var(--gfMain) !important;
}

.btn {
    border-radius: .5rem;
}

.btn-xs {
    padding: .15rem .35rem;
    font-size: .75rem;
}

.btn-primary {
    color: #fff;
    background-color: var(--gfMain);
    border-color: #01321c;
}
.btn-primary:hover, .btn-primary:focus {
    background-color: #01321c;
    border-color: var(--gfMain);
}
.btn-primary:active {
    background-color: #01321c;
    border-color: #01321c;
}

.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 var(--gfMain);
}
.btn:focus-visible {
    background-color: var(--gfMid);
    border-color: var(--gfMain);
    box-shadow: 0 0 0 0.25rem rgba(212, 230, 201, .5)
}

btn.active, .btn:first-child:active, .btn.show {
    background-color: var(--gfMid);
    border-color: var(--gfMain);
}

.btn.disabled, .btn:disabled, fieldset:disabled .btn {
    color: rgb(152, 207, 119);
    border-color: rgb(152, 207, 119);
}

.btn-outline-primary {
    color: var(--gfMain);
    border-color: var(--gfMain);
}
.btn-outline-primary:hover {
    color: #fff;
    background-color: var(--gfMain);
    border-color: var(--gfMain);
}
.btn-outline-primary:active {
    color: #fff;
    background-color: var(--gfMain);
    border-color: var(--gfMain);
}

.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(--gfMain);
    border-color: var(--gfMid);
}

.btn-close-dark {
    color: var(--gfDark);
}

div.anime-btn {
    position: relative;
    display: inline-flex;
    height: 40px;
    width: 40%;
    border: 2px solid var(--gfLight);
    border-radius: .5rem;
    margin: .75rem 0 0 .75rem;
    color: var(--gfMain);
    text-transform: uppercase;
    text-decoration: none;
    font-size: .8em;
    letter-spacing: 1.5px;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    cursor: pointer;
}
div.anime-btn a {
    color: var(--gfMain);
    text-decoration: none;
    letter-spacing: 1px;
}

div.anime-slide-btn a {
    position: relative;
    transition: all .35s ease-out;
}
div.anime-slide-btn div.slide {
    width: 100%;
    height: 100%;
    left: -200px;
    background: radial-gradient(circle, var(--gfMain), var(--gfMid));
    position: absolute;
    transition: all .35s ease-Out;
    bottom: 0;
}
div.anime-slide-btn:hover div.slide {
    left: 0;
}
div.anime-slide-btn:hover {
    border-color: var(--gfMid);
}
div.anime-slide-btn:hover a {
    color: #fefefe !important;
}

div.anime-circle-btn a {
    position: relative;
    transition: all .45s ease-out;
}
div.anime-circle-btn div.circle {
    width: 0%;
    height: 0%;
    opacity: 0;
    line-height: 40px;
    border-radius: 50%;
    background: radial-gradient(circle, var(--gfMain), var(--gfMid));
    position: absolute;
    transition: all .5s ease-Out;
    top: 20px;
    left: 70px;
}
div.anime-circle-btn:hover div.circle {
    width: 200%;
    height: 500%;
    opacity: 1;
    top: -70px;
    left: -70px;
}
div.anime-circle-btn:hover {
    border-color: var(--gfMid);
}
div.anime-circle-btn:hover a {
    color: #fefefe !important;
}

div.anime-spin-btn a {
    position: relative;
    transition: all .45s ease-out;
}
div.anime-spin-btn div.spin {
    width: 0;
    height: 0;
    opacity: 0;
    left: 70px;
    top: 20px;
    transform: rotate(0deg);
    background: none;
    position: absolute;
    transition: all .5s ease-Out;
}
div.anime-spin-btn:hover div.spin {
    width: 200%;
    height: 500%;
    opacity: 1;
    left: -70px;
    top: -70px;
    background: radial-gradient(circle, var(--gfMain), var(--gfMid));
    transform: rotate(80deg);
}
div.anime-spin-btn:hover {
    border-color: var(--gfMid);
}
div.anime-spin-btn:hover a {
    color: #fefefe !important;
}

.form-control:focus {
    border-color: #079d5b;
}

.form-check-input:checked {
    background-color: var(--gfMain);
    border-color: var(--gfMain);
}

.form-error {
    border-color: #d40b0b;
    padding-right: calc(1.5em + .75rem);
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12' width='12' height='12' fill='none' stroke='%23dc3545'%3e%3ccircle cx='6' cy='6' r='4.5'/%3e%3cpath stroke-linejoin='round' d='M5.8 3.6h.4L6 6.5z'/%3e%3ccircle cx='6' cy='8.2' r='.6' fill='%23dc3545' stroke='none'/%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: right calc(.375em + .1875rem) center;
    background-size: calc(.75em + .375rem) calc(.75em + .375rem);
}

.accordion-button {
    background-color: #fafafa;
    color: #055b35;
}
.accordion-button:focus {
    z-index: 3;
    border-color: #cde2d9;
    outline: 0;
    box-shadow: 0 0 0 0.25rem rgba(6, 117, 68, 0.25);
}
.accordion-button:not(.collapsed) {
    color: var(--gfMain);
    background-color: #cde2d9;
    box-shadow: inset 0 -1px 0 rgba(0,0,0,.125);
}

.offcanvas-header {
    background-color: var(--gfMid);
    color: #efefef;
}
.offcanvas-header .btn-close {
    color: #efefef !important;
}

.offcanvasCloseBtn {
    background-color: transparent;
    border-style: none;
    font-size: 1.65rem;
}

.nav-link {
    color: var(--gfMain);
}
.nav-link:hover {
    color: var(--gfMid);
}
.nav-link .active {
    color: var(--gfDark);
    font-weight: 500;
}

.pagination {
    --bs-pagination-color: var(--gfMain);
    --bs-pagination-border-color: var(--gfMid);
    --bs-pagination-hover-color: var(--gfLight);
    --bs-pagination-hover-border-color: var(--gfDark);
    --bs-pagination-focus-color: var(--gfLight);
    --bs-pagination-active-color: #fff;
    --bs-pagination-active-bg: var(--gfMain);
    --bs-pagination-active-border-color: var(--gfDark);
    --bs-pagination-disabled-color: var(--bs-secondary-color);
    --bs-pagination-disabled-border-color: var(--bs-border-color);
}

.page-item, .page-link {
    cursor: pointer;
}

.page-link {
    color: var(--gfMain);
}

.dropdown-item:active, .dropdown-item.active {
    background-color: var(--gfMain);
}

ul.tableList li {
    padding-top: .75rem;
    padding-bottom: .75rem;
}

.tableList-data {
    font-size: .85rem;
}

.listContainer, .makeScrollable {
    overflow-x: hidden;
    overflow-y: auto;
}

.subText {
    font-size: smaller;
}

.microText {
    font-size: x-small;
}

.card {
    border-radius: .75rem;
}

.content {
    padding-top: 1.1rem;
    margin-top: 3.95rem;
    max-width: 100vw;
}

@media (max-width: 576px) {
    .content {
        margin-top: 3.25rem;
    }
}

.valid.modified:not([type=checkbox]) {
    outline: 1px solid #26b050;
}

.invalid {
    outline: 1px solid red;
}

.validation-message {
    color: red;
}

.top-row-icon {
    font-size: 1.35rem;
}

.icon-light {
    color: #efefef;
}

.btnBar {
    margin-top: 1.5rem;
}

.form-label {
    margin-bottom: .25rem;
}

.centerScreen {
    top: 50%;
    left: 50%;
    margin: 0;
    position: absolute;
    transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
}

.alertRow {
    font-size: .9rem;
    color: #ffffff;
}

.alert-header {
    border-bottom: .1085rem solid #040404 !important;
    border-radius: 0;
}

.toast {
    border-radius: .25rem .25rem .5rem .5rem;
}

.toast-message-wrapper {
    border-radius: 0 0 .5rem .5rem;
}

.errorToast {
    background-color: #eef4f0 !important;
    border: .1125rem solid rgba(157,0,0,.85) !important;
    color: #9d0000 !important;
}

.warningToast {
    background-color: #eef4f0 !important;
    border: .1125rem solid rgba(255,102,0,.85) !important;
    color: #110f0f !important;
}

.successToast {
    background-color: #eef4f0 !important;
    border: .1125rem solid rgba(23,119,6,.85) !important;
    color: var(--gfMid) !important;
}

.staticToast {
    background-color: #eef4f0 !important;
    border: .1125rem solid rgba(17,15,15,.85) !important;
    color: #110f0f !important;
}

.errorToastHeader {
    background-color: rgba(157,0,0,.85) !important;
    color: #ffffff;
}

.warningToastHeader {
    background-color: rgba(255,102,0,.85) !important;
    color: #ffffff;
}

.successToastHeader {
    background-color: rgba(23,119,6,.85) !important;
    color: #ffffff;
}

.staticToastHeader {
    background-color: rgba(17,15,15,.85) !important;
    color: #ffffff;
}

.errorToastIcon {
    color: #c10101 !important;
}

.warningToastIcon {
    color:#ff6600 !important;
}

.successToastIcon {
    color: var(--gfMid) !important;
}

.top-20 {
    top: 20%;
}

.top-30 {
    top: 30%;
}

.nudgeDown {
    padding-top: .08rem;
}

.clickable {
    cursor: pointer;
}

.greenUp {
    color: var(--gfMain);
}

.shadeUp {
    color: #4e4e32;
}

.maroonUp {
    color: #880000;
}

.goldUp {
    color: darkgoldenrod;
}

.smokeUp {
    color: #a2a291;
}

.static {
    color: var(--gfOffBlack);
}

.lightShade {
    background-color: #efefef !important;
}

.greenShade {
    background-color: var(--gfLight) !important;
}

.hideInPlace {
    visibility: hidden;
}

#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."
}

.loading-progress {
    position: relative;
    display: block;
    width: 8rem;
    height: 8rem;
    margin: 20vh auto 1rem auto;
}
.loading-progress circle {
    fill: none;
    stroke: #e0e0e0;
    stroke-width: 0.6rem;
    transform-origin: 50% 50%;
    transform: rotate(-90deg);
}
.loading-progress circle:last-child {
    stroke: #01321c;
    stroke-dasharray: calc(3.141 * var(--blazor-load-percentage, 0%) * 0.8), 500%;
    transition: stroke-dasharray 0.05s ease-in-out;
}

.loading-progress-text {
    position: absolute;
    text-align: center;
    font-weight: bold;
    inset: calc(20vh + 3.25rem) 0 auto 0.2rem;
}
.loading-progress-text:after {
    content: var(--blazor-load-percentage-text, "Loading");
}

.loaderCircle {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    display: inline-block;
    position: relative;
    background: linear-gradient(0deg, rgba(255, 61, 0, 0.2) 33%, #ff3d00 100%);
    box-sizing: border-box;
    animation: rotation 1s linear infinite;
}
.loaderCircle::after {
    content: '';
    box-sizing: border-box;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: #263238;
}

@keyframes rotation {
    0% {
        transform: rotate(0deg)
    }

    100% {
        transform: rotate(360deg)
    }
} 


.code {
    color: #c02d76;
}

.stopWrap {
    white-space: nowrap;
    text-overflow: ellipsis;
}

.bdg-wrapper {
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 12rem;
}

.bdg {
    display: inline-block;
    min-width: .5rem; /* rem unit */
    padding: 2rem 3rem; /* rem unit */
    border-radius: 50%;
    font-size: 75px;
    text-align: center;
    background: var(--gfMain);
    color: #fefefe;
}

.autocomplete {
    position: relative;
}
.autocomplete .options {
    position: absolute;
    top: 65px;
    left: 0;
    background: white;
    width: 100%;
    padding: 0;
    z-index: 10;
    border: 1px solid #ced4da;
    border-radius: 0.5rem;
    box-shadow: 0 6px 3px 1px rgba(0, 0, 0, 0.1);
    cursor: pointer;
}
.autocomplete .option {
    display: block;
    padding: 0.25rem;
}
.autocomplete .option .option-text {
    padding: 0.25rem 0.5rem;
}
.autocomplete .option:hover, .autocomplete .option.highlight {
    border-radius: 0.5rem;
    background: var(--gfMain);
    color: #fff;
}
.autocomplete .option:hover .option-text, .autocomplete .option.highlight .option-text {
    color: #fff;
}
.autocomplete .option.disabled {
    background-color: lightgrey;
    cursor: not-allowed;
}
.autocomplete .option.disabled:hover {
    background: lightgrey;
    color: var(--bs-body);
}

.center-loading-set {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    min-height: 150px;
}
.center-loading-set img {
    display: block;
}

.resultsHeader {
    background-color: var(--gfLight);
}

.resultsHeaderText {
    color: var(--gfMid);
}

.static-container {
    position:relative;
    display: inline-block;
    height: 3.65rem;
    width: 100%;
}
.static-container .label {
    position: absolute;
    top: 0;
    left: 0;
    padding: 2px 5px;
    color: #c3c3c3;
    font-size: .95rem;
}
.static-container .data {
    padding: 1.5rem .65rem;
    font-size: 1.15rem;
}

@keyframes flasher {
    0%, 100% {
        opacity: 1;
    }
    50% {
        opacity: .1;
    }
}

.slow-flash-effect {
    animation: flasher 1.75s infinite;
}

.loader {
    --loader-size: calc(var(--block-size) / 2);
    --loader-size-half: calc(var(--loader-size) / 2);
    --loader-size-half-neg: calc(var(--loader-size-half) * -1);
    --light-color: rgba(212, 230, 201, 0.6);
    --dot-size: 7px;
    --dot-size-half: calc(var(--dot-size) / 2);
    --dot-size-half-neg: calc(var(--dot-size-half) * -1);
    display: block;
    position: relative;
    width: var(--loader-size);
    display: grid;
    place-items: center;
    color: #177706;
}

.loader::before,
.loader::after {
    content: '';
    position: absolute;
}

.loader--9 {
    --loader-size: calc(var(--block-size) / 6);
    --anim-duration: 0.6s;
    aspect-ratio: 1 / 1;
    border-radius: 50%;
    background-color: currentColor;
    box-shadow: 0 0 var(--loader-size) var(--light-color);
    animation: loader-9 calc(var(--anim-duration) * 6) linear infinite;
}

.loader--9::before,
.loader--9::after {
    width: var(--dot-size);
    aspect-ratio: 1 / 1;
    background: currentColor;
    border-radius: 50%;
    animation: loader-9-1 var(--anim-duration) cubic-bezier(0.27, 0.08, 0.26, 0.7) infinite;
}

.loader--9::before {
    --x-dist: 0;
    --y-dist: var(--loader-size-half);
    bottom: calc(100% + var(--loader-size));
    left: calc(50% - var(--dot-size-half));
    transform-origin: center var(--loader-size);
}

.loader--9::after {
    --x-dist: var(--loader-size-half);
    --y-dist: 0;
    top: calc(50% - var(--dot-size-half));
    right: calc(100% + var(--loader-size));
    transform-origin: var(--loader-size) center;
    animation-delay: calc(var(--anim-duration) / 2 * -1);
}

@keyframes loader-9 {
    100% {
        transform: rotate(1turn);
        background-color: #ededed;
    }
    0% {
        background-color: #ededed;
    }
    50% {
        background-color: #177706;
    }
}

@keyframes loader-9-1 {
    0%, 100% {
        opacity: 0;
    }

    33% {
        opacity: 1;
    }

    0% {
        transform: scale(1.1);
    }

    88% {
        transform: rotate(180deg) translate(var(--x-dist), var(--y-dist));
    }
}

.loaderItem {
    background: rgba(255, 255, 255, 0.1);
    display: grid;
    place-items: center;
    border-radius: 4px;
    transition: opacity 0.4s ease;
}
