/* --- Basis Layout --- */
#map { background-color: #ffffff; }
html, body, #map { overflow: hidden; }

/* --- Popup-Design (Breit & Sauber) --- */
.leaflet-popup {
    max-width: 600px !important;
}

.leaflet-popup-content-wrapper {
    width: 500px !important;
    border-radius: 4px;
    padding: 1px;
}

.leaflet-popup-content {
    width: 480px !important;
    margin: 15px !important;
}

.leaflet-popup-content table {
    width: 100% !important;
    border-collapse: collapse;
    table-layout: fixed;
}

.leaflet-popup-content th {
    text-align: left;
    vertical-align: top;
    padding: 10px 8px;
    border-bottom: 1px solid #ccc;
    width: 45% !important;
    color: #333;
    font-weight: bold;
    word-wrap: break-word;
}

.leaflet-popup-content td {
    padding: 10px 8px;
    border-bottom: 1px solid #ccc;
    vertical-align: top;
    width: 55% !important;
    word-wrap: break-word;
}

.leaflet-popup-content tr:nth-child(even) { 
    background-color: #f5f5f5; 
}

/* --- Suchleiste (Lupe) Fix --- */
.leaflet-control-search {
    background-color: #f8f8f8 !important;
    border: 2px solid rgba(0,0,0,0.2) !important;
    border-radius: 4px !important;
    padding: 0 !important;
}

.leaflet-control-search .search-button {
    background-color: #f8f8f8 !important;
    color: #444444 !important;
    border-radius: 0 !important;
    width: 30px !important;
    height: 30px !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
}

/* --- Allgemeine UI-Elemente --- */
.info { 
    padding: 6px 8px; 
    font: 14px/16px Arial, Helvetica, sans-serif; 
    background-color:#f8f8f8 !important; 
    color: #444444 !important; 
    box-shadow: 0 0 15px rgba(0,0,0,0.2); 
    border-radius: 5px; 
}

.leaflet-control-layers { 
    background-color: #f8f8f8 !important; 
    color: #444444 !important; 
    border: 2px solid rgba(0,0,0,0.2) !important;
}