.search-wrapper {
    display: inline-flex;
    align-items: center;
}

.search-container {
    width: 0;
    overflow: hidden;
    transition: width 0.4s ease, opacity 0.3s ease;
    opacity: 0;
}

/* Когда активен — показываем группу */
.search-container.active {
    width: 350px; /* Увеличил ширину, так как теперь там еще и кнопка */
    opacity: 1;
    margin-left: 5px;
}

/* Убираем скругления слева у инпута */
.search-container .input-group .form-control {
    border-top-left-radius: 0 !important;
    border-bottom-left-radius: 0 !important;
}

/* На всякий случай убедимся, что на стыке инпута и кнопки углы тоже прямые */
/* (Bootstrap делает это сам, но это защитит от конфликтов) */
.search-container .input-group .form-control {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
}

.search-container .btn {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
}

.search-label {
    margin-right: 10px;
    font-weight: 500;
    user-select: none;
}

.search-input {
    border: none;
    outline: none;
    margin-left: 10px;
    width: 0;
    opacity: 0;
    transition: width 0.4s ease, opacity 0.2s ease;
    box-shadow: none !important;
}

.search-container.active .search-input {
    width: 100%;
    opacity: 1;
}

.search-trigger {
    cursor: pointer;
    color: #333;
}