.search-box{
    width: fit-content;
    height: fit-content;
    position: relative;
}
.input-search{
    height: 50px;
    width: 50px;
    border: var(--main-border-color) 1px;
    border-style: solid;
    padding: 10px;
    font-size: 18px;
    outline: none;
    border-radius: 25px;
    transition: all .5s ease-in-out;
    background-color: var(--bs-body-bg) !important;
    padding-right: 40px;
    color: #fff;
}
.input-search::placeholder{
    font-size: 18px;
    font-weight: 100;
}
.btn-search{
    width: 52px;
    height: 52px;
    border-style: none;
    font-size: 20px;
    font-weight: bold;
    outline: none;
    border-radius: 50%;
    position: absolute;
    right: 0px;
    color:#fff;
    background-color: var(--bs-primary) !important;
    pointer-events: painted;
    margin-right: 0px;
    margin-top: -1px;
}
.btn-search:focus ~ .input-search{
    width: 450px;
    border-radius: 50px;
    background-color: transparent;
    transition: all 500ms cubic-bezier(0, 0.110, 0.35, 2);
}
.input-search:focus{
    width: 450px;
    background-color: transparent;
    transition: all 500ms cubic-bezier(0, 0.110, 0.35, 2);
}