.address-search-group {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.address-search-row {
    display: grid;
    grid-template-columns: minmax(118px, 150px) minmax(112px, auto);
    gap: 8px;
}

.address-search-button {
    min-height: 42px;
    padding: 0 14px;
    border-radius: 8px;
    border: 1.5px solid var(--accent);
    background: var(--accent);
    color: white;
    font-family: inherit;
    font-size: 0.84rem;
    font-weight: 700;
    cursor: pointer;
    transition: var(--transition);
    white-space: nowrap;
}

.address-search-button:hover {
    background: var(--accent-hover);
    border-color: var(--accent-hover);
}

.address-search-button:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
}

.address-search-postcode,
.address-search-base {
    cursor: pointer;
}

.address-search-postcode[readonly],
.address-search-base[readonly] {
    background: white;
    color: var(--text);
}

@media (max-width: 520px) {
    .address-search-row {
        grid-template-columns: 1fr;
    }

    .address-search-button {
        width: 100%;
    }
}
