/* ================================
   Mobile Optimierung
   ================================ */

@media (max-width: 768px) {

  /* ---------- Grundlayout ---------- */
  body {
    font-size: 16px;
    line-height: 1.6;
  }

  .wrap {
    padding-left: 16px;
    padding-right: 16px;
  }

  section {
    padding-top: 48px;
    padding-bottom: 48px;
  }

  /* ---------- Typografie ---------- */
  h1 {
    font-size: 1.6rem;
    line-height: 1.2;
    text-align: center;
  }

  h2 {
    font-size: 1.35rem;
    line-height: 1.3;
    text-align: center;
  }

  h3 {
    font-size: 1.1rem;
  }

  p {
    font-size: 1rem;
    max-width: 38ch;
    margin-left: auto;
    margin-right: auto;
  }

  /* ---------- Hero ---------- */
  .hero-content {
    padding: 0 16px;
  }

  .hero-btn {
    font-size: 1rem;
    padding: 10px 20px;
    max-width: 260px;
  }

  /* ---------- Cards / Boxen ---------- */
  .info-card,
  .donation-item,
  .progress-card {
    padding: 20px;
    border-radius: 16px;
  }

  .donation-inner {
    gap: 20px;
  }

  /* ---------- Bonus-Badges ---------- */
  .bonus {
    font-size: 0.85rem;
    padding: 6px 10px;
  }

  .bonus-list {
    text-align: left;
    line-height: 1.6;
  }

  /* ---------- Progress / Countdown ---------- */
  .progress-header {
    flex-direction: column;
    gap: 12px;
    text-align: center;
  }

  .progress-bar {
    margin: 16px 0;
  }

  .count-values {
    gap: 12px;
    flex-wrap: wrap;
  }

  .count-values span {
    font-size: 1.4rem;
  }

  .count-values small {
    font-size: 0.75rem;
  }

  /* ---------- Spendenformular ---------- */
  .donation-form {
    padding: 16px;
  }

  /* ---------- Buttons ---------- */
  .btn {
    font-size: 1rem;
    padding: 12px 20px;
  }

  /* ---------- Footer ---------- */
  footer p.small {
    text-align: center;
    font-size: 0.95rem;
  }

  footer a {
    font-size: 0.95rem;
  }

}
