/*
 * Styles – nutzt ausschliesslich Tokens aus tokens.css.
 * Mobile-first; wenige, gezielte Media Queries.
 */

/* ---- Reset (minimal) ---- */
*, *::before, *::after { box-sizing: border-box; }
body, h1, h2, h3, p, ul, figure { margin: 0; }
img { max-width: 100%; display: block; }

/* ---- Basis ---- */
body {
  font-family: var(--font-base);
  font-size: var(--fs-base);
  line-height: var(--lh-base);
  color: var(--color-text);
  background: var(--color-bg);
}

h1, h2, h3 {
  font-family: var(--font-head);
  line-height: var(--lh-tight);
  color: var(--color-primary-dark);
}
h1 { font-size: var(--fs-2xl); }
h2 { font-size: var(--fs-xl); }
h3 { font-size: var(--fs-lg); }

a { color: var(--color-primary); }
a:hover { color: var(--color-primary-dark); }

/* ---- Layout-Container ---- */
.container {
  width: 100%;
  max-width: var(--content-max);
  margin-inline: auto;
  padding-inline: var(--space-3);
}

main { padding-block: var(--space-6); }
section + section { margin-top: var(--space-6); }

/* ---- Header / Navigation ---- */
.site-header {
  background: var(--color-surface);
  border-bottom: 1px solid var(--color-border);
  box-shadow: var(--shadow);
}
.site-header .container {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding-block: var(--space-3);
}
.site-logo {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-head);
  font-size: var(--fs-xl);
  font-weight: bold;
  color: var(--color-primary-dark);
  text-decoration: none;
}
.site-logo__img {
  display: block;
  height: 2.5em;
  width: auto;
}
.site-nav ul {
  list-style: none;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}
.site-nav a {
  text-decoration: none;
  color: var(--color-text);
}
.site-nav a:hover { color: var(--color-primary); }

/* ---- Footer ---- */
.site-footer {
  background: var(--color-primary-dark);
  color: var(--color-bg);
  padding-block: var(--space-5);
  margin-top: var(--space-6);
}
.site-footer a { color: var(--color-bg); }

/* ---- Hero ---- */
.hero {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  padding: var(--space-5);
}
.hero p { color: var(--color-text-muted); margin-top: var(--space-3); }

/* ---- Spruch / Zitat ---- */
.spruch {
  text-align: center;
  padding: var(--space-5);
}
.spruch blockquote {
  margin: 0;
  font-family: var(--font-head);
  font-size: var(--fs-xl);
  line-height: var(--lh-tight);
  color: var(--color-primary-dark);
}
.spruch cite {
  display: block;
  margin-top: var(--space-3);
  font-family: var(--font-base);
  font-size: var(--fs-sm);
  font-style: normal;
  color: var(--color-text-muted);
}

/* ---- Hero-Zusaetze (Projektseiten) ---- */
.eyebrow {
  font-size: var(--fs-sm);
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--color-accent);
  margin: 0;
}
.lead {
  font-family: var(--font-head);
  font-size: var(--fs-lg);
  color: var(--color-primary-dark);
  margin-top: var(--space-2);
}
.hinweis {
  color: var(--color-text-muted);
  font-size: var(--fs-sm);
}

/* ---- Listen ---- */
.liste {
  padding-left: var(--space-4);
  margin-top: var(--space-3);
}
.liste li { margin-top: var(--space-1); }

/* ---- Schlagwort-Tags ---- */
.tags {
  list-style: none;
  padding: 0;
  margin-top: var(--space-3);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}
.tags li {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  padding: var(--space-1) var(--space-3);
  font-size: var(--fs-sm);
  color: var(--color-primary-dark);
}

/* ---- Eckdaten (Definitionsliste) ---- */
.eckdaten dl {
  margin: var(--space-3) 0 0;
  display: grid;
  gap: var(--space-3);
}
.eckdaten dt {
  font-weight: bold;
  color: var(--color-primary-dark);
}
.eckdaten dd { margin: 0; color: var(--color-text-muted); }

/* ---- Projekt-Karten ---- */
.projekt-liste {
  list-style: none;
  padding: 0;
  margin-top: var(--space-3);
  display: grid;
  gap: var(--space-4);
}
.projekt-karte {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: var(--space-4);
}
.projekt-karte h3 { margin-top: var(--space-1); }
.projekt-karte h3 a { text-decoration: none; }
.projekt-karte p { margin-top: var(--space-2); color: var(--color-text-muted); }
.projekt-karte .eyebrow { margin-top: 0; }

@media (min-width: 40rem) {
  .projekt-liste {
    grid-template-columns: repeat(auto-fill, minmax(18rem, 1fr));
  }
}

/* ---- Ab Tablet: Header horizontal ---- */
@media (min-width: 40rem) {
  .site-header .container {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
  }
  h1 { font-size: var(--fs-2xl); }
}

/* ---- Foto-Galerie ---- */
.foto-galerie {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-3);
  margin-top: var(--space-4);
}
.foto-galerie figure {
  margin: 0;
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow);
}
.foto-galerie img {
  width: 100%;
  height: 18rem;
  object-fit: cover;
  display: block;
}
.foto-galerie figcaption {
  padding: var(--space-2) var(--space-3);
  background: var(--color-surface);
  border-top: 1px solid var(--color-border);
  font-size: var(--fs-sm);
  color: var(--color-text-muted);
}

@media (min-width: 40rem) {
  .foto-galerie {
    grid-template-columns: repeat(2, 1fr);
  }
}
