.ce-search-banner__search__form {
    position: relative;
    display: flex;
    align-items: center;
    height: 3rem;
    margin-top: 1.5rem;
}

input[type="search"].ce-search-banner__search__input {
    line-height: 1.5;
    max-width: initial;
    height: 100%;
    padding: 0.625rem 0.75rem 0.625rem 2.75rem;
    transition: border-color 200ms;
    border-width: 0.125rem;
    border-style: solid;
    border-radius: 0.125rem;
}

input[type="search"].ce-search-banner__search__input:focus {
    box-shadow: initial;
}

.ce-search-banner__search__button {
    height: 100%;
    padding: 0 0.625rem;
    position: absolute;
    right: 0;
    cursor: pointer;
    border-width: 0.125rem;
    border-style: solid;
    border-radius: 0.125em;
}

.ce-search-banner__search__icon {
    position: absolute;
    left: 0.75rem;
    width: 1.5rem;
    height: 1.5rem;
}

.ce-search-banner__additional-link {
    display: inline-block;
    margin-top: 1rem;
}

/* Responsive */
@media (max-width: 61.999rem) {
    .ce-search-banner__search {
        position: absolute;
        z-index: -1;
        right: 0;
        left: 0;
        margin: 0;
        transform: translateY(5rem);
    }
}

@media (min-width: 62rem) {
    .ce-search-banner__search {
        overflow: visible;
        padding-left: 1rem;
    }

    .ce-search-banner__search__form {
        width: 100%;
    }

    .ce-search-banner.banner.banner--layout-1,
    .ce-search-banner.banner.banner--layout-1 > .flow,
    .ce-search-banner.banner.banner--layout-1 > .flow > .flow,
    .ce-search-banner.banner.banner--layout-1 .banner__content {
        display: flex;
    }

    .ce-search-banner.banner.banner--layout-1::before {
        content: '';
        float: left;
        width: 0.063rem;
        margin-left: -0.063rem;
    }

    .ce-search-banner.banner.banner--layout-1::after {
        content: '';
        display: table;
        clear: both;
    }

    .ce-search-banner.banner--layout-1::before {
        padding-top: calc(100% * 1/3);
    }

    .ce-search-banner.banner.banner--layout-1 > .flow,
    .ce-search-banner.banner.banner--layout-1 > .flow > .flow,
    .ce-search-banner.banner.banner--layout-1 .banner__content {
        width: 100%;
    }

    .ce-search-banner.banner.banner--layout-1 .banner__visual {
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
    }

    .ce-search-banner.banner--layout-1 .banner__content {
        align-items: center;
    }
}

@media (min-width: 100rem) {
    .ce-search-banner.banner--layout-1::before {
        padding-top: calc(100% * 1/4);
    }
}
