/* ============================================================
   1. Tokens
   ============================================================ */
:root {
  /* Farben (Manual S.03) */
  --c-darkred:    #550500;
  --c-red:        #A01E22;
  --c-darkgreen:  #171F04;
  --c-green:      #4C5C40;
  --c-lightgreen: #ADB994;
  --c-digital:    #CFECA5;
  --c-beige:      #F1EDE6;
  --c-white:      #FFFFFF;

  /* Anwendungsregeln (Kunden-Feedback 05-2026):
     – Sektions-BG alternieren: Beige → Hellgrün → … → Dunkelrot (Footer)
     – Schrift hell: Dunkelgrün; Eyebrow/Akzent: Dunkelrot; auf Dunkelrot: Weiß
     – Digitalgrün NIE als Schrift-/Häkchenfarbe, nur als Fläche/Button-Füllung */

  /* Tonwerte 80/60/40/20 % per color-mix() — moderne Browser */
  --c-darkred-80:    color-mix(in srgb, var(--c-darkred) 80%, white);
  --c-darkred-60:    color-mix(in srgb, var(--c-darkred) 60%, white);
  --c-darkred-40:    color-mix(in srgb, var(--c-darkred) 40%, white);
  --c-darkred-20:    color-mix(in srgb, var(--c-darkred) 20%, white);

  --c-red-80:        color-mix(in srgb, var(--c-red) 80%, white);
  --c-red-60:        color-mix(in srgb, var(--c-red) 60%, white);
  --c-red-40:        color-mix(in srgb, var(--c-red) 40%, white);
  --c-red-20:        color-mix(in srgb, var(--c-red) 20%, white);

  --c-darkgreen-80:  color-mix(in srgb, var(--c-darkgreen) 80%, white);
  --c-darkgreen-60:  color-mix(in srgb, var(--c-darkgreen) 60%, white);
  --c-darkgreen-40:  color-mix(in srgb, var(--c-darkgreen) 40%, white);
  --c-darkgreen-20:  color-mix(in srgb, var(--c-darkgreen) 20%, white);

  --c-green-80:      color-mix(in srgb, var(--c-green) 80%, white);
  --c-green-60:      color-mix(in srgb, var(--c-green) 60%, white);
  --c-green-40:      color-mix(in srgb, var(--c-green) 40%, white);
  --c-green-20:      color-mix(in srgb, var(--c-green) 20%, white);

  --c-lightgreen-80: color-mix(in srgb, var(--c-lightgreen) 80%, white);
  --c-lightgreen-60: color-mix(in srgb, var(--c-lightgreen) 60%, white);
  --c-lightgreen-40: color-mix(in srgb, var(--c-lightgreen) 40%, white);
  --c-lightgreen-20: color-mix(in srgb, var(--c-lightgreen) 20%, white);

  --c-digital-80:    color-mix(in srgb, var(--c-digital) 80%, white);
  --c-digital-60:    color-mix(in srgb, var(--c-digital) 60%, white);
  --c-digital-40:    color-mix(in srgb, var(--c-digital) 40%, white);
  --c-digital-20:    color-mix(in srgb, var(--c-digital) 20%, white);

  --c-beige-80:      color-mix(in srgb, var(--c-beige) 80%, white);
  --c-beige-60:      color-mix(in srgb, var(--c-beige) 60%, white);
  --c-beige-40:      color-mix(in srgb, var(--c-beige) 40%, white);
  --c-beige-20:      color-mix(in srgb, var(--c-beige) 20%, white);

  /* Typografie-Skala */
  --t-display:  clamp(48px, 8vw, 96px);
  --t-h1:       clamp(36px, 5vw, 64px);
  --t-h2:       clamp(28px, 3.5vw, 40px);
  --t-h3:       24px;
  --t-eyebrow:  18px;
  --t-body:     17px;
  --t-small:    14px;

  /* Spacing-Skala (8px-Grid) */
  --s-1:  4px;
  --s-2:  8px;
  --s-3:  16px;
  --s-4:  24px;
  --s-5:  32px;
  --s-6:  48px;
  --s-7:  64px;
  --s-8:  96px;
  --s-9:  128px;

  /* Layout */
  --container: 1280px;
  --gutter:    24px;
  --gutter-lg: 48px;

  /* Radius */
  --r-card:   12px;
  --r-pill:   999px;

  /* Goldener Schnitt */
  --golden: 1.618;

  /* Transitions */
  --t-fast: 160ms ease-out;
  --t-med:  240ms ease-out;
}

/* ============================================================
   2. Schriften (lokal)
   ============================================================ */
@font-face { font-family: "Geist"; font-weight: 100; font-style: normal; font-display: swap; src: url("./fonts/Geist-Thin.ttf") format("truetype"); }
@font-face { font-family: "Geist"; font-weight: 200; font-style: normal; font-display: swap; src: url("./fonts/Geist-ExtraLight.ttf") format("truetype"); }
@font-face { font-family: "Geist"; font-weight: 300; font-style: normal; font-display: swap; src: url("./fonts/Geist-Light.ttf") format("truetype"); }
@font-face { font-family: "Geist"; font-weight: 400; font-style: normal; font-display: swap; src: url("./fonts/Geist-Regular.ttf") format("truetype"); }
@font-face { font-family: "Geist"; font-weight: 500; font-style: normal; font-display: swap; src: url("./fonts/Geist-Medium.ttf") format("truetype"); }
@font-face { font-family: "Geist"; font-weight: 600; font-style: normal; font-display: swap; src: url("./fonts/Geist-SemiBold.ttf") format("truetype"); }
@font-face { font-family: "Geist"; font-weight: 700; font-style: normal; font-display: swap; src: url("./fonts/Geist-Bold.ttf") format("truetype"); }
@font-face { font-family: "Geist"; font-weight: 800; font-style: normal; font-display: swap; src: url("./fonts/Geist-ExtraBold.ttf") format("truetype"); }
@font-face { font-family: "Geist"; font-weight: 900; font-style: normal; font-display: swap; src: url("./fonts/Geist-Black.ttf") format("truetype"); }

/* ============================================================
   3. Reset
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  font-family: "Geist", system-ui, -apple-system, "Segoe UI", sans-serif;
  font-size: var(--t-body);
  line-height: 1.55;
  color: var(--c-darkgreen);
  background: var(--c-beige);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
img, svg, picture, video { max-width: 100%; height: auto; display: block; }
button, input, select, textarea { font: inherit; color: inherit; }
button { background: none; border: 0; cursor: pointer; padding: 0; }
a { color: inherit; text-decoration-thickness: 1px; text-underline-offset: 3px; }
ul, ol { padding: 0; margin: 0; list-style: none; }
h1, h2, h3, h4, h5, h6 { margin: 0; font-weight: 700; line-height: 1.1; letter-spacing: -0.01em; }
p { margin: 0; }

/* ============================================================
   4. Base / Typo-Hilfsklassen
   ============================================================ */
/* Eyebrow: NICHT in Versalien, Dunkelrot, größer (Kunden-Feedback) */
.eyebrow {
  display: inline-block;
  font-size: var(--t-eyebrow);
  font-weight: 500;
  line-height: 1.2;
  letter-spacing: 0;
  text-transform: none;
  color: var(--c-darkred);
}
.t-display { font-size: var(--t-display); line-height: 1.0; font-weight: 700; }
.t-h1      { font-size: var(--t-h1); line-height: 1.05; font-weight: 700; }
.t-h2      { font-size: var(--t-h2); line-height: 1.15; font-weight: 600; }
.t-h3      { font-size: var(--t-h3); line-height: 1.3; font-weight: 600; }
.t-body    { font-size: var(--t-body); line-height: 1.55; font-weight: 400; }
.t-small   { font-size: var(--t-small); line-height: 1.5; font-weight: 400; }

/* Überschriften nur an Wortgrenzen umbrechen (KEINE Silbentrennung mitten im Wort).
   overflow-wrap dient nur als Notbremse, falls ein Einzelwort breiter als die Zeile ist.
   Silbentrennung bleibt gezielt den schmalen Leistungs-Cards vorbehalten (.card__title). */
.t-display, .t-h1, .t-h2, .t-h3,
.hero__title, .section-head__title, .ueber-uns__title, .kontakt__title,
.blog-card__title, .team-card__name {
  overflow-wrap: break-word;
  hyphens: manual;
}

/* ============================================================
   5. Layout / Container
   ============================================================ */
.container {
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding-left: var(--gutter);
  padding-right: var(--gutter);
}
.section {
  padding-top: var(--s-7);
  padding-bottom: var(--s-7);
}
@media (min-width: 960px) {
  .container {
    padding-left: var(--gutter-lg);
    padding-right: var(--gutter-lg);
  }
  .section {
    padding-top: var(--s-8);
    padding-bottom: var(--s-8);
  }
}

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

/* ============================================================
   6. Komponenten
   ============================================================ */

/* ----- Button -----
   Primary  : Default Digitalgrün-Füllung + dunkelgrüner Rand/Text;
              Hover = Sektions-BG (transparent) + dunkelgrüner Rand/Text; Disabled 40 %
   Outline  : Default Dunkelrot + weißer Text;
              Hover = Sektions-BG + dunkelgrüner Rand/Text; Disabled 40 %
   Text-Link: Dunkelgrün unterstrichen; Hover 80 %; Disabled 60 % */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--s-2);
  padding: 12px 24px;
  font-size: var(--t-body);
  font-weight: 500;
  line-height: 1;
  border-radius: var(--r-pill);
  border: 1px solid transparent;
  text-decoration: none;
  cursor: pointer;
  transition: background var(--t-fast), color var(--t-fast), border-color var(--t-fast), transform var(--t-fast);
  white-space: nowrap;
}
.btn:focus-visible {
  outline: 2px solid var(--c-darkgreen);
  outline-offset: 2px;
}
.btn:active { transform: translateY(1px); }
.btn[aria-disabled="true"], .btn:disabled {
  opacity: 0.4;
  cursor: not-allowed;
  pointer-events: none;
}

.btn--primary {
  background: var(--c-digital);
  color: var(--c-darkgreen);
  border-color: var(--c-darkgreen);
}
.btn--primary:hover, .btn--primary.is-hover {
  background: transparent;
  color: var(--c-darkgreen);
  border-color: var(--c-darkgreen);
}

.btn--outline {
  background: var(--c-darkred);
  color: var(--c-white);
  border-color: var(--c-darkred);
}
.btn--outline:hover, .btn--outline.is-hover {
  background: transparent;
  color: var(--c-darkgreen);
  border-color: var(--c-darkgreen);
}

.btn--text {
  padding: 0;
  background: transparent;
  border: 0;
  border-radius: 0;
  color: var(--c-darkgreen);
  text-decoration: underline;
  text-decoration-color: var(--c-darkgreen);
  text-underline-offset: 4px;
}
.btn--text:hover, .btn--text.is-hover {
  color: color-mix(in srgb, var(--c-darkgreen) 80%, transparent);
  text-decoration-color: color-mix(in srgb, var(--c-darkgreen) 80%, transparent);
}
.btn--text[aria-disabled="true"] { opacity: 0.6; }

.btn.is-active { transform: translateY(1px); }

/* ----- Card (Basis + Leistungs-Cards im Goldenen Schnitt) ----- */
.card {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  padding: var(--s-5);
  border-radius: var(--r-card);
  background: var(--c-white);
  color: var(--c-darkgreen);
}
.card__icon {
  width: 36px;
  height: 36px;
  flex: 0 0 auto;
}
.card__title {
  font-size: var(--t-h3);
  font-weight: 600;
  line-height: 1.3;
  overflow-wrap: break-word;
  hyphens: auto;
}

/* Leistungs-Card: Hochformat 1 : 1,618, beige auf Hellgrün, Titel dunkelrot */
.card--service {
  position: relative;
  aspect-ratio: 1 / var(--golden);
  height: auto;
  justify-content: flex-start;
  background: var(--c-beige);
  color: var(--c-darkgreen);
}
.card--service .card__title {
  font-size: 19px;
  color: var(--c-darkred);
}
/* Wichtige Card → Digitalgrün */
.card--important { background: var(--c-digital); }
.card--important__badge {
  position: absolute;
  top: var(--s-3);
  right: var(--s-3);
}

/* ----- Form ----- */
.field {
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
}
.field__label {
  font-size: var(--t-small);
  font-weight: 500;
}
.field__control {
  display: block;
  width: 100%;
  padding: 14px 16px;
  font-size: var(--t-body);
  background: var(--c-white);
  color: var(--c-darkgreen);
  border: 1px solid var(--c-darkgreen);
  border-radius: var(--r-card);
  transition: border-color var(--t-fast), box-shadow var(--t-fast);
}
.field__control::placeholder { color: var(--c-darkgreen-40); }
.field__control:focus, .field__control.is-focus {
  outline: none;
  border-color: var(--c-darkgreen);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--c-darkgreen) 22%, transparent);
}
textarea.field__control { resize: vertical; min-height: 140px; }

.checkbox, .radio {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  cursor: pointer;
  font-size: var(--t-body);
}
.checkbox input, .radio input {
  width: 20px;
  height: 20px;
  accent-color: var(--c-darkgreen);
}

/* ----- Tag (Kategorie) ----- */
/* BG = Sektions-Hintergrund (transparent), Rand/Text abgesetzt in Dunkelgrün */
.tag {
  display: inline-flex;
  align-items: center;
  gap: var(--s-1);
  padding: 4px 14px;
  font-size: var(--t-small);
  font-weight: 500;
  line-height: 1.3;
  border-radius: var(--r-pill);
  background: transparent;
  color: var(--c-darkgreen);
  border: 1px solid color-mix(in srgb, var(--c-darkgreen) 45%, transparent);
}

/* ----- Badge „Wichtig" ----- */
.badge {
  display: inline-flex;
  align-items: center;
  gap: var(--s-1);
  padding: 4px 12px;
  font-size: var(--t-small);
  font-weight: 600;
  line-height: 1.2;
  border-radius: var(--r-pill);
}
/* Variante Rot: BG #A01E22, Rand + Text Weiß */
.badge--important {
  background: var(--c-red);
  color: var(--c-white);
  border: 1px solid var(--c-white);
}
/* Variante Digitalgrün: BG #CFECA5, Rand + Text Dunkelgrün */
.badge--important-green {
  background: var(--c-digital);
  color: var(--c-darkgreen);
  border: 1px solid var(--c-darkgreen);
}

/* ============================================================
   7. Sektionen
   ============================================================ */

/* ----- Site Header ----- */
.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  width: 100%;
  transition: background var(--t-med), box-shadow var(--t-med), color var(--t-med);
}
/* Header durchgehend hell mit rotem Logo (Kunden-Comp image1 + Präferenz „Logo in Rot").
   State-Wechsel beim Scrollen = Schatten. */
.site-header[data-state="top"] {
  background: var(--c-beige);
  color: var(--c-darkgreen);
}
.site-header[data-state="scrolled"] {
  background: var(--c-beige);
  color: var(--c-darkgreen);
  box-shadow: 0 2px 16px color-mix(in srgb, var(--c-darkgreen) 12%, transparent);
}

.site-header__inner {
  display: flex;
  align-items: center;
  gap: var(--s-5);
  padding-top: var(--s-3);
  padding-bottom: var(--s-3);
}

/* Logo links, größer */
.site-header__brand {
  display: inline-flex;
  align-items: center;
  height: 56px;
}
.site-header__logo {
  height: 52px;
  width: auto;
}
.site-header__logo--light { display: none; }
.site-header__logo--dark  { display: block; }

/* Menü linksbündig (direkt nach Logo) */
.site-nav { display: none; }
.site-nav__list {
  display: flex;
  gap: var(--s-5);
}
.site-nav__link {
  font-weight: 500;
  text-decoration: none;
  position: relative;
}
.site-nav__link::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: -6px;
  height: 2px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--t-fast);
}
.site-nav__link:hover::after { transform: scaleX(1); }

/* Primary-Button rechts */
.site-header__cta { display: none; margin-left: auto; }

.site-header__burger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px; height: 44px;
  border-radius: var(--r-pill);
  color: inherit;
  margin-left: auto;
}

@media (min-width: 768px) {
  .site-nav { display: block; }
  .site-header__cta { display: inline-flex; }
  .site-header__burger { display: none; }
}

/* ----- Mobile Nav (Off-Canvas) ----- */
.mobile-nav {
  position: fixed;
  inset: 0;
  z-index: 100;
  background: var(--c-beige);
  color: var(--c-darkgreen);
  padding: var(--s-5) var(--gutter);
  display: flex;
  flex-direction: column;
  gap: var(--s-5);
}
.mobile-nav[hidden] { display: none; }
.mobile-nav__close {
  align-self: flex-end;
  width: 44px; height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.mobile-nav__list {
  display: flex;
  flex-direction: column;
  gap: var(--s-4);
  font-size: var(--t-h2);
  font-weight: 600;
}
.mobile-nav__list a { text-decoration: none; }
.mobile-nav__cta { align-self: flex-start; }

/* ----- Hero ----- */
.hero {
  position: relative;
  min-height: calc(100vh - 84px);
  min-height: calc(100svh - 84px);
  display: flex;
  align-items: flex-end;
  color: var(--c-white);
  overflow: hidden;
}
.hero__media {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.hero__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg,
    color-mix(in srgb, var(--c-darkgreen) 55%, transparent) 0%,
    color-mix(in srgb, var(--c-darkgreen) 25%, transparent) 45%,
    color-mix(in srgb, var(--c-darkgreen) 80%, transparent) 100%);
}
.hero__inner {
  position: relative;
  z-index: 1;
  width: 100%;
  padding-top: var(--s-8);
  padding-bottom: var(--s-8);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
/* Eyebrow: H3-Größe, keine Versalien, eng & linksbündig zum Titel */
.hero__eyebrow {
  font-size: var(--t-h3);
  font-weight: 500;
  line-height: 1.2;
  letter-spacing: 0;
  color: var(--c-white);
  margin-bottom: var(--s-2);
}
.hero__title {
  font-size: var(--t-display);
  line-height: 1.0;
  font-weight: 700;
  letter-spacing: -0.02em;
  margin-bottom: var(--s-4);
  max-width: 14ch;
}
.hero__subline {
  font-size: clamp(18px, 2vw, 22px);
  line-height: 1.45;
  max-width: 56ch;
  color: color-mix(in srgb, var(--c-white) 92%, var(--c-darkgreen));
}
.hero__scroll-indicator {
  position: absolute;
  left: 50%;
  bottom: var(--s-5);
  z-index: 2;
  transform: translateX(-50%);
  width: 1px;
  height: 48px;
  background: color-mix(in srgb, var(--c-white) 60%, transparent);
  overflow: hidden;
}
.hero__scroll-indicator span {
  position: absolute;
  top: -48px;
  left: 0;
  width: 1px;
  height: 24px;
  background: var(--c-white);
  animation: scroll-pulse 1.8s ease-in-out infinite;
}
@keyframes scroll-pulse {
  0%   { transform: translateY(0); }
  100% { transform: translateY(96px); }
}

/* ----- Section Head (wiederverwendbar) ----- */
.section-head {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  margin-bottom: var(--s-6);
}
.section-head__title { letter-spacing: -0.02em; }
.section-head__lead {
  max-width: 56ch;
  color: color-mix(in srgb, var(--c-darkgreen) 78%, transparent);
}

/* ----- Über uns / Imagefilm (beige) ----- */
.ueber-uns {
  background: var(--c-beige);
  color: var(--c-darkgreen);
}
.ueber-uns__inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--s-6);
  align-items: center;
}
.ueber-uns__content { min-width: 0; }
.ueber-uns__title {
  margin: var(--s-2) 0 var(--s-4);
  letter-spacing: -0.02em;
}
.ueber-uns__lead {
  font-size: clamp(18px, 1.6vw, 20px);
  line-height: 1.55;
  max-width: 62ch;
  margin-bottom: var(--s-6);
  color: color-mix(in srgb, var(--c-darkgreen) 88%, transparent);
}
.values {
  display: flex;
  flex-direction: column;
  gap: var(--s-4);
}
.values__item {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--s-3);
  align-items: flex-start;
}
.values__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: var(--r-pill);
  background: var(--c-digital);
  color: var(--c-darkgreen);
  flex: 0 0 auto;
}
.values__title {
  display: block;
  font-size: var(--t-h3);
  font-weight: 600;
  margin-bottom: var(--s-1);
  color: var(--c-darkgreen);
}
.values__text {
  color: color-mix(in srgb, var(--c-darkgreen) 78%, transparent);
}

/* Imagefilm-Platzhalter (16:9) */
.imagefilm {
  position: relative;
  margin: 0;
  aspect-ratio: 16 / 9;
  border-radius: var(--r-card);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--s-3);
  color: var(--c-white);
  border: 1px solid color-mix(in srgb, var(--c-darkgreen) 18%, transparent);
  background:
    radial-gradient(circle at 50% 42%, color-mix(in srgb, var(--c-darkgreen) 45%, transparent), transparent 62%),
    linear-gradient(160deg, var(--c-green), var(--c-darkgreen));
}
.imagefilm__play {
  width: 72px;
  height: 72px;
  border-radius: var(--r-pill);
  background: var(--c-digital);
  color: var(--c-darkgreen);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 6px 24px color-mix(in srgb, var(--c-darkgreen) 35%, transparent);
  transition: transform var(--t-fast);
}
.imagefilm__play:hover { transform: scale(1.06); }
.imagefilm__play svg { margin-left: 3px; }
.imagefilm__caption {
  font-size: var(--t-small);
  color: color-mix(in srgb, var(--c-white) 82%, transparent);
}

@media (min-width: 960px) {
  .ueber-uns__inner {
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
    gap: var(--s-8);
  }
}

/* ----- Leistungen (hellgrün) ----- */
.leistungen {
  background: var(--c-lightgreen);
  color: var(--c-darkgreen);
}
.services-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--s-3);
  align-items: start;
}
@media (min-width: 700px)  { .services-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); } }
@media (min-width: 1000px) { .services-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); gap: var(--s-4); } }
@media (min-width: 1240px) { .services-grid { grid-template-columns: repeat(5, minmax(0, 1fr)); } }

/* ----- Team / Ansprechpartner (beige) ----- */
.team {
  background: var(--c-beige);
  color: var(--c-darkgreen);
}
.team-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--s-5);
}
@media (min-width: 768px) { .team-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); } }
.team-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--s-3);
}
.team-card__media {
  width: clamp(120px, 22vw, 168px);
  aspect-ratio: 1 / 1;
  border-radius: var(--r-pill);
  background: var(--c-lightgreen);
  color: var(--c-darkgreen);
  display: flex;
  align-items: center;
  justify-content: center;
}
.team-card__name {
  font-size: var(--t-h3);
  font-weight: 600;
  color: var(--c-darkgreen);
}
.team-card__role {
  font-size: var(--t-small);
  color: var(--c-darkred);
}

/* ----- Blog (hellgrün) ----- */
.blog {
  background: var(--c-lightgreen);
  color: var(--c-darkgreen);
}
.blog-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--s-5);
}
@media (min-width: 640px)  { .blog-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (min-width: 1000px) { .blog-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); } }
.blog-card {
  display: flex;
  flex-direction: column;
  background: var(--c-beige);
  border-radius: var(--r-card);
  overflow: hidden;
}
/* Querformat im Goldenen Schnitt (1,618 : 1) */
.blog-card__media {
  aspect-ratio: var(--golden) / 1;
  display: flex;
  align-items: center;
  justify-content: center;
  color: color-mix(in srgb, var(--c-darkgreen) 55%, transparent);
  background: linear-gradient(160deg, var(--c-lightgreen), color-mix(in srgb, var(--c-green) 65%, var(--c-lightgreen)));
}
.blog-card__body {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  padding: var(--s-4) var(--s-4) var(--s-5);
}
.blog-card__cat {
  font-size: var(--t-small);
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--c-darkred);
}
.blog-card__title {
  font-size: var(--t-h3);
  font-weight: 600;
  line-height: 1.3;
  color: var(--c-darkgreen);
}
.blog-card__body .btn--text { align-self: flex-start; }

/* ----- Kontakt (beige) ----- */
.kontakt {
  background: var(--c-beige);
  color: var(--c-darkgreen);
}
.kontakt__inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-6);
}
.kontakt__title {
  margin: var(--s-3) 0 var(--s-3);
  letter-spacing: -0.02em;
}
.kontakt__lead {
  font-size: clamp(18px, 1.6vw, 20px);
  line-height: 1.55;
  max-width: 48ch;
  margin-bottom: var(--s-5);
  color: color-mix(in srgb, var(--c-darkgreen) 78%, transparent);
}
.kontakt__data {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-3);
  margin-bottom: var(--s-5);
}
.kontakt__row {
  display: grid;
  grid-template-columns: 100px 1fr;
  gap: var(--s-3);
  font-size: var(--t-body);
  align-items: start;
}
/* Labels dunkelrot (Kunden-Feedback) */
.kontakt__row dt {
  font-weight: 600;
  color: var(--c-darkred);
}
.kontakt__row dd { margin: 0; }
.kontakt__row a { text-decoration-color: var(--c-darkred); }
.kontakt__row a:hover { color: var(--c-darkred); }

.kontakt__map {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  padding: var(--s-5);
  background: var(--c-lightgreen);
  border-radius: var(--r-card);
  font-weight: 500;
  min-height: 140px;
}

.kontakt__form {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  background: var(--c-white);
  padding: var(--s-5);
  border-radius: var(--r-card);
  border: 1px solid color-mix(in srgb, var(--c-darkgreen) 12%, transparent);
}
.kontakt__submit {
  align-self: flex-start;
  margin-top: var(--s-2);
}
.form-status {
  font-size: var(--t-small);
  min-height: 1.5em;
}
.form-status[data-state="success"] {
  color: var(--c-darkred);
  font-weight: 500;
}

@media (min-width: 900px) {
  .kontakt__inner { grid-template-columns: minmax(0, 1fr) minmax(0, 1.1fr); gap: var(--s-7); align-items: start; }
}

/* ----- Abschlussbild + Spruch (vor dem Footer) ----- */
/* Hinweis: Holz-Jahresringe als CSS-Platzhalter — echtes Foto später als background-image. */
.closing {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: var(--c-white);
  overflow: hidden;
  background:
    repeating-radial-gradient(circle at 50% 50%,
      #3a0a06 0px, #3a0a06 7px,
      #4a0d08 7px, #4a0d08 15px,
      #2e0805 15px, #2e0805 23px);
}
.closing__overlay {
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 50% 50%,
    color-mix(in srgb, var(--c-darkred) 30%, transparent) 0%,
    color-mix(in srgb, #1a0402 85%, transparent) 100%);
}
.closing__inner {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--s-4);
  padding-top: var(--s-8);
  padding-bottom: var(--s-8);
}
.closing__logo {
  width: clamp(120px, 20vw, 180px);
  height: auto;
}
.closing__claim {
  font-size: clamp(20px, 3vw, 32px);
  font-weight: 600;
  max-width: 22ch;
  line-height: 1.25;
  color: var(--c-white);
}

/* ----- Footer (dunkelrot) ----- */
.site-footer {
  background: var(--c-darkred);
  color: color-mix(in srgb, var(--c-white) 85%, var(--c-darkred));
}
.site-footer__inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-5);
  padding-top: var(--s-7);
  padding-bottom: var(--s-5);
}
.site-footer__brand {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
}
.site-footer__logo { width: 150px; height: auto; }
.site-footer__tag { color: color-mix(in srgb, var(--c-white) 70%, var(--c-darkred)); max-width: 36ch; }

.site-footer__heading {
  font-size: var(--t-small);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 600;
  color: var(--c-white);
  margin-bottom: var(--s-2);
}
.site-footer__col p { color: var(--c-white); margin-bottom: var(--s-3); }
/* :not(.btn) — Buttons behalten ihre eigene Farbgebung (sonst überschreibt color:inherit den Button-Text) */
.site-footer__col a:not(.btn) { color: inherit; }
.site-footer__col a:not(.btn):hover { color: var(--c-white); text-decoration: underline; }

.site-footer__social {
  display: flex;
  gap: var(--s-3);
  margin-bottom: var(--s-4);
}
.site-footer__social a {
  display: inline-flex;
  width: 40px; height: 40px;
  align-items: center;
  justify-content: center;
  border-radius: var(--r-pill);
  border: 1px solid color-mix(in srgb, var(--c-white) 35%, transparent);
  color: var(--c-white);
  transition: background var(--t-fast);
}
.site-footer__social a:hover { background: color-mix(in srgb, var(--c-white) 12%, transparent); }

.site-footer__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-3);
}

.site-footer__links {
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
  margin-bottom: var(--s-4);
}
.site-footer__links a { text-decoration: none; color: var(--c-white); }
.site-footer__links a:hover { text-decoration: underline; }

.site-footer__siegel {
  width: 96px; height: 96px;
  border-radius: var(--r-pill);
  border: 2px solid color-mix(in srgb, var(--c-white) 55%, transparent);
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  font-size: 11px;
  line-height: 1.25;
  font-weight: 600;
  color: var(--c-white);
  padding: var(--s-2);
}

.site-footer__copy {
  border-top: 1px solid color-mix(in srgb, var(--c-white) 15%, transparent);
}
.site-footer__copy-inner {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--s-2);
  padding-top: var(--s-4);
  padding-bottom: var(--s-4);
  font-size: var(--t-small);
  color: color-mix(in srgb, var(--c-white) 60%, var(--c-darkred));
}

@media (min-width: 768px) {
  .site-footer__inner {
    grid-template-columns: 1.5fr 1fr 1fr 1fr;
    gap: var(--s-6);
  }
}

/* ============================================================
   8. Showcase
   ============================================================ */
.showcase-divider {
  background: var(--c-beige);
  text-align: center;
  padding: var(--s-5) var(--gutter);
  border-top: 1px solid color-mix(in srgb, var(--c-darkgreen) 12%, transparent);
  border-bottom: 1px solid color-mix(in srgb, var(--c-darkgreen) 12%, transparent);
}

.showcase {
  background: var(--c-white);
  color: var(--c-darkgreen);
  padding-top: var(--s-7);
  padding-bottom: var(--s-7);
}
.showcase__intro {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  max-width: 56ch;
  margin-bottom: var(--s-7);
}
.showcase__lead {
  color: color-mix(in srgb, var(--c-darkgreen) 72%, transparent);
}

.showcase-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-4);
}
@media (min-width: 960px) {
  .showcase-grid { grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); }
  .showcase-block--full { grid-column: 1 / -1; }
}

.showcase-block {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  padding: var(--s-5);
  background: var(--c-beige-40);
  border: 1px solid color-mix(in srgb, var(--c-lightgreen) 60%, transparent);
  border-radius: var(--r-card);
}
.showcase-block__title {
  font-size: var(--t-h3);
  font-weight: 600;
}
.showcase-block__subtitle {
  font-size: var(--t-small);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 500;
  color: color-mix(in srgb, var(--c-darkgreen) 70%, transparent);
  margin-top: var(--s-3);
}
.showcase-block__desc {
  color: color-mix(in srgb, var(--c-darkgreen) 70%, transparent);
  margin-bottom: var(--s-2);
}
.showcase-block__note {
  margin-top: var(--s-3);
  color: var(--c-darkred);
  font-weight: 500;
}

/* Palette */
.palette {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--s-3);
}
@media (min-width: 768px) { .palette { grid-template-columns: repeat(4, 1fr); } }
@media (min-width: 1100px) { .palette { grid-template-columns: repeat(8, 1fr); } }

.palette__col {
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
}
.palette__strip {
  display: flex;
  flex-direction: column;
  border-radius: 8px;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--c-darkgreen) 8%, transparent);
}
.palette__chip { height: 28px; }
.palette__meta {
  display: flex;
  flex-direction: column;
  gap: 2px;
  font-size: var(--t-small);
}
.palette__meta strong { font-weight: 600; }

/* Type-Skala */
.type-scale {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-3);
}
.type-scale__row {
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: var(--s-3);
  align-items: baseline;
  padding-bottom: var(--s-3);
  border-bottom: 1px solid color-mix(in srgb, var(--c-darkgreen) 8%, transparent);
}
.type-scale__label {
  font-size: var(--t-small);
  color: color-mix(in srgb, var(--c-darkgreen) 60%, transparent);
}
.weight-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-1);
  font-size: 18px;
  margin-top: var(--s-3);
}
@media (min-width: 768px) { .weight-list { grid-template-columns: 1fr 1fr; } }

/* State-Table für Buttons */
.state-table {
  display: grid;
  gap: var(--s-3);
}
.state-table__head, .state-table__row {
  display: grid;
  grid-template-columns: 100px repeat(4, minmax(0, 1fr));
  gap: var(--s-2);
  align-items: center;
}
.state-table__head {
  font-size: var(--t-small);
  color: color-mix(in srgb, var(--c-darkgreen) 60%, transparent);
  padding-bottom: var(--s-2);
  border-bottom: 1px solid color-mix(in srgb, var(--c-darkgreen) 10%, transparent);
}
.state-table__label { font-weight: 500; font-size: var(--t-small); }
/* Demo-Buttons füllen ihre Zelle und brechen notfalls um — kein Text-Überlauf aus dem Pill */
.state-table .btn {
  width: 100%;
  min-width: 0;
  white-space: normal;
  overflow-wrap: break-word;
  hyphens: auto;
  text-align: center;
}

/* Form-Demo */
.form-demo {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-3);
}
@media (min-width: 768px) { .form-demo { grid-template-columns: 1fr 1fr; } }

/* Logo-Grid */
.logo-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--s-2);
  border-radius: var(--r-card);
  overflow: hidden;
}
@media (min-width: 768px) { .logo-grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1100px) { .logo-grid { grid-template-columns: repeat(6, 1fr); } }
.logo-cell {
  display: flex;
  align-items: center;
  justify-content: center;
  aspect-ratio: 1 / 1;
  padding: var(--s-3);
  border: 1px solid color-mix(in srgb, var(--c-darkgreen) 8%, transparent);
  border-radius: 8px;
}
.logo-cell img { max-width: 80%; max-height: 70%; }

/* Badge-Reihe */
.badge-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--s-2);
}

/* Showcase-Cards: gleiche Leistungs-Cards, 4-spaltig */
.services-grid--showcase { grid-template-columns: repeat(2, minmax(0, 1fr)); }
@media (min-width: 768px) { .services-grid--showcase { grid-template-columns: repeat(4, minmax(0, 1fr)); } }

/* ============================================================
   9. Globale Media-Queries / Mobile-Polish
   ============================================================ */

@media (max-width: 640px) {
  .hero { min-height: 90svh; }
  .hero__title { font-size: clamp(40px, 11vw, 56px); }

  .state-table__head, .state-table__row {
    grid-template-columns: 80px repeat(4, minmax(0, 1fr));
    gap: var(--s-1);
    font-size: 12px;
  }
  .state-table .btn { padding: 8px 12px; font-size: 13px; }
}

:target { scroll-margin-top: 88px; }

::selection {
  background: var(--c-digital);
  color: var(--c-darkgreen);
}

@media print {
  .site-header, .site-footer, .showcase, .closing, .hero__media, .hero__overlay, .hero__scroll-indicator { display: none !important; }
  body { color: black; background: white; }
}

/* ============================================================
   10. Mobile Polish — Kunden-Wow auf 320–640 px
   ============================================================ */

/* Global Touch-Quality */
html { -webkit-tap-highlight-color: transparent; }
a, button { touch-action: manipulation; }

/* Bessere Smooth-Scroll-Performance auf iOS */
body { -webkit-overflow-scrolling: touch; }

/* Anker-Offset an Mobile-Header anpassen */
@media (max-width: 640px) {
  :target { scroll-margin-top: 72px; }
}

/* ----- Site Header (Mobile) ----- */
@media (max-width: 640px) {
  .site-header__inner {
    padding-top: var(--s-2);
    padding-bottom: var(--s-2);
  }
  .site-header__brand { height: 44px; }
  .site-header__logo { height: 40px; }
  .site-header__burger {
    width: 40px;
    height: 40px;
  }
}

/* ----- Mobile Nav (Polish + Animation) ----- */
.mobile-nav {
  animation: navSlideIn 240ms ease-out;
  overscroll-behavior: contain;
}
@keyframes navSlideIn {
  from { opacity: 0; transform: translateY(-12px); }
  to   { opacity: 1; transform: translateY(0); }
}
.mobile-nav__close {
  background: var(--c-white);
  border-radius: var(--r-pill);
  box-shadow: 0 1px 2px color-mix(in srgb, var(--c-darkgreen) 12%, transparent);
}
.mobile-nav__list {
  margin-top: var(--s-3);
  padding-top: var(--s-4);
  border-top: 1px solid color-mix(in srgb, var(--c-darkgreen) 12%, transparent);
}
.mobile-nav__list a {
  display: inline-block;
  padding: var(--s-2) 0;
  position: relative;
}
.mobile-nav__list a::after {
  content: "→";
  position: absolute;
  right: 0;
  opacity: 0;
  transform: translateX(-8px);
  transition: all var(--t-fast);
}
.mobile-nav__list a:hover::after,
.mobile-nav__list a:focus::after {
  opacity: 1;
  transform: translateX(0);
}
.mobile-nav__cta {
  width: 100%;
  justify-content: center;
  padding: 16px 24px;
  font-size: 16px;
}

/* ----- Hero (Mobile) ----- */
@media (max-width: 640px) {
  .hero {
    min-height: calc(92svh - 60px);
    align-items: center;
  }
  .hero__inner {
    padding-top: var(--s-7);
    padding-bottom: var(--s-7);
  }
  .hero__eyebrow {
    margin-bottom: var(--s-2);
    font-size: 20px;
  }
  .hero__title {
    font-size: clamp(34px, 10.5vw, 52px);
    letter-spacing: -0.03em;
    line-height: 1.02;
    margin-bottom: var(--s-3);
    max-width: 100%;
    overflow-wrap: break-word;
    word-break: break-word;
    hyphens: auto;
  }
  /* Bruch beibehalten — ergibt sauberen 2-Zeilen-Stack auf Mobile */
  .hero__title br { display: inline; }
  .hero__subline {
    font-size: 16px;
    line-height: 1.5;
    max-width: 100%;
  }
  .hero__subline br { display: none; }
  .hero__scroll-indicator { display: none; }
}

/* ----- Section Padding (Mobile) ----- */
@media (max-width: 640px) {
  .section { padding-top: var(--s-6); padding-bottom: var(--s-6); }
  .section-head { margin-bottom: var(--s-5); gap: var(--s-2); }
  .section-head__title { letter-spacing: -0.025em; }
}

/* ----- Über uns / Imagefilm (Mobile) ----- */
@media (max-width: 640px) {
  .ueber-uns__inner { gap: var(--s-5); }
  .ueber-uns__lead { font-size: 16px; margin-bottom: var(--s-5); }
  .values { gap: var(--s-3); }
  .values__item { gap: var(--s-2); }
  .values__icon { width: 28px; height: 28px; }
  .values__title { font-size: 18px; }
  .values__text { font-size: 15px; }
  .imagefilm__play { width: 60px; height: 60px; }
}

/* ----- Leistungen (Mobile) ----- */
@media (max-width: 640px) {
  .services-grid { gap: var(--s-3); }
  .card--service { padding: var(--s-4); }
  .card--service .card__title { font-size: 17px; }
  .card__icon { width: 30px; height: 30px; }
}

/* ----- Team (Mobile) ----- */
@media (max-width: 640px) {
  .team-grid { gap: var(--s-4); }
  .team-card__media { width: clamp(100px, 34vw, 140px); }
  .team-card__name { font-size: 18px; }
}

/* ----- Blog (Mobile) ----- */
@media (max-width: 640px) {
  .blog-grid { gap: var(--s-4); }
  .blog-card__title { font-size: 19px; }
  .blog-card__body { padding: var(--s-3) var(--s-4) var(--s-4); }
}

/* ----- Kontakt (Mobile) ----- */
@media (max-width: 640px) {
  .kontakt__inner { gap: var(--s-5); }
  .kontakt__lead { font-size: 16px; margin-bottom: var(--s-4); }
  .kontakt__data {
    background: var(--c-white);
    border-radius: var(--r-card);
    padding: var(--s-4);
    border: 1px solid color-mix(in srgb, var(--c-darkgreen) 10%, transparent);
    margin-bottom: var(--s-3);
  }
  .kontakt__row {
    grid-template-columns: 1fr;
    gap: var(--s-1);
    padding-bottom: var(--s-3);
    border-bottom: 1px solid color-mix(in srgb, var(--c-darkgreen) 8%, transparent);
  }
  .kontakt__row:last-child { padding-bottom: 0; border-bottom: 0; }
  .kontakt__row dt {
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
  }
  .kontakt__form {
    padding: var(--s-4);
    gap: var(--s-3);
  }
  .kontakt__form .field__control {
    padding: 14px 14px;
    font-size: 16px; /* iOS auto-zoom-Schutz */
  }
  .kontakt__submit {
    width: 100%;
    justify-content: center;
    padding: 16px 24px;
    font-size: 16px;
  }
  .kontakt__map {
    padding: var(--s-4);
    min-height: 96px;
    font-size: 15px;
  }
}

/* ----- Abschlussbild (Mobile) ----- */
@media (max-width: 640px) {
  .closing__inner { padding-top: var(--s-7); padding-bottom: var(--s-7); }
  .closing__claim { font-size: 20px; }
}

/* ----- Showcase-Divider (Mobile) ----- */
@media (max-width: 640px) {
  .showcase-divider {
    padding: var(--s-4) var(--gutter);
  }
}

/* ----- Showcase (Mobile) ----- */
@media (max-width: 640px) {
  .showcase { padding-top: var(--s-6); padding-bottom: var(--s-6); }
  .showcase__intro { margin-bottom: var(--s-5); }
  .showcase-grid { gap: var(--s-3); }
  .showcase-block { padding: var(--s-4); gap: var(--s-2); }
  .showcase-block__title { font-size: 20px; }

  /* Palette: 4-spaltig statt 2-spaltig — kompakter */
  .palette { grid-template-columns: repeat(4, 1fr); gap: var(--s-2); }
  .palette__chip { height: 22px; }
  .palette__meta { font-size: 12px; }

  /* Type-Skala: vertikal stapeln */
  .type-scale__row {
    grid-template-columns: 1fr;
    gap: var(--s-1);
    padding-bottom: var(--s-2);
  }
  .type-scale__label { order: 2; }
  .type-scale__sample { order: 1; word-break: break-word; }
  .type-scale__sample.t-display { font-size: 40px; line-height: 1.05; }
  .type-scale__sample.t-h1 { font-size: 32px; }
  .type-scale__sample.t-h2 { font-size: 24px; }

  .weight-list { font-size: 15px; }

  /* State-Table: vertikal stapeln (Header weg, Row als Cluster) */
  .state-table__head { display: none; }
  .state-table__row {
    grid-template-columns: 1fr;
    gap: var(--s-2);
    padding: var(--s-3);
    background: var(--c-white);
    border-radius: var(--r-card);
    border: 1px solid color-mix(in srgb, var(--c-darkgreen) 10%, transparent);
  }
  .state-table__label {
    grid-column: 1 / -1;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: color-mix(in srgb, var(--c-darkgreen) 60%, transparent);
    margin-bottom: var(--s-1);
  }
  .state-table__row .btn {
    justify-content: flex-start;
    padding: 10px 16px;
    font-size: 14px;
  }

  /* Form-Demo: 1-spaltig */
  .form-demo { grid-template-columns: 1fr; gap: var(--s-2); }

  /* Logo-Grid: 3-spaltig statt 2-spaltig */
  .logo-grid { grid-template-columns: repeat(3, 1fr); }
  .logo-cell { padding: var(--s-2); }
  .logo-cell img { max-width: 85%; max-height: 75%; }
}

/* ----- Footer (Mobile) ----- */
@media (max-width: 640px) {
  .site-footer__inner {
    gap: var(--s-5);
    padding-top: var(--s-6);
    padding-bottom: var(--s-4);
  }
  .site-footer__brand { gap: var(--s-2); }
  .site-footer__logo { width: 120px; }
  .site-footer__tag { font-size: 14px; }
  .site-footer__heading { font-size: 12px; margin-bottom: var(--s-1); }
  .site-footer__col p { font-size: 14px; }
  .site-footer__actions .btn { flex: 1; justify-content: center; }
  .site-footer__copy-inner {
    flex-direction: column;
    gap: var(--s-1);
    padding-top: var(--s-3);
    padding-bottom: var(--s-3);
    font-size: 12px;
  }
}

/* Tablet-Tweaks (641–767) — kompakter Übergangsbereich */
@media (min-width: 641px) and (max-width: 767px) {
  .palette { grid-template-columns: repeat(4, 1fr); }
  .logo-grid { grid-template-columns: repeat(3, 1fr); }
}

/* ----- Tablet-Portrait (Über uns) ----- */
@media (min-width: 641px) and (max-width: 959px) {
  .ueber-uns__inner {
    grid-template-columns: 1fr;
    gap: var(--s-6);
  }
}
