/* =================================================================
   Mountain Bike Movement – Stylesheet
   Statischer Neubau · ohne Framework · ohne externe Abhängigkeiten
   -----------------------------------------------------------------
   Aufbau:
   1.  Design-Tokens (Farben, Schriften, Abstände)
   2.  Reset & Basis
   3.  Typografie
   4.  Layout-Helfer (Container, Sections)
   5.  Buttons
   6.  Header & Navigation
   7.  Mobile-Menü
   8.  Hero
   9.  Intro / Text-Bild-Bereiche
   10. Karten-Raster (Produktbereiche, Interessiert)
   11. Galerie & Lightbox
   12. Service-Detailseiten
   13. Über uns / Inhaltsseiten
   14. Partner
   15. Kontakt / Formular
   16. Footer
   17. Utilities & Scroll-Animationen
   18. Responsive
   ================================================================= */

/* ---------- 1. DESIGN-TOKENS ---------- */
:root {
  /* Markenfarben – DUNKLES THEME (schwarzer Hintergrund, helle Schrift) */
  --c-black:    #0c0c0d;
  --c-dark:     #15181d;   /* dunkle Karten / Footer / Akzentflächen */
  --c-ink:      #1b252f;   /* dunkler Text NUR auf hellen Flächen (Logo-Kacheln, Dropdowns) */
  --c-gold:     #e3b53f;   /* Akzent */
  --c-gold-600: #d7a93a;   /* Akzent Hover (auf Dunkel etwas heller) */
  --c-white:    #ffffff;
  --c-bg:       #0c0d0f;   /* Seiten-Hintergrund (schwarz) */
  --c-text:     #dce1e6;   /* Fließtext (hell) */
  --c-paper:    #131519;   /* abgesetzter Sektions-Hintergrund (dunkel) */
  --c-paper-2:  #1a1e24;   /* dunkle Karten */
  --c-muted:    #9aa3ad;   /* sekundärer Text (hell-grau) */
  --c-line:     rgba(255,255,255,.12);  /* Trennlinien */
  --c-dark-line:rgba(255,255,255,.12);

  /* Schriften – Markenschrift zuerst, danach systemeigene Fallbacks
     (keine externen Requests). Zum exakten Brand-Look die woff2-Dateien
     selbst hosten – siehe @font-face-Block am Dateiende. */
  --font-body: 'Open Sans', system-ui, -apple-system, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
  --font-head: 'Poppins', system-ui, -apple-system, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
  --font-hero: 'Merriweather Sans', 'Poppins', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;

  /* Layout */
  --maxw: 1200px;
  --maxw-narrow: 820px;
  --radius: 14px;
  --radius-sm: 8px;
  --shadow-sm: 0 2px 10px rgba(16,22,28,.06);
  --shadow:    0 10px 30px rgba(16,22,28,.10);
  --shadow-lg: 0 24px 60px rgba(16,22,28,.18);

  /* Abstände */
  --gap: clamp(1rem, 2.4vw, 1.75rem);
  --section-y: clamp(3.5rem, 7vw, 6.5rem);
  --header-h: 84px;

  --ease: cubic-bezier(.2,.7,.2,1);
}

/* ---------- 2. RESET & BASIS ---------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--font-body);
  font-size: 1rem;
  line-height: 1.7;
  color: var(--c-text);
  background: var(--c-bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img, picture, svg, video { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; padding: 0; }
button { font: inherit; color: inherit; cursor: pointer; background: none; border: 0; }
:focus-visible { outline: 3px solid var(--c-gold); outline-offset: 2px; border-radius: 4px; }

/* ---------- 3. TYPOGRAFIE ---------- */
h1, h2, h3, h4, h5, h6 { font-family: var(--font-head); line-height: 1.2; font-weight: 600; color: #fff; }
h1 { font-size: clamp(2.2rem, 5.2vw, 3.6rem); font-weight: 700; }
h2 { font-size: clamp(1.7rem, 3.6vw, 2.5rem); }
h3 { font-size: clamp(1.3rem, 2.4vw, 1.6rem); }
h4 { font-size: 1.15rem; }
p  { color: var(--c-text); }
p + p { margin-top: 1rem; }
strong { font-weight: 700; }
a:not(.btn):hover { color: var(--c-gold-600); }

.eyebrow {
  display: inline-block;
  font-family: var(--font-head);
  font-weight: 600;
  font-size: .82rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--c-gold-600);
  margin-bottom: .9rem;
}
.section-title { position: relative; }
.lead { font-size: clamp(1.05rem, 1.6vw, 1.25rem); color: var(--c-muted); }

/* Goldener Akzentstrich unter Überschriften */
.accent-line::after {
  content: ""; display: block; width: 58px; height: 4px;
  background: var(--c-gold); border-radius: 4px; margin-top: 1rem;
}
.text-center .accent-line::after,
.accent-line.is-center::after { margin-left: auto; margin-right: auto; }

/* ---------- 4. LAYOUT-HELFER ---------- */
.container { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: clamp(1.1rem, 4vw, 2.2rem); }
.container.narrow { max-width: var(--maxw-narrow); }
.section { padding-block: var(--section-y); }
.section.tight { padding-block: clamp(2.5rem, 4.5vw, 4rem); }
.section--paper { background: var(--c-paper); }
.section--dark { background: var(--c-dark); color: #eef1f4; }
.section--dark h1, .section--dark h2, .section--dark h3, .section--dark h4 { color: #fff; }
.section--dark p { color: #c4cbd3; }
.text-center { text-align: center; }
.stack > * + * { margin-top: 1rem; }
.section-head { max-width: 720px; margin-bottom: clamp(2rem, 4vw, 3rem); }
.section-head.is-center { margin-inline: auto; text-align: center; }

/* ---------- 5. BUTTONS ---------- */
.btn {
  --btn-bg: var(--c-gold);
  --btn-fg: var(--c-ink);
  display: inline-flex; align-items: center; gap: .6rem;
  font-family: var(--font-head); font-weight: 600; font-size: .98rem;
  line-height: 1; letter-spacing: .01em;
  padding: .95rem 1.7rem; border-radius: 50px;
  background: var(--btn-bg); color: var(--btn-fg);
  border: 2px solid var(--btn-bg);
  transition: transform .25s var(--ease), background .25s var(--ease), border-color .25s, color .25s, box-shadow .25s;
  will-change: transform;
}
.btn:hover { background: var(--c-gold-600); border-color: var(--c-gold-600); color: var(--c-ink); transform: translateY(-2px); box-shadow: 0 10px 24px rgba(207,159,41,.35); }
.btn .btn-arrow { transition: transform .25s var(--ease); }
.btn:hover .btn-arrow { transform: translateX(4px); }
.btn--outline { --btn-bg: transparent; --btn-fg: #fff; border-color: rgba(255,255,255,.45); }
.btn--outline:hover { background: #fff; border-color: #fff; color: var(--c-ink); box-shadow: none; }
.btn--light { --btn-bg: transparent; --btn-fg: #fff; border-color: rgba(255,255,255,.7); }
.btn--light:hover { background: #fff; border-color:#fff; color: var(--c-ink); box-shadow: none; }
.btn--ghost { --btn-bg: transparent; --btn-fg: var(--c-gold-600); border-color: transparent; padding-inline: .3rem; }
.btn--ghost:hover { background: transparent; color: var(--c-ink); box-shadow: none; transform: none; }
.btn--sm { padding: .6rem 1.1rem; font-size: .85rem; }

/* ---------- 6. HEADER & NAVIGATION ---------- */
.site-header {
  position: fixed; inset: 0 0 auto 0; z-index: 1000;
  height: var(--header-h);
  display: flex; align-items: center;
  background: var(--c-black);
  transition: height .3s var(--ease), background .3s var(--ease), box-shadow .3s;
}
.site-header.is-scrolled { height: 66px; box-shadow: 0 6px 24px rgba(0,0,0,.35); background: rgba(12,12,13,.96); backdrop-filter: blur(8px); }
.site-header .container { display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; max-width: 1320px; }
.brand { display: inline-flex; align-items: center; flex-shrink: 0; }
.brand img { height: 46px; width: auto; transition: height .3s var(--ease); }
.site-header.is-scrolled .brand img { height: 38px; }

.main-nav { display: flex; align-items: center; }
.main-nav > ul { display: flex; align-items: center; gap: clamp(.6rem, 1.4vw, 1.5rem); }
.main-nav a {
  font-family: var(--font-head); font-weight: 500; font-size: .96rem; color: #fff;
  padding: .5rem 0; position: relative; display: inline-flex; align-items: center; gap: .35rem;
  transition: color .2s;
}
.main-nav a::after {
  content: ""; position: absolute; left: 0; bottom: -2px; height: 2px; width: 0;
  background: var(--c-gold); transition: width .25s var(--ease);
}
.main-nav a:hover, .main-nav .current > a { color: var(--c-gold); }
.main-nav a:hover::after, .main-nav .current > a::after { width: 100%; }

/* Dropdown (Leistungen) */
.has-sub { position: relative; }
.has-sub > a .caret { width: 9px; height: 9px; transition: transform .25s; }
.has-sub:hover > a .caret { transform: rotate(180deg); }
.submenu {
  position: absolute; top: 100%; left: 50%; transform: translateX(-50%) translateY(10px);
  min-width: 290px; background: #fff; border-radius: var(--radius-sm);
  box-shadow: var(--shadow-lg); padding: .5rem; opacity: 0; visibility: hidden;
  transition: opacity .22s var(--ease), transform .22s var(--ease);
}
.has-sub:hover .submenu, .has-sub:focus-within .submenu { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(8px); }
.submenu::before { content:""; position:absolute; top:-8px; left:0; right:0; height:8px; }
.submenu a { display: block; color: var(--c-ink); font-size: .92rem; font-weight: 500; padding: .6rem .85rem; border-radius: 6px; }
.submenu a::after { display: none; }
.submenu a:hover { background: var(--c-paper); color: var(--c-gold-600); }

/* Sprache */
.lang-switch { position: relative; }
.lang-current { display: inline-flex; align-items: center; gap: .45rem; color: #fff; font-family: var(--font-head); font-weight: 600; font-size: .85rem; letter-spacing: .04em; padding: .4rem .6rem; border: 1px solid var(--c-dark-line); border-radius: 50px; }
.lang-current:hover { border-color: var(--c-gold); color: var(--c-gold); }
.lang-flag { width: 20px; height: 14px; border-radius: 2px; object-fit: cover; }
.lang-menu {
  position: absolute; top: 100%; right: 0; transform: translateY(10px);
  background: #fff; border-radius: var(--radius-sm); box-shadow: var(--shadow-lg);
  padding: .4rem; min-width: 150px; opacity: 0; visibility: hidden; transition: opacity .2s, transform .2s;
}
/* unsichtbare Brücke über die Lücke, damit das Hover beim Wandern zum Menü nicht abreißt */
.lang-menu::before { content: ""; position: absolute; left: 0; right: 0; top: -12px; height: 14px; }
.lang-switch:hover .lang-menu, .lang-switch:focus-within .lang-menu { opacity: 1; visibility: visible; transform: translateY(6px); }
.lang-menu a { display: flex; align-items: center; gap: .55rem; color: var(--c-ink); font-size: .9rem; font-weight: 500; padding: .55rem .7rem; border-radius: 6px; }
.lang-menu a:hover { background: var(--c-paper); }

.nav-cta { margin-left: .4rem; }

/* Hamburger */
.nav-toggle { display: none; width: 46px; height: 46px; border-radius: 10px; border: 1px solid var(--c-dark-line); align-items: center; justify-content: center; }
.nav-toggle span, .nav-toggle span::before, .nav-toggle span::after {
  content: ""; display: block; width: 22px; height: 2px; background: #fff; border-radius: 2px; transition: transform .3s var(--ease), opacity .2s;
}
.nav-toggle span { position: relative; }
.nav-toggle span::before { position: absolute; top: -7px; left: 0; }
.nav-toggle span::after  { position: absolute; top: 7px; left: 0; }
body.menu-open .nav-toggle span { background: transparent; }
body.menu-open .nav-toggle span::before { transform: translateY(7px) rotate(45deg); }
body.menu-open .nav-toggle span::after  { transform: translateY(-7px) rotate(-45deg); }

/* ---------- 7. MOBILE-MENÜ ---------- */
.mobile-nav {
  position: fixed; inset: 0; z-index: 999;
  background: var(--c-black); padding: calc(var(--header-h) + 1rem) 1.6rem 2.5rem;
  overflow-y: auto; transform: translateX(100%); transition: transform .35s var(--ease);
  display: flex; flex-direction: column;
}
body.menu-open .mobile-nav { transform: translateX(0); }
.mobile-nav ul { display: flex; flex-direction: column; }
.mobile-nav > ul > li { border-bottom: 1px solid var(--c-dark-line); }
.mobile-nav a { display: block; color: #fff; font-family: var(--font-head); font-weight: 500; font-size: 1.15rem; padding: 1rem .2rem; }
.mobile-nav a:hover, .mobile-nav .current > a { color: var(--c-gold); }
.mobile-nav .sub-toggle { display: flex; align-items: center; justify-content: space-between; width: 100%; color:#fff; font-family: var(--font-head); font-size: 1.15rem; padding: 1rem .2rem; }
.mobile-nav .sub-toggle .caret { width: 14px; height: 14px; transition: transform .3s; color: var(--c-gold); }
.mobile-nav .sub-toggle[aria-expanded="true"] .caret { transform: rotate(180deg); }
.mobile-nav .submenu-m { max-height: 0; overflow: hidden; transition: max-height .35s var(--ease); }
.mobile-nav .submenu-m a { font-size: 1rem; font-weight: 400; padding: .6rem .2rem .6rem 1.1rem; color: #c4cbd3; }
.mobile-nav .submenu-m a:hover { color: var(--c-gold); }
.mobile-lang { margin-top: auto; padding-top: 1.6rem; display: flex; gap: .6rem; }
.mobile-lang a { display: inline-flex; align-items: center; gap: .4rem; border: 1px solid var(--c-dark-line); border-radius: 50px; padding: .5rem .9rem; font-size: .9rem; }
.mobile-lang a.active { border-color: var(--c-gold); color: var(--c-gold); }

/* ---------- 8. HERO ---------- */
.hero {
  position: relative; min-height: 92vh; display: flex; align-items: center;
  padding-top: var(--header-h); color: #fff; text-align: center; isolation: isolate;
}
.hero__bg { position: absolute; inset: 0; z-index: -2; }
.hero__bg img { width: 100%; height: 100%; object-fit: cover; }
.hero::after {
  content: ""; position: absolute; inset: 0; z-index: -1;
  background: linear-gradient(180deg, rgba(8,9,11,.55) 0%, rgba(8,9,11,.45) 40%, rgba(8,9,11,.75) 100%);
}
.hero__inner { width: 100%; max-width: 880px; margin-inline: auto; padding-block: 4rem; }
.hero h1 {
  font-family: var(--font-hero); font-weight: 300; color: #fff;
  font-size: clamp(2.6rem, 7vw, 5rem); line-height: 1.15; letter-spacing: .01em;
  text-shadow: 0 4px 30px rgba(0,0,0,.4);
}
.hero h1 strong { font-weight: 700; }
.hero p { color: #eef1f4; font-size: clamp(1.05rem, 2vw, 1.3rem); max-width: 620px; margin-inline: auto; margin-top: 1.2rem; }
.hero .btn { margin-top: 2rem; }
.hero__scroll { position: absolute; bottom: 1.6rem; left: 50%; transform: translateX(-50%); z-index: 1; color: rgba(255,255,255,.8); display: grid; place-items: center; gap: .4rem; font-size: .72rem; letter-spacing: .16em; text-transform: uppercase; }
.hero__scroll .mouse { width: 24px; height: 38px; border: 2px solid rgba(255,255,255,.6); border-radius: 14px; position: relative; }
.hero__scroll .mouse::after { content:""; position: absolute; top: 7px; left: 50%; width: 4px; height: 7px; background:#fff; border-radius: 3px; transform: translateX(-50%); animation: wheel 1.6s infinite; }
@keyframes wheel { 0%{opacity:0;transform:translate(-50%,0)} 30%{opacity:1} 100%{opacity:0;transform:translate(-50%,12px)} }

/* Kleiner Seiten-Hero (Unterseiten) */
.page-hero {
  position: relative; padding-top: calc(var(--header-h) + clamp(3rem,7vw,5.5rem));
  padding-bottom: clamp(3rem,7vw,5.5rem); color: #fff; isolation: isolate; text-align: left;
}
.page-hero::before { content:""; position:absolute; inset:0; z-index:-2; background: var(--c-black); }
.page-hero.has-img::after { content:""; position:absolute; inset:0; z-index:-1; background: linear-gradient(120deg, rgba(8,9,11,.86) 0%, rgba(8,9,11,.55) 100%); }
.page-hero__bg { position:absolute; inset:0; z-index:-2; }
.page-hero__bg img { width:100%; height:100%; object-fit: cover; }
.page-hero h1 { color:#fff; }
.page-hero p { color:#d3d9df; max-width: 640px; margin-top: 1rem; }
.breadcrumb { font-size: .82rem; color: rgba(255,255,255,.6); margin-bottom: 1rem; display: flex; gap: .5rem; flex-wrap: wrap; font-family: var(--font-head); }
.breadcrumb a:hover { color: var(--c-gold); }
.breadcrumb span { color: var(--c-gold); }
.proj-badge { display: inline-block; background: var(--c-gold); color: var(--c-ink); font-family: var(--font-head); font-weight: 600; font-size: .78rem; letter-spacing: .08em; text-transform: uppercase; padding: .35rem .9rem; border-radius: 50px; margin-bottom: 1rem; }

/* ---------- 9. INTRO / TEXT-BILD ---------- */
.intro-grid { display: grid; grid-template-columns: 1.1fr 1fr; gap: clamp(2rem, 5vw, 4.5rem); align-items: center; }
.intro-gallery { display: grid; grid-template-columns: repeat(2, 1fr); gap: .9rem; }
.intro-gallery a { display:block; border-radius: var(--radius-sm); overflow: hidden; box-shadow: var(--shadow-sm); aspect-ratio: 3/4; }
.intro-gallery img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s var(--ease); }
.intro-gallery a:hover img { transform: scale(1.06); }
.intro-gallery a:nth-child(1){ margin-top: 1.6rem; }
.intro-gallery a:nth-child(4){ margin-top: -1.6rem; }

/* Allgemeiner Text-Bild-Block (wechselseitig) */
.media-row { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem,5vw,4rem); align-items: center; }
.media-row.reverse .media-row__media { order: 2; }
.media-row__media img { width: 100%; border-radius: var(--radius); box-shadow: var(--shadow); object-fit: cover; }
.media-row + .media-row { margin-top: clamp(2.5rem, 5vw, 4.5rem); }

/* ---------- 10. KARTEN-RASTER ---------- */
.card-grid { display: grid; gap: clamp(1.1rem, 2.2vw, 1.6rem); grid-template-columns: repeat(3, 1fr); }
.card-grid.cols-2 { grid-template-columns: repeat(2, 1fr); }
.card-grid.cols-4 { grid-template-columns: repeat(4, 1fr); }

/* Bild-Karte (Produktbereiche) */
.card {
  position: relative; display: flex; flex-direction: column; min-height: 340px;
  border-radius: var(--radius); overflow: hidden; color: #fff; isolation: isolate;
  box-shadow: var(--shadow-sm); transition: transform .35s var(--ease), box-shadow .35s;
}
.card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); }
.card__img { position: absolute; inset: 0; z-index: -2; }
.card__img img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s var(--ease); }
.card:hover .card__img img { transform: scale(1.07); }
.card::after { content:""; position:absolute; inset:0; z-index:-1; background: linear-gradient(180deg, rgba(10,11,13,.15) 0%, rgba(10,11,13,.55) 55%, rgba(10,11,13,.92) 100%); }
.card__body { margin-top: auto; padding: 1.5rem 1.5rem 1.6rem; }
.card__body h3 { color: #fff; font-size: 1.3rem; }
.card__body p { color: #dfe3e8; font-size: .95rem; margin-top: .4rem; }
.card__link { display: inline-flex; align-items: center; gap: .45rem; margin-top: 1rem; color: var(--c-gold); font-family: var(--font-head); font-weight: 600; font-size: .92rem; }
.card__link .btn-arrow { transition: transform .25s var(--ease); }
.card:hover .card__link .btn-arrow { transform: translateX(4px); }
.card::before { content:""; position:absolute; left:0; top:0; bottom:0; width:4px; background: var(--c-gold); transform: scaleY(0); transform-origin: bottom; transition: transform .35s var(--ease); z-index: 1; }
.card:hover::before { transform: scaleY(1); }

/* Schlichte Info-Karte (Interessiert) */
.tile {
  display: flex; flex-direction: column; background: var(--c-paper-2); border: 1px solid var(--c-line);
  border-radius: var(--radius); padding: 1.7rem 1.6rem; transition: transform .3s var(--ease), box-shadow .3s, border-color .3s;
}
.tile:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); border-color: rgba(227,181,63,.45); }
.tile__icon { width: 52px; height: 52px; border-radius: 12px; background: rgba(227,181,63,.15); color: var(--c-gold-600); display: grid; place-items: center; margin-bottom: 1.1rem; }
.tile__icon svg { width: 26px; height: 26px; }
.tile h3 { font-size: 1.25rem; }
.tile p { color: var(--c-muted); font-size: .95rem; margin-top: .4rem; flex: 1; }
.tile .card__link { color: var(--c-gold-600); }
.tile:hover .card__link .btn-arrow { transform: translateX(4px); }

/* ---------- 11. GALERIE & LIGHTBOX ---------- */
.gallery { display: grid; grid-template-columns: repeat(4, 1fr); gap: .9rem; }
.gallery a { display:block; border-radius: var(--radius-sm); overflow: hidden; aspect-ratio: 3/4; box-shadow: var(--shadow-sm); }
.gallery img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s var(--ease); }
.gallery a:hover img { transform: scale(1.07); }

.lightbox { position: fixed; inset: 0; z-index: 2000; background: rgba(8,9,11,.92); display: flex; align-items: center; justify-content: center; padding: 4vw; opacity: 0; visibility: hidden; transition: opacity .3s; }
.lightbox.open { opacity: 1; visibility: visible; }
.lightbox img { max-width: 100%; max-height: 86vh; border-radius: 8px; box-shadow: var(--shadow-lg); }
.lightbox__close, .lightbox__nav { position: absolute; color: #fff; width: 54px; height: 54px; display: grid; place-items: center; border-radius: 50%; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.2); transition: background .2s; }
.lightbox__close:hover, .lightbox__nav:hover { background: var(--c-gold); color: var(--c-ink); }
.lightbox__close { top: 4vw; right: 4vw; }
.lightbox__nav.prev { left: 3vw; top: 50%; transform: translateY(-50%); }
.lightbox__nav.next { right: 3vw; top: 50%; transform: translateY(-50%); }

/* ---------- 12. SERVICE-DETAILSEITEN ---------- */
.service-intro { display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(2rem,5vw,4rem); align-items: center; }
.service-intro__media img { border-radius: var(--radius); box-shadow: var(--shadow); width:100%; }
.feature-list { display: grid; gap: .85rem; margin-top: 1.4rem; }
.feature-list li { position: relative; padding-left: 2rem; color: var(--c-text); }
.feature-list li::before {
  content: ""; position: absolute; left: 0; top: .18em; width: 20px; height: 20px;
  background: var(--c-gold); border-radius: 50%;
  -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/></svg>") center/15px no-repeat;
          mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/></svg>") center/15px no-repeat;
}
.related { border-top: 1px solid var(--c-line); }

/* CTA-Band */
.cta-band { background: linear-gradient(120deg, var(--c-black), #1d2127); color: #fff; border-radius: var(--radius); padding: clamp(2rem,4vw,3.2rem); display: flex; flex-wrap: wrap; gap: 1.5rem; align-items: center; justify-content: space-between; }
.cta-band h2 { color: #fff; }
.cta-band p { color: #c4cbd3; margin-top: .4rem; }

/* ---------- 13. ÜBER UNS / INHALT ---------- */
.prose { max-width: var(--maxw-narrow); }
.prose h2 { margin-top: 2.4rem; }
.prose h2:first-child { margin-top: 0; }
.prose p { margin-top: 1rem; color: var(--c-text); }
.prose img { border-radius: var(--radius); box-shadow: var(--shadow); margin-block: 1.8rem; }
.profile { display: grid; grid-template-columns: 280px 1fr; gap: clamp(1.5rem,4vw,3rem); align-items: start; }
.profile__img img { border-radius: var(--radius); box-shadow: var(--shadow); width: 100%; }
.slogans { display: grid; gap: 1rem; }
.slogan { font-family: var(--font-head); font-weight: 600; font-size: clamp(1.2rem,2.4vw,1.7rem); color: #fff; padding-left: 1.4rem; border-left: 4px solid var(--c-gold); }
.statement { font-family: var(--font-head); font-weight: 700; font-size: clamp(1.4rem,3vw,2rem); color: var(--c-gold-600); }

/* ---------- 14. PARTNER ---------- */
.partner-card__media {
  height: 156px; display: grid; place-items: center; padding: .6rem; margin-bottom: 1.2rem;
  background: rgba(255,255,255,.05); border-radius: 10px; overflow: hidden;
}
.partner-card__media img { max-width: 100%; max-height: 100%; width: auto; height: auto; object-fit: contain; transition: transform .4s var(--ease); }
.tile:hover .partner-card__media img { transform: scale(1.04); }
.logo-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.2rem; }
.logo-grid a, .logo-grid div { display: grid; place-items: center; background: #fff; border: 1px solid var(--c-line); border-radius: var(--radius); padding: 1.8rem 1.4rem; min-height: 140px; transition: transform .3s var(--ease), box-shadow .3s; }
.logo-grid a:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.logo-grid img { max-height: 84px; width: auto; object-fit: contain; filter: grayscale(1); opacity: .8; transition: filter .3s, opacity .3s; }
.logo-grid a:hover img { filter: grayscale(0); opacity: 1; }

/* ---------- 15. KONTAKT / FORMULAR ---------- */
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem,5vw,4rem); align-items: start; }
.contact-card { background: var(--c-dark); color: #fff; border: 1px solid var(--c-line); border-radius: var(--radius); padding: clamp(1.8rem,4vw,2.6rem); }
.contact-card h3 { color: #fff; }
.contact-list { display: grid; gap: 1.2rem; margin-top: 1.6rem; }
.contact-list li { display: flex; gap: 1rem; align-items: flex-start; min-width: 0; }
.contact-list li > div { min-width: 0; }
.contact-list .ci { width: 44px; height: 44px; flex-shrink: 0; border-radius: 11px; background: rgba(227,181,63,.18); color: var(--c-gold); display: grid; place-items: center; }
.contact-list .ci svg { width: 22px; height: 22px; }
.contact-list a { color: #fff; overflow-wrap: anywhere; }
.contact-list a:hover { color: var(--c-gold); }
.contact-list small { display:block; color:#aeb6bf; font-size:.8rem; letter-spacing:.04em; text-transform:uppercase; }

.form { display: grid; gap: 1.1rem; }
.form .row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.1rem; }
.field { display: grid; gap: .4rem; }
.field label { font-family: var(--font-head); font-weight: 600; font-size: .88rem; }
.field input, .field textarea {
  width: 100%; padding: .85rem 1rem; border: 1px solid var(--c-line); border-radius: 10px;
  font: inherit; color: #fff; background: rgba(255,255,255,.04); transition: border-color .2s, box-shadow .2s;
}
.field input::placeholder, .field textarea::placeholder { color: #8a929b; }
.field input:focus, .field textarea:focus { outline: none; border-color: var(--c-gold); box-shadow: 0 0 0 3px rgba(227,181,63,.18); background: rgba(255,255,255,.06); }
.field textarea { min-height: 150px; resize: vertical; }
.form .note { font-size: .82rem; color: var(--c-muted); }

/* ---------- 16. FOOTER ---------- */
.site-footer { background: var(--c-dark); color: #c4cbd3; padding-top: clamp(3rem,6vw,4.5rem); }
.footer-top { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1.2fr; gap: 2.5rem; padding-bottom: 2.8rem; border-bottom: 1px solid var(--c-dark-line); }
.footer-brand img { height: 52px; margin-bottom: 1.1rem; }
.footer-brand p { color: #9aa3ad; font-size: .92rem; max-width: 30ch; }
.footer-col h4 { color: #fff; font-size: 1rem; margin-bottom: 1.1rem; letter-spacing: .02em; }
.footer-col ul { display: grid; gap: .6rem; }
.footer-col a { color: #b4bcc5; font-size: .94rem; overflow-wrap: anywhere; }
.footer-col a:hover { color: var(--c-gold); padding-left: 4px; transition: padding .2s, color .2s; }
.footer-social { display: flex; gap: .7rem; margin-top: .4rem; }
.footer-social a { width: 42px; height: 42px; border-radius: 50%; border: 1px solid var(--c-dark-line); display: grid; place-items: center; color: #c4cbd3; transition: background .25s, color .25s, transform .25s, border-color .25s; }
.footer-social a:hover { background: var(--c-gold); color: var(--c-ink); border-color: var(--c-gold); transform: translateY(-3px); }
.footer-social svg { width: 19px; height: 19px; }
.footer-bottom { display: flex; flex-wrap: wrap; gap: 1rem; align-items: center; justify-content: space-between; padding-block: 1.6rem; }
.footer-bottom p { color: #8a929b; font-size: .86rem; }
.footer-bottom a { color: var(--c-gold); }
.footer-legal { display: flex; gap: 1.4rem; }
.footer-legal a { color: #b4bcc5; font-size: .86rem; }
.footer-legal a:hover { color: var(--c-gold); }

/* ---------- 15b. JOBS (zwei Stellen nebeneinander) ---------- */
.jobs-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1.1rem, 2.4vw, 1.6rem); align-items: start; }

/* ---------- 16b. VIDEO (YouTube – Klick-zum-Laden, DSGVO-freundlich) ---------- */
.video-grid { display: grid; gap: clamp(1rem, 2.4vw, 1.6rem); grid-template-columns: repeat(2, 1fr); }
.video-grid.single { grid-template-columns: 1fr; max-width: 900px; margin-inline: auto; }
.video-embed {
  position: relative; aspect-ratio: 16/9; border-radius: var(--radius); overflow: hidden;
  cursor: pointer; box-shadow: var(--shadow); background: #0a0a0a; isolation: isolate;
}
.video-embed img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s var(--ease), opacity .3s; }
.video-embed::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(8,9,11,.1), rgba(8,9,11,.45)); transition: opacity .3s; }
.video-embed:hover img { transform: scale(1.05); }
.video-embed .video-play {
  position: absolute; inset: 0; margin: auto; width: 84px; height: 84px; z-index: 2;
  display: grid; place-items: center; border-radius: 50%;
  background: var(--c-gold); color: var(--c-ink); box-shadow: 0 10px 30px rgba(0,0,0,.4);
  transition: transform .25s var(--ease), background .25s;
}
.video-embed .video-play svg { width: 34px; height: 34px; margin-left: 4px; }
.video-embed:hover .video-play { transform: scale(1.1); background: #fff; }
.video-embed iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; z-index: 3; }

/* ---------- 16c. FAQ (Accordion, SEO/GEO) ---------- */
.faq-list { max-width: var(--maxw-narrow); margin-inline: auto; display: grid; gap: .8rem; }
.faq-item { border: 1px solid var(--c-line); border-radius: var(--radius-sm); background: var(--c-paper-2); overflow: hidden; }
.faq-item > summary { cursor: pointer; list-style: none; padding: 1.1rem 1.3rem; font-family: var(--font-head); font-weight: 600; font-size: 1.05rem; color: #fff; display: flex; justify-content: space-between; align-items: center; gap: 1rem; }
.faq-item > summary::-webkit-details-marker { display: none; }
.faq-item > summary::after { content: "+"; font-size: 1.5rem; color: var(--c-gold); transition: transform .25s var(--ease); line-height: 1; }
.faq-item[open] > summary::after { transform: rotate(45deg); }
.faq-item > summary:hover { color: var(--c-gold); }
.faq-item__a { padding: 0 1.3rem 1.2rem; color: var(--c-muted); }
.faq-item__a p { color: var(--c-muted); }

/* ---------- 17. UTILITIES & SCROLL-ANIMATIONEN ---------- */
.mt-0{margin-top:0}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}
.mb-0{margin-bottom:0}
.reveal { opacity: 0; transform: translateY(28px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in { opacity: 1; transform: none; }
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}.reveal.d5{transition-delay:.4s}
.skip-link { position: absolute; left: -999px; top: 0; z-index: 3000; background: var(--c-gold); color: var(--c-ink); padding: .7rem 1.1rem; border-radius: 0 0 8px 0; font-weight: 600; }
.skip-link:focus { left: 0; }

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; }
  .reveal { opacity: 1; transform: none; }
}

/* ---------- 18. RESPONSIVE ---------- */
@media (max-width: 1100px) {
  .footer-top { grid-template-columns: 1fr 1fr; gap: 2rem; }
  .gallery { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 980px) {
  :root { --header-h: 72px; }
  .main-nav, .nav-cta.desktop, .lang-switch.desktop { display: none; }
  .nav-toggle { display: inline-flex; }
  .card-grid, .card-grid.cols-4 { grid-template-columns: repeat(2, 1fr); }
  .intro-grid { grid-template-columns: 1fr; gap: 2.2rem; }
  .intro-gallery a:nth-child(1), .intro-gallery a:nth-child(4){ margin-top: 0; }
  .media-row, .service-intro, .contact-grid, .profile, .jobs-grid { grid-template-columns: minmax(0, 1fr); }
  .media-row.reverse .media-row__media { order: 0; }
  .profile { grid-template-columns: 1fr; max-width: 460px; }
  .gallery { grid-template-columns: repeat(3, 1fr); }
  .cta-band { flex-direction: column; align-items: flex-start; text-align: left; }
}
@media (max-width: 640px) {
  .card-grid, .card-grid.cols-2, .card-grid.cols-4 { grid-template-columns: 1fr; }
  .logo-grid { grid-template-columns: repeat(2, 1fr); }
  .gallery { grid-template-columns: repeat(2, 1fr); }
  .form .row { grid-template-columns: 1fr; }
  .footer-top { grid-template-columns: 1fr; }
  .hero { min-height: 88vh; }
  .intro-gallery { gap: .6rem; }
  .video-grid { grid-template-columns: 1fr; }
}

/* =================================================================
   MARKEN-SCHRIFTEN – selbst gehostet (DSGVO-konform, keine externen Requests).
   Die woff2-Dateien liegen in assets/fonts/. Solange sie fehlen, greift
   automatisch der System-Schrift-Fallback (siehe --font-* oben).
   Dateien laden: einmal „schriften-nachladen.command" ausführen.
   ================================================================= */
@font-face{font-family:'Poppins';src:url('../fonts/poppins-500.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'Poppins';src:url('../fonts/poppins-600.woff2') format('woff2');font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:'Poppins';src:url('../fonts/poppins-700.woff2') format('woff2');font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:'Open Sans';src:url('../fonts/opensans-400.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Open Sans';src:url('../fonts/opensans-600.woff2') format('woff2');font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:'Open Sans';src:url('../fonts/opensans-700.woff2') format('woff2');font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:'Merriweather Sans';src:url('../fonts/merriweathersans-300.woff2') format('woff2');font-weight:300;font-style:normal;font-display:swap}
@font-face{font-family:'Merriweather Sans';src:url('../fonts/merriweathersans-700.woff2') format('woff2');font-weight:700;font-style:normal;font-display:swap}

/* =================================================================
   19. COOKIE-HINWEIS / EINWILLIGUNGSVERWALTUNG (Vanilla JS, lokal)
   ================================================================= */
.cookie-banner{position:fixed;left:0;right:0;bottom:0;z-index:1200;display:none;padding:clamp(.7rem,2.5vw,1.3rem);}
.cookie-banner.is-visible{display:block;}
body.menu-open .cookie-banner.is-visible{display:none;}
.cookie-banner__inner{max-width:var(--maxw);margin:0 auto;background:var(--c-dark);color:var(--c-text);
  border:1px solid var(--c-line);border-radius:var(--radius);box-shadow:var(--shadow-lg);
  padding:clamp(1.1rem,2.6vw,1.6rem);}
.cookie-banner.is-visible .cookie-banner__inner{animation:cookieIn .35s var(--ease);}
@keyframes cookieIn{from{opacity:0;transform:translateY(18px);}to{opacity:1;transform:none;}}

.cookie-banner__row{display:flex;gap:1rem 1.6rem;align-items:center;flex-wrap:wrap;justify-content:space-between;}
.cookie-banner__text{flex:1 1 340px;min-width:0;}
.cookie-banner__text h2{font-family:var(--font-head);font-size:1.08rem;margin:0 0 .35rem;color:var(--c-white);}
.cookie-banner__text p{margin:0;font-size:.92rem;line-height:1.55;color:var(--c-muted);}
.cookie-banner__text a{color:var(--c-gold);text-decoration:underline;}
.cookie-banner__actions{display:flex;gap:.55rem;flex-wrap:wrap;align-items:center;flex:0 0 auto;}

.cookie-btn{appearance:none;cursor:pointer;font:inherit;font-weight:600;font-size:.9rem;line-height:1;
  border-radius:var(--radius-sm);padding:.72rem 1.15rem;border:1px solid var(--c-line);background:transparent;
  color:var(--c-text);transition:transform .2s var(--ease),background .2s,border-color .2s,color .2s;}
.cookie-btn:hover{transform:translateY(-2px);}
.cookie-btn--primary{background:var(--c-gold);border-color:var(--c-gold);color:#1a1205;}
.cookie-btn--primary:hover{background:var(--c-gold-600);border-color:var(--c-gold-600);}
.cookie-btn--ghost:hover{border-color:var(--c-gold);color:var(--c-gold);}
.cookie-btn--link{border:none;background:none;padding:.45rem .3rem;color:var(--c-muted);text-decoration:underline;font-weight:500;}
.cookie-btn--link:hover{color:var(--c-gold);transform:none;}

.cookie-banner__settings{display:none;margin-top:1.15rem;border-top:1px solid var(--c-line);padding-top:.4rem;}
.cookie-banner.show-settings .cookie-banner__settings{display:block;}
.cookie-banner.show-settings .cookie-banner__intro-actions{display:none;}
.cookie-opt{display:flex;gap:.95rem;align-items:flex-start;padding:.85rem 0;}
.cookie-opt+.cookie-opt{border-top:1px solid var(--c-line);}
.cookie-opt__txt{flex:1 1 auto;}
.cookie-opt__txt h3{font-size:.95rem;margin:0 0 .2rem;color:var(--c-white);}
.cookie-opt__txt p{margin:0;font-size:.85rem;color:var(--c-muted);line-height:1.5;}
.cookie-banner__settings-actions{display:flex;gap:.55rem;flex-wrap:wrap;margin-top:1.1rem;}

.cookie-switch{position:relative;flex:0 0 auto;width:46px;height:27px;margin-top:.1rem;}
.cookie-switch input{position:absolute;inset:0;width:100%;height:100%;margin:0;opacity:0;cursor:pointer;}
.cookie-switch span{position:absolute;inset:0;background:rgba(255,255,255,.18);border-radius:999px;transition:background .2s;}
.cookie-switch span::after{content:"";position:absolute;top:3px;left:3px;width:21px;height:21px;background:#fff;border-radius:50%;transition:transform .2s;}
.cookie-switch input:checked+span{background:var(--c-gold);}
.cookie-switch input:checked+span::after{transform:translateX(19px);}
.cookie-switch input:disabled{cursor:not-allowed;}
.cookie-switch input:disabled+span{opacity:.55;}
.cookie-switch input:focus-visible+span{outline:2px solid var(--c-gold);outline-offset:3px;}

@media (max-width:640px){
  .cookie-banner__actions{width:100%;}
  .cookie-banner__actions .cookie-btn{flex:1 1 auto;text-align:center;}
  .cookie-banner__settings-actions .cookie-btn{flex:1 1 auto;text-align:center;}
}
@media (prefers-reduced-motion:reduce){
  .cookie-banner.is-visible .cookie-banner__inner{animation:none;}
  .cookie-btn:hover{transform:none;}
}

/* =================================================================
   20. NATIVE-VIDEO + MEDIEN-GALERIE (Wegfräse, Vorher/Nachher)
   ================================================================= */
.video-native{max-width:960px;margin:0 auto;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-lg);background:#000;}
.video-native video{display:block;width:100%;height:auto;}
.media-gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;max-width:960px;margin:1.6rem auto 0;}
.media-gallery a{display:block;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);cursor:zoom-in;}
.media-gallery img{width:100%;height:auto;display:block;transition:transform .5s var(--ease);}
.media-gallery a:hover img{transform:scale(1.04);}
@media (max-width:640px){.media-gallery{grid-template-columns:1fr;}}

/* =================================================================
   21. MASCHINEN-KARTEN (Wegfräse – Übersicht & Anbaugeräte)
   ================================================================= */
.machine-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.2rem,3vw,2rem);align-items:stretch;}
.machine-card{display:flex;flex-direction:column;background:var(--c-paper-2);border:1px solid var(--c-line);
  border-radius:var(--radius);overflow:hidden;}
.machine-card__img{aspect-ratio:16/10;overflow:hidden;}
.machine-card__img img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease);}
.machine-card:hover .machine-card__img img{transform:scale(1.05);}
.machine-card__body{display:flex;flex-direction:column;gap:.55rem;padding:clamp(1.2rem,2.6vw,1.7rem);flex:1;}
.machine-card__body h3{font-size:1.18rem;}
.machine-card__body .eyebrow{margin-bottom:.1rem;}
.machine-card__actions{margin-top:auto;display:flex;gap:.6rem;flex-wrap:wrap;padding-top:1rem;}
@media (max-width:760px){.machine-grid{grid-template-columns:1fr;}}
