/* /find — consumer search.
 * Pulls structural primitives from design.css. Adds page-specific
 * composition (hero grid, search form, result map). */

.page { max-width: var(--max-w); margin: 0 auto; padding: 0 var(--gutter); }

/* ————————————————————————————————————————————————————————————————
   Hero — asymmetric, baseline-aligned, no centring.
   Left column carries the type, right column the form. On mobile, stacked.
   ———————————————————————————————————————————————————————————————— */
.hero {
  padding: 56px 0 40px;
  border-bottom: 1px solid var(--paper-line);
}
@media (max-width: 640px) {
  /* Vertical breathing room is precious on mobile; the hero earns its
     keep but compresses. */
  .hero { padding: 28px 0 20px; }
  .hero .display { font-size: clamp(1.9rem, 8vw, 2.4rem); }
}
.hero-grid {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 48px;
  align-items: end;
}
.hero-text .eyebrow { margin-bottom: 12px; }
.hero-text .display { margin-bottom: 14px; }
.hero-lede {
  color: var(--ink-soft);
  font-size: var(--text-md);
  max-width: 36ch;
  margin: 0;
}

.hero-form {
  /* Sits low against the baseline of the display heading so the eye
     reads them as a single tabular unit. */
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-bottom: 4px;
}
.hero-form-row {
  display: flex;
  gap: 12px;
  align-items: flex-end;
}
.hero-submit {
  /* Match input baseline height. */
  min-height: 50px;
  padding-block: 13px;
}
.hero-locate { align-self: flex-start; font-size: var(--text-sm); }
.hint {
  margin: 0;
  min-height: 1.4em;
  font-size: var(--text-sm);
  color: var(--ink-muted);
}
.hint.is-error { color: var(--signal-ink); }

.field-location { position: relative; }
.suggest {
  list-style: none;
  margin: 0;
  padding: 0;
  position: absolute;
  left: 0;
  right: 0;
  top: 100%;
  z-index: 20;
  background: var(--paper);
  border: 1px solid var(--paper-edge);
  border-top: 0;
  max-height: 240px;
  overflow-y: auto;
}
.suggest li button {
  display: block;
  width: 100%;
  text-align: left;
  padding: 10px 0;
  border: 0;
  border-bottom: 1px solid var(--paper-line);
  background: transparent;
  font: inherit;
  font-size: var(--text-sm);
  color: var(--ink);
  cursor: pointer;
}
.suggest li:last-child button { border-bottom: 0; }
.suggest li button:hover,
.suggest li button:focus-visible {
  color: var(--signal-ink);
  background: var(--signal-soft);
}
.suggest .meta {
  display: block;
  font-size: var(--text-xs);
  color: var(--ink-muted);
  margin-top: 2px;
  letter-spacing: 0.04em;
}

@media (max-width: 767px) {
  .hero { padding: 32px 0 24px; }
  .hero-grid { grid-template-columns: 1fr; gap: 28px; }
  .hero-form-row { flex-direction: column; align-items: stretch; }
  .hero-submit { width: 100%; justify-content: center; }
}

/* ————————————————————————————————————————————————————————————————
   Results — list of rows on the left, sticky map on the right.
   ———————————————————————————————————————————————————————————————— */
.results {
  padding-top: 28px;
  padding-bottom: 24px;
  /* Side-by-side layout follows available width, not only viewport —
     fixes split-pane / narrow-tool-window cases on otherwise-wide screens. */
  container-type: inline-size;
  container-name: results;
}
.results-head {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 16px;
  margin-bottom: 18px;
}
.results-head .eyebrow { color: var(--ink-soft); }
.results-head #result-summary { color: var(--ink); font-weight: 600; letter-spacing: 0.04em; text-transform: none; }

.results-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
}
@media (min-width: 768px) {
  .results-grid { grid-template-columns: 3fr 4fr; }
}
@container results (min-width: 640px) {
  .results-grid { grid-template-columns: 3fr 4fr; }
}

/* Empty state. */
.results-empty {
  border-top: 1px solid var(--paper-edge);
  border-bottom: 1px solid var(--paper-edge);
  padding: 32px 0;
  color: var(--ink-muted);
  text-align: left;
}

/* Result row specializations on top of design.css `.row`. */
.result-list .row { cursor: pointer; }
.result-list .row:hover { background: color-mix(in oklch, var(--paper) 92%, var(--signal) 8%); }
.result-list .row .actions { grid-column: 2; }

/* Map area: thin border, no shadow, slight saturation cut so the orange
   markers read as the figure against the ground. */
.result-map {
  display: none;
  height: 320px;
  border: 1px solid var(--paper-edge);
  background: var(--paper-warm);
  position: relative;
}
.result-map.is-visible { display: block; }
@media (min-width: 768px) {
  .result-map { position: sticky; top: 20px; height: calc(100vh - 80px); max-height: 760px; }
}
@container results (min-width: 640px) {
  .result-map { position: sticky; top: 20px; height: calc(100vh - 80px); max-height: 760px; order: 0; }
}
/* On narrow viewports the map sits above the list — parents looking under stress
   read "is the closest one walkable?" faster from a map than from row meta. */
@media (max-width: 767px) {
  .results-grid { grid-template-columns: 1fr; }
  .result-map { order: -1; height: 280px; margin-bottom: 4px; }
}
@container results (max-width: 639px) {
  .results-grid { grid-template-columns: 1fr; }
  .result-map { order: -1; height: 280px; margin-bottom: 4px; }
}
/* Drop the saturation a touch so map tiles don't fight the orange marks. */
.leaflet-tile-pane { filter: saturate(0.6) contrast(0.97) brightness(1.02); }
.leaflet-control-attribution {
  background: var(--paper) !important;
  border: 1px solid var(--paper-line);
  font-size: 10px !important;
  font-family: var(--font-sans) !important;
}

/* Custom Leaflet markers (set in find.js) — small diamonds in signal. */
.kita-marker {
  width: 12px; height: 12px;
  background: var(--signal);
  transform: rotate(45deg);
  outline: 1px solid var(--paper);
  outline-offset: 1px;
}
.kita-marker.is-here {
  width: 10px; height: 10px;
  background: var(--ink);
  outline: 2px solid var(--paper);
}
.kita-marker.is-sponsored {
  background: var(--paper);
  border: 2px solid var(--signal-ink);
}

.leaflet-tooltip {
  background: var(--ink) !important;
  color: var(--paper) !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  font: 500 12px var(--font-sans) !important;
  letter-spacing: 0.02em;
  padding: 4px 8px !important;
}
.leaflet-tooltip-top:before { border-top-color: var(--ink) !important; }


/* Free-slots availability line on result rows */
.free-slots {
  margin-top: 4px;
  font: 500 13px/1.4 var(--font-sans);
  color: var(--signal-ink, #c75a2f);
  letter-spacing: 0.01em;
}
.free-slots.is-stale {
  color: var(--ink-muted, #58564f);
}
.free-slots-stale {
  margin-left: 6px;
  font-weight: 400;
  color: var(--ink-muted, #58564f);
  font-size: 12px;
}

/* Hero "Plätze frei" filter toggle */
.filter-toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 12px;
  font: 500 13px/1.2 var(--font-sans);
  color: var(--ink, #1c1c1a);
  cursor: pointer;
  user-select: none;
}
.filter-toggle input[type="checkbox"] {
  width: 16px;
  height: 16px;
  accent-color: var(--signal-ink, #c75a2f);
  margin: 0;
}
