.btn-primary {
    --bs-btn-color: #fff;
    --bs-btn-bg: var(--color-primary);
    --bs-btn-border-color: var(--color-primary);
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: var(--color-hover);
    --bs-btn-hover-border-color: var(--color-hover);
    --bs-btn-focus-shadow-rgb: 49,132,253;
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: var(--color-hover);
    --bs-btn-active-border-color: var(--color-hover);
    --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
    --bs-btn-disabled-color: #fff;
    --bs-btn-disabled-bg: var(--color-secondary);
    --bs-btn-disabled-border-color: var(--color-secondary);
    white-space: nowrap;
}

.btn-primary.free-demo {
    letter-spacing: 1px;
    padding: 12px 40px;
    border-radius: 50px;
    transition: 0.5s;
    margin: 10px;
    border: 2px solid var(--color-primary);
}


.btn-link {
    --bs-btn-color: var(--color-primary);
    --bs-btn-hover-color: var(--color-hover);
    --bs-btn-active-color: var(--color-hover);
    text-decoration: none;
}

.btn-group-lg>.btn, .btn-lg {
    padding:0.5rem 2rem;
}

h1, h2, h3, h4 {
    font-weight: 400;
}

h4 {
    color: var(--color-primary);
}

.section-header {
    padding-bottom: 40px;
}


/* icons */
.svg-primary-color {
    fill: var(--color-primary);
}

.map-sm-icon {
    width:auto;
    height: 16px;
}

.map-md-icon {
    width:auto;
    height: 24px;
}

.map-lg-icon {
    width:auto;
    height: 32px;
}




/* forms */
.form-switch .form-check-input {
    width: 4em;
}

.form-check .form-check-input {
    float:none;
    margin-right: 10px;
}

.form-check-label {
    cursor: pointer;
}

input[type='checkbox'].form-check-input,
input[type='radio'].form-check-input {
    width: 1.2em;
    height: 1.2em;
}

input[role='switch'].form-check-input {
    width: 4em;
    height: 2em;
}

.form-check-input.is-valid~.form-check-label,
.was-validated .form-check-input:valid~.form-check-label {
    color: inherit;
}

.form-control-counter {
    min-width: 60px;
    max-width: 60px;
    text-align: center;
    background-color: transparent !important;
}

.form-control-counter-label {
    text-align: left;
    margin-right: 20px;
    min-width: 90px;
}

.btn-left-rounded {
    border: 1px solid #ced4da;
    border-radius: 8px 0 0 8px !important;
}

.btn-right-rounded {
    border: 1px solid #ced4da;
    border-radius: 0 8px 8px 0 !important;
}

.intl-phone {
  padding: 1rem 0.75rem;
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
  height: calc(3.5rem + 2px);
  line-height: 1.25;
  min-width: 294px;
}




/* header */

.header {
    background: #fff;
}

.header .logo h1 {
    color: var(--color-default);
}

.header .logo img {
    width: auto;
    max-height: 85px;
}

.header .logo a {
    font-size: 32px;
    font-weight: 300;
    color: #000;
}

.header .right-logo img {
    position: absolute;
    max-width: 280px;
}

.fixed-top {
    position: fixed;
    top: 0;
    right: 0;
    left: 0;
    z-index: 1030;
}

.header.sticked {
    height:80px;
    background: #fff;
    padding: 15px 0;
    box-shadow: 0px 2px 20px rgb(14 29 52 / 10%);
}

.header.sticked .logo img {
    max-height: 60px;
}

.header.sticked .right-logo img {
    max-height: 30px;
}



/* carousel */

.carousel-control-next-icon,
.carousel-control-prev-icon {
    width: 2.5rem;
    height: 2.5rem;
    background-color: #00000040;
    border-radius: 8px;
}


/* main body */

#main {
    margin-top:65px;
}

.btn-download {
    font-family: var(--font-primary);
    font-weight: 500;
    font-size: 16px;
    letter-spacing: 1px;
    display: inline-block;
    padding: 12px 40px;
    border-radius: 50px;
    transition: 0.5s;
    margin: 10px;
    border: 2px solid var(--color-primary);
    width: fit-content;
}

.btn-download:hover {
    color:#fff;
    background: var(--color-primary);
}

.most-popular {
    background: var(--color-gold);
    color: #fff;
    border-radius: 14px;
    padding: 6px 12px;
    font-size: 0.9em;
    float: right;
    margin: -20px 0 10px 20px;
}



/* Services promo box at static pages */

.services-promobox {
  background: white;
  border-radius: 20px;
  margin: 20px;
  padding: 20px;
  max-width: 280px;
  box-shadow: 0 0 0 0 rgba(0, 0, 0, 0.2), 0 6px 8px 0 rgba(0, 0, 0, 0.2)
}

.services-promobox strong {
  color: var(--color-primary);
}



/* menu */
.mobile-nav-show.bi-list {
    color: var(--color-primary);
    font-size: 3em;
}

.mobile-nav-show.bi-x {
    color: #fff;
    font-size: 3em;
}

.mobile-nav-show.d-none {
    display: inherit !important;
    visibility: hidden;
}

.navbar {
    width: 80%;
    max-width: 360px;
}

.navbar ul {
    background: #44444480;
}

.navbar .dropdown-indicator {
    margin: 0 0 0 auto !important;
}

.navbar .dropdown ul,
.navbar .dropdown .dropdown ul {
    border: 0;
}

.navbar a, 
.navbar a:focus {
    font-size: 17px;
    font-weight: 300;
    text-transform: none;
    color: #fff;
}

.navbar .dropdown>.dropdown-active, 
.navbar .dropdown .dropdown>.dropdown-active {
    background: none;
}

.navbar a .navicon {
    margin:0 10px 0 5px;
}
.navbar a .bi,
.navbar a:focus .bi {
    color: white;
    font-size: 24px;
    margin-right: 10px;
}

/* Homepage Carousel */
#carousel-home {
    margin-top:75px;
    /* background: #c3c3c3; */
}

#carousel-home .carousel-indicators {
    margin-bottom:-3rem;
}

#carousel-home .carousel-indicators [data-bs-target] {
    background-color: #000;
}

#carousel-home .carousel-control-next-icon,
#carousel-home .carousel-control-prev-icon {
    width: 5rem;
    height: 5rem;
}




/* Progress Bar */
#order-progress .rounded-pill {
    width: 2rem;
    height: 2rem;
    color: #fff;
    background: var(--color-grey);
    padding: 0.25rem;
    font-size: 0.875rem;
    text-align: center;
}

#order-progress .rounded-pill.active {
    background: var(--color-primary);
}

#order-progress .rounded-pill a,
#order-progress .rounded-pill a:link,
#order-progress .rounded-pill a:hover {
    color: #fff;
}

#order-progress .progress-desc {
    color: var(--color-grey);
}

#order-progress .progress-desc a,
#order-progress .progress-desc a:link {
    color:var(--color-grey);
}

#order-progress .progress-desc a:hover {
    color: var(--color-primary);
}

#order-progress .progress-desc .active {
    color: var(--color-primary);
}

#order-progress .progress {
    margin:30px 10% 0 10%;
}

.progress {
    --bs-progress-bar-bg: var(--color-primary);
    height: 1px;
}

.start-10 {
    left: 10%!important;
}
.start-15 {
    left: 15%!important;
}
.start-36 {
    left: 36%!important;
}
.start-63 {
    left: 63%!important;
}
.start-90 {
    left: 90%!important;
}



/* brochure */

.myconcierge-brochure {
    max-height: 460px;
    max-width: 330px;
}


/* transfers */

.vehicle {
    margin: auto;
    background: var(--color-light-grey);
    border:1px solid #eee;
    border-radius: 10px;
}

.vehicle-img {
    padding: 0;
}

.vehicle-content {
    padding: 16px 32px;
}

.vehicle-content ul {
    list-style: none;
    padding-left: 0;
}

.vehicle-content h3 {
    /* color: var(--color-primary); */
}

.vehicle-content i.bi,
.vehicle-content i.fas,
.vehicle-content i.far {
    color: var(--color-primary);
    font-size: 1.3em;
}

.price {
    font-size: 1.5em;
    font-weight: normal;
    color: var(--color-primary);
}


/* tours */

.tour-img {
    width: 100%;
    height: auto;
    max-width: 635px;
    min-height: 356px;
    border:1px solid #ddd;
    border-radius: 8px;
    background: #eee;
}
.tour-img .carousel-item img {
    border-radius: 8px;
}
.tour-price {
    color: var(--color-primary);
}
.tour-description {
    min-height: 100px;
    height: 100px;
    overflow: hidden;
}

.tour-description.active {
    height: auto;
    overflow: visible;
}


/* rent a car */

.vehicle-supplier {
    position:absolute;
    padding: 20px 0 0 200px;
  }

.vehicle-supplier img {
    max-width: 100px;
    max-height: 40px;
    background: #ffffff;
    border-radius: 5px;
    border: 5px solid #fff;
  }

.vehicle-description {
    min-height: 50px;
    height: 50px;
    overflow: hidden;
}

.vehicle-description.active {
    height: auto;
    overflow: visible;
}

.insurance-description {
    min-height: 130px;
    height: 130px;
    overflow: hidden;
    padding: 20px;
    background: #e7f2f0;
    border-radius: 10px 10px 0 0;
}
.insurance-description-more {
    padding: 10px 20px 20px 20px;
    background: #e7f2f0;
    border-radius: 0 0 10px 10px;
}

.insurance-description.active {
    height: auto;
    overflow: visible;
}



/* shop */

.categories a {
    margin-right:10px;
}

.categories a.active {
    background: var(--color-light-grey);
    padding: 8px 16px;
    border-radius: 5px;
    border-bottom: 5px solid;
}

.product-row {
    padding: 10px 0;
}

.product-row:hover {
    background: var(--color-light-grey);
    border-radius: 10px;
}

.qty-info {
    text-align: center;
}

.product-sku {
    font-size: 0.8em;
}

.product-price {
    margin-left: 35px;
}

.listprice {
    font-size: 80%;
    color: darkgray;
    text-decoration: line-through;
}

.addtocart-icon {
    padding-right: 10px;
    font-size: 24px;
    color: var(--color-primary);
}

/* cart */
i.bi-x-circle {
    color: var(--color-gold);
}

.cart-product-line {
    line-height: 24px;
    padding: 8px 0 0 0;
    font-size: 1.2em !important;
}

.cart-empty {
    font-weight: bold;
}



/* reservations */

.place-img {
    width: 100%;
    height: auto;
    max-width: 635px;
    min-height: 356px;
    border:1px solid #ddd;
    border-radius: 8px;
    background: #eee;
}
.place-img .carousel-item img {
    border-radius: 8px;
}
.place-price {
    color: var(--color-primary);
}
.place-description {
    min-height: 100px;
    height: 100px;
    overflow: hidden;
}

.place-description.active {
    height: auto;
    overflow: visible;
}




/* booking summary */
#booking-summary {
    background: var(--color-light-grey);
    padding: 32px;
    border:1px solid #eee;
    border-radius: 10px;
}

#booking-summary h3 {
    font-size: 1.5em;
    text-align: center;
    font-weight: 500;
}

#booking-summary .title {
    font-size: 1.4em;
    font-weight: 600;
}
#booking-summary .description {
    font-size: 1.2em;
    color: #696969;
}
#booking-summary img {
    width:auto;
    height: 60px;
    border-radius: 5px;
}

#booking-summary div,
#booking-summary p, 
#booking-summary li {
    font-size: 15px;
}

#booking-summary ul {
    list-style: none;
    padding-left: 0;
}

#booking-summary li span {
    color: #696969;
}

#booking-summary .subtotal,
#booking-summary .extras,
#booking-summary .total {
    text-align: right;
}

#booking-summary .subtotal .price,
#booking-summary .extras .price {
    display: inline-block;
    min-width: 110px;
    font-size: 18px;
}

#booking-summary .total {
    border-top: 1px solid #ccc;
    margin-bottom: 16px;
    font-size: 1.1em;
    font-weight: 600;
}

#booking-summary .refund-policy {
    font-style: italic;
    font-size: 0.8em;
    text-align: center;
}

#booking-summary .taxes {
    font-weight: normal;
    font-size: 0.8em;
}


/* tour summary */
#summary_passengers,
#summary_pickup_day,
#summary_pickup_date,
#summary_pickup_time {
    display:inline-block;
    font-size:100%;
}


/* payment */

.payment-description {
    width: 100%;
    margin: 16px 0;
    padding: 16px;
    background: var(--color-light-grey);
    border-radius: 10px;
    text-align: left;
}
.payment-icons img {
    max-width: 100%;
    margin:8px auto;
}
.payment-method .form-check-label {
    font-size: 1.2em;
}
.payment-discount-desc {
    background: #ae8e22;
    color: white;
    padding: 4px 8px;
    border-radius: 5px
}

#pay-form {
    margin: 0 auto;
}

/* booking response */
#payment-section .bi-exclamation-triangle {
  font-size: 2em;
  color:red;
}
#booking-section .bi-exclamation-triangle {
  font-size: 4em;
  color:red;
}
#booking-section .bi-check2-circle {
  font-size: 4em;
  color: green;
}
#booking-ref { 
   font-size: 2em;
}



/* pre-footer */

#prefooter-demo {
    background: #f6f6f6;
    padding: 20px 0 60px 0;
    margin: 60px 0 -60px 0;
}

#prefooter-demo h3 {
    color: var(--color-primary);
}

#prefooter {
    margin-top: 60px;
    padding: 0;
    border-top: 5px solid var(--color-primary);
}

#prefooter .quality-icon {
    padding-right: 20px;
}

#prefooter .quality-desc {
    min-width: 200px;
    padding-top: 5px;
    color: var(--color-primary);
}


/* footer */
.footer {
  background: var(--color-light-grey); /* #e1eeeb; */
  position:inherit;
}

.footer .footer-content h4, .footer h3 {
    color: var(--color-default);
}

.footer a, .footer .footer-content .footer-links ul a {
    color: var(--color-secondary);
}

.footer a:hover, .footer .footer-content .footer-links ul a:hover {
    color: var(--color-primary);
}

.footer .footer-content .social-links a {
  color: var(--color-primary);
}

.footer .footer-content .social-links a:hover {
    color:#fff;
}

.footer, .footer p, .footer .footer-content .footer-info p, .copyright, .footer .footer-legal .credits {
    color: var(--color-secondary);
}

.footer .footer-legal .copyright {
    border-top:1px solid #bbb;
}


/* desktop */
@media screen and (min-width: 1281px) {

    .header .logo {
        margin-left: 60px;
    }


    .vehicle-img {
        margin:0;
    }

    .vehicle-img .carousel-item img{
        width: auto !important;
        height: 210px;
        border-radius: 10px 0 0 10px;
    }

    .intl-phone {
        width:595px;
    }
}



/* tablets */

@media screen and (max-width: 1024px) {
    .header .right-logo img {
        max-width:180px;
    }

    .vehicle-supplier {
        padding:0;
        margin-top:20px;
        margin-left:64%;
    }
}


/* mobile */
@media screen and (max-width: 768px) {
    .header .logo img {
        width: auto;
        max-height: 60px;
    }
    
    .header .right-logo img {
        display:none;
    }

    .section-header h2 {
        font-size: 26px;
    }

    .services .service-item .icon img {
        max-width: 100px;
        height: auto;
    }

    /* breadcrumbs */

    .breadcrumbs {
        padding-top: 100px;
    }

    #order-progress .progress-desc {
        font-size: 14px;
    }

    .progress-desc .start-10 {
        left: 15%!important;
    }

   
    /* transfers */
    .vehicle-img .carousel-item img{
        border-radius: 10px 10px 0 0;
    }

    /* tours */
    .tour-img,
    .place-img {
        min-height: 168px;
    }

    #booking-summary {
        padding: 20px;
    }

    /* rent a car */
    .vehicle-supplier {
        padding:0;
        margin-top:20px;
        margin-left:64%;
    }

}
