@import url('https://fonts.googleapis.com/css2?family=Inter+Tight:ital,wght@0,400;0,500;0,600;0,700;0,800;0,900;1,500;1,700&family=Archivo:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=Spline+Sans+Mono:wght@400;500&display=swap');
/* Limes Heiztechnik — kompiliertes CSS (Build) */

/* ===== tokens/fonts.css ===== */
/* ============================================================
   Limes Heiztechnik — Fonts
   Brand: Inter Tight (headlines/marke) + Archivo (body/UI).
   Both free on Google Fonts. Hosted by Google; for fully
   offline use, self-host the .woff2 and swap to @font-face.
   ============================================================ */

/* ===== tokens/colors.css ===== */
/* ============================================================
   Limes Heiztechnik — Color Tokens
   "Solide & Sonnig." Max 2 brand colors per application.
   Sun is an accent only — never a large background, never text
   on light. Navy anchors everything.
   ============================================================ */

:root {
  /* ---- Brand primaries ---- */
  --limes-navy:        #1C3046;  /* Primary structure: logo, headlines, body on light */
  --limes-sun:         #FFD60A;  /* Accent: the sun. Buttons, highlights. Never large bg / text-on-light */
  --limes-cloud:       #F4F9FD;  /* Light page background */
  --limes-white:       #FFFFFF;

  /* ---- Navy ramp (100 → 10 → cloud) ---- */
  --navy-900:          #13212F;  /* navy-deep: deepest sections, footer */
  --navy-800:          #1C3046;  /* = brand navy */
  --navy-700:          #2C4A66;
  --navy-600:          #49596B;  /* 80% */
  --navy-500:          #4F6F8F;  /* steel — secondary text, meta */
  --navy-400:          #8D97A2;  /* 50% — muted text, disabled */
  --navy-300:          #C6CBD0;  /* 25% — borders, dividers strong */
  --navy-200:          #E8EAEC;  /* 10% — subtle fills, track */
  --navy-100:          #F4F9FD;  /* = cloud */

  /* ---- Sun ramp ---- */
  --sun-dark:          #76722E;  /* dark gold — text on pale gold */
  --sun-deep:          #BAA41C;  /* 60% — gold text on white (use sparingly) */
  --sun-500:           #FFD60A;  /* = brand sun */
  --sun-300:           #FFE45F;  /* +35% — hover on sun */
  --sun-200:           #FFF0A9;  /* +65% — highlight fills */
  --sun-100:           #FFF8DA;  /* pale — alert/highlight backgrounds */

  /* ---- Sky (merchandise + cool accent for "Effizienz") ---- */
  --sky-500:           #9EC9E8;
  --sky-300:           #C4DDF0;  /* sky-soft */
  --sky-100:           #E8F2FA;  /* sky-pale — info backgrounds */

  /* ---- Ink ---- */
  --ink:               #11202F;  /* near-black navy for long-form body */

  /* ---- Semantic status (kept within the cool/warm brand world) ---- */
  --success:           #1D6B3E;
  --success-bg:        #E8F5ED;
  --warning:           #8A5A00;
  --warning-bg:        #FFF0A9;
  --danger:            #A02828;
  --danger-bg:         #FDEBED;
  --info:              #2C5F86;
  --info-bg:           #E8F2FA;

  /* ============================================================
     Semantic aliases — reference these in components/UI, not the
     raw scale, so theming stays centralized.
     ============================================================ */

  /* Surfaces */
  --surface-page:      var(--limes-cloud);
  --surface-card:      var(--limes-white);
  --surface-raised:    var(--limes-white);
  --surface-sunken:    var(--navy-200);
  --surface-inverse:   var(--limes-navy);
  --surface-inverse-deep: var(--navy-900);
  --surface-accent:    var(--sun-100);   /* pale gold highlight block */
  --surface-info:      var(--sky-100);

  /* Text */
  --text-strong:       var(--limes-navy);
  --text-body:         var(--ink);
  --text-muted:        var(--navy-500);
  --text-subtle:       var(--navy-400);
  --text-on-navy:      var(--limes-white);
  --text-on-navy-soft: var(--sky-500);
  --text-on-sun:       var(--limes-navy);
  --text-link:         var(--limes-navy);

  /* Borders */
  --border-subtle:     rgba(28, 48, 70, 0.10);
  --border-default:    rgba(28, 48, 70, 0.16);
  --border-strong:     var(--navy-300);
  --border-focus:      var(--limes-navy);

  /* Interactive — primary CTA: Sun (brand), darkens on hover */
  --action-primary-bg:        #FFD60A;
  --action-primary-bg-hover:  #F0C400;
  --action-primary-fg:        var(--limes-navy);

  --action-secondary-bg:       var(--limes-navy);
  --action-secondary-bg-hover: var(--navy-700);
  --action-secondary-fg:       var(--limes-white);

  --focus-ring:        rgba(28, 48, 70, 0.28);
  --focus-ring-sun:    rgba(186, 164, 28, 0.45);
}

/* ===== tokens/typography.css ===== */
/* ============================================================
   Limes Heiztechnik — Typography Tokens
   Inter Tight  → brand, headlines, buttons, key words (500–900)
   Archivo      → body, UI, sublines (400–700)
   Spline Sans Mono → technical specs, codes, meta
   Headlines: negative tracking (-2% to -4%) at large sizes.
   ============================================================ */

:root {
  /* Families */
  --font-display: 'Inter Tight', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --font-body:    'Archivo', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --font-mono:    'Spline Sans Mono', ui-monospace, 'SF Mono', Monaco, monospace;

  /* Weights */
  --fw-regular:   400;  /* @kind font */
  --fw-medium:    500;  /* @kind font */
  --fw-semibold:  600;  /* @kind font */
  --fw-bold:      700;  /* @kind font */
  --fw-extrabold: 800;  /* @kind font */
  --fw-black:     900;  /* @kind font */

  /* Type scale (rem, 16px base) — modular ~1.22 */
  --text-2xs:  0.6875rem;  /* 11px — eyebrow caps, mono meta */
  --text-xs:   0.75rem;    /* 12px */
  --text-sm:   0.8125rem;  /* 13px */
  --text-base: 0.9375rem;  /* 15px — body default */
  --text-md:   1.0625rem;  /* 17px — lead paragraph */
  --text-lg:   1.25rem;    /* 20px — H4 / card title */
  --text-xl:   1.5rem;     /* 24px — H3 */
  --text-2xl:  1.9rem;     /* 30px — H2 */
  --text-3xl:  2.4rem;     /* 38px — H1 small */
  --text-4xl:  3.2rem;     /* 51px — hero */
  --text-5xl:  4.2rem;     /* 67px — display hero */

  /* Line heights */
  --leading-none:    1;
  --leading-tight:   1.08;
  --leading-snug:    1.25;
  --leading-normal:  1.55;
  --leading-relaxed: 1.7;

  /* Letter-spacing */
  --tracking-display: -0.035em;  /* big headlines */
  --tracking-tight:   -0.02em;
  --tracking-normal:  0;
  --tracking-wide:    0.08em;
  --tracking-caps:    0.18em;    /* eyebrow / kicker uppercase */
}

/* ===== tokens/spacing.css ===== */
/* ============================================================
   Limes Heiztechnik — Spacing & Layout Tokens
   4px base grid.
   ============================================================ */

:root {
  --space-0:   0;
  --space-1:   0.25rem;  /* 4 */
  --space-2:   0.5rem;   /* 8 */
  --space-3:   0.75rem;  /* 12 */
  --space-4:   1rem;     /* 16 */
  --space-5:   1.5rem;   /* 24 */
  --space-6:   2rem;     /* 32 */
  --space-7:   2.5rem;   /* 40 */
  --space-8:   3rem;     /* 48 */
  --space-9:   4rem;     /* 64 */
  --space-10:  5rem;     /* 80 */
  --space-12:  6rem;     /* 96 */
  --space-16:  8rem;     /* 128 */

  /* Layout */
  --container-max:   1200px;
  --container-prose: 680px;
  --gutter:          5vw;
  --section-y:       var(--space-10);  /* vertical rhythm between page sections */
}

/* ===== tokens/radius.css ===== */
/* ============================================================
   Limes Heiztechnik — Radius, Shadow & Border Tokens
   Soft, confident rounding. Shadows are navy-tinted and diffuse
   ("warm light"), never hard grey drop-shadows.
   ============================================================ */

:root {
  /* Corner radii */
  --radius-xs:   4px;    /* inputs, chips, small controls */
  --radius-sm:   8px;    /* buttons, badges */
  --radius-md:   12px;   /* cards */
  --radius-lg:   16px;   /* feature cards, dialogs */
  --radius-xl:   24px;   /* hero panels, large surfaces */
  --radius-pill: 999px;  /* tags, status pills */

  /* Shadows — navy-tinted, soft, downward */
  --shadow-xs:  0 1px 2px rgba(28, 48, 70, 0.06);
  --shadow-sm:  0 4px 14px -8px rgba(28, 48, 70, 0.20);
  --shadow-md:  0 8px 24px -14px rgba(28, 48, 70, 0.22);
  --shadow-lg:  0 18px 44px -20px rgba(28, 48, 70, 0.32);
  --shadow-xl:  0 28px 64px -28px rgba(28, 48, 70, 0.38);

  /* Focus shadow */
  --shadow-focus: 0 0 0 3px var(--focus-ring);

  /* Border widths */
  --border-1: 1px;
  --border-2: 1.5px;

  /* Motion — calm, no bounce. Confident ease. */
  --ease-out:   cubic-bezier(0.22, 0.61, 0.36, 1);   /* @kind other */
  --ease-in-out:cubic-bezier(0.45, 0, 0.2, 1);        /* @kind other */
  --dur-fast:   120ms;  /* @kind other */
  --dur-base:   200ms;  /* @kind other */
  --dur-slow:   320ms;  /* @kind other */
}

/* ===== base.css ===== */
/* ============================================================
   Limes Heiztechnik — Base layer
   Minimal global defaults wired to tokens. Imported by styles.css
   after tokens so the cascade resolves.
   ============================================================ */

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

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

body {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: var(--leading-normal);
  color: var(--text-body);
  background: var(--surface-page);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

h1, h2, h3, h4, h5 {
  font-family: var(--font-display);
  color: var(--text-strong);
  letter-spacing: var(--tracking-tight);
  line-height: var(--leading-tight);
  margin: 0;
}

p { margin: 0; text-wrap: pretty; }

a { color: var(--text-link); text-decoration-thickness: 1px; text-underline-offset: 2px; }

/* Shared helpers used across cards/specimens */
.limes-eyebrow {
  font-family: var(--font-display);
  font-weight: var(--fw-extrabold);
  font-size: var(--text-2xs);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--text-muted);
}

.limes-mono { font-family: var(--font-mono); }

::selection { background: var(--sun-200); color: var(--limes-navy); }

/* ===== ui_kits/website/site.css ===== */
/* Limes Heiztechnik - Marketing site (UI kit) layout
   Clean & airy direction: white + Sky-pale surfaces, navy as the structural
   colour and CTA colour. Sun stays in the logo only. */

.site { background: #fff; color: var(--text-body); }
.container { max-width: 1180px; margin: 0 auto; padding-inline: clamp(20px, 5vw, 60px); }
.section { padding-block: clamp(72px, 10vw, 132px); }

/* soft sky band variant */
.section--sky { background: var(--sky-100); }

.eyebrow {
  font-family: var(--font-display); font-weight: 700; font-size: var(--text-2xs);
  letter-spacing: var(--tracking-caps); text-transform: uppercase; color: var(--navy-500);
}
.h2 { font-family: var(--font-display); font-weight: 800; font-size: clamp(1.8rem, 3.6vw, 2.6rem);
  letter-spacing: -0.03em; line-height: 1.06; color: var(--text-strong); }
.lead { font-size: var(--text-md); line-height: var(--leading-relaxed); color: var(--text-muted); max-width: 54ch; }
.section-head { display: flex; flex-direction: column; gap: 16px; margin-bottom: 56px; max-width: 58ch; }

/* ---- Header (white band, navy logo) ---- */
.hdr { position: sticky; top: 0; z-index: 50; background: rgba(255,255,255,.88);
  backdrop-filter: saturate(140%) blur(14px); border-bottom: 1px solid var(--border-subtle);
  transition: box-shadow var(--dur-base) var(--ease-out), border-color var(--dur-base) var(--ease-out); }
.hdr--scrolled { box-shadow: 0 6px 24px -16px rgba(28,48,70,.45); border-bottom-color: transparent; }
.hdr__bar { display: flex; align-items: center; gap: 24px; height: 100px; }
.hdr__logo { display: flex; align-items: center; }
.hdr__logo img { height: 62px; display: block; }
.hdr__nav { display: flex; gap: 36px; margin-left: auto; }
.hdr__nav a { font-family: var(--font-display); font-weight: 600; font-size: var(--text-md);
  color: var(--text-strong); text-decoration: none; letter-spacing: -0.01em; }
.hdr__nav a:hover { color: var(--navy-500); }
.hdr__actions { display: flex; align-items: center; gap: 16px; }
.hdr__actions .lime-btn { font-size: var(--text-md); }
.hdr__phone { display: inline-flex; align-items: center; gap: 7px; font-family: var(--font-mono);
  font-size: var(--text-sm); color: var(--text-strong); text-decoration: none; white-space: nowrap; }
.hdr__phone:hover { color: var(--navy-500); }
.hdr__burger { display: none; background: none; border: 0; cursor: pointer; color: var(--limes-navy); margin-left: auto; }

/* ---- Mobile-Menü ---- */
.hdr__mobile { display: none; }
.hdr__scrim { display: none; }
@media (max-width: 640px) {
  .hdr { position: sticky; top: 0; z-index: 50; background: #fff; }
  .hdr__mobile {
    display: flex; flex-direction: column; gap: 8px;
    position: absolute; left: 0; right: 0; top: 100%;
    background: #fff; border-bottom: 1px solid var(--border-subtle);
    box-shadow: var(--shadow-lg);
    padding: 16px clamp(20px, 5vw, 60px) 24px;
    transform: translateY(-12px); opacity: 0; pointer-events: none;
    transition: transform var(--dur-base) var(--ease-out), opacity var(--dur-base) var(--ease-out);
    z-index: 60;
  }
  .hdr__mobile.is-open { transform: translateY(0); opacity: 1; pointer-events: auto; }
  .hdr__mobile-nav { display: flex; flex-direction: column; }
  .hdr__mobile-nav a {
    display: flex; align-items: center; justify-content: space-between;
    font-family: var(--font-display); font-weight: 700; font-size: var(--text-lg);
    color: var(--text-strong); text-decoration: none;
    padding: 16px 0; border-bottom: 1px solid var(--border-subtle); min-height: 44px;
  }
  .hdr__mobile-nav a svg { color: var(--sky-500); }
  .hdr__mobile .lime-btn { margin-top: 16px; width: 100%; justify-content: center; }
  .hdr__scrim {
    display: block; position: fixed; inset: 0; top: 0; z-index: 40;
    background: rgba(20,32,49,0.4); border: 0; cursor: pointer;
  }
}

/* ---- Hero (light & airy) ---- */
.hero { background: #fff; position: relative; overflow: hidden; }
.hero::before { content: ""; position: absolute; top: -260px; right: -160px; width: 720px; height: 720px;
  background: radial-gradient(circle at center, var(--sky-100), transparent 68%); border-radius: 50%; }
.hero__grid { display: grid; grid-template-columns: 1.02fr 0.98fr; gap: 64px; align-items: center;
  padding-block: clamp(64px, 9vw, 128px); position: relative; }
.hero h1 { font-family: var(--font-display); font-weight: 800; color: var(--text-strong);
  font-size: clamp(2.6rem, 5.2vw, 4rem); letter-spacing: -0.04em; line-height: 1; }
.hero__sub { font-size: var(--text-md); color: var(--text-muted); line-height: var(--leading-relaxed); max-width: 44ch; margin-top: 20px; }
.hero__cta { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 32px; }
.hero__trust { display: flex; gap: 24px; flex-wrap: wrap; margin-top: 40px; }
.hero__trust .t { display: flex; align-items: center; gap: 9px; font-size: var(--text-sm); color: var(--text-muted); font-weight: 500; }
.hero__trust .t svg { color: var(--navy-500); }
.hero__media { position: relative; }

/* photo placeholder */
.photo { position: relative; border-radius: var(--radius-xl); overflow: hidden;
  background: linear-gradient(150deg, var(--sky-300), var(--sky-100)); }
.photo--hero { aspect-ratio: 4/5; box-shadow: var(--shadow-lg); }
.photo__label { position: absolute; inset: auto 0 0 0; padding: 14px 16px; display: flex; align-items: center; gap: 8px;
  font-family: var(--font-mono); font-size: var(--text-xs); color: var(--navy-600);
  background: linear-gradient(transparent, rgba(255,255,255,.7)); }
.photo__icon { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; color: var(--navy-400); opacity: .5; }
.photo__img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; }

/* ---- Proof strip ---- */
.proof { background: #fff; }
.proof__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px; padding-block: 8px clamp(56px, 7vw, 80px); }
.proof__grid > div { border-top: 2px solid var(--sky-500); padding-top: 18px; }

/* ---- Services ---- */
.svc-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.svc { display: flex; flex-direction: column; gap: 14px; height: 100%; }
.svc__ic { width: 52px; height: 52px; border-radius: var(--radius-md); background: var(--sky-100);
  color: var(--limes-navy); display: flex; align-items: center; justify-content: center; }
.svc__title { margin: 0; font-family: var(--font-display); font-weight: 800; font-size: var(--text-lg); color: var(--text-strong); letter-spacing: -0.01em; }
.svc__desc { font-size: var(--text-sm); color: var(--text-muted); line-height: var(--leading-normal); flex: 1; }
.svc__link { display: inline-flex; align-items: center; gap: 6px; font-family: var(--font-display);
  font-weight: 700; font-size: var(--text-sm); color: var(--limes-navy); text-decoration: none; }
.svc__link:hover { gap: 10px; }

/* ---- Process ---- */
.proc-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 28px; }
.proc__step { display: flex; flex-direction: column; gap: 12px; }
.proc__num { font-family: var(--font-display); font-weight: 800; font-size: 2.4rem; color: var(--navy-300); line-height: 1; letter-spacing: -0.02em; }
.proc__t { margin: 0; font-family: var(--font-display); font-weight: 800; font-size: var(--text-lg); color: var(--text-strong); }
.proc__d { font-size: var(--text-sm); color: var(--text-muted); line-height: var(--leading-normal); }
.proc__rule { height: 2px; background: var(--sky-300); width: 28px; border-radius: 2px; }

/* ---- Förder band ---- */
.foerder__inner { display: grid; grid-template-columns: 1.3fr 1fr; gap: 48px; align-items: center; }
.foerder__big { font-family: var(--font-display); font-weight: 800; font-size: clamp(2rem,4vw,3rem);
  letter-spacing: -0.03em; color: var(--limes-navy); line-height: 1.02; }

/* ---- FAQ + Contact ---- */
.faq-wrap { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: 56px; align-items: start; }
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: start; }
.contact-actions { display: flex; flex-direction: column; gap: 14px; margin-top: 28px; max-width: 440px; }
.contact-action { display: flex; align-items: center; gap: 14px; padding: 15px 20px;
  background: var(--surface-card); color: var(--text-strong);
  border: 1px solid var(--border-subtle); border-radius: var(--radius-md);
  font-family: var(--font-display); font-weight: 600; font-size: var(--text-base); letter-spacing: -.01em;
  text-decoration: none;
  transition: background var(--dur-base) var(--ease-out), border-color var(--dur-base) var(--ease-out); }
.contact-action:hover { background: var(--sky-100); border-color: var(--border-strong); }
.contact-action i, .contact-action svg { width: 20px; height: 20px; flex-shrink: 0; color: var(--limes-navy); }
.contact-info { display: flex; flex-direction: column; gap: 20px; }
.contact-info__row { display: flex; gap: 16px; align-items: flex-start; }
.contact-info__ic { width: 46px; height: 46px; border-radius: var(--radius-md); flex-shrink: 0;
  background: var(--sky-100); color: var(--limes-navy); display: flex; align-items: center; justify-content: center; }
.contact-info__k { font-family: var(--font-display); font-weight: 700; font-size: var(--text-sm); color: var(--text-strong); }
.contact-info__v { font-family: var(--font-mono); font-size: var(--text-sm); color: var(--text-muted); }
.contact-card { background: var(--sky-100); border: 1px solid var(--border-subtle); border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm); padding: clamp(24px, 3vw, 36px); }
.form-consent { font-size: var(--text-xs); color: var(--text-muted); line-height: 1.5; margin-top: 10px; }
.form-consent a { color: var(--limes-navy); }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.form-grid .full { grid-column: 1 / -1; }

/* ---- Footer ---- */
.ftr { background: var(--navy-900); color: var(--sky-500); }
.ftr__grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 32px; padding-block: 64px; }
.ftr__grid img { height: 56px; }
.ftr__about { font-size: var(--text-sm); line-height: var(--leading-normal); color: var(--navy-400); max-width: 34ch; margin-top: 18px; }
.ftr__col h4 { font-family: var(--font-display); font-weight: 800; font-size: var(--text-2xs); letter-spacing: var(--tracking-caps);
  text-transform: uppercase; color: #fff; margin-bottom: 16px; }
.ftr__col a { display: block; color: var(--sky-500); text-decoration: none; font-size: var(--text-sm); margin-bottom: 10px; }
.ftr__col a:hover { color: #fff; }
.ftr__bar { border-top: 1px solid rgba(255,255,255,.1); padding-block: 22px; display: flex; justify-content: space-between;
  gap: 16px; flex-wrap: wrap; font-size: var(--text-xs); color: var(--navy-400); }

/* ---- Zitat band (navy) ---- */
.zitat { background: var(--limes-navy); }
.zitat__inner { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: 56px; align-items: center; }
.zitat__media { max-width: 420px; }
.zitat__quote { font-family: var(--font-display); font-weight: 800; letter-spacing: -.02em; line-height: 1.18;
  font-size: clamp(1.6rem, 3.2vw, 2.3rem); color: #fff; margin: 0; }
.zitat__by { font-size: var(--text-sm); color: var(--sky-500); margin-top: 18px; font-weight: 500; }

/* ---- Werte grid ---- */
.werte-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }

/* ---- generic split (text + media) ---- */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; }
.split__media { max-width: 520px; width: 100%; }
.region-links { display: flex; flex-direction: column; gap: 10px; margin-top: 22px; }
.region-links a { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-display);
  font-weight: 600; font-size: var(--text-base); color: var(--limes-navy); text-decoration: none; width: max-content; }
.region-links a:hover { color: var(--navy-500); }
.region-links a svg { color: var(--sun-deep); }

/* ---- Förderung band (navy) ---- */
.foerder-band { background: var(--limes-navy); }
.foerder-band__inner { display: grid; grid-template-columns: 1.4fr auto; gap: 40px; align-items: center; }

/* ---- Footer partners ---- */
.ftr__partners { display: flex; flex-direction: column; gap: 16px; align-items: center; text-align: center;
  padding-block: 40px; border-bottom: 1px solid rgba(255,255,255,.1); }
.ftr__partners-label { font-family: var(--font-display); font-weight: 700; font-size: var(--text-2xs);
  letter-spacing: var(--tracking-caps); text-transform: uppercase; color: var(--navy-400); }
.ftr__partners-row { display: flex; flex-wrap: wrap; gap: 14px 36px; justify-content: center; align-items: center; }
.ftr__partner { font-family: var(--font-display); font-weight: 800; font-size: var(--text-lg); color: var(--sky-500); letter-spacing: -.01em; }

/* ---- Subpages (Über Uns / Jobs) ---- */
.page-hero { background: var(--sky-100); padding-block: clamp(48px, 7vw, 96px); }
.page-hero__h1 { font-family: var(--font-display); font-weight: 800; letter-spacing: -.035em; line-height: 1.02;
  font-size: clamp(2.2rem, 5vw, 3.4rem); color: var(--text-strong); margin: 14px 0 0; max-width: 18ch; }
.werte-grid--4 { grid-template-columns: repeat(4, 1fr); }
.partner-chip { font-family: var(--font-display); font-weight: 800; font-size: var(--text-lg);
  color: var(--navy-500); letter-spacing: -.01em; }
.jobs-list { display: flex; flex-direction: column; gap: 16px; }
.job-row { display: flex; align-items: center; justify-content: space-between; gap: 20px; }
.job-row__cta { display: inline-flex; align-items: center; gap: 7px; flex-shrink: 0; font-family: var(--font-display);
  font-weight: 700; font-size: var(--text-base); color: var(--limes-navy); }

/* ---- Markentechnik-Strip (durchlaufende Logo-Marquee) ---- */
.marken { background: #fff; border-bottom: 1px solid var(--border-subtle); padding-block: clamp(40px, 6vw, 72px); }
.marken__inner { display: flex; flex-direction: column; align-items: center; text-align: center; }
.marken__inner--cta { margin-top: clamp(32px, 4vw, 44px); }
.marken__label { font-family: var(--font-display); font-weight: 700; font-size: var(--text-2xs);
  letter-spacing: var(--tracking-caps); text-transform: uppercase; color: var(--text-muted); }
.marken__marquee { margin-top: clamp(28px, 4vw, 40px); width: 100%; overflow: hidden;
  -webkit-mask-image: linear-gradient(to right, transparent, #000 7%, #000 93%, transparent);
  mask-image: linear-gradient(to right, transparent, #000 7%, #000 93%, transparent); }
.marken__track { display: flex; align-items: center; gap: clamp(40px, 6vw, 84px); width: max-content;
  animation: marken-scroll 34s linear infinite; }
.marken__marquee:hover .marken__track { animation-play-state: paused; }
.marken__logo { flex: none; white-space: nowrap; font-family: var(--font-display); font-weight: 800;
  letter-spacing: -.02em; font-size: clamp(20px, 2.4vw, 30px); color: var(--limes-navy); opacity: .5;
  transition: opacity var(--dur-base) var(--ease-out); }
.marken__logo:hover { opacity: 1; }
.marken__logo--img { box-sizing: border-box; width: clamp(108px, 12vw, 146px); height: clamp(28px, 3vw, 36px);
  object-fit: contain; object-position: center; opacity: .6; filter: grayscale(1);
  transition: opacity var(--dur-base) var(--ease-out), filter var(--dur-base) var(--ease-out); }
.marken__logo--img:hover { opacity: 1; filter: grayscale(0); }
.marken__logo--box { height: clamp(40px, 4.6vw, 52px); border-radius: 6px; opacity: .85; filter: none; }
.marken__logo--box:hover { opacity: 1; filter: none; }
.marken__static { display: flex; flex-wrap: wrap; justify-content: center; align-items: center;
  gap: clamp(28px, 5vw, 56px); }
@keyframes marken-scroll { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@media (prefers-reduced-motion: reduce) {
  .marken__track { animation: none; flex-wrap: wrap; justify-content: center; width: 100%; }
}
.ftr__bar a { color: var(--sky-500); text-decoration: none; }
.ftr__bar a:hover { color: #fff; }
.ftr__contact { display: flex; flex-direction: column; gap: 10px; margin-top: 18px; }
.ftr__contact a { display: inline-flex; align-items: center; gap: 9px; color: var(--sky-500);
  text-decoration: none; font-family: var(--font-mono); font-size: var(--text-sm); }
.ftr__contact a:hover { color: #fff; }

/* ---- responsive ---- */
@media (max-width: 980px) {
  .hero__grid { grid-template-columns: 1fr; gap: 40px; }
  .hero__media { max-width: 420px; }
  .werte-grid, .werte-grid--4 { grid-template-columns: 1fr 1fr; }
  .proc-grid { grid-template-columns: repeat(2, 1fr); }
  .zitat__inner, .split, .foerder-band__inner { grid-template-columns: 1fr; gap: 32px; }
  .zitat__media, .split__media { max-width: 100%; order: -1; }
  .faq-wrap, .contact-grid, .ftr__grid { grid-template-columns: 1fr; }
  .ftr__grid { gap: 28px; }
}
@media (max-width: 640px) {
  .hdr__nav, .hdr__phone { display: none; }
  .hdr__burger { display: inline-flex; }
  .proc-grid, .form-grid, .werte-grid, .werte-grid--4 { grid-template-columns: 1fr; }
  .job-row { flex-direction: column; align-items: flex-start; gap: 14px; }
}
