@import url('https://fonts.googleapis.com/css2?family=Barlow:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap');

:root{
    --gold: #FABE04;
    --dark-gold: #d4af37;
    --dark: #2c2c2c;
    --body-font: "Barlow", sans-serif;
    --btn-shadow: 0px 1px 2px 0px rgba(16, 24, 40, 0.05);
}

html{
    height: 100%;
    scroll-behavior: smooth;
    overflow-x: hidden;
}
body {
    margin: 0;
    padding: 0;
    font-family: var(--body-font);
    height: 100%;
    background-color: var(--dark);
    background-image: url(/assets/frontend/bg-dots-1-2736ed2ca881989ac9fd596b00e894715845a5ccf3693fe26d431aedbe7a0f58.png);
    /* background-size: 85%; */
    /* background-size: cover; */
    /* background-repeat: repeat; */
    background-repeat: no-repeat;
    background-position: center;
}
.main{
    flex-basis: 0;
}
.main section{
    padding-top: 6rem;
    padding-bottom: 6rem;
}
h1,h2,h3,h4,h5{
    font-weight: 600;
}
a{
    text-decoration: none;
}
.mw-480{
    max-width: 480px;
}
.mw-575{
    max-width: 575px;
}
.mw-768{
    max-width: 768px;
}
/* section{
    padding-top: 96px;
    padding-bottom: 96px;
} */

/* -------------------- */
/* Skip to main content */
/* -------------------- */
.skip-to-main-content {
    position: absolute;
    left: -9999px;
    z-index: 9999;
    padding: 1em;
    background-color: black;
    color: #fff;
    opacity: 0;
}
.skip-to-main-content:focus {
    left: 50%;
    top: 1%;
    transform: translateX(-50%);
    opacity: 1;
    border: 1px solid red;
}

/* -------------- */
/*    Homepage    */
/* -------------- */

/* header */
.home-header{
    height: 85px;
    background-color: var(--dark);
    position: relative;
}
.home-header div:first-child{
    position: relative;
}
.home-header img{
    height: 53px;
    width: auto;
    background-color: var(--dark);
}

/* banner */
.home-banner{
    height: calc(110vh - 85px);
    transition: border-radius 0.1s ease, transform 0.1s ease;
    overflow: hidden;
    background-image: url(/assets/frontend/mallaleys-bg-md-54990292a2a16b80f35b659a9506e9598313bdbeab40a9e42602d283495dc24b.jpg);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
}
.banner-content {
    width: 100%;
    height: 100%;
    transition: border-radius 0.1s ease, transform 0.1s ease;
    overflow: hidden;
}
/* .home-banner img{
    height: 100%;
    width: 100%;
    object-fit: cover;
}

.home-banner .banner-overlay{
    background-color: rgba(0, 0, 0, 0.20);
    padding-top: 48px;
    padding-bottom: 96px;
} */
/* .home-form-title h2{
    color: #101828;
    font-weight: 700;
    text-transform: uppercase;
} */
/* .home-form-title p{
    color: #475467;
    font-size: 16px;
    font-weight: 400;
    line-height: 24px;
} */

/* home form */
.home-filter-form h2{
    color: #101828;
    font-weight: 700;
    text-transform: uppercase;
}
.home-filter-form p{
    color: #475467;
    font-size: 16px;
    font-weight: 400;
    line-height: 24px; /* 150% */
}
.home-filter-form > div{
    padding: 16px;
    border-radius: var(--radius-4xl, 24px);
    background: rgba(242, 244, 247, 0.85);
    overflow: hidden;
}
.home-filter-form form.row{
    padding: 16px;
    border-radius: var(--radius-2xl, 16px);
    background: rgba(255, 255, 255, 0.75);
    margin: 0;
}
.home-filter-form .form-label{
    color: #344054;
    font-size: 14px;
    font-weight: 500;
}
.home-filter-form textarea{
    height: 135px;
    resize: none;
}
.home-filter-form option:checked{ 
    background-color: rgba(212, 175, 55, 0.5); 
    color: var(--dark);
}

form .form-select:focus{
    border-color: var(--gold);
    box-shadow: 0 0 0 .25rem rgba(250, 190, 4, 0.25);
}

/* navigation bar */
nav.navbar {
    bottom: 2%;
    position: fixed;
    width: 100%;
    z-index: 999;
    box-shadow: none;
}
.floating-menu .container {
    -webkit-backdrop-filter: blur(22.5px);
    backdrop-filter: blur(22.5px);
    background: rgba(0, 0, 0, 0.55);
    border-radius: 16px;
    border: 1px solid rgba(0, 0, 0, 0.2);
    box-shadow: 0 -1px 10px rgba(0, 0, 0, 0.1);
    margin: 0 auto;
    max-width: 768px;
    border: 2px solid var(--gold);
}

.navbar-nav {
    flex-direction: row;
    justify-content: center;
}
.nav-item {
    position: relative;
    margin: 0 10px;
}
ul.navbar-nav .nav-link.active, ul.navbar-nav .nav-link.show, a.nav-link:focus, a.nav-link:hover{
    color: var(--dark-gold);
}
.dropup .dropdown-menu {
    left: 50%;
    transform: translateX(-50%);
}
.nav-link{
    color: white;
    /* font-size: 20px; */
    font-weight: 500;
}
.navbar-nav .nav-link.active, .navbar-nav .nav-link.show, .nav-link:focus, .nav-link:hover{
    color: white;
}
.dropup .dropdown-menu[data-bs-popper]{
    margin-bottom: 0.75rem;
}
.dropdown-menu{
    background-color: rgba(0, 0, 0, 0.85);
    backdrop-filter: blur(22.5px);
    -webkit-backdrop-filter: blur(22.5px);
    overflow: hidden;
    /* border: 1px solid rgba(0, 0, 0, 0.3); */
    border: 2px solid var(--gold);
}
.dropdown-menu .dropdown-item{
    color: white;
}
.dropdown-item:focus, .dropdown-item:hover{
    background-color: rgba(45, 45, 45, 0.8);
}

/* home featured rv's section */
.home-featured{
    /* position: -webkit-sticky;
    position: sticky;
    top: 0; */
    width: 100%;
    z-index: 1;
    background: transparent;
}

.home-featured img{
    width: 250px;
    object-fit: contain;
}
.home-featured h1{
    color: #FFF;
    font-weight: 600;
}
.home-featured p{
    color: #FFF;
    font-size: 20px;
    font-weight: 200;
}
.home-featured .featured-card{
    min-width: 280px;
    height: 380px;
    flex-basis: 0;
    border-bottom: 10px solid #D4AF37;
    overflow: hidden;
}
.featured-card .featured-info{
    background: rgba(0, 0, 0, 0.25);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    padding: 24px 20px;
    height: 74px;
    overflow: hidden;
    -webkit-transition: height 0.5s;
    transition: height 0.5s;
    position: absolute;
    bottom: 0;
    width: 100%;
}
.featured-card:hover .featured-info{
    height: 75%;
}
.featured-info h4{
    flex-basis: 0;
    color: #FFF;
    /* font-size: 24px; */
    font-size: 18px;
    font-weight: 600;
    margin-bottom: 0;
}
.featured-card .featured-list ul{
    list-style: none;
    padding-left: 0;
}
.featured-card .featured-list li{
    position: relative;
    padding-left: 2rem;
    color: #FFF;
    font-size: 16px;
    font-weight: 400;
}
.featured-list span{
    font-weight: 700;
}
.featured-card .featured-list li:not(:last-child):before {
    content: '';
    position: absolute;
    left: 0;
    width: 24px;
    height: 24px;
    background: url("data:image/svg+xml;utf8,<?xml version='1.0' encoding='utf-8'?> <svg xmlns='http://www.w3.org/2000/svg' width='24' height='25' viewBox='0 0 24 25' fill='none'><path d='M7.5 12.3098L10.5 15.3098L16.5 9.30981M22 12.3098C22 17.8327 17.5228 22.3098 12 22.3098C6.47715 22.3098 2 17.8327 2 12.3098C2 6.78697 6.47715 2.30981 12 2.30981C17.5228 2.30981 22 6.78697 22 12.3098Z' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/></svg>") no-repeat;
}

/* Mallaley's products */
.home-products{
    background-color: white;
    position: relative;
    z-index: 2;
    border-radius: 30px;
    /* margin-top: 100vh; */
}
.mrv-button{
    /* width: 280px; */
    width: 100%;
    padding: 12px 18px;
    border-radius: 8px;
    background-color: var(--gold);
    border: 1px solid var(--dark-gold);
    box-shadow: var(--btn-shadow);
    color: #101828;
    font-size: 16px;
    font-weight: 600;
}
.mrv-button:hover{
    background-color: var(--dark-gold);
    border: 1px solid var(--gold);
}
.products-card .image-container{
    background-color: #f9fafb;
    height: 280px;
}
.product-badges .badge{
    border-radius: 8px;
    background: rgba(0, 0, 0, 0.45);
    backdrop-filter: blur(12px);
    padding: 4px 8px;
    font-weight: 300;
    font-size: 14px;
}
.products-card .prod-desc p{
    color: #475467;
    font-style: normal;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    font-size: 16px;
    height: 50px;
    overflow: hidden; 
    text-overflow: ellipsis;
    word-wrap: break-word;  
}
.products-card .prod-desc a{
    color: #101828;
    font-size: 16px;
    font-weight: 600;
}

/* -------------- */
/*     footer     */
/* -------------- */
footer{
    background-color: var(--dark);
    z-index: 3;
}
.main footer .parallax-footer{
    border-top-right-radius: 0px;
    border-top-left-radius: 0px;
}
.parallax-footer {
    position: relative;
    height: 314px;
    overflow: hidden;
    border-top-right-radius: 30px;
    border-top-left-radius: 30px;
    background-color: #fff;
}
.parallax-layer {
    position: absolute;
    width: 150%;
    height: 100%;
    top: 0;
    left: -25%;
    will-change: transform;
}
.parallax-layer img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    /* overflow: visible; */
}
.footer-content{
    padding-top: 64px;
    padding-bottom: 24px;
}
.footer-logo{
    width: 180px;
    height: 60px;
    object-fit: contain;
}
.footer-content ul{
    list-style: none;
    padding-left: 0;
}
.footer-content li a{
    color: #fff;
    font-size: 16px;
}
.footer-content li i{
    width: 20px!important;
    height: 20px!important;
    margin-top: 2px;
}
.footer-content h6{
    color: #FFF;
    font-size: 20px;
    font-weight: 700;
}
.footer-content .footer-menu a{
    color: #FFF;
    font-size: 20px;
    font-weight: 700;
    transition: box-shadow 0.3s ease;
}
.footer-content .footer-menu a:hover{
    -webkit-box-shadow: inset 0px -2px 0px 0px rgba(255,255,255,1);
    -moz-box-shadow: inset 0px -2px 0px 0px rgba(255,255,255,1);
    box-shadow: inset 0px -2px 0px 0px rgba(255,255,255,1);
}
.footer-content .social-icons i{
    width: 32px;
    height: 32px;
    font-size: 24px;
}
.footer-content .border-top p{
    color: #FFF;
    font-size: 16px;
    font-weight: 400;
}
.footer-content .border-top a{
    color: #FFF;
    font-weight: 700;
}
/* end footer */


/* ------------------- */
/*    Listings page    */
/* ------------------- */
.subpage-header{
    padding-top: 4rem;
    padding-bottom: 4rem;
    /* position: fixed;
    top: 0;
    left: 0; */
    width: 100%;
    height: 350px;
    /* z-index: 1; */
}
.subpage-banner h1{
    color: var(--gold, #FABE04);
    font-size: 24px;
    font-weight: 600;
}
.subpage-banner p{
    color: #FFF;
    font-weight: 300;
    max-width: 560px;
}

.subpage-banner img{
    width: 80%;
}
.subpage-banner .title-container{
    max-width: 320px;
}
.subpage-cover{
    z-index: 2;
    position: relative;
    margin-top: 350px;
}

/* sidebar */
.accordion-flush>.accordion-item>.accordion-header .accordion-button, .accordion-flush>.accordion-item>.accordion-header .accordion-button.collapsed{
    color: #fff;
    background-color: var(--dark); /* Dark background */
    padding: 16px 24px;
    font-weight: 600;
    font-size: 18px;
    border-radius: 12px;
    border: 1px solid rgba(44, 44, 44, 0.45);
    box-shadow: var(--btn-shadow);
    transition: opacity 0.2s ease;
}
.accordion-flush>.accordion-item>.accordion-header .accordion-button.collapsed:hover{
    opacity: 0.9;
}

.accordion-button::after{
    filter: invert(100%);
}

.sidebar .accordion-item .accordion-button:not(.collapsed) {
    color: #000;
    background-color: #ffc107;
    border: 1px solid var(--dark-gold);
}
.accordion-item{
    border-bottom: 0;
}
.offcanvas .accordion-button {
    color: #fff;
    background-color: #343a40;
}
.filter-menu-btn button{
    width: 100%;
}
.filter-btn{
    color: var(--dark);
    background-color: var(--gold);
    padding: 13px 24px;
    font-weight: 600;
    font-size: 18px;
    border-radius: 12px;
    border: 1px solid rgba(44, 44, 44, 0.45);
    box-shadow: none;
    -webkit-transition : box-shadow 0.15s ease-in-out;
    transition : box-shadow 0.15s ease-in-out;
}
.filter-btn:hover{
    color: var(--dark);
    background-color: var(--gold);
    -webkit-box-shadow: inset 0px 0px 0px 3px var(--dark);
    -moz-box-shadow: inset 0px 0px 0px 3px var(--dark);
    box-shadow: inset 0px 0px 0px 3px var(--dark);
}
.form-check-input:checked{
    background-color: var(--dark);
    border-color: var(--dark);
}

.form-check-input:focus{
    box-shadow: 0 0 0 .25rem rgba(212, 175, 55, 0.6);
}

/* form slider */
aside .noUi-target{
    width: 92%;
}
.tooltip-inner {
    background-color: #333 !important;
    color: #fff;
    font-weight: bold;
}
.noUi-connect{
    background-color: var(--dark);
}
.noUi-handle:after, .noUi-handle:before{
    content: none;
}
.noUi-horizontal .noUi-handle{
    width: 24px;
    height: 24px;
    top: -9px;
}
.noUi-handle{
    border-radius: 999px;
    background-color: var(--gold);
    box-shadow: none;
    border: 2px solid var(--dark-gold);
    font-weight: 600;
}
.noUi-horizontal{
    height: 8px;
}
.noUi-horizontal .noUi-tooltip{
    bottom: 160%;
    padding: 4px 8px;
    background-color: var(--dark);
    color: var(--gold);
}
.noUi-tooltip::after{
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    margin-left: -1rem;
    width:0;
    height: 0;
    border-left: 1rem solid transparent;
    border-right: 1rem solid transparent;
    border-top: .4rem solid var(--dark);
}

/* end form slider */

/* listing item */
.listing-item .carousel{
    height: 240px;
    border-radius: 16px;
    overflow: hidden;
}
.img-number{
    color: #667085;
    font-size: 14px;
}
.listing-item svg path{
    stroke: var(--dark);
}
.list-item-title{
    color: var(--dark);
}
.list-item-title:hover{
    text-decoration: underline;
    color: black;
}
.listing-item h4{
    flex-basis: 0;
    color: var(--dark);
    font-size: 24px;
    font-weight: 600;
}
.listing-item p{
    color: #475467;
    font-style: normal;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    font-size: 16px;
    height: 50px;
    overflow: hidden; 
    text-overflow: ellipsis;
    word-wrap: break-word;  
}
.list-cta{
    padding: 4px 16px;
    border-radius: 8px;
    border: 1px solid var(--dark-gold);
    background-color: var(--gold);
    box-shadow: var(--btn-shadow);
    color: var(--dark, #2C2C2C);
    font-size: 14px;
    font-weight: 600;
    transition: background-color 0.2s ease;
}
.list-cta:hover{
    background-color: var(--dark-gold);
    border: 1px solid var(--gold);
}
.listing-item .list-price{
    color: var(--dark, #2C2C2C);
    font-size: 20px;
    font-weight: 700;
}

.ratings-sec .carousel img{
    width: 100%;
    max-width: 328px;
    height: 328px;
    object-fit: cover;
    border-radius: 16px;
}
.ratings-sec .carousel .carousel-control-next, .carousel-control-prev{
    width: 5%;
}
.ratings-sec .carousel .carousel-inner{
    width: 90%;
    margin: auto;
}
.ratings-sec .carousel p{
    color: #FFF;
    font-size: 18px;
    font-weight: 400;
}
.rating i{
    color: #98A2B3;
}
i.rated{
    color: var(--gold);
}
.customer span{
    color: #fff;
    font-size: 16px;
    font-weight: 600;
}
.customer em{
    color: #fff;
    font-size: 16px;
    font-weight: 400;
}
/* -------------------------- */
/*    Listing details page    */
/* -------------------------- */
.listing-carousel{
    overflow: hidden;
}
.carousel-container{
    position: relative;
    /* overflow: hidden; */
}
.carousel-track{
    display: flex;
    transition: transform 0.5s ease;
    
}
.listingCarouselItem{
    flex: 0 0 auto;
    height: 480px;
    margin-right: 20px;
    width: 100%;
}
.listingCarouselItem img{
    width: 100%;
    height: 100%;
    border-radius: 12px;
    object-fit: cover;
}
.carousel-control {
    background: #fff;
    border: none;
}
#scrollPrev.prev,
#scrollNext.next {
    border-radius: 9999px;
    border: 1px solid #e0e0e0;
    width: 56px;
    height: 56px;
}
#scrollPrev.prev:active,
#scrollNext.next:active {
    border: 1px solid var(--dark);
    background-color: #e0e0e0;
}

/* featured items */
.featured-item{
    min-width: 150px;
    /* flex: 0 0 auto; */
}
.featured-item i{
    width: 40px!important;
    height: 40px!important;
    font-size: 32px;
}
.featured-item span{
    color: var(--dark, #2C2C2C);
    font-size: 18px;
    font-weight: 400;
    line-height: 24px; /* 133.333% */
}

/* divider */
.section-divider{
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}
.section-divider div{
    height: 1px;
    width: 100%;
    max-width: 1300px;
    padding: 0px 32px;
    align-self: center;
    background-color: #dee2e6;
}
/* featured item description */
.listing-title h2{
    color: var(--dark, #2C2C2C);
    font-weight: 600;
}
.listing-title ins{
    color: var(--dark);
    font-size: 24px;
    font-weight: 600;
    text-decoration: none;
    font-style: italic;
}
.listing-title ins.special-price{
    color: #C73200;
}
.listing-title del{
    color: #101828;
    font-size: 16px;
    font-weight: 400;
    font-style: italic;
}
.listing-list ul li{
    align-items: start;
    display: flex;
    flex: 1 0 0;
    gap: 12px;
    min-width: 240px;

    /* font settings */
    color: #475467;
    font-size: 16px;
    font-weight: 400;
    line-height: 24px;
}
.listing-list ul li .listing-svg-container{
    display: flex;
    width: 24px!important;
    height: 24px!important;
}
.listing-list ul li .listing-svg-container{
    fill: var(--gold);
}
.listing-description p{
    color: #475467;
    font-weight: 400;
}
.listing-form form label.form-label{
    color: #344054;
    font-size: 14px;
    font-weight: 500;
    line-height: 20px; /* 142.857% */
}
.listing-form form .form-control{
    padding: 10px 14px;
    border-radius: 8px;
    border: 1px solid #D0D5DD;
    
    /* Shadows/shadow-xs */
    box-shadow: 0px 1px 2px 0px rgba(16, 24, 40, 0.05);
}
.listing-form textarea{
    height: 135px;
    resize: none;
}

/* ------------------ */
/*    Contact page    */
/* ------------------ */
.contact-icon{
    background-color: var(--dark);
    width: 48px;
    height: 48px;
    border-radius: 10px;
    background: var(--dark, #2C2C2C);
}
.contact-icon i{
    color: #FFF;
    font-size: 24px;
}
.contact-info{
    padding-top: 10px;
}
.contact-info b{
    color:#101828;
    font-size: 20px;
    font-weight: 600;
    line-height: 30px; /* 150% */
}
.contact-info a{
    color: #475467;
    font-size: 16px;
    font-weight: 400;
}

/* map */
.contact-page iframe{
    width: 100%;
    height: 400px;
}

/* form */
.contact-form h3{
    color: #FFF;
    font-weight: 600;
    letter-spacing: -0.72px;
}
.contact-form p{
    color: #d2d2d2;
    font-weight: 400;
}
.contact-form div.form-bg{
    padding: 16px;
    border-radius: var(--radius-4xl, 24px);
    background: rgba(242, 244, 247, 0.85);
    overflow: hidden;
}
.contact-form form.row{
    padding: 16px;
    border-radius: var(--radius-2xl, 16px);
    background: rgba(255, 255, 255, 0.75);
    margin: 0;
}
.contact-form .form-label{
    color: #344054;
    font-size: 14px;
    font-weight: 500;
}
.contact-form textarea{
    height: 135px;
    resize: none;
}

.accordion-body:has(.show-more-container) {
    padding: 0;
}

/* Features section changes */
div.show-more-container:not(.open) {
    max-height: 200px;
    overflow: hidden;
}

div.show-more-container {
    position: relative;
    padding: 16px 20px;
}

div.show-more-button-container {
    padding-top: 10px;
    display: flex;
    justify-content: center;
    width: 100%;
}

div.show-more-container:not(.open)::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 150px;
    pointer-events: none;

    background: rgb(255,255,255);
    background: linear-gradient(180deg, rgba(255,255,255,0) 80%, rgba(255,255,255,1) 100%);
}

.filter-btn.filter-btn-reset {
    padding: 6px 12px;
    color: var(--dark);
    background-color: transparent;
    border: 1px solid var(--dark);
}
.filter-btn.filter-btn-reset:hover {
    background-color: var(--gold);
}

/* ---------------- */
/*     404 page     */
/* ---------------- */
.page-404{
    min-height: 950px;
}
.page-404 h2{
    font-size: 32px;
    line-height: 72px;
    letter-spacing: -1.2px;
}
.page-404 .card i{
    align-items: center;
    background: var(--dark);
    border-radius: 10px;
    color: #fff;
    display: flex;
    flex-shrink: 0;
    font-size: 24px;
    height: 48px;
    justify-content: center;
    padding: 12;
    width: 48px;
}
.page-404 .mrv-button{
    max-width: 300px;
}
.page-404 .card{
    align-items: flex-start;
    background: #F9FAFB;
    border-radius: 0px;
    display: flex;
    flex-direction: column;
    flex: 1 0 0;
    gap: var(--spacing-4xl, 32px);
    height: 245px;
    justify-content: center;
    min-width: 280px;
    padding: 24px;
}
.page-404 .card a{
    color: #475467;
    font-size: 16px;
    font-weight: 400;
    line-height: 24px; /* 150% */
    cursor: pointer;
}


/* --------- */
/*    NEW    */
/* --------- */
.language-toggle-home{
    padding-top: 1rem;
    color: white;
    font-size: 24px;
}
.vehicle-type-container{
    width: 100%;
}
.vehicle-type-container a .rv-type{
    flex: 1 0 0;
    /* max-width: 218px; */
    max-width: 150px;
}
.rv-type{
    background-color: #fff;
    width: 100%;
}
.rv-type div:first-child{
    background-color: #c7c8c9;
    width: 100%;
    /* height: 150px; */
    height: 100px;
}
.rv-type div:last-child{
    padding-top: 6px;
    padding-bottom: 16px;
    position: relative;
    /* border-bottom: 10px solid var(--gold); */
}
.rv-type div:last-child::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 0;
    background: var(--gold);
    transition: height 0.2s ease;
}
.rv-type:hover div:last-child::after {
    height: 10px;
}
.rv-type:hover div:last-child::after {
    height: 10px;
}
.rv-type:hover div p {
    text-decoration: underline;
}
.rv-type img{
    width: 90%;
    height: 100%;
    object-fit: contain;
}

.rv-type p{
    color: var(--dark);
    margin-bottom: 0;
    padding-bottom: 0;
    font-size: 18px;
    font-weight: 600;
    line-height: 28px;
}

.language-toggle-home,
.language-toggle-subpage{
    color: white;
    font-size: 24px;
}
.language-toggle-home a,
.language-toggle-subpage a{
    color: #fff;
    text-decoration: none;
    display: block;
}
.language-toggle-home a:hover,
.language-toggle-subpage a:hover{
    color: var(--gold);
    cursor: pointer;
}


/* new banner */
.grid-main-img{
    max-width: 916px;
}
.grid-main-img img{
    border-radius: 8px;
    box-shadow: 0px 32px 64px -12px rgba(16, 24, 40, 0.14);
}
.first-img-row a{
    width: 145px;
    height: 110px;
}
.first-img-row a img{
    border: 1px solid #EAECF0;
    border-radius: 4px;
    box-shadow: 0px 8px 24px -12px rgba(16, 24, 40, 0.14);
}
.listing-img-gallery .mrv-button{
    max-width: 250px;
}

.zoom-container {
    cursor: var(--cursor);
    position: relative;
    width: var(--container-width);
    height: var(--container-height);
    overflow: hidden;
}

.zoom-container img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 0 0;
}

.zoom-container::after {
    display: var(--display);
    pointer-events: none;
    content: '';
    width: 100%;
    height: 100%;
    background-color: black;
    background-image: var(--url);
    background-size: 200%;
    background-position: var(--zoom-x) var(--zoom-y);
    position: absolute;
    left: 0;
    top: 0;
}

.modal-footer .prev {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
    border-right: 0;
}

.modal-footer .next {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
    border-left: 0;
}

.vehicle-type-container a[data-kind='other'] img {
    -webkit-filter: grayscale(100%) brightness(0);
    filter: grayscale(100%) brightness(0);
    opacity: 0.8;
}

.social-icons a {
    color: #FFF;
}

.social-icons a:hover {
    opacity: 0.75;
}

/* new css */
.listing-description .mrv-button{
    width: auto;
}

/* new css oct 25*/
.finance-cta{
    background-color: var(--dark);
    padding: 32px;
    border-radius: 16px;
}
.finance-cta h4{
    color: #ffffff;
    font-size: 24px;
    font-weight: 600;
    text-align: center;
}
.finance-cta p{
    color: #ffffff;
    font-size: 18px;
    font-weight: 400;
    text-align: center;
}
.finance-cta .mrv-button{
    width: 100%;
}
@media screen and (min-width: 375px){ .first-img-row a{ width: 165px; height: 115px; } }

/* Small devices (landscape phones, 576px and up) */
@media screen and (min-width: 576px) {
    .subpage-banner img{
        width: 310px;
    }
    .subpage-header{
        padding-top: 6rem;
        padding-bottom: 6rem;
    }
    .nav-link{
        font-size: 20px;
    }
    .language-toggle-home{
        position: absolute;
        right: 32px;
        top: 24px;
        padding-top: 0;
    }
}

/* Medium devices (tablets, 768px and up) */
@media screen and (min-width: 768px) {
    .home-featured .featured-card{
        min-width: 320px;
    }
    .home-products .mrv-button{
        width: 280px;
    }
    .home-filter-form > div{
        padding: 24px;
    }
    .home-filter-form form.row{
        padding: 32px;
    }
    .home-filter-form p{
        font-size: 20px;
        line-height: 30px;
    }
    .home-form-title h2{
        font-size: 30px;
    }
    .home-featured h1{
        font-size: 36px;
    }
    .subpage-banner h1{
        font-size: 32px;
    }
    .customer span{
        font-size: 18px;
    }
    .listing-title ins{
        font-size: 28px;
    }
    .listing-title del{
        font-size: 18px;
    }
    .contact-form div.form-bg {
        padding: 24px;
    }
    .contact-form form.row{
        padding: 32px;
    }
    .contact-form h3{
        font-size: 36px;
        line-height: 44px;
    }
    .contact-form p{
        font-size: 20px;
        line-height: 30px;
    }
    .page-404 h2{
        font-size: 60px;
    }
    .first-img-row a{
        width: 225px;
        height: 150px;
    }
}

/* Large devices (desktops, 992px and up) */
@media screen and (min-width: 992px) {
    .featured-info h4{
        font-size: 20px;
    }
    .subpage-banner h1{
        font-size: 60px;
    }
    .subpage-banner p{
        font-size: 20px;
    }
    .subpage-banner .title-container{
        max-width: 575px;
    }
    .accordion-button:not(.collapsed)::after{
        filter: invert(0%);
    }
    .listing-title h2{
        color: var(--dark, #2C2C2C);
        font-size: 48px;
        font-weight: 600;
    }
    .listing-title ins{
        font-size: 32px;
    }
    .listing-title del{
        font-size: 20px;
    }
    .listing-description p{
        font-size: 18px;
    }
    .listingCarouselItem{
        width: auto;
    }

    /* new css oct 25 */
    .finance-cta h4{
        text-align: start;
        font-size: 30px;
    }
    .finance-cta p{
        text-align: start;
        font-size: 20px;
    }
    .finance-cta .mrv-button{
        width: auto;
    }
}

/* Extra large devices (large desktops, 1200px and up) */
@media screen and (min-width: 1200px) {
    .ratings-sec .carousel .testimonial-content p {
        font-size: 20px;
    }
    .subpage-banner .title-container{
        max-width: 768px;
    }
    .home-banner{
        background-image: url(/assets/frontend/banner-2-1ec1ca29862655629d6bd80d2c9e0b1b75b047c532b30d3f2025b2311b329eeb.jpg);
    }
}

/* XXL devices (larger desktops, 1400px and up) */
@media screen and (min-width: 1400px) {
    
}

/* Custom breakpoints for finer control */
/* Tiny devices (portrait phones, less than 480px) */
@media screen and (max-width: 479px) {
    .subpage-banner{
        text-align: center;
    }
    .ratings-sec .carousel-item div.mw-768{
        max-width: 328px;
    }
}

/* Small devices (portrait phones, 480px and up) */
@media screen and (min-width: 480px) and (max-width: 575px) {
    
}

/* Medium devices (landscape phones, 768px and up) */
@media screen and (min-width: 768px) and (max-width: 991px) {
    
}

/* Large devices (small laptops, 1024px and up) */
/* @media screen and (min-width: 1024px) and (max-width: 1279px) {
    
} */
@media screen and (max-width:1200px) {
    .home-featured {
        position: relative;
        height: auto;
    }

    .home-products {
        margin-top: 0;
    }
}

/* Extra large devices (large laptops, 1280px and up) */
@media screen and (min-width: 1280px) and (max-width: 1439px) {
    
}

/* XXL devices (larger desktops, 1440px and up) */
@media screen and (min-width: 1440px) {
    
}

@media screen and (min-width:1600px) {
    .language-toggle-home{
        right: 128px;
    }
}
/*
 * This is a manifest file that'll be compiled into application.css, which will include all the files
 * listed below.
 *
 * Any CSS (and SCSS, if configured) file within this directory, lib/assets/stylesheets, or any plugin's
 * vendor/assets/stylesheets directory can be referenced here using a relative path.
 *
 * You're free to add application-wide styles to this file and they'll appear at the bottom of the
 * compiled file so the styles you add here take precedence over styles defined in any other CSS
 * files in this directory. Styles in this file should be added after the last require_* statement.
 * It is generally better to create a new file per style scope.
 *



 */

.reverse-string {
  direction: rtl;
  unicode-bidi: bidi-override;
}

 #submit-loading {
  display: none;
  width: 100%;
  height: 100vh;
  position: fixed;
  top: 0;
  left: 0;
  text-align: center;
  background: rgba(0, 0, 0, .4);
  margin: 0;
  padding: 0;
  z-index: 9999;    
}

#submit-loading div {
  opacity: 25%;
}

.exclude-sold-checkbox {
  width: 1.5rem !important;
  height: 1.5rem !important;
}

.lang-search .language a {
  all: inherit;
  border: none;
  cursor: pointer;
  padding: 0;
}

.ripple-surface {
  max-height: 50px!important;
}

.filter-btn.ripple-surface {
  max-height: 55px!important;
}

.mrv-link:hover {
  color: #616161!important;
}

.btn {
  min-width: unset !important;
}

p:empty {
  height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
}
