/* ===== Step 1: Location (Grid, keine Horizontal-Scroll, einheitliche Ränder) ===== */
:root{
  --page-pad: clamp(16px, 4vw, 24px);   /* EIN Rand links/rechts für alle Geräte */
  --gap: 22px;
  --card-min: 280px;                    /* min Breite je Karte */
}

/* Section */
.step[data-step="1"] .loc-section{
  display: grid;
  align-content: start;
  gap: clamp(28px, 4vw, 40px);
  padding: 0;
}

/* Headline */
.step[data-step="1"] .loc-section > h2{
  margin: 0;
  font-size: var(--fs-display, clamp(24px, 3.4vw, 40px));
  line-height: var(--lh-tight, 1.15);
  font-weight: 800;
  text-align: left;
}

/* Wrapper: kein Querscroller mehr */
.step[data-step="1"] .loc-section .loc-rail{
  margin: 0;
  padding: 0;
  overflow: visible;
}

/* Grid statt Flex-Rail */
.step[data-step="1"] .loc-section .loc-grid{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(var(--card-min), 1fr));
  gap: var(--gap);
}

/* Karten (Design unverändert) */
.loc-card{
  display:flex; flex-direction:column; background:#fff; border:1px solid #e5e7eb;
  border-radius:8px; overflow:hidden; box-shadow:0 6px 20px rgba(0,0,0,.08);
  min-height:450px; width:100%;
}
.loc-card__media{ aspect-ratio:16/9; background:#fff; }
.loc-card__media img{ width:100%; height:230px; object-fit:cover; display:block;object-position: center; }

.loc-card__body{ flex:1; padding:16px 18px 8px; }
.loc-card__title{ font-weight:800; font-size:20px; margin-bottom:8px; }
.loc-card__addr{ color:#6b7280; margin-bottom:4px; }
.loc-card__phone{ color:#0b66ff; text-decoration:none; display:inline-block; margin-bottom:10px; }
.loc-card__phone:hover{ text-decoration:underline; }
.loc-card__feature{ display:flex; align-items:flex-start; gap:10px; margin-top:10px; color:#374151; }
.loc-card__feature.ok::before{ content:"✓"; color:#16a34a; font-weight:700; margin-top:1px; }
.loc-card__feature.na::before{ content:"ℹ"; color:#6b7280; margin-top:1px; }
.loc-card__actions{ padding:14px 18px 18px; display:flex; }
.btn-wide{ width:100%; padding:12px 16px; border-radius:24px; font-weight:500; background-color:#008FFF;color:white; font-size:1em; border: none; outline: none; box-shadow: none;}

/* Feinschliff Mobil */
@media (max-width: 700px){
  :root{ --card-min: 240px; }
  .loc-card{ min-height:450px; }
}

/* Aufräumen: alte Scrollbar-Styles nicht mehr nötig */