/* These styles are generated from project.scss. */
input::placeholder {
    color: var(--gray-500)!important;
}
.select2-container--bootstrap .select2-search__field::-webkit-input-placeholder {
    color: var(--gray-500)!important;
  }
.experience-card-img-overlay {
    position: absolute;
    padding: 1.25rem;
    text-align: center;
}
.alert-debug {
    color: black;
    background-color: white;
    border-color: #d6e9c6;
}
.alert-error {
    color: #b94a48;
    background-color: #f2dede;
    border-color: #eed3d7;
}
.btn-icon {
    border: 0;
}
.justify-content-evenly {
    justify-content: space-evenly;
}
#badge-avail-dates {
    position: relative;
    left: 1rem;
    /* bottom: 2.5rem;
    z-index: 1; */
    width: fit-content;
}
#discount-badge {
    display: flex;
    flex-direction: column!important;
    align-items: center;
    position: absolute;
    right: 4px;
    top: 4px;
    z-index: 1;
    width: fit-content;
    border: 2px solid white;
    border-radius: 0.85rem!important;
}
#featured-badge {
    position: absolute;
    left: 4px;
    top: 4px;
    z-index: 1;
    font-size: 2rem;

}
.deal-card {
    background-color: var(--senary)!important;
    max-width: 400px;
    border-radius: 1rem;
}
.deal-card > .card-footer {
    background-color: var(--senary)!important;
}

@media (max-width: 767.98px) {
    .deal-card {
        border-radius: 16px;
        height: 580px;
    }
    .swiper-slide {
        width: webkit-fill-available;
        margin-right: 0px;
        margin-left: 0px;
        padding-right: 15px;
        padding-left: 15px;
        height: initial;
        display: flex;
        align-items: stretch;
        justify-content: center;
    }
}

@media (min-width: 768px) {
    .deal-card {
      height: 580px;
      border-radius: 16px;

    }
  }

.fas.fa-gift {
    color: var(--secondary);
    font-size: 1.1rem;
}
.text-destination {
    color: var(--dark)!important;
    font-size: 1rem;
    font-weight: 400;
    font-style: italic;
}
.fw-600 {
    font-weight: 600;
}
.fs-1 { font-size: 1rem!important; }
.fs-1-3 { font-size: 1.3rem!important; }
.fs-1-5 { font-size: 1.5rem!important; }
.fs-1-75 { font-size: 1.75rem!important; }
.fs-0-875 { font-size: 0.875rem!important; }
.fs-0-75 { font-size: 0.75rem!important; }
.fweight-700 { font-weight: 700; }
.align-self-end { align-self: end; }
.hr-deal { border: 2px solid var(--secondary); width: 100%;}
.font-size-larger { font-size: larger; }
.font-size-large { font-size: large; }
.ff-brandon-bold { font-family: 'Brandon Text Bold', sans-serif; }
.ff-hoefler { font-family: 'Hoefler Italic', serif; }
.ff-playfair-display { font-family: 'Playfair Display', sans-serif; }

/** update template **/
.navbar-brand img { height: 60px; }
.font-size-sm { font-size: small; }

@media (min-width: 576px) {
    .card-deck .card {
        flex: auto!important;
        margin-right: 15px;
        margin-bottom: 0;
        margin-left: 15px;
        height: auto;
    }
}

.card-deck .card {
    flex: auto!important;
    margin-right: 15px;
    margin-bottom: 0;
    margin-left: 15px;
    height: auto;
}


/* Loading indicator */
.bars-indicator {
    display: none;
}
.htmx-request .bars-indicator {
    display: inline;
}
.htmx-request.bars-indicator {
    display: inline;
}

.bars-indicator-hide {
    display: inline;
}
.htmx-request .bars-indicator-hide {
    display: none;
}
.htmx-request.bars-indicator-hide {
    display: none;
}

.fade-me-in.htmx-added {
    opacity: 0;
  }
.fade-me-in {
    opacity: 1;
    transition: opacity 1s ease-out;
  }

.fade-me-out.htmx-swapping {
    opacity: 0;
    transition: opacity 1s ease-out;
  }

.push-notification {
    background-color: rgba(0, 0, 0, 0.7);
    color: white;
    padding: 15px;
    border-radius: 10px;
    text-align: left;
    font-size: small;
    min-height: 80px;
}
.push-notification p {
    margin-bottom: 0;
    font-size: small;
  }
.push-head {
    font-weight:700;
    font-size: small;
}
.push-notification img {
    width: 50px;
    height: 50px;
    border-radius: 10px;
    border: 2px solid white;
    font-size: small;
}
.notification-card {
    max-width: 300px;
    border-radius: 1rem;
}

/* published-deal detail view */
.img-deal-detail {
    min-width: 100%;
    min-height: 100%;
    object-fit: cover;
}
.card-price-sm {
    flex-direction: row;
    background-color: transparent;
    align-items: baseline;
    justify-content: center;
}
.real-estate-name {
    color: var(--dark)!important;
    font-size: calc(1.15rem + .575vw)!important;
    font-weight: 800;
}
.extra-items-head, .exclude-items-head, .include-items-head {
    color: var(--dark)!important;
    font-weight: 600;
    font-size: calc(1.25rem + .28vw);
}
.published-page-head {
    font-size: calc(1.5rem + .9vw)!important;
}
.dealImage {
    display: flex;
    justify-content: end;
    align-items: center;
    padding: 0px;
    background-size: cover;
    background-position: 0% 100%;
    height: 700px;
}

#dealContentSm {
    right: 0px;
    padding: 1rem;
    position: fixed;
    height: auto;
    background-color: var(--senary);
    justify-content: space-between;
    border-radius: 0 0 0 0.85rem;
    box-shadow: 0 .5rem 1rem rgba(0,0,0,.15)!important;
}
#dealContent {
    padding: 2rem;
    position: absolute;
    height: auto;
    right: 0;
    max-width: 400px;
    background-color: var(--senary);
    border-radius: 0 0 0 0.85rem;
    z-index: 99;
    box-shadow: 0 .5rem 1rem rgba(0,0,0,.15)!important;
}
@media only screen and (max-width: 768px) {
    .toggleDeal {
        position: inherit;
        width: fit-content;
        margin-bottom: 1rem;
        display: none;
        border-radius: 0 0.85rem 0.85rem 0!important;
    }
    #dealContentSm {
        position: inherit;
    }
    #dealContent {
        position: inherit;
    }
    #dealImageRow {
        justify-content: center;
    }
  }

@media only screen and (min-width: 769px) {
    .toggleDeal {
        position: absolute;
        left: 0px;
        border-radius: 0 0.85rem 0.85rem 0!important;
    }
}

.section-wrapper {
    margin-top: 5rem;
}

.map-section-title {
    font-family: "Playfair Display", serif !important;
}