*,
*::before,
*::after {
  box-sizing: border-box;
}

* {
  margin: 0;
  padding: 0;
}

html {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

html,
body {
  block-size: 100%;
}

body {
  line-height: var(--line-height);
  -webkit-font-smoothing: antialiased;
  /* Body als Flex-Spalte mit Mindest-Viewport-Höhe — sorgt zusammen
     mit `main { min-block-size: 100svh }` (Bug 121) und `main {
     flex: 1 0 auto }` dafür, dass main mindestens den Viewport
     füllt und der Footer initial unter dem Fold sitzt. */
  display: flex;
  flex-direction: column;
  min-block-size: 100vh;
  min-block-size: 100svh;
}

/* Bug 121: Footer auf jeder Seite erst nach Scroll sichtbar. Vor
   dieser Regel zog `main { flex: 1 0 auto }` allein den Footer
   auf den unteren Viewport-Rand (Sticky-Footer-Pattern, ursprünglich
   gewollt) — das fühlte sich auf Onboarding/Settings/Newsletter/
   Legal aber zu eng an, der Footer war optisch ständig im Sichtfeld.
   Die Landing-Page hat das Problem nie gehabt, weil `.cover { min-
   block-size: 100svh }` (login-Layout) main schon auf Viewport-
   Höhe geschoben hat. Mit dieser Regel gilt das gleiche Prinzip
   global: main füllt mindestens den Viewport, plus Header darüber
   schiebt Body-Höhe auf >100svh, Footer landet unter dem Fold.
   100svh statt 100dvh, damit die Footer-Position nicht beim
   iOS-URL-Bar-Toggle springt (svh ist die kleinste stabile
   Viewport-Variante). */
main {
  flex: 1 0 auto;
  min-block-size: 100vh;
  min-block-size: 100svh;
}

body > footer,
body > .site-footer {
  flex-shrink: 0;
}

img,
picture,
video,
canvas,
svg {
  display: block;
  max-inline-size: 100%;
}

input,
button,
textarea,
select {
  font: inherit;
  color: inherit;
}

button {
  background: none;
  border: 0;
  cursor: pointer;
}

p,
h1,
h2,
h3,
h4,
h5,
h6 {
  overflow-wrap: break-word;
}

a {
  color: inherit;
}

ul,
ol {
  list-style: none;
}

/* Defensive Default für alles, was nicht von /styles/forms.css
   überschrieben wird (z.B. Links): nur ein dünner Outline ohne
   Offset, kein zweiter Rahmen. Buttons/Inputs/Textareas haben in
   forms.css ein Border-Width-Schema statt Outline. */
:focus-visible {
  outline: var(--border-thin) solid var(--color-dark);
  outline-offset: 0;
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
