/* ==========================================================
   Valorisimo User Panel
   ========================================================== */

/* ----------------------------------------------------------
   1. Base panel
   ---------------------------------------------------------- */

.vup-panel {
    padding: 1.5rem;
    border: 1px solid #d9d9d9;
    border-radius: 0.75rem;
    background: #fff;
}

.vup-panel__title {
    margin: 0 0 0.75rem;
}


/* ----------------------------------------------------------
   2. Auth modal
   ---------------------------------------------------------- */

  .vup-auth-step[hidden],
  .vup-auth-modal[hidden] {
    display: none !important;
}

.vup-auth-modal {
    position: fixed;
    inset: 0;
    z-index: 999999;
    opacity: 0;
    transition: opacity 0.22s ease;
}

.vup-auth-modal.is-open {
    opacity: 1;
}

.vup-auth-modal__overlay {
    position: absolute;
    inset: 0;
    background: rgba(255, 255, 255, 0.98);
    opacity: 0;
    transition: opacity 0.22s ease;
}

.vup-auth-modal.is-open .vup-auth-modal__overlay {
    opacity: 1;
}

.vup-auth-modal.is-closing .vup-auth-modal__overlay {
    opacity: 0;
}

.vup-auth-modal__dialog {
    position: relative;
    z-index: 2;
    max-width: 460px;
    margin: 8vh auto 0;
    padding: 24px;
    border-radius: 16px;
    background: #fff;
    opacity: 0;
    transform: translateY(-32px);
    transition: transform 0.24s ease, opacity 0.24s ease;
}

.vup-auth-modal.is-open .vup-auth-modal__dialog {
    opacity: 1;
    transform: translateY(0);
}

.vup-auth-modal.is-closing .vup-auth-modal__dialog {
    opacity: 0;
    transform: translateY(-32px);
}

.vup-auth-modal__close {
    position: absolute;
    top: 10px;
    right: 12px;
    border: 0;
    background: transparent;
    font-size: 28px;
    line-height: 1;
    cursor: pointer;
}

.vup-auth-step {
    display: grid;
    gap: 14px;
}

.vup-auth-step label {
    display: grid;
    gap: 6px;
}

.vup-auth-step input {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid #d8d8d8;
    border-radius: 8px;
}

.vup-auth-step .iti {
    width: 100%;
}

.vup-auth-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.vup-auth-actions button,
.js-vup-auth-phone-submit {
    padding: 10px 14px;
    border: 0;
    border-radius: 8px;
    cursor: pointer;
}
.js-vup-auth-phone-submit,
.vup-auth-actions button {
  background-color: var(--valo-blue);
  color: #fff;
  transition: all .3s ease-in-out;
}
.js-vup-auth-phone-submit,
.vup-auth-actions button:hover {
  background-color: var(--main-gold);

}
.vup-auth-error {
    display: none;
    color: #b42318;
}

.vup-auth-success {
    display: none;
    color: #067647;
}

.vup-auth-note {
    font-size: 14px;
    color: #555;
}
.vup-favorite-feedback-modal[hidden] {
    display: none !important;
}

.vup-favorite-feedback-modal {
    position: fixed;
    inset: 0;
    z-index: 999998;
    opacity: 0;
    transition: opacity 0.18s ease;
}

.vup-favorite-feedback-modal.is-open {
    opacity: 1;
}

.vup-favorite-feedback-modal__overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.35);
}

.vup-favorite-feedback-modal__dialog {
    position: relative;
    z-index: 2;
    max-width: 420px;
    margin: 12vh auto 0;
    padding: 26px 22px 22px;
    border-radius: 16px;
    background: #fff;
    box-shadow: 0 18px 48px rgba(0, 0, 0, 0.18);
    transform: translateY(-18px);
    transition: transform 0.18s ease;
}

.vup-favorite-feedback-modal.is-open .vup-favorite-feedback-modal__dialog {
    transform: translateY(0);
}

.vup-favorite-feedback-modal__x {
    position: absolute;
    top: 8px;
    right: 12px;
    border: 0;
    background: transparent;
    font-size: 26px;
    line-height: 1;
    cursor: pointer;
}

.vup-favorite-feedback-modal__message {
    margin-bottom: 18px;
    color: var(--main-blue);
    font-size: 18px;
    font-weight: 700;
    text-align: center;
}

.vup-favorite-feedback-modal__actions {
    display: flex;
    justify-content: center;
    gap: 10px;
}

.vup-favorite-feedback-modal__view,
.vup-favorite-feedback-modal__close {
    min-height: 42px;
    padding: 8px 14px;
    border-radius: 8px;
    cursor: pointer;
}

.vup-favorite-feedback-modal__view {
    border: 2px solid var(--valo-blue);
    background: var(--valo-blue);
    color: #fff;
}

.vup-favorite-feedback-modal__close {
    border: 1px solid #ddd;
    background: #fff;
    color: var(--main-blue);
}

/* ----------------------------------------------------------
   3. Favorite buttons injected into source cards
   ---------------------------------------------------------- */

.valo-hot-deal-card__btn--favorite.is-loading {
    opacity: 0.6;
    pointer-events: none;
}

.opportunity-loop-card {
    position: relative;
}

.opportunity-card__btn--favorite {
    position: absolute;
    top: 12px;
    right: 12px;
    z-index: 8;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border: 0;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.92);
    cursor: pointer;
    transition: transform 0.15s ease, opacity 0.15s ease;
}

.opportunity-card__btn--favorite:hover {
    transform: scale(1.05);
}

.opportunity-card__btn--favorite i {
    font-size: 16px;
}

.opportunity-card__btn--favorite.is-saved i {
    font-weight: 900;
}


/* ----------------------------------------------------------
   4. Shortlist page layout
   ---------------------------------------------------------- */

.vup-shortlist-page {
    display: grid;
    gap: 24px;
}

.vup-shortlist-page__head {
    display: grid;
    gap: 6px;
}

.vup-shortlist-page__title,
.vup-shortlist-page__subtitle {
    margin: 0;
}

.vup-shortlist-page__subtitle {
    color: #666;
}

.vup-shortlist-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 20px;
}

.vup-shortlist-empty {
    padding: 24px;
    border-radius: 16px;
    background: #f7f7f7;
}

@media (min-width: 768px) {
    .vup-shortlist-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (min-width: 1200px) {
    .vup-shortlist-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}


/* ----------------------------------------------------------
   5. Legacy/simple shortlist card styles
   Kept as fallback for old markup or future non-Hot-Deal cards.
   ---------------------------------------------------------- */

.vup-shortlist-card {
    display: grid;
    gap: 0;
    overflow: hidden;
    border-radius: 16px;
    background: #fff;
    box-shadow: 0 10px 28px rgba(0, 0, 0, 0.08);
}

.vup-shortlist-card__image {
    display: block;
    width: 100%;
    height: 220px;
    object-fit: cover;
}

.vup-shortlist-card__body {
    display: grid;
    gap: 12px;
    padding: 16px;
}

.vup-shortlist-card__topline {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    font-size: 13px;
    color: #666;
}

.vup-shortlist-card__type {
    font-weight: 700;
}

.vup-shortlist-card__title {
    margin: 0;
    font-size: 20px;
    line-height: 1.3;
}

.vup-shortlist-card__title a {
    color: inherit;
    text-decoration: none;
}

.vup-shortlist-card__meta {
    color: #555;
    font-size: 14px;
}

.vup-shortlist-card__stats {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.vup-shortlist-card__stat {
    display: grid;
    gap: 4px;
    padding: 10px 12px;
    border-radius: 10px;
    background: #f7f7f7;
}

.vup-shortlist-card__stat-label {
    font-size: 12px;
    color: #666;
}

.vup-shortlist-card__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.vup-shortlist-card__link,
.vup-shortlist-card__remove {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 40px;
    padding: 0 14px;
    border-radius: 10px;
    text-decoration: none;
    cursor: pointer;
}

.vup-shortlist-card__link {
    background: #111;
    color: #fff;
}

.vup-shortlist-card__remove {
    border: 1px solid #ddd;
    background: #fff;
}


/* ----------------------------------------------------------
   6. Shared Hot-Deal-style shortlist cards
   Applies to saved Hot Deals and saved Opportunities.
   ---------------------------------------------------------- */

.vup-shortlist-card.valo-hot-deal-card {
    display: block;
    gap: 0;
    overflow: hidden;
    border: 1px solid #ddd;
    border-radius: 18px;
    background: #fff;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
}

.vup-shortlist-card.valo-hot-deal-card .valo-hot-deal-card__image-wrap {
    position: relative;
}

.vup-shortlist-card.valo-hot-deal-card .valo-hot-deal-card__image-link {
    display: block;
}

.vup-shortlist-card.valo-hot-deal-card .valo-hot-deal-card__image {
    display: block;
    width: 100%;
    height: 260px;
    object-fit: cover;
}

.vup-shortlist-card.valo-hot-deal-card .valo-hot-deal-card__content {
    padding: 0 20px 20px;
    color: var(--main-blue);
}

.vup-shortlist-card.valo-hot-deal-card .valo-hot-deal-card__title {
    text-align: center;
    color: var(--main-blue);
}

.vup-shortlist-card.valo-hot-deal-card .valo-hot-deal-card__title a {
    color: inherit;
    text-decoration: none;
}

.vup-shortlist-card.valo-hot-deal-card .valo-hot-deal-card__price-row {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 16px;
}

.vup-shortlist-card.valo-hot-deal-card .valo-hot-deal-card__price {
    font-size: 20px;
    font-weight: 700;
    line-height: 1;
}

.vup-shortlist-card.valo-hot-deal-card .valo-hot-deal-card__original-price {
    font-size: 20px;
    text-decoration: line-through;
}

.vup-shortlist-card.valo-hot-deal-card .red-hilight {
    color: #b91c1c;
}

.vup-shortlist-card.valo-hot-deal-card .valo-hot-deal-card__details {
    display: grid;
    gap: 1px;
    font-size: 13px;
}

.vup-shortlist-card.valo-hot-deal-card .valo-hot-deal-card__details i {
    width: 16px;
    margin-right: 4px;
    text-align: center;
}

.vup-shortlist-card.valo-hot-deal-card .valo-hot-deal-card__details span {
    font-weight: 600;
}

.vup-shortlist-card.valo-hot-deal-card .valo-hot-deal-card__actions,
.vup-shortlist-card.valo-hot-deal-card .vup-opportunity-card__actions {
    display: flex;
    justify-content: space-around;
    gap: 8px;
}

.vup-shortlist-card.valo-hot-deal-card .valo-hot-deal-card__btn,
.vup-shortlist-card.valo-hot-deal-card .vup-opportunity-card__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 4px;
    border: 2px solid var(--valo-blue);
    border-radius: 8px;
    background-color: var(--valo-blue);
    color: #fff;
    text-decoration: none;
    font-family: inherit;
    font-size: 12px;
    line-height: 1.2;
    cursor: pointer;
    transition: opacity 0.3s ease, color 0.3s ease;
}

.vup-shortlist-card.valo-hot-deal-card .valo-hot-deal-card__btn:hover,
.vup-shortlist-card.valo-hot-deal-card .vup-opportunity-card__btn:hover {
    opacity: 0.8;
    color: #fff;
}

.vup-shortlist-card.valo-hot-deal-card .valo-hot-deal-card__btn i,
.vup-shortlist-card.valo-hot-deal-card .vup-opportunity-card__btn i {
    margin-right: 6px;
    font-size: 18px;
}

.vup-shortlist-card.valo-hot-deal-card .valo-hot-deal-card__btn--whatsapp {
    background-color: #22C55E;
    border-color: #22C55E;
}

.vup-shortlist-card.valo-hot-deal-card .vup-hot-deal-card__remove,
.vup-shortlist-card.valo-hot-deal-card .vup-opportunity-card__remove {
    border-color: #ddd;
    background-color: #fff;
    color: var(--main-blue);
}

.vup-shortlist-card.valo-hot-deal-card .vup-hot-deal-card__remove:hover,
.vup-shortlist-card.valo-hot-deal-card .vup-opportunity-card__remove:hover {
    background-color: #f7f7f7;
    color: var(--main-blue);
}

.vup-hot-deal-card__type-pill,
.vup-opportunity-card__type-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    width: fit-content;
    margin: 10px auto 8px;
    padding: 5px 10px;
    border-radius: 999px;
    background: var(--main-gold);
    color: #fff;
    font-size: 12px;
    font-weight: 700;
    line-height: 1;
}

.vup-opportunity-card__type-pill::before {
    content: "\f015";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
}


/* ----------------------------------------------------------
   7. Saved Hot Deal card specifics
   ---------------------------------------------------------- */

.vup-shortlist-card--hot-deal .valo-hot-deal-card__title {
    margin: 0 0 12px;
}

.vup-shortlist-card--hot-deal .valo-hot-deal-card__price-row {
    justify-content: flex-start;
}

.vup-shortlist-card--hot-deal .valo-hot-deal-card__details {
    margin-bottom: 6px;
}

.vup-shortlist-card--hot-deal .valo-hot-deal-card__actions {
    gap: 12px;
}

.vup-shortlist-card--hot-deal .valo-hot-deal-card__btn {
    width: 50%;
}

.vup-shortlist-card--hot-deal .valo-hot-deal-card__actions .valo-hot-deal-card__btn:only-child {
    width: 100%;
}

.vup-shortlist-card--hot-deal .valo-hot-deal-card__badge {
    position: absolute;
    top: 14px;
    left: 14px;
    z-index: 2;
    display: flex;
    align-items: center;
    flex-wrap: nowrap;
    gap: 5px;
    padding: 8px 12px;
    border: 1px solid #b91c1c;
    border-radius: 6px;
    background-color: #FEE2E2;
    color: #b91c1c;
    font-size: 12px;
    font-weight: 700;
    line-height: 1;
}

.vup-shortlist-card--hot-deal .valo-hot-deal-card__badge--featured {
    right: 14px;
    left: auto;
    border-color: #44af37;
    background: #44af37;
    color: #fff;
}

.vup-shortlist-card--hot-deal .valo-hot-deal-card__extra-badges {
    position: absolute;
    top: 14px;
    left: 14px;
    z-index: 3;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.vup-shortlist-card--hot-deal .valo-hot-deal-card__extra-badges.has-discount-badge {
    right: 52px;
    left: auto;
}

.vup-shortlist-card--hot-deal .valo-hot-deal-card__extra-badge {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 6px 10px;
    border: 1px solid #b91c1c;
    border-radius: 6px;
    background-color: #FEE2E2;
    color: #b91c1c;
    font-size: 12px;
    font-weight: 700;
    line-height: 1;
}

.vup-shortlist-card--hot-deal .valo-hot-deal-card__extra-badge--special-payment-plan {
    border-color: #1d4ed8;
    background-color: #EEF5FF;
    color: #1d4ed8;
}

.vup-shortlist-card--hot-deal .valo-hot-deal-card__btn--favorite {
    position: absolute;
    top: 8px;
    right: 25px;
    z-index: 10;
    border: none;
    background: transparent;
    color: #b91c1c;
    cursor: pointer;
}

.vup-shortlist-card--hot-deal .valo-hot-deal-card__btn--share {
    position: absolute;
    top: 17px;
    right: 5px;
    z-index: 2;
    color: #fff;
    font-size: 14px;
}

.vup-shortlist-card--hot-deal .valo-hot-deal-meta.lto-badge {
    margin-bottom: 5px;
    text-align: center;
    color: #b91c1c;
    font-size: 14px;
    font-weight: 500;
}

.vup-shortlist-card--hot-deal .valo-hot-deal-card__ctas {
    margin-bottom: 10px;
    padding: 6px;
    border-radius: 6px;
    font-size: 11px;
    font-weight: normal;
}

.vup-shortlist-card--hot-deal .valo-hot-deal-card__ctas.is-limited-offer,
.vup-shortlist-card--hot-deal .valo-hot-deal-card__ctas.is-cash_deal,
.vup-shortlist-card--hot-deal .valo-hot-deal-card__ctas.is-saving,
.vup-shortlist-card--hot-deal .valo-hot-deal-card__ctas.is-discount {
    background-color: #FEE2E2;
    color: #b91c1c;
}

.vup-shortlist-card--hot-deal .valo-hot-deal-card__ctas.is-payment-plan {
    background-color: #EEF5FF;
    color: #1d4ed8;
}

.vup-shortlist-card--hot-deal .valo-hot-deal-img-whatsapp {
    position: absolute;
    top: 50%;
    left: 50%;
    z-index: 5;
    padding: 5px 8px;
    border-radius: 10px;
    background-color: #22C55E;
    color: #fff;
    white-space: nowrap;
    transform: translate(-50%, -50%);
}


/* ----------------------------------------------------------
   8. Saved Opportunity card specifics
   ---------------------------------------------------------- */

.vup-shortlist-card--building .valo-hot-deal-card__title {
    margin: 12px 0;
}

.vup-shortlist-card--building .valo-hot-deal-card__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 14px;
    margin-bottom: 14px;
    color: #666;
    font-size: 14px;
}

.vup-shortlist-card--building .valo-hot-deal-card__price-row {
    justify-content: center;
}

.vup-shortlist-card--building .valo-hot-deal-card__details {
    margin-bottom: 12px;
}

.vup-shortlist-card--building .valo-hot-deal-card__btn,
.vup-shortlist-card--building .vup-opportunity-card__btn {
    width: 33.333%;
}


/* ----------------------------------------------------------
   9. Legacy shortlist tab styles
   Not currently used by the mixed shortlist, but kept harmless.
   ---------------------------------------------------------- */

.vup-shortlist-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 8px;
}

.vup-shortlist-tab {
    padding: 10px 16px;
    border: 1px solid #d9d9d9;
    border-radius: 999px;
    background: #fff;
    font-weight: 600;
    cursor: pointer;
}

.vup-shortlist-tab.is-active {
    border-color: #111;
    background: #111;
    color: #fff;
}

.vup-shortlist-pane {
    display: none;
}

.vup-shortlist-pane.is-active {
    display: block;
}


/* ----------------------------------------------------------
   10. Responsive
   ---------------------------------------------------------- */

@media (max-width: 767px) {
    .vup-shortlist-card.valo-hot-deal-card .valo-hot-deal-card__price,
    .vup-shortlist-card.valo-hot-deal-card .valo-hot-deal-card__original-price {
        font-size: 17px;
    }

    .vup-shortlist-card.valo-hot-deal-card .valo-hot-deal-card__actions,
    .vup-shortlist-card.valo-hot-deal-card .vup-opportunity-card__actions {
        gap: 6px;
    }

    .vup-shortlist-card.valo-hot-deal-card .valo-hot-deal-card__btn,
    .vup-shortlist-card.valo-hot-deal-card .vup-opportunity-card__btn {
        font-size: 11px;
    }
}
