/* ============================================================
   KIK-S — Layout (Header, Footer, Rechtstext-Seiten)
   Baut auf tokens.css auf. Selbst gehostete Schriften.
   ============================================================ */

/* ---------- Schriften: selbst hosten (DSGVO) ----------
   woff2-Dateien unter /assets/fonts/ ablegen. Pfade beim Bau
   pruefen. Fallback-Stacks sind in tokens.css gesetzt.
*/
@font-face {
  font-family: "Public Sans";
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("/assets/fonts/PublicSans-SemiBold.woff2") format("woff2");
}
@font-face {
  font-family: "Public Sans";
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("/assets/fonts/PublicSans-Bold.woff2") format("woff2");
}
@font-face {
  font-family: "Inter";
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("/assets/fonts/InterVariable.woff2") format("woff2");
}

/* ---------- Skip-Link (Barrierefreiheit) ---------- */
.skip-link {
  position: absolute; left: -9999px; top: 0;
  background: var(--color-primary); color: #fff;
  padding: var(--space-3) var(--space-4); z-index: 100;
  border-radius: 0 0 var(--radius) 0;
}
.skip-link:focus { left: 0; }

/* ---------- Header ---------- */
.site-header {
  background: var(--surface-card);
  border-bottom: 0.5px solid var(--border);
  position: sticky; top: 0; z-index: 50;
}
.site-header__inner {
  max-width: var(--container); margin-inline: auto;
  padding: var(--space-3) var(--space-5);
  display: flex; align-items: center; justify-content: space-between; gap: var(--space-5);
}
.site-header__logo { display: inline-flex; align-items: center; gap: var(--space-2); }
.site-header__logo img { height: 40px; width: auto; display: block; }
.site-nav { display: flex; align-items: center; gap: var(--space-5); }
.site-nav a {
  font-family: var(--font-body); font-size: var(--fs-sm); font-weight: var(--fw-medium);
  color: var(--text-secondary); text-decoration: none; padding-block: var(--space-2);
}
.site-nav a:hover { color: var(--color-primary); text-decoration: none; }
.site-nav a[aria-current="page"] {
  color: var(--color-primary);
  border-bottom: 2px solid var(--color-accent);
}

/* ---------- Footer ---------- */
.site-footer {
  background: var(--surface-inverse);
  color: var(--text-on-inverse);
  padding-block: var(--space-8) var(--space-5);
  margin-top: var(--space-9);
}
.site-footer__inner {
  max-width: var(--container); margin-inline: auto; padding-inline: var(--space-5);
  display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--space-6);
}
.site-footer h2 {
  font-size: var(--fs-sm); color: #fff; text-transform: uppercase;
  letter-spacing: 0.04em; margin-bottom: var(--space-3); font-weight: var(--fw-semibold);
}
.site-footer a { color: var(--blue-100); text-decoration: none; }
.site-footer a:hover { color: #fff; text-decoration: underline; }
.site-footer__row { font-size: var(--fs-sm); line-height: var(--lh-relaxed); color: var(--blue-100); }
.site-footer__bottom {
  max-width: var(--container); margin: var(--space-7) auto 0; padding: var(--space-4) var(--space-5) 0;
  border-top: 0.5px solid rgba(255,255,255,0.15);
  display: flex; flex-wrap: wrap; justify-content: space-between; gap: var(--space-3);
  font-size: var(--fs-xs); color: var(--blue-200);
}
.site-footer__bottom nav { display: flex; gap: var(--space-4); }

/* ---------- Rechtstext-/Inhaltsseiten ---------- */
.legal {
  max-width: var(--container-text); margin-inline: auto;
  padding: var(--space-8) var(--space-5);
}
.legal h1 { margin-bottom: var(--space-2); }
.legal__lead { color: var(--text-secondary); font-size: var(--fs-md); margin-bottom: var(--space-7); }
.legal h2 {
  font-size: var(--fs-lg); margin-top: var(--space-7); margin-bottom: var(--space-3);
  padding-top: var(--space-5); border-top: 0.5px solid var(--border);
}
.legal h2:first-of-type { border-top: none; padding-top: 0; }
.legal h3 { font-size: var(--fs-md); margin-top: var(--space-5); margin-bottom: var(--space-2); }
.legal p, .legal li { color: var(--text-body); line-height: var(--lh-relaxed); }
.legal ul { padding-left: var(--space-5); margin-bottom: var(--space-4); }
.legal li { margin-bottom: var(--space-2); }
.legal address { font-style: normal; line-height: var(--lh-relaxed); }

/* Platzhalter, die echte Daten brauchen — beim Bau sichtbar markiert */
.ph {
  background: var(--bg-warning); color: var(--text-warning);
  padding: 0 var(--space-2); border-radius: var(--radius-sm);
  font-family: var(--font-mono); font-size: 0.9em; font-weight: var(--fw-medium);
}

/* Hinweisbox (z. B. „Stand", „selbst gehostet") */
.note {
  background: var(--bg-info); color: var(--text-info);
  border-radius: var(--radius-card); padding: var(--space-4) var(--space-5);
  margin-bottom: var(--space-6); font-size: var(--fs-sm); line-height: var(--lh-normal);
}
.note strong { color: var(--blue-800); }

@media (max-width: 720px) {
  .site-nav { gap: var(--space-3); flex-wrap: wrap; }
  .site-header__inner { flex-wrap: wrap; }
}
