body {
    font-family: Roboto, Arial, sans-serif;
    -webkit-print-color-adjust: exact;
}

body[data-bs-theme="dark"] {
    background-color: #1a1d20
}

h1 {
    font-size: 1.2rem;
}

h2 {
    font-size: 1rem;
}

h3 {
    font-size: .9rem;
}

h4 {
    font-size: .9rem;
    font-weight: normal;
}

h5 {
    font-size: .9rem;
    font-weight: normal;
    font-style: italic;
}

h6 {
    font-size: .8rem;
    font-weight: normal;
    font-style: italic;
}

.container-fluid {
    padding-left: 0;
    padding-right: 0
}

/* Bootstrap Overrides */
.form-floating {
    max-width: 1320px;
}

.form-control.disabled, .form-select.disabled {
    color: rgba(170, 170, 170, 1);
    border-color: rgba(0, 0, 0, 0.2);
    background-color: rgba(255, 255, 255, 0.2);
}

.form-floating > .form-control:disabled, .form-floating > .form-select:disabled {
    background-color: var(--bs-secondary-bg);
}

.form-floating > .form-control, .form-floating > .form-select {
    border-radius: 0;
    border-top-width: 0;
    border-right-width: 0;
    border-bottom: 1px solid var(--bs-border-color);
    border-left-width: 0;
}

.form-floating > .form-control:hover, .form-floating > .form-select:hover {
    border-bottom: 1px solid rgba(65 132 243, 0.8);
}

.form-floating > .form-control:focus, .form-floating > .form-select:focus {
    border-radius: 0;
    border-top-width: 0;
    border-right-width: 0;
    border-bottom: 2px solid #4184F3;
    border-left-width: 0;
    box-shadow: none;
}

.form-floating > .form-control {
    padding: 0.5rem 0.25rem 0.25rem 0.25rem;
}

.form-floating > .form-select {
    padding: 1.85rem 0.25rem 0.25rem 0.25rem;
    background-position: top 2.25rem right 0.75rem;
}

.form-floating > .form-control-plaintext:focus,
.form-floating > .form-control-plaintext:not(:placeholder-shown),
.form-floating > .form-control:focus,
.form-floating > .form-control:not(:placeholder-shown) {
    padding-bottom: 0.25rem;
}

.form-floating > .form-control ~ label {
    padding: 1.5rem 0.25rem 0 0.25rem;
    font-size: 0.9rem;
}

.form-floating > .form-control:not(:placeholder-shown) ~ label {
    transform: scale(.75) translateY(-.75rem) translateX(0);
}

.form-floating > .form-control:focus ~ label,
.form-floating > .form-control-plaintext ~ label {
    opacity: 1;
    transform: scale(.75) translateY(-.75rem) translateX(0);
    color: #4184F3
}

.form-floating > .form-select ~ label {
    opacity: .65;
    font-size: 0.8rem;
    padding: 1.25rem 0.25rem 0 0;
}

.form-floating > .form-select:focus ~ label {
    opacity: 1;
    color: #4184F3;
}

.form-floating > .form-control:-webkit-autofill ~ label {
    opacity: 1;
    transform: scale(.75) translateY(-.75rem) translateX(0);
    color: #4184F3
}

.form-floating > .form-control:invalid {
    border-color: red !important;
    border-bottom-width: 2px !important;
}

.form-floating > label::after {
    background-color: transparent !important;
}

h5.card-title {
    margin: 0;
    padding: 0;
}

.btn {
    text-transform: uppercase;
}

.btn.no-border {
    border: none;
}

.btn-block {
    display: block;
    width: 100%;
    margin: 0 !important;
}
.btn.btn-block {
    text-align: center;
}

.btn {
    text-align: left;
}

.nav-tabs {
    border-bottom: 1px solid var(--bs-border-color);
    background-color: var(--bs-body-bg)
}

.nav-tabs .nav-link {
    color: var(--bs-tertiary-color);
    border-radius: 0;
    border-width: 0;
    font-weight: bold;
    border: none;
    margin-bottom: 0;
}

.nav-tabs .nav-link.active {
    opacity: 1;
    color: var(--bs-primary);
}

.navbar-brand {
    padding-left: 8px;
    padding-right: 8px;
    margin-right: 0px;
    margin-left: 0px
}

.navbar-nav .dropdown-toggle::after {
    display: none;
}

.navbar .nav-link {
    font-size: 1.25rem;
    padding-left: 1rem;
    padding-right: 1rem;
}

.nav > .nav-item > .nav-link {
    font-weight:400;
}
.nav > .nav-item > .nav-link.active {
    color: var(--bs-primary);
    font-weight: 500;
}

.nav > .nav-item > .nav-link:not(.active) {
    color: var(--bs-body-color);
}

.nav > .nav-item > .nav-link:not(.active):hover {
    background-color: var(--bs-secondary-bg);
}

.nav > .nav-item > .nav-link.active {
    background-color: var(--bs-primary-bg-subtle);
}

.nav > .nav-item > .nav-link:not(.active) > .fa,
.nav > .nav-item > .nav-link:not(.active) > svg,
.nav > .nav-item > .nav-link:not(.active) > .fa-light,
.nav > .nav-item > .nav-link:not(.active) > .fa-solid,
.nav > .nav-item > .nav-link:not(.active) > .fa-sharp {
    color: var(--bs-body-color);
}

.nav > .nav-item > .nav-link > .fa,
.nav > .nav-item > .nav-link > svg,
.nav > .nav-item > .nav-link > .fa-light,
.nav > .nav-item > .nav-link > .fa-solid,
.nav > .nav-item > .nav-link > .fa-sharp {
    margin-right: 0.5rem;
    width: 15.75px;
    text-align: center;
}

@media screen and (min-width: 960px) {
    .nav.collapsed > .nav-item > .nav-link > span {
        display: none;
    }
}
.nav-collapse {
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    align-items: end;
    align-content: end;
    text-align: unset !important;
}
.nav-collapse.collapsed {
    align-items: center;
    align-content: center;
    text-align:center !important
}

.nav-collapse:not(.collapsed) > i:before {
    content: "\f323"
}
.nav-collapse.collapsed > i:before {
    content: "\f324"
}

@media screen and (max-width: 1099px) {
    .nav-collapse {
        display: none;
    }
}
.table thead th {
    text-transform: uppercase;
    font-size: 0.9rem;
    vertical-align: middle;
}

.table.body-p0 td {
    padding-top: 0;
    padding-bottom: 0;
    padding-right: 0;
    vertical-align: middle;
}

.table .btn:not(.btn-outline) {
    border: none;
}

.table.head-p0 th {
    padding: 0;
    vertical-align: middle;
}

.btn-outline {
    border: var(--bs-border-width) solid var(--bs-border-color)
}
@media screen and (max-width: 768px) {
    .table thead th:not([colspan]) {
        border: none;
        clip: rect(0 0 0 0);
        height: 1px;
        margin: -1px;
        overflow: hidden;
        padding: 0;
        position: absolute;
        width: 1px;
    }

    .table tr {
        display: block;
        float: left;
        clear: both;
        width: 100%;
    }

    .table td {
        display: block;
        width: 100%;
        float: left;
        clear: both;
    }
    .table tbody td:not(:last-child) {
        border:none
    }

    .table td:before {
        content: attr(aria-label);
        font-weight: 500;
        text-transform: uppercase;
        display: block;
        float: none;
        margin-right: 1rem;
    }

    .nav-tabs .nav-link {
        font-size: .8rem;
        padding: .4rem;
    }
}

@media screen and (min-width: 769px) {
    .action-col {
        text-align: right;
        white-space: nowrap;
    }
}

/* mobile */
@media screen and (min-width: 769px) {
    .mobile-visible {
        position: absolute !important;
        width: 1px !important;
        height: 1px !important;
        padding: 0 !important;
        /*margin: -1px !important; this seems to change boundaries in flex*/
        overflow: hidden !important;
        clip: rect(0,0,0,0) !important;
        white-space: nowrap !important;
        border: 0 !important;
    }
}
@media screen and (max-width: 768px) {
    .mobile-hidden {
        position: absolute !important;
        width: 1px !important;
        height: 1px !important;
        padding: 0 !important;
        margin: -1px !important;
        overflow: hidden !important;
        clip: rect(0,0,0,0) !important;
        white-space: nowrap !important;
        border: 0 !important;
    }
}

/* mobile */
@media screen and (min-width: 992px) {
    .mobile-lg-visible {
        position: absolute !important;
        width: 1px !important;
        height: 1px !important;
        padding: 0 !important;
        overflow: hidden !important;
        clip: rect(0,0,0,0) !important;
        white-space: nowrap !important;
        border: 0 !important;
    }
}

@media screen and (max-width: 991px) {
    .mobile-lg-hidden {
        position: absolute !important;
        width: 1px !important;
        height: 1px !important;
        padding: 0 !important;
        margin: -1px !important;
        overflow: hidden !important;
        clip: rect(0,0,0,0) !important;
        white-space: nowrap !important;
        border: 0 !important;
    }
}

/* Layout */
.portal-counter {
    font-size: 0.5rem;
    background: tomato;
    color: white;
    padding: 0.2rem 0.25rem;
    border-radius: 100px;
    font-weight: 500;
    vertical-align: middle;
}
.portal-counter:not(.portal-counter-inline) {
    position: relative;
    left: -1rem;
    top: -.6rem;
}
.portal-counter.portal-counter-inline {
    vertical-align: top;
}

#Loading > .modal-dialog {
    width: 125px !important;
    padding-top: 25vh;
}

#Loading > .modal-content {
    margin: 0 auto
}

/* Modal Dialogs */
.modal-btn, .modal-btn-continue, .modal-btn-close, .modal-btn-continue:disabled, .modal-btn-continue-disabled {
    -webkit-text-size-adjust: 100%;
    pointer-events: auto;
    font: inherit;
    margin: 0;
    font-family: Roboto, sans-serif;
    -webkit-font-smoothing: antialiased;
    font-weight: 500;
    letter-spacing: 0.08929em;
    text-decoration: none;
    text-transform: uppercase;
    padding: 0 8px 0 8px;
    display: inline-flex;
    position: relative;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    border: none;
    outline: none;
    line-height: inherit;
    user-select: none;
    overflow: hidden;
    vertical-align: middle;
    border-radius: 4px;
    margin-left: 8px;
    margin-right: 0;
    max-width: 100%;
    text-align: right;
    /*height: 36px;*/
    height: 2.5em !important;
    min-width: 36px;
    background-color: transparent;
}

    .modal-btn-close:enabled:hover {
        background-color: #FBE1E1;
    }

.modal-btn-close {
    outline: none;
    cursor: pointer;
    margin-left: 0;
    margin-right: 0;
    font-size: 1rem;
    border-color: #e00104;
    color: #e00104;
}

.modal-btn-continue {
    cursor: pointer;
    background-color: transparent;
    font-size: 1rem;
    border-color: #4184F3;
    color: #4184F3;
}

    .modal-btn-continue:enabled:hover {
        background-color: #D6E5FD;
    }

    .modal-btn-continue-disabled, .modal-btn-continue:disabled {
        color: gray;
    }

        .modal-btn-continue:disabled, .modal-btn-continue:disabled:hover, .modal-btn-continue-disabled:hover,
        .modal-btn-close:disabled, .modal-btn-close:disabled:hover, .modal-btn-close-disabled:hover {
            background-color: transparent;
            border-color: #4184F3;
            cursor: not-allowed !important;
            font-size: 1rem;
            color: grey;
        }

.modal-frame-box {
    -webkit-box-sizing: content-box;
    -moz-box-sizing: content-box;
    box-sizing: content-box;
    border-radius: 5px;
    background: white;
    padding: 0;
    overflow: visible;
}

.modal-dialog-center {
    top: 50vh;
    left: 50vw;
    transform: translate(-50%,-50%);
}

.modal-dialog { /*Bootstrap Override*/
    box-shadow: none !important;
    margin-top: 5px;
    margin-bottom: 5px;
    overflow: visible;
}

.modal-backdrop {
    background-color: rgba(0,0,0,0.46);
}

/* Left Navigation CSS */
@media screen and (min-width: 960px) {
    .left-nav-wrap {
        display: flex;
    }

    .left-nav {
        display: flex;
        flex-direction:column;
        flex-shrink: 1;
        border-right: 1px solid rgba(0, 0, 0, 0.175);
        background-color: var(--bs-tertiary-bg);
    }

    .left-nav > .nav {
        flex-direction: column;
    }

    .left-nav .nav-link {
        white-space: nowrap;
    }

    .right-content {
        flex-grow: 1;
        min-height: calc(98.4vh - 68px);
    }
    .nav {
        flex-grow: 1
    }
}

@media screen and (max-width: 959px) {
    .left-nav-wrap {
        display: block;
    }

    .left-nav {
        flex-direction: row;
        font-size: 0.8rem;
        border-bottom: 1px solid rgba(0, 0, 0, 0.175);
        background-color: var(--bs-tertiary-bg);
    }
}

/* left hand mobile presentation */
@media screen and (max-width: 768px) {
    .left-nav .nav {
        flex-direction: column;
        flex-wrap: nowrap;
        flex-grow: 1;
        font-size: 1rem;
    }
    .left-nav {
        display: none;
    }
    .left-nav[aria-expanded='true'] {
        display: flex !important;
        background-color: var(--bs-tertiary-bg);
    }
}

/* right alignment styles */
@media screen and (min-width: 769px) {
    .bubble {
        --shadow-color: rgba(0, 0, 0, 0.15);
        background-color: var(--bs-body-bg);
        border: 1px solid var(--shadow-color);
        box-shadow: var(--shadow-color) 0px 0px 4px;
        border-radius: 6px;
        padding: 0.75rem;
    }
    [data-bs-theme=dark] .bubble {
        --shadow-color: rgba(0, 0, 0, 0.4);
    }
}

@media screen and (max-width: 768px) {
    .bubble {
        padding: 0.75rem;
    }
}

.desc::after {
    content: ' \2B73'
}

.asc::after {
    content: ' \2B71'
}

@media print {
    .left-nav, .customer-info-wrapper, header, .print-hide {
        display: none !important;
    }

    /*#oReportDiv, #oReportDiv~div {
        background-color: white;
    }*/

    .right-content>#content:has(#oReportDiv) {
        background-color: transparent !important;
    }

    body {
        background-color: transparent !important;
    }
}

/* Pet Profile Items  */
.pet-profile-container {
    display: inline-block;
    width: 76px;
    min-height: 76px;
}

.pet-profile-image::before {
    position: relative;
    top: 0;
    left: 0;
    height: 76px;
    width: 76px;
    border-radius: 38px;
    background-color: lightgray;
}

.pet-profile-image {
    display: block;
    width: 76px;
    max-width: 100%;
    border-radius: 38px;
    border-color: transparent
}

    .pet-profile-image::after {
        clear: both;
    }

.pet-profile-edit {
    font-size: 0.75rem;
    cursor: pointer;
}

.pet-profile-selector {
    position: relative;
    left: 0;
}

.pet-profile-name {
    display: block;
    margin: 0;
    padding: 0;
    text-align: center;
}

/* Invoice Summary */
.invoice-summary dl {
    font-size: 0.825rem;
    width: 100%;
}

.invoice-summary dt {
    float: left;
    clear: both;
}

.invoice-summary dd {
    float: left;
    clear: none;
    margin-left: 0.75rem;
    margin-bottom: 0;
}

@media screen, print and (min-width: 500px) {
    .invoice-summary dt {
        min-width: 125px;
    }
}

@media print {
    .invoice-summary {
        border: 1px solid rgba(0,0,0, 0.15);
        display: block;
        padding: 0.5rem;
    }
}

@media screen and (min-width: 769px) {
    .billboard {
        display: flex;
        flex-direction: row;
    }

    .billboard-icon {
        flex-shrink: 1
    }

    .billboard-body {
        flex-grow: 1;
        display: flex;
        align-items: center;
        justify-content: center;
        text-align: justify;
        padding: 0 1rem;
    }
}

@media screen and (max-width: 768px) {
    .billboard {
        margin: 0 auto;
        text-align: center;
    }

    .billboard-body {
        text-align: justify;
    }
}

#customer-name {
    font-size: 1.25rem;
    font-weight: 500;
}

.text-small {
    font-size: .8rem
}

.customer-info {
    margin-left: -0.5rem;
}

@media screen and (max-width: 768px) {
    .customer-info {
        max-width: 400px;
        margin: 0 auto;
    }
}

@media screen and (min-width: 769px) {
    .customer-info .col-md-3 {
        padding-top: 8px;
    }
}

#invoice-body td {
    vertical-align: middle;
}

.progress-steps {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 2rem;
    position: relative;
}

.progress-step {
    z-index: 10;
    text-align: center;
    display: flex;
    justify-content: center;
    flex-direction: column;
    text-align: center;
    vertical-align: middle;
}

.progress-icon {
    display: flex;
    border-radius: 50%;
    min-width: 25px;
    min-height: 25px;
    margin: 0 auto;
    border: 5px solid rgba(0,0,0,0);
    background-color: #b1b1b1;
    text-align: center;
    color: #ffffff
}

.progress-step.done > .progress-icon {
    background-color: #0381ff !important;
}

.progress-steps progress {
    -webkit-appearance: none;
    position: absolute;
    width: 100%;
    z-index: 5;
    height: 10px;
    padding-left: 1rem;
    padding-right: 1rem;
    margin-bottom: 18px;
}

    .progress-steps progress::-webkit-progress-value {
        background-color: #0381ff;
        transition: .5s ease;
    }

    .progress-steps progress::-webkit-progress-bar {
        background-color: #b1b1b1;
    }

.table td {
    vertical-align: middle !important;
}

#btnRefund.disabled-link {
    pointer-events: none;
    cursor: default;
}

.pet-profiles-container {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(auto-fit, minmax(78px, 78px));
}

/* Snackbar */
#snackbar {
    visibility: hidden;
    min-width: 250px;
    margin-left: -125px;
    background-color: #333;
    color: #fff;
    text-align: center;
    border-radius: 2px;
    padding: 16px;
    position: fixed;
    z-index: 1;
    left: 50%;
    bottom: 30px;
    font-size: 17px;
}

    #snackbar.show {
        visibility: visible;
        -webkit-animation: fadein 0.5s, fadeout 0.5s 2.5s;
        animation: fadein 0.5s, fadeout 0.5s 2.5s;
    }

@-webkit-keyframes fadein {
    from {
        bottom: 0;
        opacity: 0;
    }

    to {
        bottom: 30px;
        opacity: 1;
    }
}

@keyframes fadein {
    from {
        bottom: 0;
        opacity: 0;
    }

    to {
        bottom: 30px;
        opacity: 1;
    }
}

@-webkit-keyframes fadeout {
    from {
        bottom: 30px;
        opacity: 1;
    }

    to {
        bottom: 0;
        opacity: 0;
    }
}

@keyframes fadeout {
    from {
        bottom: 30px;
        opacity: 1;
    }

    to {
        bottom: 0;
        opacity: 0;
    }
}

/* Filter display for tables */
.filters {
    width:100%;
}
.filters .btn {
    border-width: var(--bs-border-width);
    border-radius: var(--bs-border-radius);
}

.filters > span, .filters > label, .filters .form-check-label {
    font-weight: bold;
    text-transform: uppercase;
    font-size: 0.9rem;
}
.filters .form-label {
    margin-right: .25rem;
}

.filters > div.form-check {
    margin-left: 1rem;
}
.filters .form-control, .filters .form-select {
    display: inline-block;
    width: auto;
}

p > code {
    border: 1px solid var(--bs-code-color);
    border-radius: .25rem;
    padding-left: .25rem;
    padding-right: .25rem;
}

/* give inactive unchecked checkboxes a darker background to make them more easily distinguishable */
.form-check-input:disabled:not(:checked) {
    filter: brightness(80%);
}

input:disabled+label {
    color: #ccc
}