.nav-link.active-underline {
    background-color: none;
    border-color: none;
    border-bottom: 3px solid #0d6efd;
}

/* Remove border from toggler */
.navbar-toggler {
    border: 0;
}

.navbar-toggler:focus,
.navbar-toggler:active,
.navbar-toggler-icon:focus {
    outline: none;
    box-shadow: none;
    border: 0;
}

/* Lines of the Toggler */
.toggler-icon {
    width: 30px;
    height: 3px;
    background-color: #e74c3c;
    display: block;
    transition: all 0.2s;
}

/* Adds Space between the lines */
.middle-bar {
    margin: 5px auto;
}

/* State when navbar is opened (START) */
.navbar-toggler .top-bar {
    transform: rotate(45deg);
    transform-origin: 10% 10%;
}

.navbar-toggler .middle-bar {
    opacity: 0;
    filter: alpha(opacity=0);
}

.navbar-toggler .bottom-bar {
    transform: rotate(-45deg);
    transform-origin: 10% 90%;
}
/* State when navbar is opened (END) */

/* State when navbar is collapsed (START) */
.navbar-toggler.collapsed .top-bar {
    transform: rotate(0);
}

.navbar-toggler.collapsed .middle-bar {
    opacity: 1;
    filter: alpha(opacity=100);
}

.navbar-toggler.collapsed .bottom-bar {
    transform: rotate(0);
}
/* State when navbar is collapsed (END) */

/* Color of Toggler when collapsed */
.navbar-toggler.collapsed .toggler-icon {
    background-color: #777777;
}

@media (max-width: 992px) {
    .downdownopen {
        display: block;
    }
}

#lptapp {
    font-family: 'Roboto',sans-serif;
}

.main-container {
    margin-top: 112px;
}

.form-submit-loader {
    border: 6px solid #f3f3f3;
    border-radius: 50%;
    border-top: 6px solid #3498db;
    width: 30px;
    height: 30px;
    -webkit-animation: spin 2s linear infinite; /* Safari */
    animation: spin 2s linear infinite;
}

/* Safari */
@-webkit-keyframes spin {
    0% { -webkit-transform: rotate(0deg); }
    100% { -webkit-transform: rotate(360deg); }
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

@media (max-width: 1199px) {
    #top-nav-container {
        justify-content: space-between !important;
        padding-left: 25px !important;
        padding-right: 25px !important;
    }

    #top-navbar-hamburger {
        display: inline-block !important;
    }

    #top-nav-search-container {
        display: none !important;
    }
}

.btn-hover-shadow:hover {
    box-shadow: 0 13px 17px 0 rgb(0 0 0 / 10%), 0 2px 4px 0 rgb(0 0 0 / 22%) !important;
}

/* Custom Color Themes: buttons */
.theme-btn-blue {
    color: #fff;
    background-color: #1c72ac;
    border-color: #1c72ac;
}
.theme-btn-green {
    color: #000;
    background-color: #a8c941;
    border-color: #a8c941;
}
.theme-btn-red {
    color: #fff;
    background-color: #bd2932;
    border-color: #bd2932;
}
.theme-btn-teal {
    color: #fff;
    background-color: #2ba4a0;
    border-color: #2ba4a0;
}
.theme-btn-yellow {
    color: #000;
    background-color: #facc0f;
    border-color: #facc0f;
}
.theme-btn-purple {
    color: #fff;
    background-color: #664058;
    border-color: #664058;
}
/* Custom Color Themes: button hover colors */
.theme-btn-blue:hover {
    color: #fff !important;
}
.theme-btn-green:hover {
    color: #000 !important;
}
.theme-btn-red:hover {
    color: #fff !important;
}
.theme-btn-teal:hover {
    color: #fff !important;
}
.theme-btn-yellow:hover {
    color: #000 !important;
}
.theme-btn-purple:hover {
    color: #fff !important;
}
/* Custom Color Themes: backgrounds */
.theme-bg-blue {
    background-color: #1c72ac !important;
}
.theme-bg-green {
    background-color: #a8c941 !important;
}
.theme-bg-red {
    background-color: #bd2932 !important;
}
.theme-bg-teal {
    background-color: #2ba4a0 !important;
}
.theme-bg-yellow {
    background-color: #facc0f !important;
}
.theme-bg-purple {
    background-color: #664058 !important;
}
/* Custom Color Themes: text */
.theme-text-blue {
    color: #1c72ac !important;
}
.theme-text-green {
    color: #a8c941 !important;
}
.theme-text-red {
    color: #bd2932 !important;
}
.theme-text-teal {
    color: #2ba4a0 !important;
}
.theme-text-yellow {
    color: #facc0f !important;
}
.theme-text-purple {
    color: #664058 !important;
}
.theme-text-light {
    color: #fff !important;
}
.theme-text-dark {
    color: #000 !important;
}

/* SVG Color Change Filters */
.svg-filter-blue {
    filter: brightness(0%) saturate(100%) invert(42%) sepia(80%) hue-rotate(177deg) contrast(400%);
}
.svg-filter-green {
    filter: brightness(10%) saturate(100%) invert(44%) sepia(90%) hue-rotate(40deg) contrast(400%);
}
.svg-filter-red {
    filter: brightness(0%) saturate(100%) invert(42%) sepia(80%) hue-rotate(310deg) contrast(400%);
}
.svg-filter-teal {
    filter: brightness(0%) saturate(100%) invert(42%) sepia(90%) hue-rotate(130deg) contrast(500%);
}
.svg-filter-yellow {
    filter: brightness(0%) saturate(100%) invert(46%) sepia(85%) hue-rotate(372deg) contrast(560%);
}
.svg-filter-purple {
    filter: brightness(0%) saturate(100%) invert(35%) sepia(80%) hue-rotate(240deg) contrast(280%);
}

.headshot img {
    width: 100%;
}

.navbar .logo {
    max-height: 52px;
}

.navbar .logo-container {
    max-width: 310px;
}

.listing-card {
    margin-top: 15px;
    min-width: 358px;
}
.listing-card .card-hero {
    min-height: 224px;
}
.listing-card .carousel-inner {
    border-top-right-radius: 6px;
    border-top-left-radius: 6px;
}
.listing-card .card-info-container {
    background-color: white;
    height: 116px;
    border-bottom-right-radius: 6px;
    border-bottom-left-radius: 6px;
    box-shadow: 0 10px 40px 0 rgba(0, 0, 0, 0.15);
}
.listing-card .card-info-container:hover {
    background-color: #efefef;
    cursor: pointer;
}
.listing-card .floater {
    padding: 8px;
    position: relative;
    top: -8px;
    line-height: normal;
    float: right;
    color: white;
    width: 52%;
    background-color: #1469ab;
    box-shadow: 0 3px 20px 0 rgba(0, 0, 0, 0.35);
    background-image: linear-gradient(-180deg, #378dd0, #1469ab 90%);
    color: #fff;
    border-top-left-radius: 4px;
    border-bottom-left-radius: 4px;
}
.listing-card .floater .money-icon {
    width: 27px;
    margin-top: 6%;
    margin-left: 5px;
    float: left;
    margin-right: 5px;
}
.listing-card .floater .money-icon img {
    position: relative;
    top: -6px;
    left: -3px;
}
.listing-card .floater a {
    font-size: 14px;
    font-weight: normal;
    letter-spacing: 0.5px;
    color: white;
    text-decoration: none;
}
.listing-card .floater a:hover {
    text-decoration: underline;
}
.listing-card .card-info-container .left {
    float: left;
    margin-left: 14px;
}
.listing-card .card-info-container .right {
    float: right;
    clear: right;
    margin-right: 23px;
    margin-top: 10px;
    position: relative;
    bottom: 5px;
    color: black;
    font-size: 15px;
}
.listing-card .beds, .listing-card .baths, .listing-card .footage {
    float: left;
    clear: both;
}
.listing-card .right span {
    color: #cfcfcf;
}
.listing-card .left .price span:nth-child(1) {
    font-size: 10px;
    font-weight: bold;
    letter-spacing: 0.2px;
    color: #555555;
}
.listing-card .left .price .actual-price {
    font-size: 24px;
    font-weight: bold;
    letter-spacing: 0.2px;
    color: #555555;
}
.listing-card .left .address span:nth-child(1) {
    font-size: 14px;
    font-weight: bold;
    letter-spacing: 0.1px;
    color: #555555;
}
.listing-card .left .address a {
    text-decoration: none;
}
.listing-card .left .address a:hover {
    text-decoration: underline;
}
.listing-card .left .address .city-state-zip {
    font-size: 13px;
    font-weight: normal;
    font-style: italic;
    letter-spacing: 0.2px;
    color: #555555;
}

.card-banner-wrapper {
    position: relative;
    width: 0;
    height: 0;
    z-index: 2;
}

.card-banner-wrapper-inner {
    position: absolute;
    width: fit-content;
}

.card-banner {
    min-height: 40px;
    min-width: 130px;
    border-bottom-right-radius: 6px;
    border-top-left-radius: 5px;
    background-color: white;
}

.card-banner-text {
    color: #555555;
    font-weight: bold;
    letter-spacing: 1px;
}

.toast-container {
    z-index: 99999;
}

.apply-card {
    border-radius: 10px;
}

.apply-card-h3 {
    font-size: 20px;
    margin-top: 0;
    margin-bottom: 15px;
}

.apply-card-input {
    width: 100%;
    margin-bottom: 13px;
    height: 45px;
    border-radius: 50px;
    padding-left: 20px;
    font-size: 14px;
    line-height: 1.42857143;
    color: #555;
}

.apply-card-button {
    height: 45px;
    border-radius: 50px;
    border: none;
    box-shadow: 0px 2px 8px 0 rgb(0 0 0 / 30%);
    width: 100%;
    margin-top: 20px;
}

.form-loading {
    margin-top: 20px;
    height: 45px;
    text-align: center;
    text-align: -webkit-center;
}

.form-message {
    margin-top: 20px;
    height: 45px;
    font-size: 14px;
    text-align: center;
    text-align: -webkit-center;
}

#footer {
    font-size: 12px;
    background-color: #f7f7f7;
}

#top-nav-container {
    height: 98px;
}

.logo-container img {
    cursor: pointer;
}

#top-nav-search {
    font-size: 14px;
    min-width: 550px;
    border-radius: 20px;
    min-height: 42px;
}

#top-nav-search:hover {
    box-shadow: 0 .2rem 1rem rgba(0,0,0,.13) !important;
}

#top-nav-search-all {
    min-width: 150px;
    font-size: 14px;
    border-radius: 20px;
    min-height: 42px;
}

#top-nav-search-collapsed {
    font-size: 14px;
    border-radius: 20px;
    min-height: 42px;
}

#top-nav-search-collapsed:hover {
    box-shadow: 0 .2rem 1rem rgba(0,0,0,.13) !important;
}

#top-nav-search-all-collapsed {
    min-width: 150px;
    font-size: 14px;
    border-radius: 20px;
    min-height: 42px;
}

.search-icon {
    position: relative;
    right: 3.8rem;
    top: 0.5rem;
    cursor: pointer;
}

/* clears the 'X' from Internet Explorer */
#top-nav-search::-ms-clear {
    display: none;
    width : 0;
    height: 0;
}
#top-nav-search::-ms-reveal {
    display: none;
    width : 0;
    height: 0;
}
#top-nav-search-collapsed::-ms-clear {
    display: none;
    width : 0;
    height: 0;
}
#top-nav-search-collapsed::-ms-reveal {
    display: none;
    width : 0;
    height: 0;
}

/* clears the 'X' from Chrome */
#top-nav-search::-webkit-search-decoration,
#top-nav-search::-webkit-search-cancel-button,
#top-nav-search::-webkit-search-results-button,
#top-nav-search::-webkit-search-results-decoration {
    display: none;
}
#top-nav-search-collapsed::-webkit-search-decoration,
#top-nav-search-collapsed::-webkit-search-cancel-button,
#top-nav-search-collapsed::-webkit-search-results-button,
#top-nav-search-collapsed::-webkit-search-results-decoration {
    display: none;
}

.top-navbar {
    z-index: 9999;
}

#top-navbar-collapse {
    position: fixed;
    width: 100%;
    top: 106px;
    right: -4px;
    background-color: #f8f9fa;
    border-bottom-left-radius: 10px;
    border-bottom-right-radius: 10px;
    padding-bottom: 24px !important;
    padding-top: 24px !important;
}

.separator {
    height: 0.1px;
    border: solid 0.5px #e5e5e5;
    margin-top: 28px;
    margin-bottom: 28px;
}

.profile-layout-wrapper {
    margin-top: 10rem !important;
}
.profile-apply-card {
    float: right;
    max-width: 360px;
}

.property-layout-wrapper {
    margin-top: 114px !important;
}
.property-section-header {
    font-size: 13px;
    font-weight: 700;
    font-style: normal;
    font-stretch: normal;
    line-height: 4.08;
    letter-spacing: 1.2px;
    color: #555555;
}
.property-apply-card {
    max-width: 360px;
}

.search-layout-wrapper {
    min-height: 700px;
    margin-top: 112px !important;
}
.search-similar-container {
    max-height: 88vh;
    width: 415px;
    height: 100%;
    float: left;
    background-color: white;
    padding: 10px;
    position: absolute;
    overflow: scroll;
}
.search-map-container {
    left: 415px;
    visibility: visible;
    height: auto;
    width: auto;
    right: 0;
    bottom: 0;
    position: fixed;
}

.agent-bio-container h2 {
    font-size: 18px;
    letter-spacing: 0.4px;
}

.agent-bio-container p {
    font-size: 18px;
    color: #464646;
}

.agent-details {
    margin-bottom: 30px;
}

.agent-details h2 {
    color: #1469ab;
    font-weight: 600;
    letter-spacing: 0.5px;
    font-size: 24px;
}

.agent-details h4 {
    color: #555555;
    font-weight: 600;
    letter-spacing: 0.3px;
    font-size: 15px;
    line-height: 1.2;
}

.agent-contact h4 {
    letter-spacing: 0.5px;
    font-size: 16px;
    font-weight: bold;
    line-height: 1.1;
    color: #555555;
}

.agent-contact a {
    text-decoration: none;
}

.agent-contact a span span:hover {
    text-decoration: underline;
}

.agent-view-profile {
    cursor: pointer;
}

.agent-view-profile:hover {
    text-decoration: underline;
}

.cities h1 {
    font-size: 36px;
    font-weight: 300;
    font-style: normal;
    font-stretch: normal;
    line-height: normal;
    letter-spacing: 0.1px;
    color: #30302f;
    margin-top: 30px;
    margin-left: 20px;
}
.cities li {
    display: inline-block;
    list-style-type: none;
    font-size: 16px;
    font-weight: normal;
    font-style: normal;
    font-stretch: normal;
    line-height: 1.56;
    letter-spacing: 0px;
    color: #1469ab;
    margin-right: 20px;
    text-decoration: none;
}
.cities li a {
    cursor: pointer;
    text-decoration: none !important;
}
.cities li a:hover {
    cursor: pointer;
    text-decoration: underline;
}
.cities-bottom-padding {
    margin-top: 60px;
}

.maplist-legend {
    font-size: 16px;
    color: #464646;
}

.maplist-tabs {
    font-size: 14px;
    cursor: pointer;
}

.maplist-tab-ul {
    display: flex;
    flex-wrap: wrap;
    padding-left: 0;
    margin-bottom: 0;
    list-style: none;
}

.maplist-tab-link {
    padding: 0.5rem 1rem;
    text-decoration: none;
    border: 0;
    border-radius: .25rem;
}

.appointment-header-icon {
    font-size: 25px;
}

.appointment-header-text {
    font-size: 20px;
    font-weight: bold;
    font-style: normal;
    font-stretch: normal;
    letter-spacing: 0.2px;
}

#selectedDate {
    font-weight: bold;
    color: #555555 !important;
}

.selected-time {
    min-width: 80px;
    font-weight: bold;
    font-size: large;
    text-align: center;
    align-self: center;
}

.appointment-top-wrapper {
    max-width: 500px;
    border-top: 1px solid #e0e0e0;
    border-right: 1px solid #e0e0e0;
    border-left: 1px solid #e0e0e0;
    border-top-right-radius: 6px;
    border-top-left-radius: 6px;
    color: #555555;
}

.appointment-bottom-wrapper {
    max-width: 500px;
    border-bottom-right-radius: 6px;
    border-bottom-left-radius: 6px;
    border: solid 1px #e0e0e0;
    background-color: #f6f6f6;
    color: #555555;
}

.appointment-button {
    min-width: 150px;
    font-size: 14px;
    border-radius: 20px;
    min-height: 42px;
}

.time-button-container {
    max-width: 400px;
    overflow: hidden;
}

.time-button {
    height: 35px;
    border-radius: 6px;
    box-shadow: 0 11px 9px 0 rgb(0 0 0 / 9%), 0 2px 4px 0 transparent;
    margin: 8px;
    font-size: 14px;
    font-weight: bold;
    font-style: normal;
    font-stretch: normal;
    text-align: center;
    line-height: normal;
    letter-spacing: 0px;
    padding-top: 7px;
}

.selected-time-button {
    box-shadow: 0 13px 17px 0 rgb(0 0 0 / 10%), 0 2px 4px 0 rgb(0 0 0 / 22%);
    cursor: pointer;
}

#carouselContainer {
    max-width: 1200px;
}

.description-text {
    font-size: 14px;
    font-weight: normal;
    font-style: normal;
    font-stretch: normal;
    line-height: 1.5;
    letter-spacing: 0.2px;
    color: #555555;
}

.detail-icon-card {
    width: 90px;
    background-color: #f6f6f6;
    border: none;
    overflow-wrap: normal;
}

.detail-icon-card-body {
    overflow-wrap: normal;
}

.detail-icon-card-amount {
    font-size: 12px;
    font-style: normal;
    font-stretch: normal;
    line-height: normal;
    letter-spacing: 0.2px;
    width: 100%;
}

#share-button {
    min-width: 100px;
    font-size: 14px;
    border-radius: 20px;
}

.details-wrapper {
    color: #555555;
}

.sold-date {
    font-size: 28px;
    color: #ce0a0a;
}

.details-price {
    font-size: 36px;
    line-height: 1.36;
    letter-spacing: 0.3px;
}

.share-icon {
    font-size: 12px;
}

.details-city-state-zip {
    height: 16px;
    font-size: 14px;
    font-style: italic;
    line-height: normal;
    letter-spacing: 0.2px;
}

.additional-details {
    font-size: 14px;
    line-height: 1.42857143;
}

.presented-by {
    display: inline-block;
    font-weight: normal;
    font-style: normal;
    font-stretch: normal;
    line-height: 1.5;
    letter-spacing: 0.2px;
    color: #555555;
}

.navigation-nav-link {
    cursor: pointer;
}

.open-house-wrapper {
    color: #555555;
}

.open-house {
    letter-spacing: 1.2px;
}

.open-house-time {
    font-style: italic;
}

.appointment-modal-img {
    display: inline-block;
}

.appointment-modal-content {
    border-radius: 10px;
}

.appointment-modal-header {
    font-size: 18px;
    font-weight: bold;
    font-style: normal;
    font-stretch: normal;
    line-height: 1.22;
    letter-spacing: 0.2px;
    color: #555555;
    display: inline-block;
    width: 60%;
    margin-left: 12px;
    margin-top: 20px;
}

.appointment-modal-input {
    width: 100%;
    margin-bottom: 13px;
    height: 45px;
    border-radius: 50px;
    padding-left: 20px;
    font-size: 14px;
    line-height: 1.42857143;
    color: #555;
}

.appointment-modal-textarea {
    height: 137px;
    border-radius: 1px;
    border: solid 1px #e5e5e5;
    margin-bottom: 18px;
    padding-top: 5px;
    padding-left: 14px;
    width: 100%;
    font-size: 14px;
    line-height: 1.42857143;
    color: #555;
}

.appointment-modal-button {
    height: 45px;
    border-radius: 50px;
    border: none;
    box-shadow: 0px 2px 8px 0 rgb(0 0 0 / 30%);
    width: 100%;
    margin-top: 20px;
}