/* Поиск: шапка + страница /search */

:root {
    --hs-trans: max-width .24s ease .12s, width .24s ease .12s, padding .24s ease .12s;
}

.search-slot {
    position: relative;
    flex-shrink: 0;
    min-width: 0;
    z-index: 10;
}
.search-slot--mob {
    align-self: flex-start;
    margin-bottom: .75rem;
}

#offcanvasNav .offcanvas-body { overflow-x: visible; }

/* — Обёртка анимированного поля — */
.wr-search {
    position: relative;
    z-index: 220;
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
}

.wr-search .region-search {
    box-sizing: border-box;
    position: absolute;
    right: 100%;
    top: 50%;
    transform: translate3d(0, -50%, 0);
    width: 0;
    min-width: 0;
    max-width: 0;
    min-height: 2.75rem;
    margin-right: .35rem;
    padding: 0;
    background: transparent;
    opacity: 0;
    visibility: hidden;
    overflow: hidden;
    white-space: nowrap;
    pointer-events: none;
    transition: opacity .12s ease, var(--hs-trans), visibility 0s linear .36s;
}

.wr-search .region-search.active {
    --hs-w: min(calc(17.5rem + 60px), calc(100vw - 2.5rem - 10px));
    display: flex;
    align-items: center;
    justify-content: stretch;
    width: var(--hs-w);
    max-width: var(--hs-w);
    min-height: 2.85rem;
    padding: 0;
    background: transparent;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    z-index: 230;
    transition: max-width .26s ease, width .26s ease, padding .26s ease, opacity .2s ease .07s, visibility 0s linear 0s;
}

/* — Кнопка поиска (лупа/крестик) — */
.wr-search .js-search-btn {
    position: relative;
    z-index: 2;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: .2rem;
    border: 0;
    background: transparent;
    color: inherit;
    line-height: 0;
    cursor: pointer;
}
.wr-search .js-search-btn__icon { display: inline-flex; }
.wr-search .js-search-btn__icon--close { display: none; }
.wr-search .js-search-btn svg { display: block; }
.wr-search .js-search-btn.active .js-search-btn__icon--loupe { display: none; }
.wr-search .js-search-btn.active .js-search-btn__icon--close { display: inline-flex; }

/* — Форма (в шапке и на странице /search) — */
.wr-search .region-search.active form,
:is(body.path-search, body.vesta-route-search-api-page) #main form.vesta-search-page-form {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    margin: 0;
    display: flex !important;
    flex-wrap: nowrap !important;
    align-items: center;
    justify-content: stretch;
    float: none !important;
}

.wr-search .region-search.active :is(> .block, .contextual-region, .contextual-region > .block, > .block > .block__content) {
    flex: 1 1 auto;
    width: 100%;
    min-width: 0;
    max-width: 100%;
    display: flex;
    align-items: center;
    background: transparent !important;
    box-shadow: none !important;
    float: none !important;
}

.wr-search .region-search.active form :is(.form-item, .js-form-item),
:is(body.path-search, body.vesta-route-search-api-page) #main form.vesta-search-page-form :is(.form-item, .js-form-item) {
    flex: 1 1 auto;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    margin: 0;
    display: block !important;
    float: none !important;
}

/* — Скрытые заголовки/лейблы/submit — */
.wr-search .region-search :is(h2, .block-title, form .form-item > label, .form-actions, .form-actions input[type="submit"], .form-actions button[type="submit"]),
:is(body.path-search, body.vesta-route-search-api-page) #main form.vesta-search-page-form :is(.form-item > label, .form-actions, .form-actions input[type="submit"], .form-actions button[type="submit"]) {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    margin: -1px !important;
    padding: 0 !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
    border: 0 !important;
    opacity: 0;
    pointer-events: none !important;
}

/* — Поле ввода — */
.header-search-keys-wrap {
    position: relative;
    display: block;
    width: 100%;
}
.header-search-keys-wrap :is(input.form-text, input[type="search"], input[type="text"]) {
    box-sizing: border-box;
    display: block;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    padding-right: 2.4rem;
    color: var(--mc-search-fg, #2f2a30);
    background-color: var(--mc-search-bg, #fff);
    background-clip: padding-box;
    border: 1px solid var(--mc-search-fg, #2f2a30) !important;
    border-radius: .25rem;
    box-shadow: none !important;
    appearance: none;
    -webkit-appearance: none;
    -webkit-tap-highlight-color: transparent;
}
.header-search-keys-wrap input::placeholder {
    color: rgba(47, 42, 48, .45);
    opacity: 1;
}
.header-search-keys-wrap :is(input:focus, input:focus-visible, .form-control:focus) {
    outline: none !important;
    border-color: var(--mc-search-fg, #2f2a30) !important;
    box-shadow: none !important;
}
.header-search-keys-wrap input:-webkit-autofill,
.header-search-keys-wrap input:-webkit-autofill:hover,
.header-search-keys-wrap input:-webkit-autofill:focus {
    -webkit-text-fill-color: var(--mc-search-fg, #2f2a30);
    caret-color: var(--mc-search-fg, #2f2a30);
    transition: background-color 9999s ease-out;
    box-shadow: 0 0 0 1000px var(--mc-search-bg, #fff) inset !important;
}

/* — Иконка submit поверх инпута — */
.header-search__submit-icon {
    position: absolute;
    right: .35rem;
    top: 50%;
    transform: translateY(-50%);
    z-index: 2;
    margin: 0;
    padding: .15rem;
    border: 0;
    background: transparent;
    line-height: 0;
    cursor: pointer;
    -webkit-tap-highlight-color: transparent;
}
.header-search__submit-icon svg { display: block; }
.header-search__submit-icon svg path { fill: var(--mc-search-fg, #2f2a30); }
.header-search__submit-icon:focus-visible {
    outline: 2px solid var(--mc-search-fg, #2f2a30);
    outline-offset: 2px;
}

/* — Страница /search — */
:is(body.path-search, body.vesta-route-search-api-page) #main form.vesta-search-page-form {
    width: 100%;
    margin: 0 auto 0 0;
}
:is(body.path-search, body.vesta-route-search-api-page) #main .header-search-keys-wrap :is(input.form-text, input[type="search"], input[type="text"]) {
    padding-top: calc(.375rem + 5px);
    padding-bottom: calc(.375rem + 5px);
}

/* Ссылки в результатах */
:is(body.path-search, body.vesta-route-search-api-page, body.path-poisk, body.path-poisk-po-sajtu) #main .region-content
  :not(#block-vesta-theme-page-title) :is(.search-result__title a, h1 a, h2 a, h3 a) {
    color: var(--c-text);
    text-decoration: none;
    cursor: pointer;
}
:is(body.path-search, body.vesta-route-search-api-page, body.path-poisk, body.path-poisk-po-sajtu) #main .region-content
  :not(#block-vesta-theme-page-title) :is(.search-result__title a, h1 a, h2 a, h3 a):hover,
:is(body.path-search, body.vesta-route-search-api-page, body.path-poisk, body.path-poisk-po-sajtu) #main .region-content
  :not(#block-vesta-theme-page-title) :is(.search-result__title a, h1 a, h2 a, h3 a):focus-visible {
    color: var(--c-accent);
    text-decoration: underline;
}

/* — Адаптив: внутри offcanvas — */
@media (max-width: 991px) {
    #offcanvasNav .search-slot--mob {
        width: 100%;
        margin-bottom: 1rem;
    }
    #offcanvasNav .wr-search {
        display: flex;
        flex-direction: column;
        align-items: stretch;
        justify-content: flex-start;
        width: 100%;
    }
    #offcanvasNav .wr-search .js-search-btn { display: none !important; }

    #offcanvasNav .wr-search :is(.region-search, .region-search.active) {
        position: static;
        right: auto;
        top: auto;
        transform: none;
        display: block;
        width: 100% !important;
        max-width: 100% !important;
        min-height: 0;
        margin-right: 0;
        padding: 0;
        opacity: 1 !important;
        visibility: visible !important;
        pointer-events: auto !important;
        overflow: visible;
        white-space: normal;
        transition: none;
        z-index: 1;
    }
    #offcanvasNav .wr-search :is(.region-search, .region-search.active) form {
        width: 100%;
        justify-content: stretch;
    }
    #offcanvasNav .wr-search :is(.region-search, .region-search.active) .contextual-region {
        display: block;
        width: 100%;
    }
    #offcanvasNav .header-search-keys-wrap :is(input.form-text, input[type="search"], input[type="text"]) {
        padding: 10px 2.75rem 10px 12px;
        font-family: var(--ff-base, "IBM Plex Sans", sans-serif);
        font-size: 16px;
        line-height: 1.35;
        background: var(--c-bg, #fff);
        border-color: #333 !important;
        border-radius: var(--r-sm, 6px);
    }
    #offcanvasNav .header-search-keys-wrap input::placeholder {
        color: #a9a9a9;
        opacity: 1;
    }
}

/* — Шапка: только input белый, оболочки прозрачные — */
#header.header-cvetok .wr-search :is(.block, .block__content, .contextual-region, form, .form-item, .js-form-item, .container-inline) {
    background-color: transparent !important;
    box-shadow: none !important;
    float: none !important;
}
#header.header-cvetok .wr-search .header-search-keys-wrap { background: transparent; }

@media (min-width: 992px) {
    #header.header-cvetok .wr-search .region-search.active {
        --hs-w: min(calc(17.5rem + 60px), max(12rem, calc(100vw - 52rem)));
    }
    #header.header-cvetok .wr-search .container-inline {
        display: flex !important;
        width: 100% !important;
        clear: none !important;
    }
    body:not(.search-ui-ready) #desktop-search-target .wr-search .region-search {
        width: 0 !important;
        max-width: 0 !important;
        opacity: 0 !important;
        visibility: hidden !important;
        pointer-events: none !important;
    }
}
