/* ============================================================
   Datenschutzseite – Final CSS (funktioniert mit deinem HTML)
   Keine neuen Elemente, keine Wrapper nötig.
   ============================================================ */

/* Abstand zur Navigation */
body {
  padding-top: 120px; /* Fix: Titel nicht mehr im Header */
  background: #F7F5F1;
  color: var(--brand);
  font-family: inherit;
  line-height: 1.6;
  overflow-x: hidden;
}

/* Haupttitel */
h1 {
  font-size: var(--fs-h1, 2.6rem);
  color: var(--brand);
  margin-bottom: 0.75rem; /* sauberer Abstand */
}

/* Untertitel direkt unter H1 */
h1 + p {
  margin-top: 0.5rem;
  margin-bottom: 2rem;
  color: var(--brand);
  max-width: 65ch;
}

/* Inhaltsverzeichnis Abstand */
ol {
  margin-top: 0.5rem;
  margin-bottom: 3rem; /* Fix: mehr Luft unter TOC */
  padding-left: 1.4rem;
}

ol li {
  margin-bottom: 0.4rem;
}

/* H2-Sektionen (große Blöcke) */
h2 {
  font-size: var(--fs-h2, 2rem);
  color: var(--ink-1);
  margin-top: 4rem;    /* Fix: ordentlicher Section-Start */
  margin-bottom: 1rem; /* Fix: nicht gequetscht */
  font-weight: 600;
}

/* H3-Unterüberschriften */
h3 {
  font-size: var(--fs-h3, 1.3rem);
  color: var(--ink-1);
  margin-top: 2.5rem;  /* kompakter als H2 */
  margin-bottom: 0.75rem;
  font-weight: 500;
}

/* Normale Absätze */
p {
  margin-bottom: 1.2rem;
  max-width: 85ch;
}

/* Listen (unter H2/H3) */
ul {
  margin-top: 0.5rem;
  margin-bottom: 2rem;
  padding-left: 1.4rem;
}

ul li {
  margin-bottom: 0.4rem;
}

/* Kontaktblock unten */
footer,
.back,
.back a {
  margin-top: 3rem;
}

/* Allgemeiner Containerbreiten-Fix für dein HTML */
body > * {
  padding-inline: clamp(1rem, 4vw, 2rem);
  max-width: min(1200px, 100%);
  margin-inline: auto;
  box-sizing: border-box;
}

p,
li,
td,
th {
  overflow-wrap: anywhere;
  word-break: break-word;
  hyphens: auto;
}

table {
  width: 100%;
  max-width: 100%;
  border-collapse: collapse;
  display: block;
  overflow-x: auto;
}

thead,
tbody,
tr {
  width: 100%;
  display: table;
  table-layout: fixed;
}

th,
td {
  text-align: left;
  padding: 0.5rem 0.6rem;
  font-size: 0.9rem;
}

@media (max-width: 600px) {
  h1 {
    font-size: 2rem;
  }

  h2 {
    font-size: 1.6rem;
  }

  h3 {
    font-size: 1.2rem;
  }

  p,
  li,
  td,
  th {
    font-size: 0.95rem;
    line-height: 1.55;
  }

  table thead {
    display: none;
  }

  table tbody tr {
    display: block;
    width: 100%;
    margin-bottom: 1.2rem;
    padding: 0.8rem;
    background: rgba(0,0,0,0.03);
    border-radius: 8px;
  }

  table tbody td {
    display: block;
    width: 100%;
    padding: 0.35rem 0;
    font-size: 0.95rem;
  }

  table tbody td::before {
    content: attr(data-label);
    display: block;
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--ink-2);
    margin-bottom: 0.1rem;
  }

  table td,
  table th {
    hyphens: none;
    word-break: normal;
  }
}
