/* ===========================
   Mobile-First Verfeinerungen
   =========================== */

/* Sichere Ränder für iOS-Notch */
body {
  padding-left: max(0px, env(safe-area-inset-left));
  padding-right: max(0px, env(safe-area-inset-right));
}

/* Kompaktere Card auf sehr kleinen Screens */
@media (max-width: 420px) {
  .card {
    border-radius: 12px;
    padding: 16px;
    box-shadow: var(--shadow-sm);
  }

  h1 {
    font-size: clamp(20px, 6vw, 24px);
    margin-bottom: 8px;
  }

  .muted {
    font-size: var(--fs-sm);
    margin-bottom: 14px;
  }

  /* Labels und Inputs etwas dichter, aber gut antippbar */
  label {
    font-size: 14.5px;
    gap: 6px;
  }

  .input {
    padding: 12px 13px;
    min-height: 44px; /* Apple HIG / WCAG Touch-Ziel */
  }

  .btn {
    width: 100%;
    min-height: 46px;
    font-size: 15px;
  }

  .small {
    display: inline-block;
    margin-top: 8px;
  }
}

/* Checkbox-Gitter: 1 Spalte sehr klein, 2 Spalten ab 380px, 3 Spalten ab 560px */
.check-row {
  grid-template-columns: 1fr;
  gap: 8px;
}

@media (min-width: 380px) {
  .check-row { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 560px) {
  .check-row { grid-template-columns: repeat(3, 1fr); }
}

/* Checkbox-Kärtchen auf Mobile griffiger */
.check-row > label {
  padding: 11px 12px;
  border-radius: 12px;
  min-height: 44px;           /* Touch-Zielgröße */
}

.check-row input[type="checkbox"] {
  width: 20px;
  height: 20px;
}

/* Form-Gesamtgrid: etwas mehr Luft auf XS, normal ab ~480px */
form {
  gap: 12px;
}

@media (min-width: 480px) {
  form { gap: 14px; }
}

/* Kleinere Helfer: Link-Ziel besser antippbar */
a.small {
  padding: 6px 4px;
  border-radius: 6px;
}

/* Visuelle Stabilität beim Zoomen / Umlaufen langer Domains in Platzhaltern */
.input,
.btn {
  word-break: break-word;
  -webkit-tap-highlight-color: transparent;
}

/* Fokus-Ringe auf Mobile etwas weicher, damit’s nicht “springt” */
@media (max-width: 420px) {
  .input:focus-visible {
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.18);
  }
  .btn:focus-visible {
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.24);
  }
}

/* Fehler-/Erfolgsmeldungen: bessere Lesbarkeit auf kleinen Screens */
@media (max-width: 420px) {
  .alert { font-size: 14.5px; padding: 10px 12px; }
}
