.star {
    font-size: 25px;
    color: gray;
    cursor: pointer;
    transition: color 0.3s ease;
    position:relative;
}

.star.filled {
    color: gold;
}


/* Sticky footer styles
-------------------------------------------------- */

html {
    position: relative;
    min-height: 100%;
}

body {
    /* Margin bottom by footer height */
    margin-bottom: 100px;
}

.footer {
    position: absolute;
    bottom: 0;
    width: 100%;
    /* Set the fixed height of the footer here */
    height: auto;
    /* line-height: 60px; /* Vertically center the text there */
}

/* Custom CSS */
.favs .accordion-body{
padding-top:0 !important;
}
.favs .accordion-button{
padding:5px 0px;
}
.footer-logo {
    max-width: 310px;
    margin-right: 15px;
}

.print_only {
    display: none;
}

.clickable, .homelink {
    cursor: pointer;
}

.report-card {
    cursor: pointer;
}

.navbar-logo img {
    /* height: 100px; */
}

.navbar-brand {
    color: #000000;
    font-size: 36px;
    font-weight: bold;
}

.navbar-brand:hover, .navbar-brand:focus {
    color: rgb(22, 15, 72) !important;
}

.navbar-portal {
    color: #000000;
    font-size: 28px;
    font-weight: bold;
}

.navbar-brand:hover, .navbar-brand:focus {
    color: rgba(0, 0, 255, 0.568);
}

img.tableIcon {
    max-height: 55px;
    max-width: -webkit-fill-available;
    padding: 3px;
}

.card {
    /*border-color: #160f48;*/
}

.card-header {
    /*background-color: #f7c026;*/
    background-color: #efefef;
    border: 0px;
    /*border-bottom-color: rgba(0, 113, 188, 0.75)*/
}

.homecard .card-body{
    padding: 0px;
}

.apptitle {
    font-size: 16px;
}

.currentclient {
    font-size: 40px;
    font-weight: bold;
    margin-bottom: 0;
}

.titleseparator {
    border-top: 0;
    opacity: 1;
    margin: 0;
    height: 5px;
    background-image: #1e104c;
}

.limit-two-lines{
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 2; /* number of lines to show */
    line-clamp: 2;
    -webkit-box-orient: vertical;
}

.print_only {
    display: none;
}

/*.report-card .card-title {
    min-height: 48px;
}

.report-card .card-text {
    min-height: 61px;
}*/

/* Styling to reverse datatables search and page length selector */
/* ALSO MUST use the dom attribute when creating a datatable */
.dtToolSwapped .dataTables_length, .dataTables_paginate {
    float: right;
}

.dtToolSwapped .dataTables_length label {
    display: inline-flex;
}

.dtToolSwapped .dataTables_filter {
    float: left;
}

.dtToolSwapped .dataTables_filter label {
    display: inline-flex;
}

.dtToolSwapped .dataTables_filter label input {
    margin-left: 5px;
}

.homecardheader {
    font-size: 18px;
	padding-top: 2px;
	padding-bottom: 2px;
}

.dash_data{
    font-size:2.25em;
}

.dash_data_cube{
    margin:3px;
    padding:3px;
    border:2px solid #1e104c;
    border-radius: 25px;
}

.hide-button{
    display: none;
}

main{
    opacity: 1;
    background-color: #1e104c;
}
main h3:first-of-type {
    color: white;
}
.homecard .homelink{
    position: relative;
    display: flex;
    align-items: center;
    width: 100%;
    padding: 16px 20px 16px 0px;
    font-size: 18px;
    text-align: left;
    border: 0;
    border-radius: 0;
    overflow-anchor: none;
}
.homecard .homecardheader .accordion-button{
    padding-left:0px;
}
/*.homecard h2{
    border-bottom: 1px solid #dee2e6;
}
.homecard h2:last-of-type{    
    border-bottom: 0px;
}*/
/* Custom button class */
.btn.btn-sbo-gold{
    background-color: #ffd580;
    border-color: #160f48;
    color: black;
    text-shadow:unset;
    border-width: 4px;
    font-weight: bold;
    letter-spacing: 0.05em;
    border-radius: 30px;
    padding-left: 15px !important;
    padding-right: 15px !important;
    margin-left: 12px;
    margin-right: 12px;
    margin-bottom: 4px;
}

.btn.btn-sbo-gold:hover {
    color: white;
    text-shadow: 1px 1px 0 #4074b5, 1px -1px 0 #4074b5, -1px 1px 0 #4074b5, -1px -1px 0 #4074b5, 1px 0px 0 #4074b5, 0px 1px 0 #4074b5, -1px 0px 0 #4074b5, 0px -1px 0 #4074b5;
}

.btn.btn-sbo-gold:active {
    /*background-color: #f7c026;*/
    background-color: #cbcbcb;
    border-color: #160f48;
    color: black;
    text-shadow:unset;
}

.table-class{
    max-width:inherit;
    width: 100%!important;
}

.table-class td {
    width: 8%!important;
}

/* Start Kiel Added CSS */

@media (min-width: 992px) {

    #groupModal {
        visibility: hidden;
    }

    #groupModal .modal-dialog {
        position: absolute;
        margin: 0 !important;
        transform: none !important;
    }

    #groupModal.show {
        visibility: visible;
    }
}

#w2contractor .form-label, #contractor1099 .form-label {
    font-size:16px;
}

#w2contractor .form-control, #contractor1099 .form-control{
    line-height: 1;
}
#w2contractor hr, #contractor1099  hr{
    margin: .5rem 0;
}
#w2contractor .table>:not(caption)>*>*, #contractor1099 .table>:not(caption)>*>* {
    padding: 0.15rem;
}
#w2contractor .card-body, #contractor1099 .card-body{
    padding: .5rem var(--bs-card-spacer-x)
}
#w2contractor .table, #contractor1099 .table{
    margin-bottom:0px;
}
.card-header .btn-primary {
	background-color: #ffd580;
	border-color: transparent;
	color: #000;
}
.card-header .btn-primary:hover {
	color: white;
    text-shadow: 1px 1px 0 #4074b5, 1px -1px 0 #4074b5, -1px 1px 0 #4074b5, -1px -1px 0 #4074b5, 1px 0px 0 #4074b5, 0px 1px 0 #4074b5, -1px 0px 0 #4074b5, 0px -1px 0 #4074b5;
}

.dash_data_cube {
  position: relative; /* makes offsetTop measurement relative to the container */
  --stop: 32px;       /* fallback */
  /* gradient: solid color from top to --stop, then transparent */
  background: linear-gradient(
    to bottom,
    #ffd580 0px,
    #ffd580 calc(var(--stop)),
    rgba(0,0,0,0) calc(var(--stop))
  );
  padding: 8px 12px;
}

/* keep your typography styles */
.dash_data_cube p { margin: 20px auto; }
.dash_data { margin-top: 6px; } /* example spacing */

li.nav-item {
    margin: 0 15px;
}

.navbar-nav .branches_select {
    margin: 0 25px !important;
}

.btn.report_btn {
    background-color: #ffd580;
    color: black;
    text-shadow: unset;
    font-weight: bold;
    letter-spacing: 0.05em;
    padding-left: 15px !important;
    padding-right: 15px !important;
}

.document_center_link .row:last-child {
    margin-bottom: .5rem; 
}

/* End Kiel Added CSS */

@media print {
    .print_only {
        display: block;
        visibility: visible;
    }

    .navbar, .filtercard {
        display: none;
    }

    .table-responsive {
        overflow: visible !important;
    }

    .table {
        font-size: 12px;
    }

    .table>:not(caption)>*>* {
        padding: 0.25rem 0.25rem;
    }

    .hideprint {
        display: none;
    }

    .hideborder {
        border:unset;
    }
}

@media only screen and (max-width: 1000px){
    .btn.btn-sbo-gold{
        padding-left: 15px !important;
        padding-right: 15px !important;
        margin-left: 2px;
        margin-right: 2px;
    }
}

@media only screen and (max-width: 767px){
    .branches_select{
        text-align: center;
        margin: 15px auto;
    }
    .report-card{
        margin-top:-5px !important;
    }
}