:root {
    --sak-filter-accent: #0055cc;
    --sak-filter-accent-dark: #0047aa;
    --sak-filter-accent-soft: #eef5ff;
    --sak-filter-panel-bg: #ffffff;
    --sak-filter-body-bg: #f7faff;
    --sak-filter-border: #e1eaf5;
    --sak-filter-border-strong: #cfdced;
    --sak-filter-text: #15385f;
    --sak-filter-muted: #64748b;
    --sak-filter-shadow: -24px 0 70px rgba(15, 23, 42, 0.22);
}

#filterModal {
    width: 100vw;
    height: 100vh;
    height: 100svh;
    height: 100dvh;
    z-index: 2060 !important;
    padding: 0 !important;
    overflow: hidden !important;
}

body.filter-modal-open .modal-backdrop {
    top: 0;
    height: 100vh;
    height: 100svh;
    height: 100dvh;
    z-index: 2050 !important;
}

#filterModal.modal-slide .modal-dialog,
#filterModal .sak-filter-modal__dialog {
    position: fixed !important;
    top: 0;
    right: 0;
    bottom: 0;
    display: flex;
    align-items: stretch;
    justify-content: flex-end;
    width: min(100vw, 720px);
    max-width: 720px;
    height: 100vh;
    height: 100svh;
    height: 100dvh;
    min-height: 100vh;
    min-height: 100svh;
    min-height: 100dvh;
    max-height: 100vh;
    max-height: 100svh;
    max-height: 100dvh;
    margin: 0 0 0 auto !important;
    z-index: 2061 !important;
}

#filterModal .sak-filter-modal {
    display: flex;
    flex-direction: column;
    width: 100%;
    height: 100%;
    max-height: 100%;
    border: 0;
    border-left: 1px solid var(--sak-filter-border);
    border-radius: 0;
    overflow: hidden;
    background: var(--sak-filter-panel-bg);
    box-shadow: var(--sak-filter-shadow);
}

#filterModal .sak-filter-modal__header {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    min-height: 76px;
    padding: calc(22px + env(safe-area-inset-top)) calc(28px + env(safe-area-inset-right)) 18px calc(28px + env(safe-area-inset-left));
    border-bottom: 1px solid var(--sak-filter-border);
    background:
        linear-gradient(135deg, rgba(0, 85, 204, .10), rgba(255, 255, 255, 0) 56%),
        #ffffff;
    color: var(--sak-filter-text);
}

#filterModal .sak-filter-modal__header::before {
    content: "";
    position: absolute;
    left: 28px;
    right: 28px;
    bottom: 0;
    height: 3px;
    border-radius: 999px;
    background: linear-gradient(90deg, var(--sak-filter-accent), rgba(0, 85, 204, 0));
}

#filterModal .sak-filter-modal__title-wrap {
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
}

#filterModal .sak-filter-modal__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    flex: 0 0 42px;
    border-radius: 14px;
    background: var(--sak-filter-accent-soft);
    color: var(--sak-filter-accent);
    border: 1px solid #dbe8fb;
    font-size: 18px;
}

#filterModal .sak-filter-modal__title {
    margin: 0;
    color: var(--sak-filter-text);
    font-size: 22px;
    font-weight: 850;
    line-height: 1.18;
    letter-spacing: 0;
}

#filterModal .sak-filter-modal__subtitle {
    margin: 4px 0 0;
    color: var(--sak-filter-muted);
    font-size: 13px;
    line-height: 1.35;
    font-weight: 650;
}

#filterModal .sak-filter-modal__close {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    flex: 0 0 40px;
    padding: 0;
    margin: 0 0 0 auto;
    border-radius: 999px;
    background: #f4f8fd;
    border: 1px solid var(--sak-filter-border);
    color: var(--sak-filter-text);
    font-size: 22px;
    line-height: 1;
    opacity: 1;
    text-shadow: none;
    transition: background .18s ease, border-color .18s ease, color .18s ease, transform .18s ease;
}

#filterModal .sak-filter-modal__close:hover,
#filterModal .sak-filter-modal__close:focus {
    background: var(--sak-filter-accent-soft);
    border-color: #bed3f2;
    color: var(--sak-filter-accent);
    outline: none;
    transform: translateY(-1px);
}

#filterModal .sak-filter-modal__close .fe {
    font-size: 18px;
}

#filterModal .sak-filter-modal__form {
    display: flex;
    flex-direction: column;
    min-height: 0;
    flex: 1 1 auto;
    background: var(--sak-filter-panel-bg);
}

#filterModal .sak-filter-modal__body {
    flex: 1 1 auto;
    overflow-y: auto;
    padding: 22px calc(24px + env(safe-area-inset-right)) 14px calc(24px + env(safe-area-inset-left));
    background: var(--sak-filter-body-bg);
}

#filterModal .sak-filter-modal__row {
    margin: 0;
}

#filterModal .sak-filter-modal__container {
    width: 100%;
}

#filterModal .sak-filter-section {
    padding: 16px 18px;
    margin-bottom: 14px;
    border: 1px solid var(--sak-filter-border);
    border-radius: 18px;
    background: #ffffff;
    box-shadow: 0 12px 32px rgba(15, 23, 42, .06);
}

#filterModal .sak-filter-section__heading {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 14px;
    color: var(--sak-filter-text);
    font-size: 16px;
    font-weight: 850;
}

#filterModal .sak-filter-section__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: 12px;
    background: var(--sak-filter-accent-soft);
    color: var(--sak-filter-accent);
    font-size: 14px;
}

#filterModal .sak-filter-grid {
    display: grid;
    gap: 14px;
}

#filterModal .sak-filter-grid--two {
    grid-template-columns: minmax(0, 1fr) minmax(170px, 0.42fr);
}

#filterModal .search-phrases-container.sak-filter-grid--two {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

#filterModal .sak-filter-field,
#filterModal .form-group {
    margin-bottom: 0;
}

#filterModal .control-label {
    display: block;
    margin-bottom: 7px;
    color: var(--sak-filter-text);
    font-size: 12px;
    line-height: 1.2;
    font-weight: 850;
    letter-spacing: .04em;
    text-transform: uppercase;
}

#filterModal .form-control,
#filterModal .select2-container--default .select2-selection--single,
#filterModal .select2-container--default .select2-selection--multiple {
    min-height: 46px;
    border: 1px solid var(--sak-filter-border-strong) !important;
    border-radius: 14px !important;
    background: #fff !important;
    box-shadow: none !important;
    color: var(--sak-filter-text);
    font-size: 15px;
    font-weight: 650;
    transition: border-color .18s ease, box-shadow .18s ease;
}

#filterModal .form-control:focus,
#filterModal .select2-container--default.select2-container--focus .select2-selection--multiple,
#filterModal .select2-container--default.select2-container--open .select2-selection--single {
    border-color: #9fc0f5 !important;
    box-shadow: 0 0 0 4px rgba(0, 85, 204, .09) !important;
}

#filterModal input.form-control,
#filterModal select.form-control {
    padding: 10px 14px;
}

#filterModal .select2-container {
    width: 100% !important;
}

#filterModal .select2-container--default .select2-selection--multiple {
    display: flex;
    align-items: center;
    padding: 5px 9px;
}

#filterModal .select2-container--default .select2-selection--multiple .select2-selection__rendered {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    padding: 0 !important;
}

#filterModal .select2-container--default .select2-selection--multiple .select2-selection__choice {
    margin-top: 0;
    padding: 5px 8px;
    border: 1px solid #dbe7f7;
    border-radius: 999px;
    background: var(--sak-filter-accent-soft);
    color: var(--sak-filter-text);
    font-size: 12px;
    font-weight: 750;
}

#filterModal .select2-search--inline .select2-search__field {
    margin-top: 0 !important;
    height: 24px;
}

.select2-container--open {
    z-index: 2070 !important;
}

#filterModal .forNoSearchPhrase,
#filterModal .forYesSearchPhrasex {
    padding: 14px;
    border-radius: 16px;
    border: 1px solid var(--sak-filter-border);
}

#filterModal .forNoSearchPhrase {
    background: #fff9f9;
    border-color: #efd1d1;
}

#filterModal .forNoSearchPhrase .control-label {
    color: #b54747;
}

#filterModal #NoSearchPhrase,
#filterModal #NoSearchPhrase + .select2 .select2-selection--multiple {
    border-color: #ebc8c8 !important;
    background: #fffefe !important;
}

#filterModal #NoSearchPhrase + .select2 .select2-selection__choice {
    background: #fff0f0 !important;
    border-color: #f1d3d3 !important;
    color: #b54747 !important;
}

#filterModal .forYesSearchPhrasex {
    background: #f7fcf7;
    border-color: #d6ead5;
}

#filterModal .forYesSearchPhrasex .control-label {
    color: #2c7d44;
}

#filterModal #YesSearchPhrase,
#filterModal #YesSearchPhrase + .select2 .select2-selection--multiple {
    border-color: #cfe4d0 !important;
    background: #fcfffc !important;
}

#filterModal #YesSearchPhrase + .select2 .select2-selection__choice {
    background: #eaf7ec !important;
    border-color: #d6ebd8 !important;
    color: #2c7d44 !important;
}

#filterModal .dimensions-container {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

#filterModal .dimension-group {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 14px;
    border: 1px solid var(--sak-filter-border);
    border-radius: 16px;
    background: #ffffff;
}

#filterModal .sak-range-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 10px;
}

#filterModal .form-control-range {
    width: 100%;
    accent-color: var(--sak-filter-accent);
}

#filterModal .sak-range-value {
    min-width: 58px;
    padding: 6px 8px;
    border-radius: 12px;
    background: var(--sak-filter-accent-soft);
    color: var(--sak-filter-text);
    font-size: 12px;
    font-weight: 800;
    text-align: center;
    white-space: nowrap;
}

#filterModal .sak-filter-modal__footer {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    padding: 18px calc(28px + env(safe-area-inset-right)) calc(24px + env(safe-area-inset-bottom)) calc(28px + env(safe-area-inset-left));
    margin-top: auto;
    border-top: 1px solid var(--sak-filter-border);
    background: #ffffff;
}

#filterModal .sak-filter-btn {
    min-width: 148px;
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 10px 20px;
    border-radius: 999px;
    font-size: 14px;
    line-height: 1.1;
    font-weight: 800;
    letter-spacing: 0;
    box-shadow: none;
    transition: background .18s ease, border-color .18s ease, color .18s ease, transform .18s ease, box-shadow .18s ease;
}

#filterModal .sak-filter-btn--primary {
    border-color: var(--sak-filter-accent);
    background: var(--sak-filter-accent);
    color: #ffffff;
    box-shadow: 0 14px 30px rgba(0, 85, 204, .24);
}

#filterModal .sak-filter-btn--primary:hover,
#filterModal .sak-filter-btn--primary:focus {
    border-color: var(--sak-filter-accent-dark);
    background: var(--sak-filter-accent-dark);
    color: #ffffff;
    box-shadow: 0 18px 36px rgba(0, 85, 204, .30);
    transform: translateY(-1px);
}

#filterModal .sak-filter-btn--ghost {
    border: 1px solid var(--sak-filter-border-strong);
    background: #fff;
    color: var(--sak-filter-text);
}

#filterModal .sak-filter-btn--ghost:hover,
#filterModal .sak-filter-btn--ghost:focus {
    border-color: #bed3f2;
    background: var(--sak-filter-accent-soft);
    color: var(--sak-filter-accent);
    transform: translateY(-1px);
}

@media (max-width: 991.98px) {
    #filterModal.modal-slide .modal-dialog,
    #filterModal .sak-filter-modal__dialog {
        width: min(100vw, 760px);
        max-width: none;
    }

    #filterModal .sak-filter-grid--two,
    #filterModal .search-phrases-container.sak-filter-grid--two,
    #filterModal .dimensions-container {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 575.98px) {
    #filterModal.modal-slide .modal-dialog,
    #filterModal .sak-filter-modal__dialog {
        width: 100%;
        max-width: none;
    }

    #filterModal .sak-filter-modal {
        border-radius: 0;
    }

    #filterModal .sak-filter-modal__header,
    #filterModal .sak-filter-modal__body,
    #filterModal .sak-filter-modal__footer {
        padding-left: calc(14px + env(safe-area-inset-left));
        padding-right: calc(14px + env(safe-area-inset-right));
    }

    #filterModal .sak-filter-modal__header {
        min-height: 68px;
        padding-top: calc(18px + env(safe-area-inset-top));
        padding-bottom: 15px;
    }

    #filterModal .sak-filter-modal__body {
        padding-top: 16px;
        padding-bottom: 12px;
    }

    #filterModal .sak-filter-modal__footer {
        flex-direction: column-reverse;
        padding-top: 14px;
        padding-bottom: calc(18px + env(safe-area-inset-bottom));
    }

    #filterModal .sak-filter-btn {
        width: 100%;
        min-width: 0;
    }

    #filterModal .sak-filter-section {
        padding: 14px;
        border-radius: 16px;
    }

    #filterModal .sak-filter-section__heading {
        margin-bottom: 12px;
        font-size: 15px;
    }

    #filterModal .form-control,
    #filterModal .select2-container--default .select2-selection--single,
    #filterModal .select2-container--default .select2-selection--multiple {
        min-height: 44px;
        font-size: 14px;
    }

    #filterModal .sak-range-row {
        grid-template-columns: 1fr;
    }

    #filterModal .sak-range-value {
        justify-self: start;
    }
}

@media (max-width: 380px) {
    #filterModal .sak-filter-modal__title {
        font-size: 19px;
    }

    #filterModal .sak-filter-modal__subtitle {
        display: none;
    }

    #filterModal .sak-filter-modal__icon {
        width: 38px;
        height: 38px;
        flex-basis: 38px;
        border-radius: 13px;
    }

    #filterModal .sak-filter-section {
        padding: 12px;
    }
}


/* Aktivní stav tlačítka podrobných filtrů v horním vyhledávání */
[data-target="#filterModal"].is-filter-open,
[data-bs-target="#filterModal"].is-filter-open {
    background: linear-gradient(135deg, #084fb8, #073f93) !important;
    color: #fff !important;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.18), 0 10px 24px rgba(11,99,229,.16) !important;
}

[data-target="#filterModal"].is-filter-open .filter-button-icon,
[data-bs-target="#filterModal"].is-filter-open .filter-button-icon {
    background: rgba(255,255,255,.22) !important;
    color: #fff !important;
}


/*
   Public header autocomplete was intentionally removed from this modal file.
   The search suggest UI is now styled only in sakeshop-public-header-search-fix.css,
   so search-filter-modal.css no longer overrides the public header after it is loaded.
*/
