/* =============================================================================
   LT Search & Filter — Front-end Styles
   Namespace: .ltsf-
   Avada compatibility: .fusion-body parent not required; plugin uses its own
   namespace. Override via: .fusion-body .ltsf-{element} { }
   ============================================================================= */

/* ── Custom Properties ─────────────────────────────────────────────────────── */
:root {
    /* Values mirror Avada Global Options on leibtour.com (extracted from the
       site's compiled dynamic CSS, Avada 7.15.4 — see CLAUDE.md section 8). */
    --ltsf-primary:       #001023;  /* awb-color8 — dark navy */
    --ltsf-accent:        #e10707;  /* awb-color3 — primary brand red */
    --ltsf-accent-soft:   #ff5a5f;  /* awb-color4 — hover / focus states */
    --ltsf-bg:            #ffffff;
    --ltsf-bg-panel:      #f9f9f9;  /* sidebar_bg_color */
    --ltsf-border:        #d2d2d2;  /* form_border_color */
    --ltsf-text:          #190502;  /* body_typography color */
    --ltsf-text-muted:    #565a5c;  /* awb-color6 */
    --ltsf-radius:        6px;      /* form_border_radius */
    --ltsf-radius-btn:    4px;      /* button border radius */
    --ltsf-shadow:        0 2px 12px rgba(0,0,0,.08);
    --ltsf-transition:    0.2s ease;
    --ltsf-font:          inherit;
    --ltsf-font-btn:      Roboto, Verdana, Geneva, sans-serif; /* button_typography */
}

/* ── Wrapper & Layouts ─────────────────────────────────────────────────────── */
.ltsf-wrapper {
    display: flex;
    flex-direction: column;
    gap: 24px;
    font-family: var(--ltsf-font);
    color: var(--ltsf-text);
    box-sizing: border-box;
}

/* Side-by-side: filter left 280px, results fill */
@media (min-width: 900px) {
    .ltsf-layout--side-by-side {
        flex-direction: row;
        align-items: flex-start;
    }
    .ltsf-layout--side-by-side .ltsf-filter-panel {
        width: 280px;
        flex-shrink: 0;
        position: sticky;
        top: 24px;
    }
    .ltsf-layout--side-by-side .ltsf-results-panel {
        flex: 1;
        min-width: 0;
    }
}

/* Top layout: full width stacked */
.ltsf-layout--top .ltsf-filter-panel {
    width: 100%;
}
.ltsf-layout--top .ltsf-form {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    align-items: flex-end;
}
.ltsf-layout--top .ltsf-fields {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    flex: 1;
}
.ltsf-layout--top .ltsf-field {
    flex: 1 1 200px;
}

/* ── Filter Panel ──────────────────────────────────────────────────────────── */
.ltsf-filter-panel {
    background: var(--ltsf-bg-panel);
    border: 1px solid var(--ltsf-border);
    border-radius: var(--ltsf-radius);
    padding: 20px;
}

.ltsf-form {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.ltsf-fields {
    display: flex;
    flex-direction: column;
}

/* ── Field ─────────────────────────────────────────────────────────────────── */
.ltsf-field {
    padding: 14px 0;
    border-bottom: 1px solid var(--ltsf-border);
}
.ltsf-field:last-child {
    border-bottom: none;
}

.ltsf-label {
    display: block;
    font-size: .8125rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: var(--ltsf-text-muted);
    margin: 0 0 8px;
}

/* ── Collapsible field groups ──────────────────────────────────────────────── */
.ltsf-field--collapsible {
    padding: 0;
}
.ltsf-field__toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    width: 100%;
    padding: 18px 0;
    background: transparent;
    border: none;
    cursor: pointer;
    font-family: var(--ltsf-font);
    font-size: 1.0625rem;
    font-weight: 600;
    color: var(--ltsf-text);
    text-align: left;
}
.ltsf-field__toggle:focus-visible {
    outline: 2px solid var(--ltsf-accent-soft);
    outline-offset: 2px;
}
.ltsf-field__note {
    display: block;
    margin-top: 6px;
    font-size: .9375rem;
    font-weight: 500;
    color: var(--ltsf-text);
}
.ltsf-field__chevron {
    flex-shrink: 0;
    width: 9px;
    height: 9px;
    border-right: 2px solid currentColor;
    border-bottom: 2px solid currentColor;
    transform: rotate(45deg) translateY(-2px);
    transition: transform var(--ltsf-transition);
}
.ltsf-field--open .ltsf-field__chevron {
    transform: rotate(225deg) translateY(-2px);
}
.ltsf-field__body {
    padding: 0 0 16px;
}

/* ── Inputs ────────────────────────────────────────────────────────────────── */
.ltsf-input,
.ltsf-select {
    width: 100%;
    height: 29px;       /* form_input_height — native Avada input metrics */
    padding: 0 15px;
    border: 1px solid var(--ltsf-border);
    border-radius: var(--ltsf-radius);
    background: var(--ltsf-bg);
    color: #aaa9a9;     /* form_text_color */
    font-size: 16px;    /* form_text_size */
    font-family: var(--ltsf-font);
    transition: border-color var(--ltsf-transition);
    box-sizing: border-box;
    appearance: none;
    -webkit-appearance: none;
}
.ltsf-input:focus,
.ltsf-select:focus {
    outline: none;
    border-color: var(--ltsf-accent-soft); /* form_focus_border_color, no glow */
}

.ltsf-input-wrap--search {
    position: relative;
}
.ltsf-input-wrap--search .ltsf-input {
    padding-right: 36px;
}
.ltsf-icon--search::before {
    content: '⌕';
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--ltsf-text-muted);
    font-size: 1.1rem;
    pointer-events: none;
}

/* ── Autocomplete (acf_autocomplete_{key}="true") ──────────────────────────── */
/* Mirrors Avada Live Search's dropdown: white panel, soft-red dividers, fade-in,
   and a subtle padding indent on the active row. */
.ltsf-autocomplete {
    position: relative;
}
.ltsf-suggestions {
    list-style: none;
    margin: 4px 0 0;
    padding: 0;
    position: absolute;
    left: 0;
    right: 0;
    top: 100%;
    z-index: 999;
    background: var(--ltsf-bg);
    border: 1px solid var(--ltsf-border);
    border-radius: var(--ltsf-radius);
    max-height: 320px;
    overflow-y: auto;
    box-shadow: var(--ltsf-shadow);
}
.ltsf-suggestions[hidden] {
    display: none;
}
.ltsf-suggestions:not([hidden]) {
    animation: ltsf-suggest-in 0.25s ease;
}
@keyframes ltsf-suggest-in {
    from { opacity: 0; transform: translateY(-4px); }
    to   { opacity: 1; transform: translateY(0); }
}
.ltsf-suggestion {
    display: flex;
    align-items: center;
    padding: 14px 12px;
    color: var(--ltsf-primary);
    font-size: 16px;
    line-height: 1.4;
    cursor: pointer;
    border-bottom: 0.8px solid var(--ltsf-accent-soft);
    transition: padding var(--ltsf-transition), background-color var(--ltsf-transition);
}
.ltsf-suggestion:last-child {
    border-bottom: 0;
}
.ltsf-suggestion--active {
    background-color: var(--ltsf-bg-panel);
    padding-left: 18px;
}

.ltsf-select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23717188' d='M6 8L0 0h12z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    padding-right: 32px;
}

/* ── Checklist ─────────────────────────────────────────────────────────────── */
.ltsf-checklist {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.ltsf-checklist__item {
    display: flex;
    align-items: center;
    gap: 8px;
}
.ltsf-check {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
    accent-color: var(--ltsf-accent);
    cursor: pointer;
}
.ltsf-check-label {
    font-size: .9375rem;
    cursor: pointer;
    line-height: 1.3;
    color: var(--ltsf-text);
    user-select: none;
}
.ltsf-count {
    color: var(--ltsf-text-muted);
    font-size: .8125rem;
    margin-left: 4px;
}

/* ── "Show more" collapse (show_more="N") ──────────────────────────────────── */
.ltsf-checklist__item[hidden] {
    display: none;   /* the items' display:flex would override the hidden attr */
}
.ltsf-show-more {
    margin-top: 8px;
    padding: 0;
    background: none;
    border: 0;
    color: var(--ltsf-accent);
    font-family: var(--ltsf-font);
    font-size: .9375rem;
    line-height: 1.3;
    cursor: pointer;
}
.ltsf-show-more:hover {
    color: var(--ltsf-accent-soft);
    text-decoration: underline;
}
.ltsf-show-more:focus-visible {
    outline: 2px solid var(--ltsf-accent-soft);
    outline-offset: 2px;
}

/* ── Date range ────────────────────────────────────────────────────────────── */
.ltsf-date-range {
    display: flex;
    flex-direction: column;
    gap: 12px;
}
@media (min-width: 640px) {
    .ltsf-date-range {
        flex-direction: row;
    }
    .ltsf-date-range__group {
        flex: 1;
    }
}
.ltsf-input--date {
    cursor: pointer;
}

/* ── Range slider (acf_type_{key}="range") ─────────────────────────────────── */
.ltsf-slider {
    position: relative;
    height: 24px;
    margin-top: 4px;
}
.ltsf-slider__track {
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    height: 2px;
    transform: translateY(-50%);
    background: var(--ltsf-border);
    border-radius: 2px;
}
.ltsf-slider__fill {
    position: absolute;
    top: 0;
    bottom: 0;
    background: var(--ltsf-accent);
}
.ltsf-slider input[type="range"] {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 24px;
    margin: 0;
    padding: 0;
    appearance: none;
    -webkit-appearance: none;
    background: none;
    border: none;
    pointer-events: none;   /* thumbs re-enable below */
}
.ltsf-slider input[type="range"]::-webkit-slider-thumb {
    -webkit-appearance: none;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: var(--ltsf-bg);
    border: 1px solid var(--ltsf-accent);
    box-shadow: var(--ltsf-shadow);
    cursor: grab;
    pointer-events: auto;
}
.ltsf-slider input[type="range"]::-moz-range-thumb {
    width: 16px;
    height: 16px;
    border-radius: 50%;
    background: var(--ltsf-bg);
    border: 1px solid var(--ltsf-accent);
    box-shadow: var(--ltsf-shadow);
    cursor: grab;
    pointer-events: auto;
}
.ltsf-slider input[type="range"]:focus-visible::-webkit-slider-thumb {
    box-shadow: 0 0 0 3px rgba(255, 90, 95, .4);
}
.ltsf-slider input[type="range"]:focus-visible::-moz-range-thumb {
    box-shadow: 0 0 0 3px rgba(255, 90, 95, .4);
}
.ltsf-slider__value {
    display: block;
    margin-top: 6px;
    font-size: .9375rem;
    color: var(--ltsf-text);
}

/* ── Price filter (show_price): basis + slider + preset tiles ───────────────── */
.ltsf-price__head {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
    margin-bottom: 12px;
}
.ltsf-price__label {
    font-size: 1rem;
    font-weight: 600;
    color: var(--ltsf-text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
}
.ltsf-price__range {
    font-weight: 400;
    color: var(--ltsf-text-muted);
    font-variant-numeric: tabular-nums;
}
.ltsf-price__reset {
    flex-shrink: 0;
    padding: 0;
    background: none;
    border: 0;
    color: var(--ltsf-accent);
    font-family: inherit;
    font-size: .875rem;
    cursor: pointer;
}
.ltsf-price__reset:hover {
    text-decoration: underline;
}
.ltsf-price__reset:focus-visible {
    outline: 2px solid var(--ltsf-accent-soft);
    outline-offset: 2px;
}
.ltsf-price__basis {
    margin-bottom: 14px;
    color: var(--ltsf-text);
    cursor: pointer;
    /* Native chevron is removed by .ltsf-select (appearance:none) — restore one. */
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='none' stroke='%23565a5c' stroke-width='1.6' d='M1 1.5 6 6.5l5-5'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    padding-right: 34px;
}
.ltsf-price .ltsf-slider {
    margin-top: 0;
    margin-bottom: 16px;
}
.ltsf-price__tiles {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
}
.ltsf-price-tile {
    padding: 9px 6px;
    background: var(--ltsf-bg-panel);
    border: 1px solid var(--ltsf-border);
    border-radius: var(--ltsf-radius);
    color: var(--ltsf-text);
    font-family: inherit;
    font-size: .8125rem;
    line-height: 1.2;
    text-align: center;
    white-space: nowrap;
    font-variant-numeric: tabular-nums;
    cursor: pointer;
    transition: border-color var(--ltsf-transition), background var(--ltsf-transition), color var(--ltsf-transition);
}
.ltsf-price-tile:hover {
    border-color: var(--ltsf-text-muted);
}
.ltsf-price-tile--active {
    border-color: var(--ltsf-accent);
    background: rgba(225, 7, 7, .06);
    color: var(--ltsf-accent);
    font-weight: 600;
}
.ltsf-price-tile:focus-visible {
    outline: 2px solid var(--ltsf-accent-soft);
    outline-offset: 2px;
}

/* ── Form actions ──────────────────────────────────────────────────────────── */
.ltsf-form__actions {
    display: flex;
    gap: 8px;
    padding-top: 16px;
}

/* ── Buttons ───────────────────────────────────────────────────────────────── */
.ltsf-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 13px 29px;          /* Avada button padding */
    border-radius: var(--ltsf-radius-btn);
    font-family: var(--ltsf-font-btn);
    font-size: 15px;             /* button_font_size (typography3) */
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: .1em;
    cursor: pointer;
    transition: background var(--ltsf-transition), color var(--ltsf-transition);
    border: none;
    line-height: 1;
}
.ltsf-btn--submit {
    background: linear-gradient(180deg, #f14a51, #c44205); /* button_gradient */
    color: #fff;
    flex: 1;
}
.ltsf-btn--submit:hover {
    background: var(--ltsf-accent-soft); /* hover gradient stops are both #ff5a5f */
    color: #f4f4f4;
}
.ltsf-btn--reset {
    background: transparent;
    color: var(--ltsf-text-muted);
    border: 1px solid var(--ltsf-border);
}
.ltsf-btn--reset:hover {
    background: var(--ltsf-border);
    color: var(--ltsf-text);
}

/* ── Off-canvas trigger ────────────────────────────────────────────────────── */
.ltsf-btn--trigger {
    background: var(--ltsf-primary);
    color: #fff;
    margin-bottom: 0;
}

/* ── Results panel ─────────────────────────────────────────────────────────── */
.ltsf-results {
    position: relative;
}

.ltsf-results__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 16px;
}
.ltsf-results__count {
    font-size: .875rem;
    color: var(--ltsf-text-muted);
    margin: 0;
}

/* ── Results grid (card layout handled by Avada's native [fusion_post_cards]) ── */
.ltsf-results__grid {
    width: 100%;
}

/* ── No results ────────────────────────────────────────────────────────────── */
.ltsf-no-results {
    text-align: center;
    padding: 32px 24px;
    color: var(--ltsf-text-muted);
}

/* ── AJAX loading overlay ──────────────────────────────────────────────────── */
.ltsf-results--loading::before {
    content: '';
    position: absolute;
    inset: 0;
    background: rgba(255,255,255,.65);
    z-index: 2;
    border-radius: var(--ltsf-radius);
    backdrop-filter: blur(2px);
}
.ltsf-results--loading::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 36px;
    height: 36px;
    margin: -18px 0 0 -18px;
    border: 3px solid var(--ltsf-border);
    border-top-color: var(--ltsf-accent);
    border-radius: 50%;
    z-index: 3;
    animation: ltsf-spin .6s linear infinite;
}
@keyframes ltsf-spin {
    to { transform: rotate(360deg); }
}

/* ── Pagination ────────────────────────────────────────────────────────────── */
.ltsf-pagination {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-top: 32px;
}
.ltsf-pagination__row {
    /* No justify-content: the column parent centers the row while it fits;
       on overflow, default flex-start keeps the first arrow reachable. */
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: nowrap;   /* arrows + numbers stay on one line at any width */
    max-width: 100%;
    overflow-x: auto;    /* pathological page counts scroll inside the row instead of wrapping */
}
.ltsf-page-btn {
    min-width: 44px;
    height: 44px;
    padding: 0 14px;
    border: 1px solid transparent;
    border-radius: 999px;
    background: transparent;
    color: var(--ltsf-text);
    font-size: .9375rem;
    font-weight: 500;
    font-family: var(--ltsf-font);
    cursor: pointer;
    transition: background var(--ltsf-transition), border-color var(--ltsf-transition),
                color var(--ltsf-transition), box-shadow var(--ltsf-transition);
}
.ltsf-page-btn:hover:not(:disabled):not(.ltsf-page-btn--active) {
    background: var(--ltsf-bg-panel);
    border-color: var(--ltsf-border);
}
.ltsf-page-btn:focus-visible {
    outline: 2px solid var(--ltsf-accent-soft);
    outline-offset: 2px;
}
.ltsf-page-btn--arrow {
    border-color: var(--ltsf-border);
    background: var(--ltsf-bg);
}
.ltsf-page-btn:disabled {
    opacity: .35;
    cursor: default;
}
.ltsf-page-btn--active {
    background: var(--ltsf-accent);
    border-color: var(--ltsf-accent);
    color: #fff;
    font-weight: 700;
    cursor: default;
    box-shadow: 0 4px 14px rgba(225, 7, 7, .3); /* soft glow of --ltsf-accent */
}
.ltsf-page-ellipsis {
    color: var(--ltsf-text-muted);
    padding: 0 4px;
    user-select: none;
}
.ltsf-pagination__info {
    text-align: center;
    font-size: .8125rem;
    color: var(--ltsf-text-muted);
    margin-top: 6px;
}

/* ── Off-canvas (mobile) ───────────────────────────────────────────────────── */
.ltsf-layout--off-canvas .ltsf-form {
    position: fixed;
    top: 0;
    left: -320px;
    width: 300px;
    height: 100vh;
    overflow-y: auto;
    background: var(--ltsf-bg);
    box-shadow: 4px 0 24px rgba(0,0,0,.18);
    z-index: 99990;
    padding: 24px 20px;
    transition: left .28s cubic-bezier(.4,0,.2,1);
}
.ltsf-layout--off-canvas .ltsf-form.ltsf-form--open {
    left: 0;
}
.ltsf-offcanvas-backdrop {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.4);
    z-index: 99989;
}
.ltsf-offcanvas-backdrop.ltsf-offcanvas-backdrop--visible {
    display: block;
}

/* ── Mobile (≤768px) ───────────────────────────────────────────────────────── */
@media (max-width: 768px) {
    /* Tighter vertical rhythm on small screens (BUG-04 / BUG-05). */
    .ltsf-wrapper {
        gap: 16px;
    }
    .ltsf-results__header {
        margin-bottom: 12px;
    }

    /* Pagination (BUG-01): buttons shrink so the row fits small viewports.
       Wrapping is impossible by construction — .ltsf-pagination__row is
       flex-wrap:nowrap with overflow-x:auto for pathological page counts. */
    .ltsf-pagination {
        margin-top: 20px;
    }
    .ltsf-pagination__row {
        gap: 4px;
    }
    .ltsf-page-btn {
        min-width: 36px;
        height: 36px;
        padding: 0 6px;
        font-size: .875rem;
    }
    .ltsf-page-ellipsis {
        padding: 0 2px;
    }
    .ltsf-pagination__info {
        width: 100%;
        margin-top: 8px;
    }
}

/* ── Zero-result lead capture ──────────────────────────────────────────────── */
/* Mobile-first: single column at every width. */
.ltsf-lead-form {
    margin-top: 16px;
    padding: 24px 20px;
    background: var(--ltsf-bg-panel);
    border: 1px solid var(--ltsf-border);
    border-radius: var(--ltsf-radius);
}
.ltsf-lead-form__title {
    margin: 0 0 4px;
    font-size: 1.125rem;
    color: var(--ltsf-text);
}
.ltsf-lead-form__text {
    margin: 0 0 16px;
    font-size: .9375rem;
    color: var(--ltsf-text-muted);
}
.ltsf-lead-form__form {
    display: flex;
    flex-direction: column;
    gap: 12px;
    max-width: 420px;
}
.ltsf-lead-form__form[hidden] {
    display: none;   /* the display:flex above would override the hidden attr */
}
.ltsf-lead-form .ltsf-input {
    height: 44px;    /* comfortable touch target — wins over the 29px base by specificity */
}
.ltsf-lead-form__hp {
    position: absolute;
    left: -9999px;
    width: 1px;
    height: 1px;
    overflow: hidden;
}
.ltsf-lead-form__consent {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    font-size: .875rem;
    line-height: 1.4;
    color: var(--ltsf-text-muted);
    cursor: pointer;
}
.ltsf-lead-form__consent .ltsf-check {
    margin-top: 2px;
}
.ltsf-lead-form__submit {
    flex: 0 0 auto;  /* the base .ltsf-btn--submit flex:1 would stretch in this column */
    min-height: 44px;
}
.ltsf-lead-form__error {
    margin: 0;
    font-size: .875rem;
    color: var(--ltsf-accent);
}
.ltsf-lead-form__success {
    margin: 0;
    font-weight: 600;
    color: var(--ltsf-text);
}

/* ── Favorite (star) engagement (show_engagement="true") ────────────────────── */
/* JS injects .ltsf-engage onto each Avada card and adds .ltsf-engage-host to it,
   so the bar can pin to the card's top-right corner. */
.ltsf-engage-host {
    position: relative;
}
.ltsf-engage {
    position: absolute;
    top: 10px;
    right: 10px;
    z-index: 10;  /* above Avada's card image/link overlay */
    display: flex;
    gap: 6px;
}
.ltsf-engage__btn {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    margin: 0;
    padding: 5px 9px;
    border: 1px solid var(--ltsf-border);
    border-radius: 999px;
    background: rgba(255, 255, 255, .92);
    color: var(--ltsf-text);
    font-family: var(--ltsf-font-btn);
    font-size: 13px;
    line-height: 1;
    cursor: pointer;
    box-shadow: var(--ltsf-shadow);
    -webkit-backdrop-filter: blur(2px);
    backdrop-filter: blur(2px);
    transition: color var(--ltsf-transition), background var(--ltsf-transition), border-color var(--ltsf-transition);
}
.ltsf-engage__btn:hover {
    border-color: var(--ltsf-accent-soft);
    color: var(--ltsf-accent-soft);
}
.ltsf-engage__btn:focus-visible {
    outline: 2px solid var(--ltsf-accent-soft);
    outline-offset: 1px;
}
.ltsf-engage__btn:disabled {
    opacity: .6;
    cursor: default;
}
.ltsf-engage__icon {
    display: inline-flex;
}
.ltsf-engage__icon svg {
    display: block;
    width: 16px;
    height: 16px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
}
.ltsf-engage__count {
    min-width: 8px;
    font-variant-numeric: tabular-nums;  /* count never shifts the button width */
}

/* Active = this browser has favorited this listing. */
.ltsf-engage__btn.is-active {
    color: var(--ltsf-accent);
    border-color: var(--ltsf-accent);
}
.ltsf-engage__btn--star.is-active .ltsf-engage__icon svg {
    fill: currentColor;  /* star fills in when active */
}
