:root {
    --bg: #f7f7fb;
    --card: #fff;
    --border: #e5e7eb;
    --text: #111827;
    --muted: #6b7280
}

* {
    box-sizing: border-box
}

body {
    margin: 0;
    background: var(--bg);
    color: var(--text);
    font: 16px/1.5 system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif
}

.wrap {
    max-width: 1100px;
    margin: 32px auto;
    padding: 0 16px
}

.card {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: 16px;
    box-shadow: 0 6px 24px rgba(0, 0, 0, .06);
    padding: 18px
}

h1 {
    font-size: 28px;
    line-height: 1.2;
    margin: 0 0 12px
}

.row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px
}

label {
    display: block;
    font-weight: 600;
    margin: 6px 0
}

input,
select {
    width: 100%;
    padding: 10px;
    border: 1px solid var(--border);
    border-radius: 10px;
    background: #fff
}

#map {
    height: 380px;
    border: 1px solid var(--border);
    border-radius: 12px;
    margin-top: 8px
}

.muted {
    color: var(--muted);
    font-size: 14px
}

.actions {
    margin-top: 12px
}

button {
    padding: 10px 14px;
    border-radius: 10px;
    border: 0;
    background: #111827;
    color: #fff;
    cursor: pointer
}

.result {
    font-weight: 700;
    font-size: 18px;
    margin-top: 12px
}

.select2-container {
    width: 100% !important;
    font: inherit;
}

/* Auswahlfeld wie deine Inputs */
.s2-selection.select2-selection--single {
    height: 42px;
    border: 1px solid var(--border);
    border-radius: 10px;
    background: #fff;
}

.s2-selection .select2-selection__rendered {
    line-height: 40px;
    padding: 0 36px 0 12px;
    /* links Text, rechts Platz für Pfeil */
    color: var(--text);
}

.s2-selection .select2-selection__arrow {
    height: 40px;
    right: 10px;
}

/* Fokus wie bei Inputs */
.select2-container--open .s2-selection,
.s2-selection:focus {
    outline: 0;
    border-color: #9ca3af;
    /* oder deine Fokusfarbe */
    box-shadow: 0 0 0 3px rgba(17, 24, 39, 0.08);
}

/* Dropdown sauber, mit Suche oben */
.s2-dropdown.select2-dropdown {
    border: 1px solid var(--border);
    border-radius: 10px;
    overflow: hidden;
    box-shadow: 0 6px 24px rgba(0, 0, 0, .08);
    z-index: 3000;
}

/* Suchfeld im Dropdown */
.s2-dropdown .select2-search--dropdown {
    padding: 8px;
    border-bottom: 1px solid var(--border);
}

.s2-dropdown .select2-search__field {
    width: 100%;
    height: 36px;
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 6px 10px;
    outline: none;
    box-shadow: none;
    font: inherit;
}

/* Ergebnisliste */
.s2-dropdown .select2-results {
    padding: 4px 0;
}

.s2-dropdown .select2-results__option {
    padding: 8px 12px;
}

.s2-dropdown .select2-results__option--highlighted {
    background: #111827;
    color: #fff;
}

/* Clear-Button (x) nicht überdimensioniert */
.s2-selection .select2-selection__clear {
    line-height: 40px;
    margin-right: 2px;
}