/* ===== 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 */


/* =========================================================
   BASIS / DESKTOP & TABLET
   ========================================================= */

:root{
  --page-pad: clamp(16px, 4vw, 24px);
  --gap: 22px;
  --card-min: 280px;
}

/* 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: clamp(24px, 3.4vw, 40px);
  line-height: 1.15;
  font-weight: 800;
}

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

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

/* Card – Desktop */
.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%;
}

/* Media */
.loc-card__media{
  aspect-ratio:16/9;
  background:#fff;
}

.loc-card__media img{
  width:100%;
  height:230px;
  object-fit:cover;
  display:block;
}

/* Body */
.loc-card__body{
  flex:1;
  padding:16px 18px 8px;
}

.loc-card__title{
  font-weight:800;
  font-size:20px;
  margin-bottom:8px;
}

.loc-card__name2{
  font-size:14px;
  color:#6b7280;
  margin-bottom:6px;
}

.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;
}

/* Actions – Desktop sichtbar */
.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;
}

/* =========================================================
   MOBILE: KOMPAKTE LISTENANSICHT
   ========================================================= */

@media (max-width: 700px){

  /* Grid → Liste */
  .step[data-step="1"] .loc-section .loc-grid{
    grid-template-columns: 1fr;
    gap: 10px;
  }

  /* Card → List Row */
  .loc-card{
    min-height:0;
    display:grid;
    grid-template-columns:84px 1fr;
    gap:10px 14px;
    padding:12px;
    border-radius:12px;
    cursor:pointer;
    -webkit-tap-highlight-color:transparent;
    transition: box-shadow .15s ease, transform .1s ease;
  }

  .loc-card:hover{
    box-shadow:0 6px 18px rgba(0,0,0,.10);
  }

  .loc-card:active{
    transform:translateY(1px);
  }

  /* Quadratbild */
  .loc-card__media{
    width:84px;
    aspect-ratio:1 / 1;
    border-radius:10px;
    overflow:hidden;
  }

  .loc-card__media img{
    width:100%;
    height:100%;
    object-fit:cover;
  }

  /* Body kompakt */
  .loc-card__body{
    padding:0;
  }

  .loc-card__title{
    font-size:16px;
    margin:0 0 1px 0;
    line-height:1.2;
  }

  .loc-card__name2{
    font-size:12px;
    margin:0 0 1px 0;
  }

  .loc-card__addr{
    font-size:12px;
    line-height:1.25;
    margin:0 0 1px 0;

    display:-webkit-box;
    -webkit-line-clamp:2;
    -webkit-box-orient:vertical;
    overflow:hidden;
  }

  .loc-card__phone{
    font-size:12px;
    margin:0;
  }

  /* Features & Buttons weg auf Mobile */
  .loc-card__feature,
  .loc-card__actions{
    display:none !important;
  }
}

/* Extra kleine Phones */
@media (max-width: 420px){
  .loc-card{
    grid-template-columns:72px 1fr;
    padding:10px;
  }

  .loc-card__media{
    width:72px;
  }
}