/* =========================================================
   Search App responsive layer
   Desktop / notebook / tablet / mobile behavior lives here.
   This file is intentionally loaded after index.css.
   ========================================================= */
:root {
    --sa-shell-max: 1480px;
    --sa-shell-gutter: 20px;
    --sa-sidebar-width: 320px;
    --sa-card-gap: 14px;
    --sa-card-gap-compact: 10px;
    --sa-chip-radius: 999px;
    --sa-soft-border: rgba(15, 23, 42, .12);
    --sa-green: #15803d;
    --sa-red: #b91c1c;
}

html,
body {
    overflow-x: hidden !important;
}

.sa-hidden {
    display: none !important;
}

.sa-main-shell {
    width: min(calc(100vw - (var(--sa-shell-gutter) * 2)), var(--sa-shell-max)) !important;
    max-width: var(--sa-shell-max) !important;
    margin-inline: auto !important;
    padding: 16px 0 28px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 14px !important;
}

.sa-top,
.sa-panel--search,
.sa-search,
.sa-search__row,
.sa-content,
.sa-panel--results,
.sa-results,
.sa-home-results {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
}

/* Search: full-width, never a narrow island. */
.sa-panel--search {
    padding: 12px 14px !important;
}

.sa-search__row {
    display: grid !important;
    grid-template-columns: 44px minmax(0, 1fr) 48px !important;
    align-items: center !important;
    gap: 10px !important;
}

.sa-search__brand {
    width: 44px !important;
    height: 44px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 14px !important;
    overflow: hidden !important;
}

.sa-search__brand img {
    width: 34px !important;
    height: 34px !important;
    object-fit: contain !important;
}

.sa-input--search {
    width: 100% !important;
    min-width: 0 !important;
    height: 44px !important;
}

.sa-search__controls {
    display: flex !important;
    justify-content: flex-end !important;
    min-width: 0 !important;
}

.sa-btn--searchIcon {
    width: 48px !important;
    min-width: 48px !important;
    height: 44px !important;
    padding: 0 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
}

/* Desktop and notebook: sidebar + results. */
.sa-work {
    display: grid !important;
    grid-template-columns: var(--sa-sidebar-width) minmax(0, 1fr) !important;
    gap: 14px !important;
    align-items: start !important;
    width: 100% !important;
    min-width: 0 !important;
}

.sa-left {
    width: 100% !important;
    max-width: var(--sa-sidebar-width) !important;
    min-width: 0 !important;
    position: sticky !important;
    top: 14px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
}

.sa-content {
    display: flex !important;
    flex-direction: column !important;
    gap: 14px !important;
    overflow: visible !important;
}

/* Filter header and expanders: aligned, compact. */
.sa-panel__head--filters {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto auto !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 12px 12px 6px !important;
}

.sa-panel__head--filters .sa-panel__title,
.sa-panel__meta {
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

.sa-panel__actions--filters {
    justify-self: end !important;
}

.sa-filter-clear-all {
    min-height: 30px !important;
    padding: 0 10px !important;
    border-radius: var(--sa-chip-radius) !important;
    white-space: nowrap !important;
}

.sa-it-groups {
    display: flex !important;
    flex-direction: column !important;
    gap: 9px !important;
    padding: 10px 12px 12px !important;
    min-width: 0 !important;
}

.sa-filter-group,
.sa-market-filter {
    min-width: 0 !important;
    max-width: 100% !important;
    border-radius: 16px !important;
    overflow: hidden !important;
}

.sa-filter-group + .sa-filter-group,
.sa-market-filter + .sa-filter-group,
.sa-filter-tree__branch + .sa-filter-tree__branch {
    margin-top: 0 !important;
}

.sa-filter-group__title--summary,
.sa-filter-tree__summary,
.sa-market-filter__summary {
    display: grid !important;
    grid-template-columns: 18px minmax(0, 1fr) auto !important;
    align-items: center !important;
    gap: 8px !important;
    min-height: 42px !important;
    padding: 9px 11px !important;
    cursor: pointer !important;
}

.sa-filter-group__title--summary::before,
.sa-filter-group__title--summary::after,
.sa-filter-tree__summary::before,
.sa-filter-tree__summary::after {
    content: none !important;
}

.sa-filter-group__summaryIcon,
.sa-filter-tree__summaryIcon {
    width: 18px !important;
    height: 18px !important;
    display: inline-grid !important;
    place-items: center !important;
    border-radius: 999px !important;
    background: rgba(47, 111, 237, .10) !important;
    color: #245fda !important;
}

.sa-filter-group__summaryIcon::before,
.sa-filter-tree__summaryIcon::before {
    content: '›' !important;
    display: inline-block !important;
    transform: rotate(0deg) !important;
    font-weight: 900 !important;
    line-height: 1 !important;
    transition: transform .16s ease !important;
}

.sa-filter-group[open] > .sa-filter-group__title--summary .sa-filter-group__summaryIcon::before,
.sa-filter-tree__branch[open] > .sa-filter-tree__summary .sa-filter-tree__summaryIcon::before {
    transform: rotate(90deg) !important;
}

.sa-filter-group__titleText,
.sa-filter-tree__summaryText,
.sa-market-filter__name,
.sa-filter-option__label {
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

.sa-filter-group__titleCount,
.sa-filter-tree__count,
.sa-filter-option__count,
.sa-market-filter__count {
    min-width: 22px !important;
    height: 22px !important;
    padding: 0 7px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: var(--sa-chip-radius) !important;
    white-space: nowrap !important;
    font-size: 11px !important;
    line-height: 1 !important;
}

.sa-filter-group__body,
.sa-market-filter__body {
    padding: 8px !important;
    min-width: 0 !important;
}

.sa-filter-group__options,
.sa-market-filter__row {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(118px, 1fr)) !important;
    gap: 7px !important;
}

.sa-filter-group__options--nested {
    grid-template-columns: 1fr !important;
}

.sa-filter-option,
.sa-market-filter__item {
    width: 100% !important;
    min-width: 0 !important;
    min-height: 34px !important;
    padding: 6px 9px !important;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    align-items: center !important;
    gap: 6px !important;
    border-radius: 12px !important;
}

.sa-market-filter__title,
.sa-market-filter__logo {
    display: none !important;
}

/* Active filters: desktop can use two chips per row when it fits. */
#activeFiltersPanel {
    overflow: hidden !important;
    padding: 10px 12px !important;
}

.sa-active-filters__head {
    margin: 0 0 7px !important;
    font-size: 12px !important;
    font-weight: 800 !important;
    color: #526074 !important;
}

.sa-active-filters {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(128px, 1fr)) !important;
    gap: 7px !important;
    align-items: stretch !important;
}

.sa-active-filter {
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    min-height: 32px !important;
    padding: 6px 9px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 5px !important;
    border-radius: var(--sa-chip-radius) !important;
    white-space: nowrap !important;
}

.sa-active-filter__key {
    flex: 0 0 auto !important;
    font-size: 10px !important;
    font-weight: 800 !important;
}

.sa-active-filter__value {
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

.sa-active-filter__remove {
    flex: 0 0 auto !important;
    margin-left: auto !important;
}

/* Results grid: JS only changes --sa-result-columns; CSS guarantees no overflow. */
.sa-results-grid {
    display: grid !important;
    grid-template-columns: repeat(var(--sa-result-columns, 3), minmax(0, 1fr)) !important;
    gap: var(--sa-card-gap) !important;
    padding: 14px !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    overflow: visible !important;
}

.sa-results-grid--exact .sa-results-toolbar {
    grid-column: 1 / -1 !important;
}

.sa-result-card,
.sa-result-row__layout,
.sa-result-row__identity,
.sa-result-row__text,
.sa-result-row__offersColumn,
.sa-offer-list,
.sa-offer-row,
.sa-offer-row__line,
.sa-offer-row__marketCell,
.sa-offer-row__marketIdentity,
.sa-offer-row__valueCell {
    min-width: 0 !important;
    max-width: 100% !important;
}

.sa-result-card {
    padding: 13px !important;
    gap: 11px !important;
    border-radius: 20px !important;
}

.sa-result-card .sa-result-row__identity {
    display: grid !important;
    grid-template-columns: 84px minmax(0, 1fr) !important;
    gap: 11px !important;
    align-items: start !important;
}

.sa-result-card .sa-result-row__imgWrap,
.sa-result-row__imgLink {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    min-width: 0 !important;
}

.sa-result-card .sa-result-row__img,
.sa-result-card .sa-result-row__imgph {
    width: 78px !important;
    height: 78px !important;
    max-width: 100% !important;
    aspect-ratio: 1 / 1 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    overflow: hidden !important;
    border-radius: 16px !important;
}

.sa-result-card .sa-result-row__img img {
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
    object-position: center !important;
    display: block !important;
}

.sa-result-card .sa-result-row__nameLink,
.sa-result-card .sa-result-row__name {
    font-size: 14px !important;
    line-height: 1.24 !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 3 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
}

.sa-result-card .sa-result-row__metaLine {
    min-width: 0 !important;
    font-size: 11px !important;
    line-height: 1.25 !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
    white-space: normal !important;
}

.sa-result-card .sa-offer-list--cards {
    gap: 7px !important;
}

.sa-result-card .sa-offer-row {
    padding: 8px 9px !important;
    border-radius: 14px !important;
    display: block !important;
}

.sa-result-card .sa-offer-row__line,
.sa-result-card .sa-offer-row__line--single {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) max-content !important;
    align-items: center !important;
    gap: 7px !important;
    width: 100% !important;
}

.sa-result-card .sa-offer-row__marketIdentity {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    align-items: center !important;
    gap: 5px !important;
    width: 100% !important;
}

.sa-result-card .sa-offer-row__marketLink,
.sa-result-card .sa-offer-row__market {
    min-width: 0 !important;
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    font-size: 12px !important;
    line-height: 1.1 !important;
    font-weight: 800 !important;
}

.sa-result-card .sa-offer-row__distance {
    flex: 0 0 auto !important;
    white-space: nowrap !important;
    font-size: 10px !important;
    line-height: 1 !important;
    opacity: .78 !important;
}

.sa-result-card .sa-offer-row__valueCell {
    display: inline-flex !important;
    align-items: baseline !important;
    justify-content: flex-end !important;
    gap: 5px !important;
    white-space: nowrap !important;
    text-align: right !important;
}

.sa-result-card .sa-offer-row__saving {
    color: var(--sa-green) !important;
    font-size: 10.5px !important;
    font-weight: 900 !important;
    line-height: 1 !important;
}

.sa-result-card .sa-offer-row__saving--empty {
    display: none !important;
}

.sa-result-card .sa-offer-row__price {
    font-size: 14px !important;
    font-weight: 900 !important;
    line-height: 1 !important;
    white-space: nowrap !important;
}

.sa-result-card .sa-offer-row--best .sa-offer-row__price {
    color: var(--sa-green) !important;
}

.sa-result-card .sa-offer-row:not(.sa-offer-row--best) .sa-offer-row__price {
    color: var(--sa-red) !important;
}

.sa-result-row__detailLink--secondary,
.sa-offer-row__actions {
    display: none !important;
}

@media (min-width: 1440px) {
    :root {
        --sa-sidebar-width: 330px;
        --sa-card-gap: 14px;
    }
}

@media (min-width: 1200px) and (max-width: 1439px) {
    :root {
        --sa-shell-gutter: 16px;
        --sa-sidebar-width: 300px;
        --sa-card-gap: 12px;
    }

    .sa-main-shell {
        width: min(calc(100vw - 32px), var(--sa-shell-max)) !important;
    }

    .sa-result-card {
        padding: 12px !important;
    }

    .sa-result-card .sa-result-row__identity {
        grid-template-columns: 76px minmax(0, 1fr) !important;
        gap: 10px !important;
    }

    .sa-result-card .sa-result-row__img,
    .sa-result-card .sa-result-row__imgph {
        width: 70px !important;
        height: 70px !important;
    }
}

/* Tablet and mobile share the filter/menu concept. */
@media (max-width: 1199px) {
    :root {
        --sa-shell-gutter: 12px;
        --sa-card-gap: 10px;
    }

    .sa-main-shell {
        width: min(calc(100vw - 24px), 100%) !important;
        padding-top: 10px !important;
    }

    .sa-work {
        display: flex !important;
        flex-direction: column !important;
        gap: 10px !important;
    }

    .sa-left {
        position: static !important;
        top: auto !important;
        width: 100% !important;
        max-width: none !important;
        display: flex !important;
        flex-direction: column !important;
        gap: 6px !important;
        z-index: 7 !important;
    }

    #interpretationPanel {
        order: 1 !important;
        overflow: visible !important;
        background: transparent !important;
        border: 0 !important;
        box-shadow: none !important;
    }

    #activeFiltersPanel {
        order: 2 !important;
        overflow: visible !important;
        background: transparent !important;
        border: 0 !important;
        box-shadow: none !important;
        padding: 0 !important;
    }

    .sa-panel__head--filters,
    .sa-active-filters__head,
    .sa-panel__empty#interpretationEmpty {
        display: none !important;
    }

    .sa-interpretation,
    .sa-it-groups {
        overflow: visible !important;
    }

    .sa-it-groups {
        display: flex !important;
        flex-direction: row !important;
        flex-wrap: nowrap !important;
        align-items: center !important;
        gap: 5px !important;
        padding: 0 0 4px !important;
        overflow-x: auto !important;
        overflow-y: visible !important;
        -webkit-overflow-scrolling: touch !important;
        scrollbar-width: thin !important;
    }

    .sa-filter-group,
    .sa-market-filter {
        position: relative !important;
        flex: 0 0 auto !important;
        width: auto !important;
        min-width: auto !important;
        max-width: none !important;
        overflow: visible !important;
        border-radius: var(--sa-chip-radius) !important;
        background: transparent !important;
        border: 0 !important;
        box-shadow: none !important;
    }

    .sa-filter-group__title--summary,
    .sa-market-filter__summary {
        grid-template-columns: 14px minmax(0, auto) auto !important;
        gap: 4px !important;
        min-height: 31px !important;
        max-width: 172px !important;
        padding: 5px 8px !important;
        border-radius: var(--sa-chip-radius) !important;
        background: #ffffff !important;
        border: 1px solid var(--sa-soft-border) !important;
        box-shadow: 0 6px 14px rgba(15, 23, 42, .06) !important;
    }

    .sa-filter-group__summaryIcon,
    .sa-filter-tree__summaryIcon {
        width: 14px !important;
        height: 14px !important;
        font-size: 10px !important;
    }

    .sa-filter-group__titleText,
    .sa-market-filter .sa-filter-group__titleText {
        font-size: 12px !important;
        font-weight: 800 !important;
    }

    .sa-filter-group__titleCount,
    .sa-filter-tree__count,
    .sa-filter-option__count,
    .sa-market-filter__count {
        min-width: 18px !important;
        height: 18px !important;
        padding: 0 5px !important;
        font-size: 10px !important;
    }

    .sa-filter-group__body,
    .sa-market-filter__body {
        position: absolute !important;
        top: calc(100% + 7px) !important;
        left: 0 !important;
        z-index: 40 !important;
        width: min(330px, calc(100vw - 24px)) !important;
        max-height: 46vh !important;
        overflow: auto !important;
        padding: 9px !important;
        border-radius: 16px !important;
        background: #ffffff !important;
        border: 1px solid var(--sa-soft-border) !important;
        box-shadow: 0 18px 38px rgba(15, 23, 42, .16) !important;
    }

    .sa-filter-group:not([open]) > .sa-filter-group__body,
    .sa-market-filter:not([open]) > .sa-market-filter__body {
        display: none !important;
    }

    .sa-filter-tree__branch {
        border-radius: 12px !important;
    }

    .sa-filter-tree__summary {
        min-height: 34px !important;
        padding: 7px 8px !important;
    }

    .sa-filter-group__options,
    .sa-market-filter__row {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 6px !important;
    }

    .sa-filter-option,
    .sa-market-filter__item {
        min-height: 31px !important;
        padding: 5px 8px !important;
        border-radius: 11px !important;
    }

    .sa-filter-option__label,
    .sa-market-filter__name {
        font-size: 11.5px !important;
        line-height: 1.1 !important;
    }

    .sa-active-filters {
        display: flex !important;
        flex-wrap: nowrap !important;
        gap: 5px !important;
        overflow-x: auto !important;
        overflow-y: hidden !important;
        padding: 0 0 4px !important;
        -webkit-overflow-scrolling: touch !important;
        scrollbar-width: thin !important;
    }

    .sa-active-filter {
        flex: 0 0 auto !important;
        width: auto !important;
        max-width: 66vw !important;
        min-height: 28px !important;
        padding: 4px 8px !important;
        gap: 5px !important;
        background: #ecfdf5 !important;
        border: 1px solid rgba(21, 128, 61, .16) !important;
    }

    .sa-active-filter__key,
    .sa-active-filter--clearAll {
        display: none !important;
    }

    .sa-active-filter__value {
        font-size: 11.5px !important;
        font-weight: 800 !important;
        color: #14532d !important;
    }

    .sa-content {
        gap: 10px !important;
    }

    .sa-panel--markets,
    .sa-summary-row,
    .sa-map-area {
        display: none !important;
    }

    .sa-results-grid {
        padding: 9px !important;
        gap: var(--sa-card-gap) !important;
    }

    .sa-result-card {
        padding: 10px !important;
        border-radius: 17px !important;
        gap: 9px !important;
    }

    .sa-result-card .sa-result-row__identity {
        display: flex !important;
        flex-direction: column !important;
        align-items: stretch !important;
        gap: 8px !important;
    }

    .sa-result-card .sa-result-row__imgWrap {
        justify-content: center !important;
    }

    .sa-result-card .sa-result-row__nameLink,
    .sa-result-card .sa-result-row__name {
        font-size: 13px !important;
        text-align: left !important;
        -webkit-line-clamp: 3 !important;
    }

    .sa-result-card .sa-result-row__metaLine {
        font-size: 10.5px !important;
        -webkit-line-clamp: 2 !important;
    }

    .sa-result-card .sa-offer-row {
        padding: 7px 7px !important;
        border-radius: 12px !important;
    }

    .sa-result-card .sa-offer-row__line--single {
        gap: 5px !important;
    }

    .sa-result-card .sa-offer-row__marketIdentity {
        gap: 4px !important;
    }

    .sa-result-card .sa-offer-row__marketLink,
    .sa-result-card .sa-offer-row__market {
        font-size: 11px !important;
    }

    .sa-result-card .sa-offer-row__distance {
        font-size: 9.5px !important;
    }

    .sa-result-card .sa-offer-row__valueCell {
        gap: 4px !important;
    }

    .sa-result-card .sa-offer-row__saving {
        font-size: 9.5px !important;
    }

    .sa-result-card .sa-offer-row__price {
        font-size: 12.5px !important;
    }
}

@media (min-width: 768px) and (max-width: 1199px) {
    .sa-result-card .sa-result-row__img,
    .sa-result-card .sa-result-row__imgph {
        width: 76px !important;
        height: 76px !important;
    }

    .sa-filter-group__title--summary,
    .sa-market-filter__summary {
        max-width: 190px !important;
    }
}

@media (max-width: 767px) {
    :root {
        --sa-shell-gutter: 8px;
        --sa-card-gap: 8px;
    }

    .sa-main-shell {
        width: min(calc(100vw - 16px), 100%) !important;
        gap: 8px !important;
    }

    .sa-top {
        gap: 8px !important;
    }

    .sa-panel--search {
        padding: 9px !important;
        border-radius: 16px !important;
    }

    .sa-search__row {
        grid-template-columns: minmax(0, 1fr) 42px !important;
        gap: 7px !important;
    }

    .sa-search__brand {
        display: none !important;
    }

    .sa-input--search {
        height: 42px !important;
        border-radius: 13px !important;
        font-size: 14px !important;
    }

    .sa-btn--searchIcon {
        width: 42px !important;
        min-width: 42px !important;
        height: 42px !important;
        border-radius: 13px !important;
    }

    .sa-panel--msg {
        padding: 6px 9px !important;
        border-radius: 14px !important;
    }

    .sa-message {
        font-size: 11.5px !important;
        min-height: 14px !important;
    }

    .sa-it-groups,
    .sa-active-filters {
        gap: 4px !important;
        padding-bottom: 3px !important;
    }

    .sa-filter-group__title--summary,
    .sa-market-filter__summary {
        max-width: 144px !important;
        min-height: 29px !important;
        padding: 4px 7px !important;
    }

    .sa-filter-group__titleText {
        font-size: 11px !important;
    }

    .sa-filter-group__body,
    .sa-market-filter__body {
        width: min(316px, calc(100vw - 16px)) !important;
        max-height: 44vh !important;
    }

    .sa-filter-group__options,
    .sa-market-filter__row {
        grid-template-columns: 1fr 1fr !important;
        gap: 5px !important;
    }

    .sa-results-grid {
        grid-template-columns: repeat(var(--sa-result-columns, 2), minmax(0, 1fr)) !important;
        padding: 7px !important;
        gap: 8px !important;
    }

    .sa-result-card {
        padding: 8px !important;
        border-radius: 15px !important;
        gap: 7px !important;
    }

    .sa-result-card .sa-result-row__img,
    .sa-result-card .sa-result-row__imgph {
        width: 58px !important;
        height: 58px !important;
        border-radius: 13px !important;
    }

    .sa-result-card .sa-result-row__nameLink,
    .sa-result-card .sa-result-row__name {
        font-size: 12px !important;
        line-height: 1.2 !important;
    }

    .sa-result-card .sa-result-row__metaLine {
        font-size: 9.5px !important;
    }

    .sa-result-card .sa-offer-row {
        padding: 6px !important;
    }

    .sa-result-card .sa-offer-row__marketLink,
    .sa-result-card .sa-offer-row__market {
        font-size: 10px !important;
    }

    .sa-result-card .sa-offer-row__distance {
        font-size: 8.5px !important;
    }

    .sa-result-card .sa-offer-row__saving {
        display: none !important;
    }

    .sa-result-card .sa-offer-row__price {
        font-size: 11.5px !important;
    }
}

@media (max-width: 359px) {
    .sa-results-grid {
        grid-template-columns: 1fr !important;
    }
}

/* =========================================================
   Responsive optimization pass: filters, cards, loading.
   ========================================================= */
:root {
    --sa-filter-chip-width: 176px;
    --sa-offer-logo-size: 42px;
    --sa-offer-distance-min: 62px;
}

body.sa-busy {
    cursor: wait !important;
}

body.sa-busy .sa-main-shell {
    pointer-events: none !important;
    user-select: none !important;
}

.sa-busy-overlay {
    pointer-events: auto !important;
    z-index: 2147483000 !important;
    min-height: 100dvh !important;
}

.sa-busy-overlay__card {
    width: min(320px, calc(100vw - 32px)) !important;
    text-align: center !important;
}

.sa-loading-state {
    min-height: clamp(220px, 44vh, 420px) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 14px !important;
    padding: 28px 18px !important;
    text-align: left !important;
}

.sa-loading-state__spinner {
    width: 34px !important;
    height: 34px !important;
    flex: 0 0 auto !important;
    border-radius: 999px !important;
    border: 3px solid rgba(15, 23, 42, .10) !important;
    border-top-color: #2563eb !important;
    animation: sa-spin .8s linear infinite !important;
}

.sa-loading-state__content {
    min-width: 0 !important;
}

.sa-loading-state__title {
    color: #0f172a !important;
    font-size: 15px !important;
    font-weight: 900 !important;
    line-height: 1.2 !important;
}

.sa-loading-state__text {
    margin-top: 3px !important;
    color: #64748b !important;
    font-size: 12px !important;
    line-height: 1.35 !important;
}

.sa-results-grid {
    align-items: stretch !important;
}

.sa-result-card {
    height: 100% !important;
}

.sa-result-card .sa-result-row__offersColumn {
    margin-top: auto !important;
}

.sa-result-card .sa-offer-row__line,
.sa-result-card .sa-offer-row__line--single {
    grid-template-columns: var(--sa-offer-logo-size) minmax(var(--sa-offer-distance-min), 1fr) max-content !important;
    align-items: center !important;
    gap: 8px !important;
}

.sa-result-card .sa-offer-row__marketCell {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    width: var(--sa-offer-logo-size) !important;
    min-width: var(--sa-offer-logo-size) !important;
}

.sa-offer-row__marketLogoLink,
.sa-offer-row__marketLogo {
    width: var(--sa-offer-logo-size) !important;
    height: var(--sa-offer-logo-size) !important;
    min-width: var(--sa-offer-logo-size) !important;
    max-width: var(--sa-offer-logo-size) !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 12px !important;
    overflow: hidden !important;
    background: #ffffff !important;
    border: 1px solid rgba(148, 163, 184, .20) !important;
    box-shadow: 0 4px 10px rgba(15, 23, 42, .06) !important;
    text-decoration: none !important;
}

.sa-offer-row__marketLogoLink .sa-offer-row__marketLogo {
    border: 0 !important;
    box-shadow: none !important;
}

.sa-offer-row__marketLogo img {
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
    object-position: center !important;
    display: block !important;
    padding: 4px !important;
}

.sa-offer-row__marketInitials {
    color: #0f172a !important;
    font-size: 11px !important;
    font-weight: 900 !important;
    line-height: 1 !important;
    letter-spacing: .02em !important;
}

.sa-result-card .sa-offer-row__distanceCell {
    min-width: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
}

.sa-result-card .sa-offer-row__distance {
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

.sa-result-card .sa-offer-row__valueCell {
    min-width: 0 !important;
    justify-content: flex-end !important;
}

.sa-result-card .sa-offer-row__price {
    text-align: right !important;
}

@media (max-width: 1199px) {
    :root {
        --sa-filter-chip-width: 176px;
        --sa-offer-logo-size: 36px;
        --sa-offer-distance-min: 54px;
    }

    .sa-it-groups,
    .sa-active-filters {
        scrollbar-width: none !important;
        -ms-overflow-style: none !important;
    }

    .sa-it-groups::-webkit-scrollbar,
    .sa-active-filters::-webkit-scrollbar {
        width: 0 !important;
        height: 0 !important;
        display: none !important;
    }

    .sa-filter-group,
    .sa-market-filter {
        flex: 0 0 var(--sa-filter-chip-width) !important;
        width: var(--sa-filter-chip-width) !important;
        max-width: var(--sa-filter-chip-width) !important;
    }

    .sa-filter-group__title--summary,
    .sa-market-filter__summary {
        width: 100% !important;
        max-width: 100% !important;
        grid-template-columns: 14px minmax(0, 1fr) auto !important;
    }

    .sa-filter-group__body,
    .sa-market-filter__body {
        position: fixed !important;
        top: var(--sa-filter-dropdown-top, 112px) !important;
        left: var(--sa-filter-dropdown-left, 12px) !important;
        width: var(--sa-filter-dropdown-width, min(340px, calc(100vw - 24px))) !important;
        max-width: calc(100vw - 24px) !important;
        z-index: 2147482000 !important;
        max-height: min(420px, calc(100dvh - var(--sa-filter-dropdown-top, 112px) - 14px)) !important;
        overscroll-behavior: contain !important;
    }

    .sa-result-card .sa-offer-row__line,
    .sa-result-card .sa-offer-row__line--single {
        grid-template-columns: var(--sa-offer-logo-size) minmax(var(--sa-offer-distance-min), 1fr) max-content !important;
        gap: 6px !important;
    }
}

@media (max-width: 767px) {
    :root {
        --sa-filter-chip-width: 132px;
        --sa-offer-logo-size: 30px;
        --sa-offer-distance-min: 44px;
    }

    .sa-filter-group__title--summary,
    .sa-market-filter__summary {
        grid-template-columns: 14px minmax(0, 1fr) !important;
    }

    .sa-filter-group__titleCount,
    .sa-filter-tree__count,
    .sa-filter-option__count,
    .sa-market-filter__count {
        display: none !important;
    }

    .sa-filter-option,
    .sa-market-filter__item {
        grid-template-columns: minmax(0, 1fr) !important;
    }

    .sa-loading-state {
        min-height: clamp(200px, 50vh, 360px) !important;
        flex-direction: column !important;
        text-align: center !important;
        gap: 10px !important;
    }

    .sa-result-card .sa-offer-row__line,
    .sa-result-card .sa-offer-row__line--single {
        gap: 5px !important;
    }

    .sa-offer-row__marketLogoLink,
    .sa-offer-row__marketLogo {
        border-radius: 9px !important;
    }

    .sa-offer-row__marketLogo img {
        padding: 3px !important;
    }
}

/* =========================================================
   2026-05-09 pass 2 · compact supermarket rows and filter UX.
   ========================================================= */
:root {
    --sa-offer-logo-size: 32px;
    --sa-offer-distance-min: 38px;
}

.sa-result-card .sa-offer-row {
    min-height: calc(var(--sa-offer-logo-size) + 10px) !important;
    padding: 5px 7px !important;
    display: flex !important;
    align-items: center !important;
}

.sa-result-card .sa-offer-row__line,
.sa-result-card .sa-offer-row__line--single {
    width: 100% !important;
    grid-template-columns: var(--sa-offer-logo-size) minmax(0, 1fr) minmax(0, max-content) !important;
    align-items: center !important;
    gap: 6px !important;
}

.sa-result-card .sa-offer-row__marketCell {
    width: var(--sa-offer-logo-size) !important;
    min-width: var(--sa-offer-logo-size) !important;
    max-width: var(--sa-offer-logo-size) !important;
    height: var(--sa-offer-logo-size) !important;
    min-height: var(--sa-offer-logo-size) !important;
}

.sa-offer-row__marketLogoLink,
.sa-offer-row__marketLogo {
    width: var(--sa-offer-logo-size) !important;
    height: var(--sa-offer-logo-size) !important;
    min-width: var(--sa-offer-logo-size) !important;
    max-width: var(--sa-offer-logo-size) !important;
    border-radius: 10px !important;
}

.sa-offer-row__marketLogo img {
    padding: 3px !important;
}

.sa-result-card .sa-offer-row__distanceCell,
.sa-result-card .sa-offer-row__valueCell {
    min-width: 0 !important;
    height: var(--sa-offer-logo-size) !important;
}

.sa-result-card .sa-offer-row__distance {
    line-height: 1 !important;
    white-space: nowrap !important;
}

.sa-result-card .sa-offer-row__valueCell {
    overflow: hidden !important;
}

.sa-result-card .sa-offer-row__price {
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: clip !important;
    font-variant-numeric: tabular-nums !important;
}

@media (max-width: 1199px) {
    :root {
        --sa-filter-chip-width: 176px;
        --sa-offer-logo-size: 27px;
        --sa-offer-distance-min: 32px;
    }

    #interpretationPanel {
        position: relative !important;
    }

    #interpretationPanel::before,
    #interpretationPanel::after {
        content: '' !important;
        position: absolute !important;
        top: 0 !important;
        bottom: 2px !important;
        width: 28px !important;
        z-index: 12 !important;
        pointer-events: none !important;
    }

    #interpretationPanel::before {
        left: 0 !important;
        background: linear-gradient(90deg, rgba(248, 250, 252, .96), rgba(248, 250, 252, 0)) !important;
    }

    #interpretationPanel::after {
        right: 0 !important;
        background: linear-gradient(270deg, rgba(248, 250, 252, .96), rgba(248, 250, 252, 0)) !important;
    }

    .sa-it-groups {
        padding-inline: 4px 20px !important;
    }

    .sa-filter-group__title--summary,
    .sa-market-filter__summary {
        min-height: 32px !important;
        padding: 5px 8px 5px 10px !important;
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) auto 14px !important;
        align-items: center !important;
        column-gap: 6px !important;
    }

    .sa-filter-group__titleText,
    .sa-market-filter .sa-filter-group__titleText {
        grid-column: 1 !important;
        grid-row: 1 !important;
        align-self: center !important;
        line-height: 1 !important;
    }

    .sa-filter-group__titleCount,
    .sa-market-filter__count {
        grid-column: 2 !important;
        grid-row: 1 !important;
        align-self: center !important;
        justify-self: end !important;
    }

    .sa-filter-group__summaryIcon {
        grid-column: 3 !important;
        grid-row: 1 !important;
        align-self: center !important;
        justify-self: end !important;
        margin: 0 !important;
    }

    .sa-filter-group__body,
    .sa-market-filter__body {
        top: var(--sa-filter-dropdown-top, 112px) !important;
        left: var(--sa-filter-dropdown-left, 12px) !important;
        width: var(--sa-filter-dropdown-width, min(340px, calc(100vw - 24px))) !important;
        max-height: var(--sa-filter-dropdown-max-height, min(420px, calc(100dvh - var(--sa-filter-dropdown-top, 112px) - 14px))) !important;
    }

    .sa-result-card .sa-offer-row {
        min-height: 35px !important;
        padding: 4px 6px !important;
    }

    .sa-result-card .sa-offer-row__line,
    .sa-result-card .sa-offer-row__line--single {
        grid-template-columns: var(--sa-offer-logo-size) minmax(0, 1fr) minmax(0, max-content) !important;
        gap: 5px !important;
    }

    .sa-result-card .sa-offer-row__distance {
        font-size: 9.25px !important;
    }

    .sa-result-card .sa-offer-row__price {
        font-size: 12px !important;
    }
}

@media (max-width: 767px) {
    :root {
        --sa-filter-chip-width: 136px;
        --sa-offer-logo-size: 23px;
        --sa-offer-distance-min: 24px;
    }

    .sa-filter-group__title--summary,
    .sa-market-filter__summary {
        min-height: 30px !important;
        padding: 4px 7px 4px 9px !important;
        grid-template-columns: minmax(0, 1fr) 14px !important;
        column-gap: 5px !important;
    }

    .sa-filter-group__summaryIcon {
        grid-column: 2 !important;
    }

    .sa-result-card .sa-offer-row {
        min-height: 31px !important;
        padding: 4px 5px !important;
        border-radius: 10px !important;
    }

    .sa-result-card .sa-offer-row__line,
    .sa-result-card .sa-offer-row__line--single {
        gap: 4px !important;
        grid-template-columns: var(--sa-offer-logo-size) minmax(0, 1fr) minmax(48px, max-content) !important;
    }

    .sa-result-card .sa-offer-row__distance {
        font-size: 8px !important;
    }

    .sa-result-card .sa-offer-row__price {
        font-size: 10.6px !important;
        letter-spacing: -.01em !important;
    }

    .sa-offer-row__marketLogoLink,
    .sa-offer-row__marketLogo {
        border-radius: 8px !important;
    }

    .sa-offer-row__marketLogo img {
        padding: 2px !important;
    }
}

@media (max-width: 359px) {
    .sa-result-card .sa-offer-row__line,
    .sa-result-card .sa-offer-row__line--single {
        grid-template-columns: 21px minmax(0, 1fr) minmax(44px, max-content) !important;
        gap: 3px !important;
    }

    .sa-result-card .sa-offer-row__price {
        font-size: 10px !important;
    }
}

/* =========================================================
   2026-05-09 pass 3 · compact filter carousel, submenu sizing
   and supermarket offer row alignment.
   ========================================================= */
:root {
    --sa-offer-logo-size: 30px;
    --sa-offer-price-width: 78px;
    --sa-offer-distance-min: 42px;
}

.sa-result-card .sa-offer-row__line,
.sa-result-card .sa-offer-row__line--single {
    grid-template-columns: var(--sa-offer-logo-size) minmax(var(--sa-offer-distance-min), 1fr) var(--sa-offer-price-width) !important;
    align-items: center !important;
}

.sa-result-card .sa-offer-row__marketCell,
.sa-result-card .sa-offer-row__distanceCell,
.sa-result-card .sa-offer-row__valueCell {
    align-self: center !important;
}

.sa-result-card .sa-offer-row__valueCell {
    width: var(--sa-offer-price-width) !important;
    min-width: var(--sa-offer-price-width) !important;
    max-width: var(--sa-offer-price-width) !important;
    height: var(--sa-offer-logo-size) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    text-align: right !important;
    overflow: hidden !important;
}

.sa-result-card .sa-offer-row__price {
    width: 100% !important;
    display: block !important;
    line-height: 1.08 !important;
    text-align: right !important;
    font-variant-numeric: tabular-nums !important;
}

@media (max-width: 1199px) {
    :root {
        --sa-offer-logo-size: 26px;
        --sa-offer-price-width: 64px;
        --sa-offer-distance-min: 34px;
    }

    #interpretationPanel {
        position: relative !important;
        padding-bottom: var(--sa-filter-menu-reserve-height, 0) !important;
        transition: padding-bottom .16s ease !important;
    }

    .sa-it-groups {
        padding-inline: 34px !important;
        gap: 5px !important;
    }

    .sa-filter-carousel-control {
        position: absolute !important;
        top: 1px !important;
        z-index: 24 !important;
        width: 26px !important;
        height: 31px !important;
        border: 1px solid rgba(148, 163, 184, .28) !important;
        border-radius: 999px !important;
        background: rgba(255, 255, 255, .94) !important;
        box-shadow: 0 8px 18px rgba(15, 23, 42, .10) !important;
        color: #0f172a !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        padding: 0 !important;
        cursor: pointer !important;
        touch-action: manipulation !important;
    }

    .sa-filter-carousel-control--prev {
        left: 1px !important;
    }

    .sa-filter-carousel-control--next {
        right: 1px !important;
    }

    .sa-filter-carousel-control span {
        display: block !important;
        font-size: 20px !important;
        font-weight: 900 !important;
        line-height: 1 !important;
        transform: translateY(-1px) !important;
    }

    .sa-filter-carousel-control.is-disabled {
        opacity: .36 !important;
        box-shadow: none !important;
        cursor: default !important;
    }

    .sa-filter-group,
    .sa-market-filter {
        flex: 0 0 auto !important;
        width: auto !important;
        min-width: 0 !important;
        max-width: 174px !important;
    }

    .sa-filter-group__title--summary,
    .sa-market-filter__summary {
        width: auto !important;
        min-width: 90px !important;
        max-width: 174px !important;
        min-height: 31px !important;
        padding: 5px 8px 5px 10px !important;
        display: inline-grid !important;
        grid-template-columns: minmax(0, max-content) auto 14px !important;
        align-items: center !important;
        column-gap: 6px !important;
        vertical-align: middle !important;
    }

    .sa-filter-group__titleText,
    .sa-market-filter .sa-filter-group__titleText {
        max-width: 118px !important;
        align-self: center !important;
        line-height: 1 !important;
    }

    .sa-filter-group__summaryIcon,
    .sa-filter-tree__summaryIcon {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        align-self: center !important;
        justify-self: end !important;
        line-height: 1 !important;
    }

    .sa-filter-group__summaryIcon::before,
    .sa-filter-tree__summaryIcon::before {
        line-height: 1 !important;
        transform-origin: 50% 50% !important;
    }

    .sa-filter-group[open] > .sa-filter-group__title--summary .sa-filter-group__summaryIcon::before,
    .sa-filter-tree__branch[open] > .sa-filter-tree__summary .sa-filter-tree__summaryIcon::before {
        transform: rotate(90deg) !important;
    }

    .sa-filter-group__body,
    .sa-market-filter__body {
        width: var(--sa-filter-dropdown-width, min(360px, calc(100vw - 24px))) !important;
        max-height: var(--sa-filter-dropdown-max-height, 320px) !important;
        padding: 8px !important;
        border-radius: 15px !important;
    }

    .sa-filter-group__options,
    .sa-market-filter__row {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 5px !important;
    }

    .sa-filter-tree__summary {
        min-height: 31px !important;
        padding: 6px 7px !important;
        grid-template-columns: 14px minmax(0, 1fr) auto !important;
        gap: 6px !important;
    }

    .sa-filter-option,
    .sa-market-filter__item {
        min-height: 28px !important;
        padding: 4px 7px !important;
        gap: 5px !important;
        border-radius: 10px !important;
    }

    .sa-filter-option__label,
    .sa-market-filter__name {
        font-size: 11px !important;
        line-height: 1.05 !important;
    }

    .sa-active-filters {
        gap: 4px !important;
    }

    .sa-active-filter {
        flex: 0 0 auto !important;
        width: auto !important;
        min-width: 0 !important;
        max-width: min(220px, 58vw) !important;
        min-height: 26px !important;
        padding: 3px 7px !important;
        gap: 4px !important;
    }

    .sa-active-filter__value {
        font-size: 11px !important;
        line-height: 1 !important;
    }

    .sa-active-filter__remove {
        width: 14px !important;
        min-width: 14px !important;
        height: 14px !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        line-height: 1 !important;
    }

    .sa-result-card .sa-offer-row__line,
    .sa-result-card .sa-offer-row__line--single {
        grid-template-columns: var(--sa-offer-logo-size) minmax(var(--sa-offer-distance-min), 1fr) var(--sa-offer-price-width) !important;
        gap: 5px !important;
    }

    .sa-result-card .sa-offer-row__price {
        font-size: 11.6px !important;
    }
}

@media (max-width: 767px) {
    :root {
        --sa-offer-logo-size: 22px;
        --sa-offer-price-width: 54px;
        --sa-offer-distance-min: 24px;
    }

    .sa-it-groups {
        padding-inline: 30px !important;
        gap: 4px !important;
    }

    .sa-filter-carousel-control {
        width: 24px !important;
        height: 29px !important;
    }

    .sa-filter-carousel-control span {
        font-size: 18px !important;
    }

    .sa-filter-group,
    .sa-market-filter {
        max-width: 132px !important;
    }

    .sa-filter-group__title--summary,
    .sa-market-filter__summary {
        min-width: 74px !important;
        max-width: 132px !important;
        min-height: 29px !important;
        padding: 4px 6px 4px 8px !important;
        grid-template-columns: minmax(0, max-content) 14px !important;
        column-gap: 4px !important;
    }

    .sa-filter-group__titleText,
    .sa-market-filter .sa-filter-group__titleText {
        max-width: 104px !important;
        font-size: 10.8px !important;
    }

    .sa-filter-group__summaryIcon,
    .sa-filter-tree__summaryIcon {
        width: 14px !important;
        height: 14px !important;
        font-size: 10px !important;
    }

    .sa-filter-group__body,
    .sa-market-filter__body {
        width: var(--sa-filter-dropdown-width, min(304px, calc(100vw - 16px))) !important;
        max-height: var(--sa-filter-dropdown-max-height, 260px) !important;
        padding: 7px !important;
        border-radius: 14px !important;
    }

    .sa-filter-group__options,
    .sa-market-filter__row {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 5px !important;
    }

    .sa-filter-option,
    .sa-market-filter__item {
        min-height: 27px !important;
        padding: 4px 6px !important;
    }

    .sa-filter-option__label,
    .sa-market-filter__name {
        font-size: 10.6px !important;
    }

    .sa-active-filter {
        max-width: 56vw !important;
        min-height: 24px !important;
        padding: 3px 6px !important;
    }

    .sa-active-filter__value {
        font-size: 10.6px !important;
    }

    .sa-result-card .sa-offer-row {
        min-height: 30px !important;
        padding: 4px 5px !important;
    }

    .sa-result-card .sa-offer-row__line,
    .sa-result-card .sa-offer-row__line--single {
        grid-template-columns: var(--sa-offer-logo-size) minmax(var(--sa-offer-distance-min), 1fr) var(--sa-offer-price-width) !important;
        gap: 4px !important;
    }

    .sa-result-card .sa-offer-row__distance {
        font-size: 7.8px !important;
    }

    .sa-result-card .sa-offer-row__price {
        font-size: 10.2px !important;
        letter-spacing: -.015em !important;
    }
}

@media (max-width: 359px) {
    :root {
        --sa-offer-logo-size: 21px;
        --sa-offer-price-width: 50px;
        --sa-offer-distance-min: 22px;
    }

    .sa-filter-group__title--summary,
    .sa-market-filter__summary {
        min-width: 68px !important;
        max-width: 124px !important;
    }

    .sa-filter-group__titleText,
    .sa-market-filter .sa-filter-group__titleText {
        max-width: 96px !important;
    }
}

/* =========================================================
   2026-05-09 pass 4 · mobile/tablet filter refinement.
   Keeps current behavior but removes vertical jumps, hides
   counters in compact layouts, and softens carousel controls.
   ========================================================= */
@media (max-width: 1199px) {
    #interpretationPanel {
        padding-bottom: 0 !important;
    }

    #activeFiltersPanel,
    .sa-panel--active-filters {
        margin-bottom: 4px !important;
        padding: 0 !important;
    }

    .sa-interpretation,
    .sa-it-groups {
        min-width: 0 !important;
    }

    .sa-it-groups {
        justify-content: center !important;
        align-items: center !important;
        padding: 0 24px 3px !important;
        min-height: 28px !important;
        scrollbar-width: none !important;
    }

    .sa-it-groups.has-scroll {
        justify-content: flex-start !important;
    }

    .sa-it-groups::-webkit-scrollbar,
    .sa-active-filters::-webkit-scrollbar {
        display: none !important;
        width: 0 !important;
        height: 0 !important;
    }

    .sa-filter-carousel-control {
        top: 2px !important;
        width: 18px !important;
        height: 25px !important;
        border: 0 !important;
        border-radius: 999px !important;
        background: rgba(255, 255, 255, .68) !important;
        box-shadow: none !important;
        color: rgba(15, 23, 42, .48) !important;
        transition: background-color .14s ease, color .14s ease, opacity .14s ease !important;
    }

    .sa-filter-carousel-control:hover,
    .sa-filter-carousel-control:focus-visible {
        background: rgba(255, 255, 255, .92) !important;
        color: rgba(15, 23, 42, .74) !important;
    }

    .sa-filter-carousel-control--prev {
        left: 0 !important;
    }

    .sa-filter-carousel-control--next {
        right: 0 !important;
    }

    .sa-filter-carousel-control span {
        font-size: 13px !important;
        font-weight: 800 !important;
        line-height: 1 !important;
        transform: none !important;
    }

    .sa-filter-carousel-control.is-disabled {
        opacity: .18 !important;
    }

    .sa-filter-group,
    .sa-market-filter {
        max-width: 168px !important;
    }

    .sa-filter-group__title--summary,
    .sa-market-filter__summary {
        min-height: 26px !important;
        padding: 3px 7px 3px 9px !important;
        grid-template-columns: minmax(0, max-content) 13px !important;
        column-gap: 5px !important;
        align-items: center !important;
    }

    .sa-filter-group__titleText,
    .sa-market-filter .sa-filter-group__titleText {
        font-size: 11px !important;
        line-height: 1 !important;
        align-self: center !important;
    }

    .sa-filter-group__summaryIcon,
    .sa-filter-tree__summaryIcon {
        width: 13px !important;
        height: 13px !important;
        min-width: 13px !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        align-self: center !important;
        margin: 0 !important;
        transform: translateY(0) !important;
    }

    .sa-filter-group__summaryIcon::before,
    .sa-filter-tree__summaryIcon::before {
        line-height: 1 !important;
        transform: translateY(0) !important;
    }

    .sa-filter-group__titleCount,
    .sa-filter-tree__count,
    .sa-filter-option__count,
    .sa-market-filter__count {
        display: none !important;
    }

    .sa-filter-group__body,
    .sa-market-filter__body {
        position: fixed !important;
        top: var(--sa-filter-dropdown-top, 94px) !important;
        left: var(--sa-filter-dropdown-left, 12px) !important;
        z-index: 120 !important;
        width: var(--sa-filter-dropdown-width, min(340px, calc(100vw - 24px))) !important;
        max-height: var(--sa-filter-dropdown-max-height, 300px) !important;
        overflow: auto !important;
        overscroll-behavior: contain !important;
        padding: 7px !important;
        border-radius: 14px !important;
        background: #ffffff !important;
        border: 1px solid rgba(148, 163, 184, .22) !important;
        box-shadow: 0 14px 32px rgba(15, 23, 42, .16) !important;
    }

    .sa-filter-group__options,
    .sa-market-filter__row {
        gap: 5px !important;
    }

    .sa-filter-option,
    .sa-market-filter__item {
        min-height: 26px !important;
        padding: 4px 7px !important;
        gap: 4px !important;
        align-items: center !important;
    }

    .sa-filter-option__label,
    .sa-market-filter__name {
        font-size: 10.8px !important;
        line-height: 1.05 !important;
    }

    .sa-filter-tree__summary {
        min-height: 27px !important;
        padding: 4px 7px !important;
        grid-template-columns: 13px minmax(0, 1fr) !important;
        align-items: center !important;
    }

    .sa-active-filters {
        justify-content: center !important;
        align-items: center !important;
        min-height: 0 !important;
        padding: 0 0 3px !important;
        gap: 4px !important;
        scrollbar-width: none !important;
    }

    .sa-active-filter {
        min-height: 23px !important;
        padding: 2px 6px !important;
        gap: 4px !important;
        border-radius: 999px !important;
    }

    .sa-active-filter__value {
        font-size: 10.8px !important;
        line-height: 1 !important;
    }

    .sa-active-filter__remove {
        width: 13px !important;
        min-width: 13px !important;
        height: 13px !important;
        font-size: 11px !important;
    }
}

@media (max-width: 767px) {
    .sa-it-groups {
        padding-inline: 22px !important;
        min-height: 26px !important;
    }

    .sa-filter-carousel-control {
        width: 16px !important;
        height: 23px !important;
    }

    .sa-filter-carousel-control span {
        font-size: 12px !important;
    }

    .sa-filter-group,
    .sa-market-filter {
        max-width: 128px !important;
    }

    .sa-filter-group__title--summary,
    .sa-market-filter__summary {
        min-height: 24px !important;
        padding: 2px 6px 2px 8px !important;
        column-gap: 4px !important;
    }

    .sa-filter-group__titleText,
    .sa-market-filter .sa-filter-group__titleText {
        max-width: 104px !important;
        font-size: 10.5px !important;
    }

    .sa-filter-group__body,
    .sa-market-filter__body {
        width: var(--sa-filter-dropdown-width, min(300px, calc(100vw - 16px))) !important;
        max-height: var(--sa-filter-dropdown-max-height, 240px) !important;
        padding: 6px !important;
        border-radius: 13px !important;
    }

    .sa-filter-option,
    .sa-market-filter__item {
        min-height: 25px !important;
        padding: 3px 6px !important;
    }

    .sa-filter-option__label,
    .sa-market-filter__name,
    .sa-active-filter__value {
        font-size: 10.4px !important;
    }

    .sa-active-filter {
        min-height: 22px !important;
        padding: 2px 6px !important;
    }
}

/* =========================================================
   2026-05-09 pass 5 · mobile/tablet filter menu as real row
   and compact Explore cards.
   ========================================================= */
@media (max-width: 1199px) {
    .sa-filter-compact-menu-host {
        order: 3 !important;
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
        display: block !important;
        margin: 2px 0 8px !important;
        padding: 0 !important;
        overflow: visible !important;
    }

    .sa-filter-compact-menu-host.sa-hidden {
        display: none !important;
        margin: 0 !important;
    }

    .sa-filter-compact-menu-host .sa-filter-group__body,
    .sa-filter-compact-menu-host .sa-market-filter__body,
    .sa-filter-group__body.sa-filter-group__body--portal,
    .sa-market-filter__body.sa-filter-group__body--portal {
        position: static !important;
        inset: auto !important;
        top: auto !important;
        left: auto !important;
        right: auto !important;
        bottom: auto !important;
        z-index: auto !important;
        display: block !important;
        width: 100% !important;
        max-width: 100% !important;
        max-height: 300px !important;
        overflow: auto !important;
        overscroll-behavior: contain !important;
        margin: 0 !important;
        padding: 7px !important;
        border-radius: 14px !important;
        background: rgba(255, 255, 255, .96) !important;
        border: 1px solid rgba(148, 163, 184, .22) !important;
        box-shadow: 0 10px 24px rgba(15, 23, 42, .10) !important;
    }

    .sa-filter-compact-menu-host .sa-filter-group__options,
    .sa-filter-compact-menu-host .sa-market-filter__row {
        display: grid !important;
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
        gap: 5px !important;
    }

    .sa-filter-compact-menu-host .sa-filter-tree {
        display: flex !important;
        flex-direction: column !important;
        gap: 5px !important;
    }

    .sa-filter-compact-menu-host .sa-filter-tree__summary,
    .sa-filter-compact-menu-host .sa-filter-option,
    .sa-filter-compact-menu-host .sa-market-filter__item {
        min-height: 26px !important;
        padding: 4px 7px !important;
        border-radius: 10px !important;
    }

    .sa-filter-compact-menu-host .sa-filter-option__label,
    .sa-filter-compact-menu-host .sa-market-filter__name,
    .sa-filter-compact-menu-host .sa-filter-tree__summaryText {
        font-size: 10.8px !important;
        line-height: 1.05 !important;
    }

    .sa-filter-compact-menu-host .sa-filter-tree__branch[open] > .sa-filter-group__options--nested {
        margin-top: 5px !important;
    }

    .sa-results-grid--home {
        align-items: stretch !important;
    }

    .sa-result-card--home {
        min-height: 0 !important;
        padding: 10px !important;
        gap: 8px !important;
        border-radius: 16px !important;
    }

    .sa-result-card--home .sa-result-row__identity {
        gap: 8px !important;
    }

    .sa-result-card--home .sa-result-row__img,
    .sa-result-card--home .sa-result-row__imgph {
        width: 68px !important;
        height: 68px !important;
        border-radius: 14px !important;
    }

    .sa-result-card--home .sa-result-row__name {
        font-size: 12.5px !important;
        line-height: 1.16 !important;
        -webkit-line-clamp: 3 !important;
    }

    .sa-home-product-card__subtitle {
        margin-top: 5px !important;
        font-size: 10.8px !important;
        line-height: 1.22 !important;
        display: -webkit-box !important;
        -webkit-line-clamp: 2 !important;
        -webkit-box-orient: vertical !important;
        overflow: hidden !important;
    }

    .sa-home-product-card__footer {
        margin-top: 6px !important;
        gap: 5px !important;
        align-items: center !important;
    }

    .sa-home-product-card__badge {
        padding: 4px 7px !important;
        font-size: 10px !important;
        line-height: 1 !important;
    }

    .sa-home-product-card__count {
        font-size: 10px !important;
        line-height: 1 !important;
    }
}

@media (min-width: 768px) and (max-width: 1199px) {
    .sa-filter-compact-menu-host .sa-filter-group__body,
    .sa-filter-compact-menu-host .sa-market-filter__body,
    .sa-filter-group__body.sa-filter-group__body--portal,
    .sa-market-filter__body.sa-filter-group__body--portal {
        max-height: 320px !important;
    }

    .sa-results-grid--home {
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 767px) {
    .sa-filter-compact-menu-host {
        margin: 1px 0 7px !important;
    }

    .sa-filter-compact-menu-host .sa-filter-group__body,
    .sa-filter-compact-menu-host .sa-market-filter__body,
    .sa-filter-group__body.sa-filter-group__body--portal,
    .sa-market-filter__body.sa-filter-group__body--portal {
        max-height: 238px !important;
        padding: 6px !important;
        border-radius: 13px !important;
    }

    .sa-filter-compact-menu-host .sa-filter-group__options,
    .sa-filter-compact-menu-host .sa-market-filter__row {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 4px !important;
    }

    .sa-filter-compact-menu-host .sa-filter-tree__summary,
    .sa-filter-compact-menu-host .sa-filter-option,
    .sa-filter-compact-menu-host .sa-market-filter__item {
        min-height: 24px !important;
        padding: 3px 6px !important;
    }

    .sa-filter-compact-menu-host .sa-filter-option__label,
    .sa-filter-compact-menu-host .sa-market-filter__name,
    .sa-filter-compact-menu-host .sa-filter-tree__summaryText {
        font-size: 10.3px !important;
    }

    .sa-results-grid--home {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 8px !important;
        padding: 7px !important;
    }

    .sa-result-card--home {
        padding: 8px !important;
        gap: 6px !important;
        border-radius: 14px !important;
    }

    .sa-result-card--home .sa-result-row__identity {
        gap: 6px !important;
    }

    .sa-result-card--home .sa-result-row__img,
    .sa-result-card--home .sa-result-row__imgph {
        width: 54px !important;
        height: 54px !important;
        border-radius: 12px !important;
    }

    .sa-result-card--home .sa-result-row__name {
        font-size: 11.4px !important;
        line-height: 1.14 !important;
        -webkit-line-clamp: 3 !important;
    }

    .sa-home-product-card__subtitle {
        margin-top: 4px !important;
        font-size: 9.8px !important;
        line-height: 1.18 !important;
    }

    .sa-home-product-card__footer {
        margin-top: 5px !important;
    }

    .sa-home-product-card__badge {
        padding: 3px 6px !important;
        font-size: 9.4px !important;
    }

    .sa-home-product-card__count {
        font-size: 9.4px !important;
    }
}
