
/* Container für alle Filterboxen */
.filters form {
    display: flex;
    flex-wrap: wrap;
    background-color:var(--border-color);
    gap: 10px;
    padding: 10px;
    margin-bottom: 15px;
    border-radius: var(--radius-big);
    box-shadow: var(--shadow-offset) var(--shadow-color);
    border: 1px solid var(--border-color);
    box-sizing: border-box;
}

/* Einzelne Filterboxen (Zeitraum, Location, Sortierung) */
.filter_location, .filter_period, .filter_sorter, .filter_controls {
    flex: 0 1 auto;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 5px;
    background-color: var(--neutral-color-light);
    padding: 10px;
    border-radius: var(--radius-big);
    border: 1px solid var(--border-color);
    font-weight: bold;
    font-size: 1em;
    box-sizing: border-box;
}

/* Reihenfolge der Filterboxen */
.filter_location { order: 0; }
.filter_period { order: 1; }
.filter_sorter { order: 2; }
.filter_controls { order: 3; }

.filter_controls {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
}
.filter_controls button { height: 50%; }


/* Inhalt von .filter-location: alles in einer Zeile, flexible Items */
.filter_location .input-group {
    display: flex;
    gap: 5px;
    flex-wrap: wrap;
    width: 100%;
}

.filter_location .item {
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
    gap: 5px;
}

/* PLZ Input */
.filter_location input[type="text"] {
    flex: 1;
    max-width: 80px;
    padding: 5px;
    border-radius: var(--radius-small);
    border: 1px solid var(--border-color);
    box-sizing: border-box;
}

/* Radius Select */
.filters select {
    flex: 1;
    min-width: 80px;
    /* max-width: 80px; rho: wozu? */
    padding: 5px;
    border-radius: var(--radius-small);
    border: 1px solid var(--border-color);
    box-sizing: border-box;
}

/* Submit Button */
.filters button[type="submit"] {
    flex: 0 0 auto;
    padding: 5px 10px;
    background-color: var(--button-color);
    color: var(--font-color-light);
    border: none;
    border-radius: var(--radius-small);
    font-size: 14px;
    cursor: pointer;
    white-space: nowrap;
    transition: background-color var(--transition-time), transform 0.1s ease;
}

.filters button[type="submit"]:hover {
    background-color: var(--button-color-aktiv);
}

.filters button[type="submit"]:active {
    transform: scale(0.98);
}

/* Disabled Select */
select:disabled {
    background-color: #e0e0e0;
    color: #777;
    cursor: not-allowed;
}

/* Responsive: bei kleinen Bildschirmen */
@media (max-width: 600px) {
    .filters{
        min-width:120px ;
    }
    .filter-location input[type="text"] {
        flex: 1 1 auto;
        max-width: 80px;
        min-width: 80px;
    }

    .filters select {
        flex: 1 1 auto;
        min-width: 80px;
        max-width: 80px;
    }

    .filter-location button[type="submit"] {
        flex: 0 0 auto;
        white-space: nowrap;
        padding: 5px 10px;
    }
}
