/* ==========================================================================
   r2go4-Skin — 1:1 extrahiert aus packages/immo/assets/css/immo.css
   Refactor 2026-05-28
   ========================================================================== */

/* ── Filter-Toggle + Form ────────────────────────────────────────────────── */
.immo-filter-toggle {
  display: none;
  align-items: center;
  justify-content: center;
  gap: 0.625rem;
  width: 100%;
  padding: 0.875rem 1.25rem;
  background: #fff;
  border: 1px solid #aaa;
  border-radius: 3px;
  font-size: 1rem;
  font-weight: 500;
  color: var(--color-text-dark, #1a1a1a);
  font-family: inherit;
  cursor: pointer;
  margin-bottom: 1rem;
}
.immo-filter-toggle:hover {
  border-color: var(--immo-ci-color);
}
.immo-filter-toggle svg {
  flex-shrink: 0;
}
/* Mobile-Show/Hide-Logik steht weiter unten im großen Mobile-Block (line ~929),
   damit sie nach der Default-`.immo-search-form { display: flex }` greift. */

/* ==========================================================================
   SEARCH FILTER
   ========================================================================== */

.immo-search-filter-container {
  margin: 0 0 2rem;
}

.immo-search-form {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

/* 8-column grid layout (matches WP plugin exactly) */
.filter-row {
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  gap: 1.25rem;
  align-items: end;
}

/* Main filters: 2 columns each */
.filter-group[data-filter="objektart"],
.filter-group[data-filter="vermarktungsart"],
.filter-group[data-filter="location"],
.filter-group[data-filter="radius"] {
  grid-column: span 2;
}

/* Secondary filters: 1 column each */
.filter-group[data-filter="area"],
.filter-group[data-filter="rooms"],
.filter-group[data-filter="price"],
.filter-group[data-filter="objektnummer"],
.search-button-group {
  grid-column: span 1;
}

.filter-group {
  position: relative;
}

/* Input & Select Styling */
.filter-group input[type="text"],
.filter-group input[type="number"],
.select-wrapper select {
  width: 100%;
  height: 3rem;
  padding: 0 1rem;
  border: 1px solid #aaa;
  border-radius: 3px;
  font-size: 0.875rem;
  font-family: inherit;
  font-weight: 400;
  background: #fff;
  color: #333;
  box-sizing: border-box;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

.select-wrapper select {
  padding-right: 2.5rem;
  cursor: pointer;
}

.filter-group input:focus,
.select-wrapper select:focus {
  outline: none;
  border-color: var(--immo-ci-color);
}

/* Einheitliche Placeholder-/Default-Darstellung über Inputs UND Selects */
.filter-group input::placeholder,
.select-wrapper select option[value=""],
.select-wrapper select:invalid {
  color: #666;
  font-family: inherit;
  font-size: 0.875rem;
  font-weight: 400;
}

/* Select wrapper & arrow */
.select-wrapper {
  position: relative;
  width: 100%;
}

.select-arrow {
  position: absolute;
  right: 0.875rem;
  top: 50%;
  transform: translateY(-50%);
  pointer-events: none;
}

/* Location autocomplete */
.location-input-wrapper {
  position: relative;
  width: 100%;
}

/* Search button */
.search-button {
  width: 100%;
  height: 3rem;
  padding: 0 1.5rem;
  background: var(--immo-ci-color);
  border: 1px solid var(--immo-ci-color);
  border-radius: 0;
  color: #fff;
  font-size: 0.875rem;
  font-weight: 500;
  letter-spacing: 0.5px;
  cursor: pointer;
  text-transform: uppercase;
  transition: background 0.2s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
}

.search-button:hover {
  background: var(--immo-ci-color-hover);
  border-color: var(--immo-ci-color-hover);
  color: #fff;
}

/* ==========================================================================
   RESULTS HEADER
   ========================================================================== */


/* ── Sorting-Wrapper ─────────────────────────────────────────────────────── */
.sorting-wrapper {
  min-width: 12rem;
}

.sorting-wrapper select {
  height: 2.5rem;
  font-size: 0.875rem;
}

/* ==========================================================================
   RESULTS GRID & CARDS
   ========================================================================== */


/* ── Filter-Responsive ───────────────────────────────────────────────────── */
@media (max-width: 1200px) {
  .filter-row {
    grid-template-columns: repeat(4, 1fr);
  }
  .filter-group[data-filter="objektart"],
  .filter-group[data-filter="vermarktungsart"],
  .filter-group[data-filter="location"],
  .filter-group[data-filter="radius"] {
    grid-column: span 2;
  }
  .filter-group[data-filter="area"],
  .filter-group[data-filter="rooms"],
  .filter-group[data-filter="price"],
  .filter-group[data-filter="objektnummer"],
  .search-button-group {
    grid-column: span 1;
  }
}

/* Mobile */
@media (max-width: 768px) {
  /* Filter-Toggle: Button anzeigen, Form per Default verstecken,
     bei .is-open auf dem Container wieder zeigen. */
  .immo-filter-toggle { display: inline-flex; }
  .immo-search-form { display: none; }
  .immo-search-filter-container.is-open .immo-search-form { display: flex; }

  .filter-row {
    grid-template-columns: repeat(2, 1fr);
    gap: 0.75rem;
  }

  .filter-row .filter-group {
    grid-column: span 1;
  }
  /* Search-Button-Group bekommt volle Breite (eigene Zeile) */
  .filter-row .search-button-group {
    grid-column: span 2;
  }

  .filter-group input,
  .select-wrapper select,
  .search-button {
    height: 3rem;
    font-size: 1rem;
  }

  /* Placeholder + leeres Select-Item: identische Größe/Farbe wie das Feld selbst */
  .filter-group input::placeholder,
  .select-wrapper select option[value=""],
  .select-wrapper select:invalid {
    font-size: 1rem;
    color: #666;
    font-family: inherit;
    font-weight: 400;
  }

  .result-content {
    padding: 1.5rem 1.5rem 1.75rem;
  }

  .result-title {
    /* min-height weg auf Mobile, sonst klafft Lücke unter kurzen Titeln. */
    min-height: 0;
  }

  .result-location {
    font-size: 1rem;
    margin-bottom: 0.5rem;
  }

  .results-header {
    flex-direction: column;
    gap: 1rem;
    align-items: stretch;
  }

  .results-controls {
    flex-direction: column;
    gap: 0.75rem;
  }

  .layout-grid {
    grid-template-columns: 1fr;
  }

  .results-pagination {
    flex-direction: column;
    gap: 0.75rem;
  }

  .result-props-grid {
    flex-wrap: wrap;
    gap: 0.75rem 1.25rem;
  }

  .prop-col-button {
    margin-left: auto;
  }

  /* Map responsive */
  .immo-map-legend {
    display: none;
  }

  .immo-marker {
    width: 20px;
    height: 20px;
    font-size: 10px;
  }

  /* Popup: hide image on mobile */
  .immo-popup-left {
    display: none;
  }

  .immo-map .leaflet-popup-content-wrapper {
    min-width: 280px;
    max-width: 320px;
  }

  .immo-popup-container {
    min-width: 280px;
    max-width: 320px;
  }

  .immo-popup-right {
    width: 100%;
    padding: 0.875rem 1rem;
  }

}

/* Under 480px: further compaction */
