/* base.css — Design Tokens, Reset, globale Komponenten */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  /* Base */
  --bg:       #F1F2F3;
  --surface:  #F0F1F2;
  --surface2: #FFFFFF;

  /* Borders (etwas stärker für klare Trennung) */
  --border:   #D4D8DC;
  --border2:  #C7CCD1;

  /* Text (HIER liegt der grösste Fix) */
  --text:     #1A0D0C;   /* dunkler → besserer Kontrast */
  --text-dim: #5A3A33;   /* deutlich dunkler als vorher */

  /* Accents (kontrastreicher gemacht) */
  --accent:   #5FA764;   /* dunkleres Grün → besser für Text */
  --accent2:  #4A90E2;   /* kräftigeres Blau */

  /* States */
  --muted:    #9FA8AE;   /* etwas dunkler → besser lesbar */
  --danger:   #C94F4F;   /* weniger „washed out“ */

  --nav-h:    64px;
  --popup-gap: 24px;

  --font-display: 'Space Grotesk', sans-serif;
  --font-body:    'Plus Jakarta Sans', sans-serif;
  --font-data:    'JetBrains Mono', monospace;
}

html, body { min-height: 100%; font-family: var(--font-body); background: var(--bg); color: var(--text); }
body.page-app { height: 100%; overflow: hidden; }

.btn-primary {
  font-family: var(--font-display); font-weight: 700; font-size: 0.9rem;
  padding: 12px 28px; border-radius: 8px; border: none;
  background: var(--accent); color: var(--bg); cursor: pointer;
  letter-spacing: 0.04em; transition: opacity 0.2s;
  text-decoration: none; display: inline-block;
}
.btn-primary:hover { opacity: 0.87; transform: translateY(-2px);}

.btn-outline {
  font-family: var(--font-body); font-size: 0.82rem;
  padding: 12px 24px; border-radius: 8px; border: 1px solid var(--border2);
  background: transparent; color: var(--text-dim); cursor: pointer;
  transition: border-color 0.2s, color 0.2s;
  text-decoration: none; display: inline-block;
}
.btn-outline:hover { border-color: var(--accent); color: var(--accent); transform: translateY(-2px);}

.section-eyebrow { font-size: 0.65rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--accent); margin-bottom: 12px; }
.section-title { font-family: var(--font-display); font-weight: 700; font-size: clamp(1.6rem, 3vw, 2.4rem); letter-spacing: -0.03em; color: var(--text); margin-bottom: 48px; }

.img-placeholder { width: 100%; background: var(--surface); border: 1px solid var(--border2); border-radius: 12px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 12px; color: var(--text-dim); font-size: 0.78rem; padding: 32px; }
.img-placeholder .icon { font-size: 2rem; opacity: 0.4; }
.img-placeholder--media { padding: 16px; overflow: hidden; min-height: 0; box-sizing: border-box; }
.img-placeholder--media img { max-width: 100%; max-height: 100%; width: auto; height: auto; object-fit: contain; flex: 0 0 auto; }

/* Use when an image should fully fill the container. */
.img-placeholder--cover { padding: 0; display: block; }
.img-placeholder--cover img { width: 100%; height: 100%; object-fit: cover; display: block; }

footer { background: var(--surface); border-top: 1px solid var(--border); padding: 24px 32px; display: flex; align-items: center; justify-content: space-between; font-size: 0.72rem; color: var(--text-dim); flex-wrap: wrap; gap: 12px; }
.footer-logo { font-family: var(--font-display); font-weight: 700; color: var(--accent); letter-spacing: -0.03em; text-decoration: none; }
.footer-logo span { color: var(--text-dim); font-weight: 400; }
