.search-core-container {
    container: search-core-container / inline-size;
}

.search-core {
    --input-eraser-display: none;
    --input-size: 50px;
    --input-p: calc(var(--grid-gutter) * 2);
    --input-border-side: 5px;
    --search-core-eraser-right-offset: calc(var(--input-size) + var(--input-p));

    --text-align: center;
    --title-fz: 28px;

    --map-fz: 16px;
    --map-align-self: center;
    --map-justify-self: center;

    --example-fz: 13px;
    --example-justify-self: center;

    --sample-justify-self: center;

    position: relative;

    display: grid;
    grid-template:  'title' auto
                    'gap1' calc(var(--grid-gutter) * 4)
                    'form' auto
                    'gap2' calc(var(--grid-gutter) * 5.5)
                    'map' auto / auto ;

    color: currentColor;
    font-family: Roboto, sans-serif;
    font-style: normal;
    line-height: 1.4;
}

.search-core--not-empty {
    --input-eraser-display: block;
}

.search-core__form {
    grid-area: form;
    display: grid;
    grid-template:  'input' auto
                    'inputGap' calc(var(--grid-gutter) * 1.5)
                    'btn' auto
                    'btnGap' calc(var(--grid-gutter) * 2.5)
                    'example' auto
                    'exampleGap' calc(var(--grid-gutter) * 5.5)
                    'sample' auto / auto;
}

@supports (container-type: inline-size) {
    @container search-core-container (min-width: 500px) {
        .search-core {
            --input-size: 60px;
            --input-border-side: 0;

            --text-align: left;
            --title-fz: 32px;

            --map-fz: 18px;
            --map-align-self: center;
            --map-justify-self: start;

            --example-fz: 15px;
            --example-justify-self: start;
            --sample-justify-self: end;

            grid-template:  'title map' auto
                            'gap   gap' calc(var(--grid-gutter) * 4)
                            'form  form' auto
                        /   auto   min-content;
        }

        .search-core__form {
            grid-template:  'input   btn' auto
                            'gap     gap' calc(var(--grid-gutter) * 2)
                            'example sample' auto
                        /   1fr 180px;

        }
    }
}

@supports not (container-type: inline-size) {
    @media (min-width: 768px) {
        .search-core {
            --input-size: 60px;
            --input-border-side: 0;

            --text-align: left;
            --title-fz: 32px;

            --map-fz: 18px;
            --map-align-self: center;
            --map-justify-self: start;

            --example-fz: 15px;
            --example-justify-self: start;
            --sample-justify-self: end;

            grid-template:  'title map' auto
                            'gap   gap' calc(var(--grid-gutter) * 4)
                            'form  form' auto
                        /   auto   min-content;
        }

        .search-core__form {
            grid-template:  'input   btn' auto
                            'gap     gap' calc(var(--grid-gutter) * 2)
                            'example sample' auto
                        /   1fr 180px;

        }
    }
}

.search-core__title {
    grid-area: title;
    text-align: var(--text-align);
    font-size: var(--title-fz);
    line-height: 1.4;
    font-weight: 500;
    text-wrap: balance;
    margin: 0;
}

.search-core__input-wrap {
    grid-area: input;
    position: relative;
}

.search-core__input {
    width: 100%;
    height: var(--input-size);
    border-radius: 5px;
    border-top-right-radius: var(--input-border-side);
    border-bottom-right-radius: var(--input-border-side);
    border: none;
    background: #fff;
    padding-left: 16px;
    padding-right: calc(16px + var(--input-size));
}

.search-core__input:focus,
.search-core__input:focus-visible {
    outline: 1px solid #0065BF;
}

.search-core__input::placeholder {
    color: #93A5B3;
    font-size: 14px;
}

.search-core__eraser {
    position: absolute;
    display: var(--input-eraser-display);
    right: 0;
    top: 0;
    width: var(--input-size);
    height: var(--input-size);
    background: transparent;
    border: none;
    fill: #c4c4c4;
    transition: all .2s;
}

.search-core__eraser:hover,
.search-core__eraser:active {
    fill: #000;
}

.search-core__eraser:focus,
.search-core__eraser:focus-within {
    outline: 0;
    box-shadow: 0 0 2px 1px rgb(0 123 255 / 25%), inset 0 0 2px 1px rgb(0 123 255 / 25%);
}

.search-core__eraser-svg {
    width: 16px;
    height: 100%;
}

.search-core__send {
    grid-area: btn;
    width: 100%;
    height: var(--input-size);
    min-height: var(--input-size);
    border-radius: 5px;
    border-top-left-radius: var(--input-border-side);
    border-bottom-left-radius: var(--input-border-side);
    transition: none;
}

.search-core__example-lint,
.search-core__sample-text,
.search-core__map-link {
    color: currentColor;
}

.search-core__example {
    grid-area: example;
    text-align: var(--text-align);
    font-size: var(--example-fz);
    line-height: 1.8;
    justify-self: var(--example-justify-self);
}

.search-core__sample {
    grid-area: sample;
    font-size: 15px;
    text-align: center;
    justify-self: var(--sample-justify-self);
}

.search-core__sample-svg {
    transform: translate(-2px, 3px);
}

.search-core__map {
    grid-area: map;
    font-size: var(--map-fz);
    align-self: var(--map-align-self);
    justify-self: var(--map-justify-self);
}

.search-core__map-link {
    display: inline-block;
    background-image: url(/assets/frontend/icons/map-icon.svg);
    background-repeat: no-repeat;
    padding-left: 20px;
    background-position: -1px 4px;
}
