/* ============================================================
   TAURUS INTERNATIONAL LOGISTICS — Design System
   Look: edel & hochwertig, modern & clean
   Brand-Hook: Taurus = der Stier (Stärke, Verlässlichkeit)
   Prototyp — Google Fonts hier per CDN; in WordPress self-hosted (DSGVO)
   ============================================================ */

:root {
  /* Farben — Markenpalette aus dem Logo (Grün #008000 + Schwarz) */
  --ink:        #16181A;   /* near-black (neutral, wie Logo-Schwarz) */
  --ink-2:      #1F2225;
  --ink-3:      #2B2F32;
  --paper:      #F6F7F4;   /* helles, leicht grün-neutrales Off-White */
  --paper-2:    #FFFFFF;
  --paper-3:    #ECEFE9;
  --accent:     #008000;   /* Taurus-Grün (Logo) */
  --accent-2:   #15A015;   /* helleres Grün (Hover/Glow) */
  --accent-ink: #0A6B0A;   /* dunkleres Grün (Text auf hell, Kontrast) */
  --steel:      #4F6058;   /* gedämpftes Grün-Grau (sekundär) */
  --steel-2:    #6E8076;
  --line:       rgba(20,23,28,.10);
  --line-2:     rgba(20,23,28,.16);
  --line-dark:  rgba(255,255,255,.12);
  --muted:      #5C636C;
  --muted-2:    #868D96;
  --ok:         #2E7D5B;

  /* Semantische Theme-Tokens (schalten Hell/Dunkel; --ink* bleiben fix dunkel für dunkle Sektionen) */
  --bg:            #F6F7F4;
  --surface:       #FFFFFF;
  --surface-2:     #ECEFE9;
  --text:          #16181A;
  --text-muted:    #5C636C;
  --text-muted-2:  #868D96;
  --hairline:      rgba(20,23,28,.10);
  --hairline-2:    rgba(20,23,28,.16);
  --accent-text:   #0A6B0A;
  /* Invertierte Sektionen (Hero, Trustbar, CTA-Bänder) — schalten mit; Showcases bleiben fix dunkel */
  --inv-bg:        #ECEFE9;
  --inv-bg-2:      #F1F3EE;
  --inv-bg-3:      #FFFFFF;
  --inv-text:      #16181A;
  --inv-soft:      #4C535C;
  --inv-line:      rgba(20,23,28,.12);
  --inv-btn-bg:    #16181A;
  --inv-btn-text:  #FFFFFF;
  --inv-ghost-bd:  rgba(20,23,28,.30);
  --inv-glow:      rgba(16,140,16,.10);
  color-scheme: light;

  /* Typo */
  --font-display: "Space Grotesk", system-ui, sans-serif;
  --font-body:    "Inter", system-ui, -apple-system, sans-serif;

  /* Maße */
  --wrap: 1200px;
  --wrap-narrow: 820px;
  --radius: 4px;
  --radius-lg: 10px;
  --radius-xl: 18px;
  --shadow-sm: 0 1px 2px rgba(20,23,28,.06), 0 4px 14px rgba(20,23,28,.05);
  --shadow:    0 8px 30px rgba(20,23,28,.10);
  --shadow-lg: 0 24px 60px rgba(20,23,28,.16);
  --ease: cubic-bezier(.22,.61,.36,1);
  --header-h: 78px;
}

/* ---------- Dunkelmodus ---------- */
:root[data-theme="dark"] {
  --bg:            #0E1012;
  --surface:       #181B1E;
  --surface-2:     #23272B;
  --text:          #E9EBEE;
  --text-muted:    #AEB4BC;
  --text-muted-2:  #8C939C;
  --hairline:      rgba(255,255,255,.12);
  --hairline-2:    rgba(255,255,255,.22);
  --accent-text:   #46C24A;   /* helleres Grün → lesbar auf dunklem Grund */
  --inv-bg:        #16181A;
  --inv-bg-2:      #1F2225;
  --inv-bg-3:      #2B2F32;
  --inv-text:      #FFFFFF;
  --inv-soft:      rgba(255,255,255,.72);
  --inv-line:      rgba(255,255,255,.12);
  --inv-btn-bg:    #FFFFFF;
  --inv-btn-text:  #16181A;
  --inv-ghost-bd:  rgba(255,255,255,.5);
  --inv-glow:      rgba(16,140,16,.22);
  --shadow-sm: 0 1px 2px rgba(0,0,0,.45), 0 4px 14px rgba(0,0,0,.45);
  --shadow:    0 10px 30px rgba(0,0,0,.55);
  --shadow-lg: 0 24px 60px rgba(0,0,0,.65);
  color-scheme: dark;
}
/* Sanfter Moduswechsel (kein Flackern bei Animationen/Reveals) */
body, .card, .jobx, .loc-card, .faq-item, .form-card, .field input, .field select, .field textarea { transition: background-color .3s var(--ease), color .3s var(--ease), border-color .3s var(--ease); }

/* ---------- Reset & Base ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: var(--font-body);
  color: var(--text);
  background: var(--bg);
  line-height: 1.65;
  font-size: 17px;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; }
:focus-visible { outline: 2px solid var(--accent); outline-offset: 3px; border-radius: 2px; }

/* ---------- Typografie ---------- */
h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 600;
  line-height: 1.08;
  letter-spacing: -.02em;
  margin: 0 0 .5em;
  color: var(--text);
  overflow-wrap: break-word;
  text-wrap: balance;
}
.lead, p { text-wrap: pretty; }
h1 { font-size: clamp(2.6rem, 6vw, 4.6rem); font-weight: 700; }
h2 { font-size: clamp(2rem, 4vw, 3.1rem); }
h3 { font-size: clamp(1.3rem, 2.4vw, 1.7rem); }
h4 { font-size: 1.1rem; }
p  { margin: 0 0 1rem; }
.lead { font-size: clamp(1.1rem, 1.8vw, 1.35rem); line-height: 1.6; color: var(--text-muted); }
strong { font-weight: 600; color: var(--text); }
.accent-text { color: var(--accent-text); }

/* Eyebrow / Kicker */
.kicker {
  display: inline-flex; align-items: center; gap: .55rem;
  font-family: var(--font-display);
  font-size: .8rem; font-weight: 600;
  letter-spacing: .16em; text-transform: uppercase;
  color: var(--accent-text);
  margin-bottom: 1.1rem;
}
.kicker::before {
  content: ""; width: 26px; height: 2px; background: var(--accent); display: inline-block;
}
.on-dark .kicker { color: var(--accent-2); }

/* ---------- Layout ---------- */
.wrap { width: 100%; max-width: var(--wrap); margin-inline: auto; padding-inline: clamp(20px, 5vw, 48px); }
.narrow { max-width: var(--wrap-narrow); }
section { padding-block: clamp(64px, 9vw, 130px); }
.section-head { max-width: 720px; margin-bottom: clamp(36px, 5vw, 60px); }
.section-head.center { margin-inline: auto; text-align: center; }
.grid { display: grid; gap: clamp(20px, 3vw, 34px); }
.cols-2 { grid-template-columns: repeat(2, 1fr); }
.cols-3 { grid-template-columns: repeat(3, 1fr); }
.cols-4 { grid-template-columns: repeat(4, 1fr); }

/* ---------- Buttons ---------- */
.btn {
  --bg: var(--accent); --fg: #fff;
  display: inline-flex; align-items: center; justify-content: center; gap: .55rem;
  background: var(--bg); color: var(--fg);
  font-family: var(--font-display); font-weight: 600; font-size: .98rem;
  padding: .92rem 1.7rem; border: 0; border-radius: var(--radius-lg);
  transition: transform .25s var(--ease), box-shadow .25s var(--ease), background .2s;
  box-shadow: 0 6px 18px rgba(16,140,16,.28);
  white-space: nowrap;
}
.btn:hover { transform: translateY(-2px); background: var(--accent-2); box-shadow: 0 10px 26px rgba(16,140,16,.36); }
.btn:active { transform: translateY(0); }
.btn svg { width: 18px; height: 18px; }
.btn.ghost { background: transparent; color: var(--text); box-shadow: inset 0 0 0 1.5px var(--hairline-2); }
.btn.ghost:hover { background: var(--ink); color: #fff; box-shadow: none; }
.btn.on-dark { background: #fff; color: var(--ink); box-shadow: 0 8px 24px rgba(0,0,0,.3); }
.btn.on-dark:hover { background: var(--surface-2); }
.btn.ghost.on-dark { background: transparent; color: #fff; box-shadow: inset 0 0 0 1.5px var(--line-dark); }
.btn.ghost.on-dark:hover { background: #fff; color: var(--ink); }
.btn.lg { padding: 1.1rem 2.1rem; font-size: 1.05rem; }
.btn.sm { padding: .65rem 1.15rem; font-size: .9rem; border-radius: var(--radius); }
.link-arrow {
  display: inline-flex; align-items: center; gap: .45rem;
  font-family: var(--font-display); font-weight: 600; color: var(--accent-text);
}
.link-arrow svg { width: 16px; height: 16px; transition: transform .25s var(--ease); }
.link-arrow:hover svg { transform: translateX(5px); }

/* ---------- Header / Nav ---------- */
.site-header {
  position: fixed; inset: 0 0 auto 0; z-index: 100; height: var(--header-h);
  display: flex; align-items: center; color: #fff;
  background: transparent;
  transition: background .35s var(--ease), box-shadow .35s var(--ease), height .35s var(--ease);
}
.site-header.scrolled {
  background: rgba(18,20,23,.82);
  backdrop-filter: saturate(160%) blur(16px);
  box-shadow: inset 0 -1px 0 rgba(255,255,255,.10);
  height: 66px;
}
/* Hell-Modus: Header ist eine dunkle Glas-Leiste (auch über dem hellen Hero) → weiße Navi bleibt lesbar */
:root[data-theme="light"] .site-header {
  background: rgba(18,20,23,.86);
  -webkit-backdrop-filter: saturate(160%) blur(16px); backdrop-filter: saturate(160%) blur(16px);
  box-shadow: inset 0 -1px 0 rgba(255,255,255,.10);
}
.site-header .wrap { display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; width: 100%; }

/* Logo */
.brand { display: inline-flex; align-items: center; gap: .65rem; }
.brand-mark { display: inline-flex; align-items: center; flex: none; }
.brand .lm { height: 30px; width: auto; display: block; }
.brand .lm-light { display: none; }   /* Header durchgehend dunkel → immer helle Marke (weiß+grün) */
.brand-text { display: flex; flex-direction: column; line-height: 1; }
.brand-text .name { font-family: var(--font-display); font-weight: 700; font-size: 1.18rem; letter-spacing: .02em; }
.brand-text .name { color: #fff; }
.brand-text .sub { font-size: .62rem; letter-spacing: .28em; text-transform: uppercase; color: rgba(255,255,255,.6); margin-top: 3px; }

/* Nav */
.nav { display: flex; align-items: center; gap: 1.4rem; }
.nav-links { display: flex; align-items: center; gap: 1.3rem; list-style: none; margin: 0; padding: 0; }
.nav-links a {
  font-family: var(--font-display); font-weight: 500; font-size: .95rem; white-space: nowrap;
  position: relative; padding: .3rem 0; color: inherit; opacity: .9;
}
.nav-links a::after {
  content: ""; position: absolute; left: 0; bottom: -2px; width: 0; height: 2px;
  background: var(--accent); transition: width .25s var(--ease);
}
.nav-links a:hover { opacity: 1; }
.nav-links a:hover::after, .nav-links a.active::after { width: 100%; }
.nav-links a.active { opacity: 1; }

.nav-cta { display: flex; align-items: center; gap: .65rem; }
.phone-link {
  display: inline-flex; align-items: center; gap: .5rem; white-space: nowrap;
  padding: .38rem .85rem .38rem .65rem; border-radius: 100px;
  box-shadow: inset 0 0 0 1.5px var(--hairline-2);
  font-family: var(--font-display); transition: box-shadow .2s, background .2s;
}
.phone-link svg { width: 20px; height: 20px; color: var(--accent); flex: none; }
.phone-link .pl-txt { display: flex; flex-direction: column; line-height: 1.05; }
.phone-link .pl-eyebrow { font-size: .6rem; letter-spacing: .08em; text-transform: uppercase; color: var(--text-muted-2); }
.phone-link .pl-num { font-weight: 700; font-size: 1rem; }
.phone-link:hover { box-shadow: inset 0 0 0 1.5px var(--accent); background: rgba(0,128,0,.06); }
.on-hero-dark:not(.scrolled) .phone-link { box-shadow: inset 0 0 0 1.5px var(--line-dark); }
.on-hero-dark:not(.scrolled) .phone-link svg { color: var(--accent-2); }
.on-hero-dark:not(.scrolled) .phone-link .pl-eyebrow { color: rgba(255,255,255,.6); }
.on-hero-dark:not(.scrolled) .phone-link:hover { background: rgba(255,255,255,.06); box-shadow: inset 0 0 0 1.5px var(--accent-2); }
/* Mobiler Anruf-Button (immer sichtbar ≤1024px) */
.phone-btn-mobile { display: none; width: 44px; height: 44px; border-radius: 50%; background: var(--accent); color: #fff; place-items: center; flex: none; box-shadow: 0 6px 16px rgba(16,140,16,.3); }
.phone-btn-mobile svg { width: 20px; height: 20px; }

/* Burger — klar sichtbarer, tippbarer Button */
.burger {
  display: none; width: 46px; height: 46px; cursor: pointer;
  border: 1px solid rgba(255,255,255,.24); background: rgba(255,255,255,.10);
  -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px);
  flex-direction: column; justify-content: center; align-items: center; gap: 5px; border-radius: 11px;
  transition: background .2s, border-color .2s;
}
.burger:hover { background: rgba(255,255,255,.18); border-color: rgba(255,255,255,.4); }
.burger span { width: 22px; height: 2.5px; background: #fff; border-radius: 2px; transition: transform .3s var(--ease), opacity .2s; }

/* Mobile menu — Drawer mit eigenem Schließen-Button */
.mobile-menu {
  position: fixed; inset: 0; z-index: 200; color: #fff;
  background: linear-gradient(165deg, #1c2024 0%, #121417 62%);
  display: flex; flex-direction: column; padding: 1rem 7vw 2.4rem; overflow-y: auto;
  transform: translateX(100%); transition: transform .4s var(--ease); visibility: hidden;
}
.mobile-menu.open { transform: translateX(0); visibility: visible; }
.mm-head { display: flex; align-items: center; justify-content: space-between; min-height: var(--header-h); margin-bottom: 1.4rem; }
.mm-logo { height: 32px; width: auto; }
.mm-close {
  width: 48px; height: 48px; border-radius: 50%; cursor: pointer; flex: none;
  border: 1px solid rgba(255,255,255,.22); background: rgba(255,255,255,.10); color: #fff;
  display: flex; align-items: center; justify-content: center; transition: background .2s, transform .25s;
}
.mm-close:hover { background: rgba(255,255,255,.18); transform: rotate(90deg); }
.mm-close svg { width: 22px; height: 22px; }
.mm-nav { display: flex; flex-direction: column; }
.mobile-menu .mm-nav a {
  font-family: var(--font-display); font-size: 1.45rem; font-weight: 600; color: #fff;
  padding: 1.05rem .2rem; border-bottom: 1px solid rgba(255,255,255,.12);
  display: flex; align-items: center; justify-content: space-between; transition: color .2s, padding-left .2s;
}
.mobile-menu .mm-nav a:hover { color: var(--accent-2); padding-left: .5rem; }
.mobile-menu .mm-nav a::after { content: "→"; color: var(--accent-2); opacity: .55; font-size: 1.05rem; }
.mm-foot { margin-top: auto; padding-top: 1.8rem; display: flex; flex-direction: column; gap: .8rem; }
.mm-foot .btn { width: 100%; }

/* ---------- Hero ---------- */
.hero {
  position: relative; min-height: 100svh; display: flex; align-items: center;
  background: radial-gradient(120% 90% at 75% 0%, var(--inv-bg-3) 0%, var(--inv-bg) 55%);
  color: var(--inv-text); overflow: hidden; padding-top: var(--header-h);
}
.hero::after {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(60% 50% at 85% 80%, var(--inv-glow), transparent 70%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='40'%3E%3Cpath d='M0 39.5H40M39.5 0V40' stroke='%23808080' stroke-opacity='0.06'/%3E%3C/svg%3E");
}
.hero-bg-mark {
  position: absolute; right: -4%; bottom: 6%; width: min(58vw, 700px); height: auto; opacity: .10; pointer-events: none; z-index: 1;
}
.hero .wrap { position: relative; z-index: 2; }
.hero-inner { max-width: 760px; }
.hero h1 { color: var(--inv-text); margin-bottom: 1.5rem; }
.hero h1 .hl { color: var(--accent-text); }
.hero .lead { color: var(--inv-soft); max-width: 560px; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 1rem; margin-top: 2.2rem; }
.hero-stats { display: flex; flex-wrap: wrap; gap: clamp(1.5rem, 4vw, 3.2rem); margin-top: 3.5rem; padding-top: 2rem; border-top: 1px solid var(--inv-line); }
.hero-stats .stat .num { font-family: var(--font-display); font-size: clamp(1.8rem, 3vw, 2.4rem); font-weight: 700; color: var(--inv-text); }
.hero-stats .stat .lbl { font-size: .85rem; color: var(--inv-soft); letter-spacing: .03em; }
.hero-scroll { position: absolute; bottom: 26px; left: 50%; transform: translateX(-50%); z-index:2; color: var(--inv-soft); font-size: .75rem; letter-spacing: .2em; text-transform: uppercase; display:flex; flex-direction:column; align-items:center; gap:.5rem; }
.hero-scroll .line { width: 1px; height: 36px; background: linear-gradient(var(--inv-soft), transparent); animation: scrollline 1.8s var(--ease) infinite; }
@keyframes scrollline { 0% { transform: scaleY(0); transform-origin: top; } 50% { transform: scaleY(1); transform-origin: top; } 50.1% { transform-origin: bottom; } 100% { transform: scaleY(0); transform-origin: bottom; } }

/* Sektion auf Dunkel */
.on-dark { background: var(--ink); color: rgba(255,255,255,.82); }
.on-dark h1, .on-dark h2, .on-dark h3, .on-dark h4 { color: #fff; }
.on-dark .lead { color: rgba(255,255,255,.7); }

/* ---------- Trust-Bar (4 Spalten, Trenner) ---------- */
.trustbar { background: var(--inv-bg-2); border-bottom: 1px solid var(--inv-line); }
.trustbar .wrap { display: grid; grid-template-columns: repeat(4, 1fr); padding-inline: clamp(8px, 3vw, 24px); }
.tb-item { display: flex; align-items: center; gap: .85rem; padding: 24px clamp(.8rem, 2.2vw, 2rem); position: relative; }
.tb-item + .tb-item::before { content: ""; position: absolute; left: 0; top: 50%; transform: translateY(-50%); height: 40px; width: 1px; background: var(--inv-line); }
.tb-ic { width: 44px; height: 44px; border-radius: 12px; flex: none; display: grid; place-items: center; background: rgba(21,160,21,.12); }
.tb-ic svg { width: 22px; height: 22px; color: var(--accent-text); stroke-width: 1.75; }
.tb-txt { display: flex; flex-direction: column; line-height: 1.25; }
.tb-txt b { font-family: var(--font-display); color: var(--inv-text); font-size: 1rem; }
.tb-txt span { color: var(--inv-soft); font-size: .82rem; }
@media (max-width: 860px) {
  .trustbar .wrap { grid-template-columns: repeat(2, 1fr); }
  .trustbar .wrap > .tb-item:nth-child(odd)::before { display: none; }
  .trustbar .wrap > .tb-item:nth-child(n+3) { border-top: 1px solid var(--line-dark); }
}
@media (max-width: 480px) {
  .trustbar .wrap { grid-template-columns: 1fr; }
  .trustbar .wrap > .tb-item::before { display: none; }
  .trustbar .wrap > .tb-item + .tb-item { border-top: 1px solid var(--line-dark); }
}

/* ---------- Cards ---------- */
.card {
  background: var(--surface); border: 1px solid var(--hairline); border-radius: var(--radius-xl);
  padding: clamp(1.6rem, 2.5vw, 2.2rem); transition: transform .3s var(--ease), box-shadow .3s var(--ease), border-color .3s;
  position: relative; overflow: hidden; height: 100%;
}
.card:hover { transform: translateY(-5px); box-shadow: var(--shadow); border-color: var(--hairline-2); }
.card .ic { width: 52px; height: 52px; border-radius: 12px; display: grid; place-items: center; background: linear-gradient(135deg, rgba(16,140,16,.14), rgba(16,140,16,.05)); margin-bottom: 1.3rem; }
.card .ic svg { width: 26px; height: 26px; color: var(--accent-text); }
.card h3 { margin-bottom: .55rem; }
.card p { color: var(--text-muted); margin-bottom: 1rem; font-size: .98rem; }
.card .card-link { margin-top: auto; }

/* ---------- Media + Platzhalter-System ----------
   Jedes .media zeigt einen edlen Dark-Panel-Platzhalter mit Bull-Mark + Label.
   Sobald ein echtes/KI-Bild unter dem src-Pfad liegt, überdeckt es den Platzhalter. */
.media { position: relative; overflow: hidden; background: linear-gradient(140deg, var(--ink-2), var(--ink)); }
.media::before {
  content: ""; position: absolute; inset: 0; opacity: .08;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Cpath fill='%23fff' d='M32 14c-5 0-9 3-11 7-4-1-8-4-9-9-1 6 1 11 5 14-1 2-1 4-1 6 0 9 7 16 16 16s16-7 16-16c0-2 0-4-1-6 4-3 6-8 5-14-1 5-5 8-9 9-2-4-6-7-11-7zm-7 22a3 3 0 110-6 3 3 0 010 6zm14 0a3 3 0 110-6 3 3 0 010 6z'/%3E%3C/svg%3E") center / 36% no-repeat;
}
.media[data-label]::after {
  content: attr(data-label); position: absolute; inset: auto 0 16px; text-align: center;
  font-family: var(--font-display); font-size: .72rem; letter-spacing: .14em; text-transform: uppercase;
  color: rgba(255,255,255,.4);
}
.media > img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 1; }

/* Service-Card mit Bild */
.svc-card { display: flex; flex-direction: column; padding: 0; }
.svc-card .media { aspect-ratio: 16/10; }
.svc-card .media > img { transition: transform .6s var(--ease); }
.svc-card:hover .media > img { transform: scale(1.06); }
.svc-card .body { padding: 1.6rem 1.7rem 1.8rem; display: flex; flex-direction: column; flex: 1; }
.svc-card .tag { position: absolute; z-index: 2; top: 14px; left: 14px; background: rgba(20,23,28,.78); color:#fff; font-family: var(--font-display); font-size: .72rem; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; padding: .4rem .7rem; border-radius: 6px; backdrop-filter: blur(4px); }

/* Feature-Liste */
.feat-list { list-style: none; margin: 0; padding: 0; display: grid; gap: .9rem; }
.feat-list li { display: flex; gap: .8rem; align-items: flex-start; }
.feat-list .chk { flex: none; width: 24px; height: 24px; border-radius: 50%; background: rgba(16,140,16,.12); display: grid; place-items: center; margin-top: 2px; }
.feat-list .chk svg { width: 13px; height: 13px; color: var(--accent-text); }
.feat-list strong { display: block; }
.feat-list span { color: var(--text-muted); font-size: .96rem; }

/* Split media + text */
.split { display: grid; grid-template-columns: 1fr 1.08fr; gap: clamp(2rem, 5vw, 5rem); align-items: stretch; }
.split.reverse .split-media { order: 2; }
.split-text { align-self: center; }
.split-media { position: relative; min-height: 100%; }
.split-media .media { border-radius: var(--radius-xl); box-shadow: var(--shadow-lg); height: 100%; min-height: 420px; aspect-ratio: auto; }
.split-media .badge {
  position: absolute; bottom: -22px; left: -22px; background: var(--surface); border-radius: var(--radius-lg);
  box-shadow: var(--shadow); padding: 1rem 1.3rem; display: flex; align-items: center; gap: .8rem;
}
.split-media .badge .b-num { font-family: var(--font-display); font-weight: 700; font-size: 1.7rem; color: var(--accent-text); }
.split-media .badge .b-lbl { font-size: .82rem; color: var(--text-muted); line-height: 1.3; }

/* Stat-Band */
.statband { background: var(--surface-2); }
.statband .grid { text-align: center; }
.statband .num { font-family: var(--font-display); font-weight: 700; font-size: clamp(2.4rem,5vw,3.4rem); color: var(--text); line-height: 1; }
.statband .num .u { color: var(--accent); }
.statband .lbl { color: var(--text-muted); margin-top: .5rem; font-size: .95rem; }

/* Steps / Prozess */
.steps { counter-reset: step; display: grid; gap: 1.5rem; }
.step { display: flex; gap: 1.4rem; align-items: flex-start; }
.step .n { flex: none; counter-increment: step; width: 52px; height: 52px; border-radius: 50%; border: 1.5px solid var(--accent); color: var(--accent-text); font-family: var(--font-display); font-weight: 700; font-size: 1.2rem; display: grid; place-items: center; }
.step .n::before { content: counter(step, decimal-leading-zero); }
.step h3 { margin-bottom: .3rem; }
.step p { color: var(--text-muted); margin: 0; }

/* CTA-Band */
.cta-band { position: relative; overflow: hidden; background: radial-gradient(130% 150% at 85% 0%, var(--inv-bg-3), var(--inv-bg) 58%); color: var(--inv-text); border-radius: var(--radius-xl); padding: clamp(2.5rem, 6vw, 5rem); border: 1px solid var(--inv-line); }
.cta-band::after { content:""; position:absolute; inset:0; background: radial-gradient(50% 80% at 90% 100%, var(--inv-glow), transparent 60%); pointer-events:none; }
.cta-band .inner { position: relative; z-index: 2; max-width: 620px; }
.cta-band h2 { color: var(--inv-text); }
.cta-band .lead { color: var(--inv-soft); }
.cta-band .hero-actions { margin-top: 1.8rem; }

/* ---------- Standort-Karten ---------- */
.loc-card { background: var(--surface); border: 1px solid var(--hairline); border-radius: var(--radius-xl); overflow: hidden; display: flex; flex-direction: column; }
.loc-card .media { aspect-ratio: 16/9; }
.loc-card .media .pin { position:absolute; z-index:2; top: 14px; left: 14px; background: var(--accent); color:#fff; font-family:var(--font-display); font-weight:600; font-size:.78rem; padding:.35rem .7rem; border-radius:6px; }
.loc-card .body { padding: 1.6rem 1.7rem; }
.loc-card address { font-style: normal; color: var(--text-muted); line-height: 1.6; }
.loc-card .meta { display:flex; gap:1.2rem; flex-wrap:wrap; margin-top:1rem; padding-top:1rem; border-top:1px solid var(--hairline); font-size:.9rem; }
.loc-card .meta b { font-family: var(--font-display); }

/* ---------- Jobs / Stellenbörse ---------- */
.job { display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; padding: 1.5rem 1.7rem; background: var(--surface); border: 1px solid var(--hairline); border-radius: var(--radius-lg); transition: border-color .25s, box-shadow .25s, transform .25s; }
.job:hover { border-color: var(--accent); box-shadow: var(--shadow-sm); transform: translateX(4px); }
.job .j-main h3 { margin: 0 0 .35rem; font-size: 1.25rem; }
.job .j-tags { display: flex; flex-wrap: wrap; gap: .5rem; }
.job .pill { font-size: .8rem; font-family: var(--font-display); font-weight: 500; color: var(--steel); background: var(--surface-2); padding: .3rem .7rem; border-radius: 100px; display:inline-flex; align-items:center; gap:.35rem; }
.job .pill svg { width: 13px; height: 13px; }
.job .j-action { flex: none; }

/* ---------- Formular ---------- */
.form-card { background: var(--surface); border: 1px solid var(--hairline); border-radius: var(--radius-xl); padding: clamp(1.8rem, 3vw, 2.6rem); box-shadow: var(--shadow-sm); }
.field { margin-bottom: 1.2rem; }
.field label { display: block; font-family: var(--font-display); font-weight: 500; font-size: .9rem; margin-bottom: .45rem; }
.field label .req { color: var(--accent); }
.field input, .field select, .field textarea {
  width: 100%; font-family: inherit; font-size: 1rem; color: var(--text);
  padding: .85rem 1rem; border: 1.5px solid var(--hairline-2); border-radius: var(--radius-lg);
  background: var(--bg); transition: border-color .2s, box-shadow .2s;
}
.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px rgba(16,140,16,.14); }
.field textarea { resize: vertical; min-height: 130px; }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.2rem; }
.consent { display: flex; gap: .7rem; align-items: flex-start; font-size: .9rem; color: var(--text-muted); }
.consent input { width: 18px; height: 18px; margin-top: 3px; flex: none; accent-color: var(--accent); }
.form-note { font-size: .82rem; color: var(--text-muted-2); margin-top: 1rem; }
.anfrage-hint { display: flex; align-items: center; gap: 1rem; padding: .95rem 1.15rem; margin-bottom: 1.5rem; border: 1px solid rgba(0,128,0,.25); background: rgba(0,128,0,.06); border-radius: var(--radius-lg); color: var(--text); text-decoration: none; transition: background .2s, border-color .2s, transform .2s; }
.anfrage-hint:hover { background: rgba(0,128,0,.1); border-color: var(--accent); transform: translateY(-1px); }
.anfrage-hint span { font-size: .9rem; line-height: 1.45; }
.anfrage-hint strong { font-family: var(--font-display); color: var(--accent-text); }
.anfrage-hint svg { width: 22px; height: 22px; color: var(--accent); flex: none; }
.file-input { width: 100%; font-family: inherit; font-size: .9rem; color: var(--text-muted); padding: .6rem .85rem; border: 1.5px dashed var(--hairline-2); border-radius: var(--radius-lg); background: var(--bg); cursor: pointer; transition: border-color .2s; }
.file-input:hover { border-color: var(--accent); }
.file-input::file-selector-button { font-family: var(--font-display); font-weight: 600; font-size: .82rem; border: 0; background: var(--ink); color: #fff; padding: .5rem .9rem; border-radius: 8px; margin-right: .9rem; cursor: pointer; }
.file-input::-webkit-file-upload-button { font-family: var(--font-display); font-weight: 600; font-size: .82rem; border: 0; background: var(--ink); color: #fff; padding: .5rem .9rem; border-radius: 8px; margin-right: .9rem; cursor: pointer; }

/* Kontakt-Methoden */
.contact-methods { display: grid; gap: 1rem; }
.contact-method { display: flex; gap: 1rem; align-items: center; padding: 1.1rem 1.3rem; border: 1px solid var(--hairline); border-radius: var(--radius-lg); background: var(--surface); transition: border-color .2s, transform .2s; }
.contact-method:hover { border-color: var(--accent); transform: translateY(-2px); }
.contact-method .cm-ic { width: 46px; height: 46px; border-radius: 12px; display: grid; place-items: center; background: rgba(16,140,16,.12); flex: none; }
.contact-method .cm-ic svg { width: 22px; height: 22px; color: var(--accent-text); }
.contact-method .cm-ic.wa { background: rgba(37,211,102,.14); }
.contact-method .cm-ic.wa svg { color: #1da851; }
.contact-method .cm-t { font-size: .82rem; color: var(--text-muted); }
.contact-method .cm-v { font-family: var(--font-display); font-weight: 600; }

/* WhatsApp Float */
.wa-float { position: fixed; right: 22px; bottom: 22px; z-index: 90; width: 58px; height: 58px; border-radius: 50%; background: #25d366; display: grid; place-items: center; box-shadow: 0 10px 30px rgba(37,211,102,.45); transition: transform .25s var(--ease); }
.wa-float:hover { transform: scale(1.08); }
.wa-float svg { width: 30px; height: 30px; color: #fff; }

/* ---------- Page Hero (Subpages) ---------- */
.page-hero { background: radial-gradient(130% 130% at 80% 0%, var(--inv-bg-3), var(--inv-bg) 60%); color: var(--inv-text); padding-top: calc(var(--header-h) + clamp(40px,7vw,80px)); padding-bottom: clamp(48px,7vw,90px); position: relative; overflow: hidden; }
.page-hero::after { content:""; position:absolute; inset:0; background: radial-gradient(50% 60% at 90% 0, var(--inv-glow), transparent 60%); pointer-events:none;}
.page-hero .wrap { position: relative; z-index: 2; }
.page-hero h1 { color: var(--inv-text); max-width: 16ch; }
.page-hero .lead { color: var(--inv-soft); max-width: 56ch; }
.breadcrumb { display: flex; gap: .5rem; align-items: center; font-size: .85rem; color: var(--inv-soft); margin-bottom: 1.3rem; font-family: var(--font-display); }
.breadcrumb a:hover { color: var(--inv-text); }
.breadcrumb .sep { opacity: .5; }

/* ---------- Footer ---------- */
.site-footer { background: var(--ink); color: rgba(255,255,255,.6); padding-top: clamp(56px, 8vw, 90px); }
.site-footer a:hover { color: #fff; }
.footer-top { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1.2fr; gap: 2.5rem; padding-bottom: 3rem; border-bottom: 1px solid var(--line-dark); }
.footer-logo { width: 200px; max-width: 62%; height: auto; }
.footer-brand p { margin: 1.2rem 0; max-width: 34ch; font-size: .95rem; }
.footer-col h3 { color: #fff; font-size: .8rem; letter-spacing: .14em; text-transform: uppercase; margin-bottom: 1.1rem; }
.footer-col ul { list-style: none; margin: 0; padding: 0; display: grid; gap: .7rem; font-size: .95rem; }
.footer-social { display: flex; gap: .7rem; margin-top: 1.3rem; }
.footer-social a { width: 40px; height: 40px; border-radius: 10px; border: 1px solid var(--line-dark); display: grid; place-items: center; transition: background .2s, border-color .2s; }
.footer-social a:hover { background: var(--accent); border-color: var(--accent); }
.footer-social svg { width: 18px; height: 18px; }
.footer-bottom { padding-block: 1.4rem; font-size: .85rem; color: var(--text-muted-2); }
.fb-bar { display: flex; align-items: center; justify-content: space-between; gap: .8rem 1.6rem; flex-wrap: wrap; padding-bottom: 1.05rem; border-bottom: 1px solid rgba(255,255,255,.08); }
.fb-copy { margin: 1.05rem 0 0; }
.footer-bottom .fb-links { display: flex; align-items: center; gap: 1.3rem; flex-wrap: wrap; }
.fb-legal { display: flex; align-items: center; flex-wrap: wrap; gap: .2rem .9rem; }
.fb-legal a { color: var(--text-muted-2); text-decoration: none; transition: color .2s ease; }
.fb-legal a:hover { color: var(--accent-2); }
.fb-legal a::before { content: "·"; margin-right: .9rem; opacity: .4; }
.fb-legal a:first-child::before { content: none; }
.fb-tools { display: flex; align-items: center; gap: 1.1rem; }
.footer-bottom .fb-game { display: inline-flex; align-items: center; opacity: .45; transition: color .2s ease, opacity .2s ease; }
.footer-bottom .fb-game:hover { color: var(--accent-2); opacity: 1; }
.footer-bottom .fb-game svg { width: 15px; height: 15px; }
.footer-bottom .fb-login { display: inline-flex; align-items: center; opacity: .45; transition: color .2s ease, opacity .2s ease; }
.footer-bottom .fb-login:hover { color: var(--accent-2); opacity: 1; }
.footer-bottom .fb-login svg { width: 13px; height: 13px; }
/* Hell/Dunkel-Umschalter dezent im Footer (überschreibt den boxigen Header-Stil) */
.footer-bottom .fb-theme.theme-toggle { width: auto; height: auto; padding: .25rem; border: 0; background: none;
  -webkit-backdrop-filter: none; backdrop-filter: none; color: var(--text-muted-2); opacity: .55; border-radius: 7px; }
.footer-bottom .fb-theme.theme-toggle:hover { color: var(--accent-2); opacity: 1; background: none; border-color: transparent; }
.footer-bottom .fb-theme svg { width: 15px; height: 15px; }

/* ---------- Jobbörse (premium, datengetrieben) ---------- */
.jobs-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 22px; align-items: stretch; }
.jobx { display: flex; flex-direction: column; height: 100%; background: var(--surface); border: 1px solid var(--hairline); border-radius: var(--radius-xl); padding: 1.8rem; transition: transform .3s var(--ease), box-shadow .3s var(--ease), border-color .3s; }
.jobx:hover { transform: translateY(-5px); box-shadow: var(--shadow); border-color: var(--accent); }
.jobx .jx-head { display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin-bottom: 1rem; }
.jx-cat { display: inline-block; font-family: var(--font-display); font-size: .7rem; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--accent-text); background: rgba(0,128,0,.10); padding: .35rem .75rem; border-radius: 100px; }
.jobx .jx-date { font-size: .8rem; color: var(--text-muted-2); white-space: nowrap; }
.jobx h3 { font-size: 1.3rem; margin-bottom: .55rem; line-height: 1.2; }
.jobx .jx-meta { display: flex; flex-wrap: wrap; align-items: center; color: var(--text-muted); font-family: var(--font-display); font-weight: 500; font-size: .92rem; margin-bottom: 1.1rem; }
.jobx .jx-meta span + span::before { content: "·"; margin: 0 .55rem; color: var(--hairline-2); }
.jobx .jx-intro { color: var(--text-muted); font-size: .96rem; margin: 0 0 1.2rem; }
.jobx .jx-hl { list-style: none; margin: 0 0 1.5rem; padding: 0; display: grid; gap: .6rem; }
.jobx .jx-hl li { display: flex; gap: .6rem; align-items: flex-start; font-size: .93rem; color: var(--text); }
.jobx .jx-hl svg { width: 16px; height: 16px; color: var(--accent-text); flex: none; margin-top: 3px; }
.jobx .jx-apply { margin-top: auto; width: 100%; }
/* Initiativ-Karte: volle Breite, horizontal */
.jobx.full { grid-column: 1 / -1; flex-direction: row; align-items: center; gap: 1.8rem; flex-wrap: wrap; background: var(--ink); }
.jobx.full .jx-body { flex: 1; min-width: 240px; }
.jobx.full .jx-cat { color: var(--accent-2); background: rgba(21,160,21,.16); }
.jobx.full h3 { color: #fff; margin: .5rem 0 0; }
.jobx.full .jx-intro { color: rgba(255,255,255,.7); }
.jobx.full .btn { flex: none; }
.jobs-empty { grid-column: 1 / -1; text-align: center; color: var(--text-muted); padding: 40px; border: 1px dashed var(--hairline-2); border-radius: var(--radius-xl); }
/* Modal-Meta gleich gestylt */
.tmodal-card .jm-meta span + span::before { content: "·"; margin: 0 .55rem; color: var(--hairline-2); }
.tmodal-card .jm-meta span { color: var(--text-muted); font-family: var(--font-display); font-weight: 500; }

/* ---------- Modal (öffentlich: Job-Detail + Bewerbung) ---------- */
.tmodal { position: fixed; inset: 0; z-index: 120; background: rgba(16,18,20,.6); display: none; place-items: center; padding: 20px; backdrop-filter: blur(2px); }
.tmodal.open { display: grid; }
.tmodal-card { background: var(--surface); border-radius: var(--radius-xl); box-shadow: var(--shadow-lg); width: 100%; max-width: 640px; max-height: 92vh; overflow: auto; padding: clamp(1.6rem, 3vw, 2.4rem); position: relative; }
.tmodal-close { position: absolute; top: 14px; right: 14px; width: 40px; height: 40px; border: 0; background: var(--surface-2); border-radius: 50%; font-size: 1.3rem; cursor: pointer; line-height: 1; }
.tmodal-close:hover { background: var(--hairline-2); }
.tmodal-card .jm-meta { display: flex; gap: .5rem; flex-wrap: wrap; margin: .6rem 0 1.2rem; }
.tmodal-card .jm-desc { color: var(--text-muted); }
.tmodal-card .jm-desc p { margin: 0 0 .8rem; }
.tmodal-card hr.divider { margin: 1.4rem 0; }
.tmodal-card h3.jm-apply-h { font-size: 1.1rem; margin-bottom: 1rem; }
.jm-badge { display: inline-block; font-family: var(--font-display); font-size: .72rem; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; padding: .35rem .8rem; border-radius: 100px; margin-bottom: .9rem; background: rgba(0,128,0,.12); color: var(--accent-text); }
.jm-badge.initiativ { background: var(--ink); color: #fff; }
.tmodal-card .jm-lead { color: var(--text-muted); font-size: 1rem; margin: 0; }

/* ============================================================
   PREMIUM-FX — Scroll, Kinetik, Tilt, Live-Tracking, Marquee
   ============================================================ */
/* Scroll-Fortschrittsleiste */
.scroll-prog { position: fixed; top: 0; left: 0; height: 3px; width: 0; z-index: 200;
  background: linear-gradient(90deg, var(--accent), var(--accent-2)); box-shadow: 0 0 12px rgba(21,160,21,.5); }

/* Kinetische Überschrift (Wort-für-Wort) */
.w-mask { display: inline-block; overflow: hidden; vertical-align: top; padding-bottom: .08em; }
.w-in { display: inline-block; transform: translateY(118%); transition: transform .9s cubic-bezier(.16,1,.3,1); }
.hero-in .w-in { transform: none; }

/* Hero-Spotlight (folgt dem Cursor) */
.hero-spot { position: absolute; inset: 0; z-index: 1; pointer-events: none; opacity: 0; transition: opacity .5s ease;
  background: radial-gradient(320px circle at var(--mx,70%) var(--my,28%), rgba(21,160,21,.16), transparent 62%); }
.hero:hover .hero-spot { opacity: 1; }

/* 3D-Tilt + Lichtschein auf Karten */
.tilt { transition: transform .3s var(--ease), box-shadow .3s var(--ease), border-color .3s; }
.tilt-glow { position: absolute; inset: 0; border-radius: inherit; pointer-events: none; opacity: 0; transition: opacity .35s ease; z-index: 3;
  background: radial-gradient(200px circle at var(--gx,50%) var(--gy,0%), rgba(0,128,0,.12), transparent 60%); }
.tilt:hover .tilt-glow { opacity: 1; }

/* Endlos-Laufband (mit Rand-Fade) */
.marquee { overflow: hidden; background: var(--ink); border-bottom: 1px solid var(--line-dark); padding: 0;
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 9%, #000 91%, transparent);
          mask-image: linear-gradient(90deg, transparent, #000 9%, #000 91%, transparent); }
.marquee-track { display: flex; width: max-content; animation: marq 46s linear infinite; }
.marquee:hover .marquee-track { animation-play-state: paused; }
.marquee-item { display: inline-flex; align-items: center; padding: .95rem 0; font-family: var(--font-display); font-weight: 600; font-size: .82rem; letter-spacing: .14em; text-transform: uppercase; color: rgba(255,255,255,.48); white-space: nowrap; }
.marquee-item .mq-dot { width: 5px; height: 5px; border-radius: 50%; background: var(--accent-2); margin: 0 2.4rem; flex: none; opacity: .85; }
@keyframes marq { to { transform: translateX(-50%); } }

/* Live-Sendungsverfolgung */
.track-section { background: var(--surface); }
.track-card { position: relative; background: var(--surface); border: 1px solid var(--hairline); border-radius: var(--radius-xl); box-shadow: var(--shadow); padding: clamp(1.5rem, 3vw, 2.3rem); }
.track-head { display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin-bottom: .4rem; }
.track-id { font-family: var(--font-display); font-weight: 600; font-size: 1.05rem; }
.track-id span { color: var(--text-muted); font-weight: 400; font-size: .85rem; display: block; }
.track-live { display: inline-flex; align-items: center; gap: .45rem; font-size: .8rem; color: var(--accent-text); font-family: var(--font-display); font-weight: 600; }
.track-live .pulse { width: 9px; height: 9px; border-radius: 50%; background: var(--accent); animation: livePulse 1.7s infinite; }
@keyframes livePulse { 0% { box-shadow: 0 0 0 0 rgba(0,128,0,.5); } 70% { box-shadow: 0 0 0 9px rgba(0,128,0,0); } 100% { box-shadow: 0 0 0 0 rgba(0,128,0,0); } }
.track-meta { display: flex; gap: 2rem; margin: 1.4rem 0 2.2rem; }
.track-meta .tm-l { font-size: .78rem; color: var(--muted2); text-transform: uppercase; letter-spacing: .08em; }
.track-meta .tm-v { font-family: var(--font-display); font-weight: 600; font-size: 1.05rem; }
.track-route { position: relative; height: 5px; background: var(--surface-2); border-radius: 5px; margin: 2.6rem 0 1.3rem; }
.track-fill { position: absolute; left: 0; top: 0; height: 100%; width: 0; border-radius: 5px; background: linear-gradient(90deg, var(--accent), var(--accent-2)); transition: width 1.4s cubic-bezier(.65,0,.35,1); }
.track-truck { position: absolute; top: 50%; left: 0; transform: translate(-50%, -50%); transition: left 1.4s cubic-bezier(.65,0,.35,1); width: 34px; height: 34px; border-radius: 50%; background: var(--ink); display: grid; place-items: center; box-shadow: 0 4px 12px rgba(0,0,0,.25); z-index: 2; }
.track-truck svg { width: 18px; height: 18px; color: #fff; }
.track-stops { display: flex; justify-content: space-between; }
.track-stop { flex: 1; text-align: center; position: relative; }
.track-stop:first-child { text-align: left; } .track-stop:last-child { text-align: right; }
.track-stop .sdot { width: 12px; height: 12px; border-radius: 50%; background: var(--surface-2); border: 2px solid var(--hairline-2); margin: 0 auto 8px; transition: background .4s, border-color .4s, transform .4s; }
.track-stop:first-child .sdot { margin-left: 0; } .track-stop:last-child .sdot { margin-right: 0; }
.track-stop.done .sdot { background: var(--accent); border-color: var(--accent); transform: scale(1.15); }
.track-stop .st { font-size: .82rem; color: var(--text-muted); font-family: var(--font-display); }
.track-stop.done .st { color: var(--text); font-weight: 600; }

/* Live-Zähler (Karte) */
.eu-live { display: inline-flex; align-items: center; gap: .5rem; margin-top: 1.6rem; font-family: var(--font-display); font-size: .9rem; color: rgba(255,255,255,.85); }
.eu-live .pulse { width: 9px; height: 9px; border-radius: 50%; background: var(--accent-2); animation: livePulse 1.7s infinite; }
.eu-live b { color: #fff; }

/* Prozess-Timeline mit gezeichneter Linie */
.steps { position: relative; }
.steps.timeline::before { content: ""; position: absolute; left: 25px; top: 26px; bottom: 26px; width: 2px; background: var(--hairline-2); }
.steps.timeline::after { content: ""; position: absolute; left: 25px; top: 26px; width: 2px; height: 0; background: linear-gradient(var(--accent), var(--accent-2)); transition: height 1.4s var(--ease); }
.steps.timeline.drawn::after { height: calc(100% - 52px); }
.steps.timeline .step { position: relative; z-index: 1; }
.steps.timeline .step .n { background: var(--bg); }
.on-dark .steps.timeline .step .n, .eu-section .steps.timeline .step .n { background: var(--ink); }

@media (prefers-reduced-motion: reduce) {
  .w-in { transform: none !important; }
  .marquee-track { animation: none; }
  .track-fill, .track-truck { transition: none; }
}
@media (max-width: 760px) {
  .track-meta { flex-direction: column; gap: .8rem; }
}

/* ---------- Fließende Routenlinien (Startseiten-Hero) ---------- */
.hero-flow { position: absolute; inset: 0; z-index: 1; pointer-events: none; }
.hero-flow .flow { fill: none; stroke: var(--accent-2); stroke-width: 1.6; stroke-dasharray: 9 16; opacity: .16; animation: flowmove 2.6s linear infinite; }
/* Watermark im Unterseiten-Hero (kein transform-Centering → kollidiert nicht mit Parallax) */
.page-hero .ph-mark { right: -3%; top: -15%; bottom: auto; height: 140%; width: auto; max-width: 54%; opacity: .08; z-index: 1; }
@keyframes flowmove { to { stroke-dashoffset: -50; } }

@media (prefers-reduced-motion: reduce) { .hero-flow .flow { animation: none; } }

/* ---------- Kühlkette-Live-Chart (Daten-Viz) ---------- */
.cc-section { position: relative; background: radial-gradient(120% 120% at 15% 0%, var(--ink-3), var(--ink) 62%); color: #fff; overflow: hidden; }
.cc-section::after { content: ""; position: absolute; inset: 0; pointer-events: none; background: radial-gradient(45% 60% at 20% 60%, rgba(16,140,16,.16), transparent 70%); }
.cc-wrap { position: relative; z-index: 2; display: grid; grid-template-columns: .9fr 1.3fr; gap: clamp(2rem, 5vw, 4.5rem); align-items: center; }
.cc-intro .kicker { color: var(--accent-2); }
.cc-intro h2 { color: #fff; }
.cc-intro .lead { color: rgba(255,255,255,.72); }
.cc-readout { display: inline-flex; align-items: baseline; gap: .6rem; margin-top: 1.8rem; padding: .7rem 1.1rem; border: 1px solid var(--line-dark); border-radius: 100px; }
.cc-readout .t { font-family: var(--font-display); font-weight: 700; font-size: 1.7rem; color: #fff; line-height: 1; }
.cc-readout .s { color: var(--accent-2); font-family: var(--font-display); font-weight: 600; font-size: .9rem; }
.cc-chart { width: 100%; height: auto; overflow: visible; }
.cc-band { fill: rgba(21,160,21,.13); }
.cc-bandline { stroke: rgba(21,160,21,.45); stroke-width: 1; stroke-dasharray: 4 5; }
.cc-grid { stroke: rgba(255,255,255,.07); stroke-width: 1; }
.cc-axis { fill: rgba(255,255,255,.5); font-family: var(--font-body); font-size: 13px; }
.cc-area { fill: url(#ccArea); opacity: 0; transition: opacity 1.1s ease .7s; }
.cc-section .drawn .cc-area, .cc-chart.drawn .cc-area { opacity: 1; }
.cc-line { fill: none; stroke: url(#ccGrad); stroke-width: 3; stroke-linecap: round; stroke-linejoin: round; stroke-dasharray: 1400; stroke-dashoffset: 1400; transition: stroke-dashoffset 2.3s cubic-bezier(.16,1,.3,1); }
.cc-chart.drawn .cc-line { stroke-dashoffset: 0; }
.cc-dot { fill: #fff; opacity: 0; transition: opacity .4s ease 1.7s; }
.cc-chart.drawn .cc-dot { opacity: 1; }
.cc-dot-pulse { fill: var(--accent-2); transform-box: fill-box; transform-origin: center; opacity: 0; }
.cc-chart.drawn .cc-dot-pulse { opacity: 1; animation: hubPulse 2.4s ease-out infinite 1.8s; }

/* ---------- Qualitäts-Ringe (animierte Gauges) ---------- */
.anspruch-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 26px; }
.kpi { text-align: center; }
.kpi-ring { position: relative; width: 150px; height: 150px; margin: 0 auto 1.1rem; }
.kpi-ring svg { width: 100%; height: 100%; transform: rotate(-90deg); }
.ring-track { fill: none; stroke: var(--hairline); stroke-width: 8; }
.ring-fg { fill: none; stroke: url(#kpiGrad); stroke-width: 8; stroke-linecap: round; stroke-dasharray: 327; stroke-dashoffset: 327; transition: stroke-dashoffset 1.8s cubic-bezier(.16,1,.3,1); }
.kpi-num { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; gap: 1px; font-family: var(--font-display); font-weight: 700; font-size: 2.1rem; color: var(--text); line-height: 1; }
.kpi-num .u { color: var(--accent-text); font-size: 1.05rem; font-weight: 600; align-self: center; }
.kpi-lbl { font-family: var(--font-display); font-weight: 600; }
.kpi-sub { color: var(--text-muted); font-size: .85rem; margin-top: .2rem; }

@media (prefers-reduced-motion: reduce) {
  .cc-line, .cc-area, .ring-fg { transition: none; }
  .cc-dot-pulse { animation: none; }
}
@media (max-width: 900px) { .cc-wrap { grid-template-columns: 1fr; } }
@media (max-width: 760px) { .anspruch-grid { grid-template-columns: repeat(2, 1fr); } }

/* ---------- Dunkles Daten-Band + animierte Kennzahlen (Unterseiten) ---------- */
.band-dark { position: relative; background: radial-gradient(120% 130% at 80% 0%, var(--ink-3), var(--ink) 62%); color: #fff; overflow: hidden; }
.band-dark::after { content: ""; position: absolute; inset: 0; pointer-events: none; background: radial-gradient(45% 60% at 12% 50%, rgba(16,140,16,.14), transparent 70%); }
.band-dark .wrap { position: relative; z-index: 2; }
.band-dark .section-head h2 { color: #fff; }
.band-dark .section-head .lead { color: rgba(255,255,255,.72); }
.statrow { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(16px, 3vw, 30px); }
.statrow .sr { text-align: center; }
.statrow .sr .n { font-family: var(--font-display); font-weight: 700; font-size: clamp(2rem, 4vw, 2.9rem); color: #fff; line-height: 1; font-variant-numeric: tabular-nums; }
.statrow .sr .n .u { color: var(--accent-2); }
.statrow .sr .l { color: rgba(255,255,255,.62); margin-top: .55rem; font-size: .9rem; }
@media (max-width: 760px) { .statrow { grid-template-columns: repeat(2, 1fr); row-gap: 32px; } }

/* ---------- Meilenstein-Timeline (Über uns) ---------- */
.milestones { position: relative; max-width: 760px; margin: 0 auto; padding-left: 4px; }
.milestones::before { content: ""; position: absolute; left: 19px; top: 12px; bottom: 12px; width: 2px; background: var(--hairline-2); }
.milestones::after { content: ""; position: absolute; left: 19px; top: 12px; width: 2px; height: 0; background: linear-gradient(var(--accent), var(--accent-2)); transition: height 1.8s var(--ease); }
.milestones.drawn::after { height: calc(100% - 24px); }
.ms { position: relative; display: flex; gap: 1.4rem; padding-bottom: 2.4rem; }
.ms:last-child { padding-bottom: 0; }
.ms .ms-dot { position: relative; z-index: 1; flex: none; width: 40px; height: 40px; border-radius: 50%; background: var(--bg); border: 2px solid var(--hairline-2); display: grid; place-items: center; transition: border-color .5s, background .5s, transform .5s; }
.ms .ms-dot::after { content: ""; width: 11px; height: 11px; border-radius: 50%; background: var(--hairline-2); transition: background .5s; }
.milestones.drawn .ms .ms-dot { border-color: var(--accent); transform: scale(1.04); }
.milestones.drawn .ms .ms-dot::after { background: var(--accent); }
.ms .ms-body { padding-top: 6px; }
.ms .ms-year { font-family: var(--font-display); font-weight: 700; color: var(--accent-text); font-size: .95rem; letter-spacing: .02em; }
.ms h3 { margin: .15rem 0 .35rem; font-size: 1.2rem; }
.ms p { color: var(--text-muted); margin: 0; }

/* ---------- Mini-Routenkarte (Standorte) ---------- */
.mini-route { width: 100%; height: auto; overflow: visible; }
.mr-line { fill: none; stroke: url(#mrGrad); stroke-width: 2.5; stroke-linecap: round; stroke-dasharray: 600; stroke-dashoffset: 600; transition: stroke-dashoffset 1.8s var(--ease); }
.mini-route.drawn .mr-line { stroke-dashoffset: 0; }
.mr-node { fill: var(--accent); }
.mr-node-ring { fill: var(--accent-2); transform-box: fill-box; transform-origin: center; animation: hubPulse 2.6s ease-out infinite; }
.mr-label { fill: #fff; font-family: var(--font-display); font-weight: 600; font-size: 15px; }
.mr-sub { fill: rgba(255,255,255,.6); font-family: var(--font-body); font-size: 12px; }
.mr-trav { fill: #fff; filter: drop-shadow(0 0 6px rgba(21,160,21,.9)); offset-rotate: 0deg; animation: mrTravel 3.4s ease-in-out infinite; }
@keyframes mrTravel { to { offset-distance: 100%; } }
@media (prefers-reduced-motion: reduce) { .mr-trav, .mr-node-ring { animation: none; } .mr-line { stroke-dashoffset: 0; } }

/* ---------- Autobahn-Karte (Standorte, Bergisches Land) ---------- */
.abmap-wrap { max-width: 940px; margin: 0 auto; }
.abmap { width: 100%; height: auto; display: block; overflow: visible; }
.ab-grid { stroke: rgba(255,255,255,.05); stroke-width: 1; }
.ab-casing { fill: none; stroke: #2a3036; stroke-width: 13; stroke-linecap: round; }
.ab-road { fill: none; stroke: #444c54; stroke-width: 8; stroke-linecap: round; }
.ab-flow { fill: none; stroke: var(--accent-2); stroke-width: 3; stroke-linecap: round; stroke-dasharray: 16 30; animation: abflow 1.3s linear infinite; }
@keyframes abflow { to { stroke-dashoffset: -46; } }
.ab-conn { fill: none; stroke: var(--accent-2); stroke-width: 2.5; stroke-dasharray: 6 7; stroke-linecap: round; opacity: 0; transition: opacity .5s ease; }
.abmap.drawn .ab-conn { opacity: .95; animation: abflow 1s linear infinite; }
.ab-loc-ring { fill: var(--accent-2); transform-box: fill-box; transform-origin: center; animation: hubPulse 2.6s ease-out infinite; }
.ab-loc { fill: #fff; stroke: var(--accent); stroke-width: 3; }
.ab-loc-label { fill: #fff; font-family: var(--font-display); font-weight: 600; font-size: 17px; }
.ab-loc-sub { fill: rgba(255,255,255,.62); font-family: var(--font-body); font-size: 13px; }
@media (prefers-reduced-motion: reduce) { .ab-flow, .ab-loc-ring, .abmap.drawn .ab-conn { animation: none; } }

/* ---------- Echte Deutschlandkarte (Leaflet) ---------- */
.de-map { height: 560px; border-radius: var(--radius-xl); overflow: hidden; box-shadow: var(--shadow-lg); border: 1px solid var(--line-dark); }
.de-map .leaflet-container { background: var(--ink); font-family: var(--font-body); }
/* Helle deutsche OSM-Kacheln in dunkles Taurus-Design wandeln (nur Kacheln, nicht Routen/Marker) */
.de-map .leaflet-tile-pane { filter: invert(1) hue-rotate(180deg) brightness(.82) contrast(.95) grayscale(.85); }
/* Grüne Taurus-Tönung über die Kacheln (z-index zwischen Kacheln 200 und Overlays 400) */
.de-tint { position: absolute; inset: 0; z-index: 350; pointer-events: none; background: #0aa033; mix-blend-mode: color; opacity: .92; }
.de-tint::after { content: ""; position: absolute; inset: 0; background: linear-gradient(135deg, rgba(0,90,0,.35), rgba(8,40,20,.5)); mix-blend-mode: multiply; }
.de-map .leaflet-control-attribution { background: rgba(0,0,0,.55); color: rgba(255,255,255,.55); font-size: 10px; }
.de-map .leaflet-control-attribution a { color: rgba(255,255,255,.8); }
.de-map .leaflet-bar a { background: var(--ink-2); color: #fff; border-bottom-color: var(--line-dark); }
.de-map .leaflet-bar a:hover { background: var(--ink-3); }
.de-route { stroke-dasharray: 7 11; animation: deflow 1.1s linear infinite; }
@keyframes deflow { to { stroke-dashoffset: -36; } }
.de-pin { position: relative; }
.de-pin-dot { display: block; width: 15px; height: 15px; border-radius: 50%; background: var(--accent); border: 2.5px solid #fff; box-shadow: 0 0 0 0 rgba(21,160,21,.55); animation: depulse 2.2s infinite; }
@keyframes depulse { 0% { box-shadow: 0 0 0 0 rgba(21,160,21,.55); } 70% { box-shadow: 0 0 0 16px rgba(21,160,21,0); } 100% { box-shadow: 0 0 0 0 rgba(21,160,21,0); } }
.de-pin-label { position: absolute; left: 20px; top: -3px; white-space: nowrap; font-family: var(--font-display); font-weight: 700; font-size: 14px; color: #fff; text-shadow: 0 1px 5px rgba(0,0,0,.9); }
.de-pin-label span { display: block; font-weight: 400; font-size: 11px; color: rgba(255,255,255,.7); }
.de-legend { display: flex; gap: 1.6rem; flex-wrap: wrap; justify-content: center; margin-top: 1.4rem; color: rgba(255,255,255,.7); font-size: .88rem; font-family: var(--font-display); }
.de-legend span { display: inline-flex; align-items: center; gap: .5rem; }
.de-legend .dot { width: 10px; height: 10px; border-radius: 50%; }
/* Legende auf hellem Hintergrund (z. B. Anfahrt-Sektion Kontaktseite) lesbar machen */
.bg-paper2 .de-legend, .bg-paper .de-legend { color: var(--text-muted); }
.de-note { text-align: center; color: rgba(255,255,255,.45); font-size: .78rem; margin-top: .8rem; }

/* ---------- Anfrageseite: luftige, gegliederte Form ---------- */
.anfrage-wrap { max-width: 880px; margin: 0 auto; }
.flow-steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem; margin-bottom: clamp(2rem, 4vw, 3rem); }
.flow-step { display: flex; gap: .85rem; align-items: flex-start; padding: 1.2rem 1.3rem; background: var(--surface); border: 1px solid var(--hairline); border-radius: var(--radius-lg); }
.flow-step .fs-n { width: 30px; height: 30px; flex: none; border-radius: 50%; background: rgba(0,128,0,.12); color: var(--accent-text); font-family: var(--font-display); font-weight: 700; font-size: .9rem; display: grid; place-items: center; }
.flow-step b { font-family: var(--font-display); display: block; margin-bottom: .2rem; font-size: .98rem; }
.flow-step span { color: var(--text-muted); font-size: .86rem; line-height: 1.45; }
.form-card.wide { padding: clamp(1.8rem, 4vw, 3.2rem); }
.fgroup { margin-bottom: 2.4rem; }
.fgroup:last-of-type { margin-bottom: 0; }
.fgroup-head { display: flex; align-items: center; gap: .8rem; margin-bottom: 1.4rem; }
.fgroup-num { width: 30px; height: 30px; flex: none; border-radius: 50%; background: var(--accent); color: #fff; font-family: var(--font-display); font-weight: 700; font-size: .92rem; display: grid; place-items: center; box-shadow: 0 4px 12px rgba(0,128,0,.25); }
.fgroup-head h3 { margin: 0; font-size: 1.18rem; }
.fgroup .field, .fgroup .field-row { margin-bottom: 1.2rem; }
.fgroup .field:last-child, .fgroup .field-row:last-child { margin-bottom: 0; }
.anfrage-callout { display: flex; align-items: center; gap: .8rem; justify-content: center; margin-top: 1.8rem; color: var(--text-muted); font-size: .92rem; }
.anfrage-callout svg { width: 18px; height: 18px; color: var(--accent); }
.anfrage-callout a { color: var(--accent-text); font-family: var(--font-display); font-weight: 600; }
@media (max-width: 760px) { .flow-steps { grid-template-columns: 1fr; } }

/* ---------- Info-Tooltip („i") für Formularfelder ---------- */
.info-tip { position: relative; display: inline-flex; vertical-align: middle; margin-left: .4rem; }
.info-tip > .info-btn { width: 17px; height: 17px; border-radius: 50%; border: 0; background: var(--hairline-2); color: #fff; font-family: var(--font-display); font-size: 11px; font-weight: 700; font-style: italic; cursor: help; display: grid; place-items: center; line-height: 1; padding: 0; }
.info-tip > .info-btn:hover, .info-tip > .info-btn:focus-visible { background: var(--accent); }
.info-pop { position: absolute; bottom: calc(100% + 9px); left: 50%; transform: translateX(-50%) translateY(4px); width: 250px; max-width: 70vw; background: var(--ink); color: #fff; font-family: var(--font-body); font-weight: 400; font-size: .82rem; line-height: 1.5; padding: .7rem .85rem; border-radius: 10px; box-shadow: var(--shadow-lg); opacity: 0; visibility: hidden; transition: opacity .2s, transform .2s; z-index: 30; pointer-events: none; text-align: left; }
.info-pop::after { content: ""; position: absolute; top: 100%; left: 50%; transform: translateX(-50%); border: 6px solid transparent; border-top-color: var(--text); }
.info-tip:hover .info-pop, .info-tip:focus-within .info-pop { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0); }
@media (max-width: 560px) { .info-pop { left: auto; right: 0; transform: translateY(4px); } .info-pop::after { left: auto; right: 6px; } .info-tip:hover .info-pop, .info-tip:focus-within .info-pop { transform: translateY(0); } }

/* ---------- Prose (Recht) ---------- */
.prose { max-width: var(--wrap-narrow); }
.prose h2 { font-size: clamp(1.4rem,2.5vw,1.9rem); margin-top: 2.5rem; }
.prose h3 { font-size: 1.2rem; margin-top: 1.8rem; }
.prose p, .prose li { color: var(--text-muted); }
.prose a { color: var(--accent-text); text-decoration: underline; text-underline-offset: 3px; }
.prose ul { padding-left: 1.2rem; }
.marker { background: #FFF3CD; color: #7a5b00; padding: 0 .35em; border-radius: 3px; font-weight: 500; }

/* ---------- Reveal Animation (verfeinert, „Apple"-Easing) ---------- */
.reveal { opacity: 0; transform: translateY(32px); transition: opacity .9s cubic-bezier(.16,1,.3,1), transform .9s cubic-bezier(.16,1,.3,1); will-change: opacity, transform; }
.reveal.in { opacity: 1; transform: none; }
.reveal.r-scale { transform: translateY(24px) scale(.97); }
.reveal.r-scale.in { transform: none; }
.reveal[data-d="1"] { transition-delay: .09s; }
.reveal[data-d="2"] { transition-delay: .18s; }
.reveal[data-d="3"] { transition-delay: .27s; }
.reveal[data-d="4"] { transition-delay: .36s; }
.reveal[data-d="5"] { transition-delay: .45s; }
/* Parallax-Helfer (per JS gesteuert) */
[data-parallax] { will-change: transform; }
/* Count-up: gleiche Breite, kein Springen */
.statband .num, .hero-stats .num { font-variant-numeric: tabular-nums; }

@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1 !important; transform: none !important; transition: none; }
  .hero-scroll, .hero-scroll .line { animation: none; }
  .eu-route { stroke-dashoffset: 0 !important; opacity: .9 !important; }
  .eu-traveler { display: none; }
  html { scroll-behavior: auto; }
}

/* ---------- Icon-Einheitlichkeit (ein Strichgewicht site-weit) ---------- */
.card .ic svg, .feat-list .chk svg, .contact-method .cm-ic svg, .jobx .jx-ic svg,
.value-ic svg, .trustbar .items svg, .step .n svg { stroke-width: 1.75; stroke-linecap: round; stroke-linejoin: round; }

/* ---------- Europakarte mit animierten Routen ---------- */
.eu-section { position: relative; background: radial-gradient(120% 120% at 80% 0%, var(--ink-3), var(--ink) 62%); color: #fff; overflow: hidden; }
.eu-section::after { content: ""; position: absolute; inset: 0; pointer-events: none; background: radial-gradient(50% 60% at 85% 50%, rgba(16,140,16,.16), transparent 70%); }
.eu-wrap { position: relative; z-index: 2; display: grid; grid-template-columns: .85fr 1.25fr; gap: clamp(2rem, 5vw, 4.5rem); align-items: center; }
.eu-intro .kicker { color: var(--accent-2); }
.eu-intro h2 { color: #fff; }
.eu-intro .lead { color: rgba(255,255,255,.72); }
.eu-facts { display: flex; gap: 2rem; margin-top: 2rem; flex-wrap: wrap; }
.eu-facts .num { font-family: var(--font-display); font-weight: 700; font-size: 2rem; color: #fff; line-height: 1; }
.eu-facts .lbl { color: rgba(255,255,255,.6); font-size: .85rem; margin-top: .35rem; }
.eu-map-box { position: relative; }
.eu-map { width: 100%; height: auto; display: block; overflow: visible; }
.eu-land-dot { fill: rgba(255,255,255,.12); }
.eu-route { fill: none; stroke: url(#euGrad); stroke-width: 2; stroke-linecap: round; opacity: 0; }
.eu-route.draw { opacity: .85; stroke-dashoffset: 0 !important; transition: stroke-dashoffset 1.7s cubic-bezier(.16,1,.3,1), opacity .5s ease; }
.eu-city-dot { fill: #fff; opacity: 0; transform-box: fill-box; transform-origin: center; transition: opacity .4s ease; }
.eu-city-dot.show { opacity: 1; }
.eu-city-ring { fill: none; stroke: var(--accent-2); stroke-width: 1.5; opacity: 0; }
.eu-city-label { fill: rgba(255,255,255,.78); font-family: var(--font-display); font-size: 14px; font-weight: 500; opacity: 0; transition: opacity .5s ease; }
.eu-city-label.show { opacity: 1; }
.eu-hub-core { fill: var(--accent-2); }
.eu-hub-pulse { fill: var(--accent-2); transform-box: fill-box; transform-origin: center; animation: hubPulse 2.4s ease-out infinite; }
@keyframes hubPulse { 0% { transform: scale(1); opacity: .55; } 70%, 100% { transform: scale(4.5); opacity: 0; } }
.eu-traveler { fill: #fff; filter: drop-shadow(0 0 6px rgba(21,160,21,.9)); }
.eu-hub-label { fill: #fff; font-family: var(--font-display); font-size: 15px; font-weight: 600; }

/* ---------- Value-Cards (einheitliche Icon-Boxen) ---------- */
.value-ic { width: 52px; height: 52px; border-radius: 14px; display: grid; place-items: center; background: linear-gradient(135deg, rgba(0,128,0,.14), rgba(0,128,0,.05)); margin-bottom: 1.2rem; }
.value-ic svg { width: 26px; height: 26px; color: var(--accent-text); }

@media (max-width: 900px) {
  .eu-wrap { grid-template-columns: 1fr; }
  .eu-map-box { order: 2; }
}

/* ---------- Utilities ---------- */
.mt-0 { margin-top: 0; } .mb-0 { margin-bottom: 0; }
.text-center { text-align: center; }
.bg-paper2 { background: var(--surface); }
.bg-paper3 { background: var(--surface-2); }
.divider { height:1px; background: var(--hairline); border:0; margin: 0; }

/* ---------- Responsive ---------- */
@media (max-width: 1024px) {
  .nav-links, .nav .phone-link { display: none; }
  .phone-btn-mobile { display: grid; }
  .burger { display: flex; }
  .footer-top { grid-template-columns: 1fr 1fr; gap: 2rem; }
}
@media (max-width: 760px) {
  body { font-size: 16px; }
  h1 { font-size: clamp(2.1rem, 8.5vw, 3rem); }
  h2 { font-size: clamp(1.7rem, 6vw, 2.4rem); }
  .cols-2, .cols-3, .cols-4 { grid-template-columns: 1fr; }
  .jobs-grid { grid-template-columns: 1fr; }
  .split { grid-template-columns: 1fr; }
  .split.reverse .split-media { order: 0; }
  .split-media .media { min-height: 0; height: auto; aspect-ratio: 4/3; }
  .field-row { grid-template-columns: 1fr; }
  .trustbar .wrap { justify-content: center; text-align: center; }
  .job { flex-direction: column; align-items: flex-start; }
  .job .j-action { width: 100%; }
  .job .j-action .btn { width: 100%; }
  .footer-top { grid-template-columns: 1fr; }
  .split-media .badge { left: 50%; transform: translateX(-50%); bottom: -20px; }
  .nav-cta .btn:not(.burger) { display: none; }
  .nav-cta .lang-switch { display: none; }
}
.mm-lang { display: none; }
@media (max-width: 760px) {
  .mm-foot .mm-lang { display: flex; justify-content: center; margin-top: .4rem; }
  .mm-foot .mm-lang .lang-btn .lc { display: inline; }
}
@media (max-width: 420px) {
  .hero-stats { gap: 1.4rem; }
  .wa-float { width: 52px; height: 52px; bottom: 16px; right: 16px; }
}

/* --- WhatsApp Floating-Button --- */
.wa-fab {
  position: fixed; right: 22px; bottom: 22px; z-index: 850;
  display: flex; align-items: center; height: 58px; width: 58px;
  background: #25d366; color: #fff; border-radius: 999px;
  box-shadow: 0 10px 28px rgba(0,0,0,.22), 0 2px 6px rgba(0,0,0,.18);
  overflow: hidden; text-decoration: none;
  transition: width .38s cubic-bezier(.2,.8,.2,1), box-shadow .25s ease, transform .25s ease;
  animation: waPop .4s cubic-bezier(.2,.8,.2,1) .6s both;
}
.wa-fab .wa-fab-ic { flex: 0 0 58px; width: 58px; height: 58px; display: grid; place-items: center; }
.wa-fab .wa-fab-ic svg { width: 31px; height: 31px; }
.wa-fab .wa-fab-label { white-space: nowrap; font-family: var(--font-display); font-weight: 600; font-size: .95rem; opacity: 0; transform: translateX(-6px); transition: opacity .25s ease, transform .25s ease; }
.wa-fab:hover { width: 216px; box-shadow: 0 14px 34px rgba(37,211,102,.5); transform: translateY(-2px); }
.wa-fab:hover .wa-fab-label { opacity: 1; transform: none; padding-right: 22px; }
.wa-fab:focus-visible { outline: 3px solid rgba(37,211,102,.6); outline-offset: 3px; }
@keyframes waPop { from { opacity: 0; transform: scale(.6) translateY(10px); } to { opacity: 1; transform: scale(1) translateY(0); } }
@media (max-width: 640px) {
  .wa-fab { right: 16px; bottom: 16px; height: 54px; width: 54px; }
  .wa-fab .wa-fab-ic { flex-basis: 54px; width: 54px; height: 54px; }
  .wa-fab:hover { width: 54px; }
  .wa-fab .wa-fab-label { display: none; }
}
@media (prefers-reduced-motion: reduce) { .wa-fab { animation: none; } }

/* Spiel-Launcher „Auf Achse" — runder Floating-Button, rechts unten über dem WhatsApp-Button */
.game-fab {
  position: fixed; right: 22px; bottom: 92px; z-index: 851;
  width: 56px; height: 56px; border-radius: 999px;
  display: flex; align-items: center; justify-content: center;
  background: #16181b; color: var(--accent-2); border: 1px solid rgba(255,255,255,.18);
  box-shadow: 0 10px 28px rgba(0,0,0,.26), 0 2px 6px rgba(0,0,0,.2);
  cursor: pointer; transition: transform .25s ease, box-shadow .25s ease, background .25s ease;
  animation: waPop .4s cubic-bezier(.2,.8,.2,1) .9s both;
}
.game-fab::after { content: ""; position: absolute; inset: 0; border-radius: 999px; pointer-events: none;
  animation: gameRing 2.8s ease-out infinite; }
.game-fab .game-fab-ic { width: 26px; height: 26px; display: block; }
.game-fab .game-fab-label { position: absolute; right: calc(100% + 12px); top: 50%;
  transform: translateY(-50%) translateX(6px); white-space: nowrap;
  background: #16181b; color: #fff; padding: .42rem .72rem; border-radius: 9px;
  font-family: var(--font-display); font-weight: 600; font-size: .85rem; letter-spacing: .01em;
  box-shadow: 0 8px 22px rgba(0,0,0,.28); opacity: 0; pointer-events: none;
  transition: opacity .22s ease, transform .22s ease; }
.game-fab:hover, .game-fab:focus-visible { transform: translateY(-3px); background: #1d2024; box-shadow: 0 16px 36px rgba(0,0,0,.38); }
.game-fab:hover .game-fab-label, .game-fab:focus-visible .game-fab-label { opacity: 1; transform: translateY(-50%) translateX(0); }
.game-fab:focus-visible { outline: 3px solid var(--accent); outline-offset: 3px; }
@keyframes gameRing { 0% { box-shadow: 0 0 0 0 rgba(21,160,21,.5); } 70%, 100% { box-shadow: 0 0 0 14px rgba(21,160,21,0); } }
@media (max-width: 640px) {
  .game-fab { right: 16px; bottom: 84px; width: 50px; height: 50px; }
  .game-fab .game-fab-ic { width: 24px; height: 24px; }
}
@media (prefers-reduced-motion: reduce) { .game-fab, .game-fab::after { animation: none; } }
/* Spiel-Unterseite (spiel.html) — zentriertes Landing */
.game-land { max-width: 760px; margin-inline: auto; text-align: center; }
.game-land .hero-actions { justify-content: center; }
/* Bestenliste auf der Spiel-Unterseite */
.hs-board { max-width: 520px; margin: 1.6rem auto 0; }
.hs-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 6px; }
.hs-list li { display: flex; align-items: center; gap: 1rem; padding: .8rem 1.1rem; background: var(--surface); border: 1px solid var(--hairline); border-radius: var(--radius-lg); }
.hs-list li .r { width: 1.8em; text-align: right; font-family: var(--font-display); font-weight: 700; color: var(--text-muted-2); font-variant-numeric: tabular-nums; }
.hs-list li .n { flex: 1; font-family: var(--font-display); font-weight: 600; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.hs-list li .s { font-family: var(--font-display); font-weight: 700; color: var(--accent-text); font-variant-numeric: tabular-nums; }
.hs-list li:first-child { border-color: var(--accent); box-shadow: var(--shadow-sm); }
.hs-empty { text-align: center; color: var(--text-muted); }
/* Brandsta-Media-Werbung auf der Spiel-Unterseite */
.bm-ad-section .wrap { padding-top: 1.4rem; padding-bottom: 2.2rem; }
.bm-ad { display: flex; align-items: center; justify-content: center; flex-wrap: wrap; gap: .6rem 1rem; max-width: 760px; margin: 0 auto; padding: 1rem 1.4rem; background: var(--surface); border: 1px solid var(--hairline); border-radius: var(--radius-xl); text-decoration: none; box-shadow: var(--shadow-sm); transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease; }
.bm-ad:hover { border-color: var(--accent); box-shadow: var(--shadow); transform: translateY(-2px); }
.bm-ad-tag { flex: none; font-family: var(--font-display); font-size: .62rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--text-muted-2); border: 1px solid var(--hairline-2); border-radius: 6px; padding: .2rem .45rem; }
.bm-ad-txt { color: var(--text-muted); font-size: .95rem; }
.bm-ad-txt strong { color: var(--text); font-family: var(--font-display); }
.bm-ad-cta { flex: none; font-family: var(--font-display); font-weight: 700; color: var(--accent-text); white-space: nowrap; }

/* --- Karten-Consent-Overlay (DSGVO Klick-zum-Laden) --- */
.de-map { position: relative; }
.map-consent { position: absolute; inset: 0; z-index: 500; display: grid; place-items: center; padding: 1.5rem;
  background: radial-gradient(120% 120% at 50% 40%, rgba(18,20,23,.92), rgba(10,12,14,.97)); text-align: center; }
.map-consent .mc-inner { max-width: 460px; color: rgba(255,255,255,.92); }
.map-consent svg { width: 38px; height: 38px; color: var(--accent-2); margin-bottom: .6rem; }
.map-consent .mc-title { font-family: var(--font-display); font-weight: 700; font-size: 1.05rem; color: #fff; margin: 0 0 .5rem; }
.map-consent .mc-sub { font-size: .86rem; line-height: 1.6; color: rgba(255,255,255,.65); margin: 0 0 1.1rem; }
.map-consent .mc-sub a { color: var(--accent-2); text-decoration: underline; text-underline-offset: 3px; }
.map-consent .btn { margin: 0 auto; }
.map-consent .mc-remember { display: inline-flex; align-items: center; gap: .5rem; margin-top: .9rem; font-size: .82rem; color: rgba(255,255,255,.6); cursor: pointer; }
.map-consent .mc-remember input { accent-color: var(--accent); }

/* ===== Leistungen: vertikale Punkt-Leiste (Scroll-Spy, dezent) ===== */
.svc-rail { position: fixed; right: 22px; top: 50%; transform: translateY(-50%); z-index: 45; display: flex; flex-direction: column; gap: 16px; align-items: flex-end; }
.svc-rail a { display: flex; align-items: center; gap: 11px; text-decoration: none; }
.svc-rail .sr-l { font-family: var(--font-display); font-weight: 600; font-size: .8rem; color: #fff; background: rgba(18,20,23,.92); padding: .38rem .75rem; border-radius: 100px; white-space: nowrap; opacity: 0; transform: translateX(8px); transition: opacity .25s ease, transform .25s ease; pointer-events: none; box-shadow: 0 8px 22px rgba(0,0,0,.28); }
.svc-rail .sr-d { width: 11px; height: 11px; border-radius: 100px; background: rgba(125,135,128,.5); transition: height .35s cubic-bezier(.2,.8,.2,1), background .3s ease, box-shadow .3s ease; flex: none; }
.svc-rail a:hover .sr-l { opacity: 1; transform: none; }
.svc-rail a:hover .sr-d { background: var(--accent-2); }
.svc-rail a.active .sr-d { background: var(--accent); height: 28px; box-shadow: 0 0 0 4px rgba(0,128,0,.18), 0 0 14px rgba(58,209,58,.55); }
.svc-rail a.active .sr-l { opacity: 1; transform: none; }
section[id] { scroll-margin-top: calc(var(--header-h) + 24px); }
@media (prefers-reduced-motion: no-preference) { html { scroll-behavior: smooth; } }
@media (max-width: 1100px) { .svc-rail { display: none; } }

/* ===== Leistungs-Accents ===== */
.svc-usage { margin-top: 1.1rem; background: var(--surface); border: 1px solid var(--hairline); border-radius: var(--radius-lg); padding: 1rem 1.15rem; box-shadow: var(--shadow); }
.svc-usage .su-top { display: flex; justify-content: space-between; align-items: baseline; font-family: var(--font-display); font-weight: 600; font-size: .85rem; color: var(--text); margin-bottom: .55rem; }
.svc-usage .su-top span:last-child { color: var(--accent-text); }
.svc-usage .su-bar { height: 14px; border-radius: 999px; background: var(--surface-2); overflow: hidden; }
.svc-usage .su-fill { height: 100%; width: 0; border-radius: 999px; background: linear-gradient(90deg, var(--accent), var(--accent-2)); transition: width 1.4s cubic-bezier(.2,.8,.2,1); }
.reveal.in .svc-usage .su-fill { width: var(--su, 55%); }
.svc-usage .su-cap { margin-top: .55rem; font-size: .8rem; color: var(--text-muted); }

.svc-cycle { display: flex; align-items: center; gap: .55rem; flex-wrap: wrap; margin-top: 1.2rem; }
.svc-cycle .cy { display: inline-flex; align-items: center; gap: .45rem; padding: .55rem .95rem; border-radius: 999px; background: var(--surface); border: 1px solid var(--hairline); font-family: var(--font-display); font-weight: 600; font-size: .85rem; color: var(--text); opacity: 0; transform: translateY(8px); }
.svc-cycle .cy svg { width: 16px; height: 16px; color: var(--accent); }
.svc-cycle .cy-arr { color: var(--accent); font-weight: 700; opacity: .55; }
.reveal.in .svc-cycle .cy { animation: cyIn .5s forwards; }
.svc-cycle .cy:nth-child(1) { animation-delay: .12s; }
.svc-cycle .cy:nth-child(3) { animation-delay: .34s; }
.svc-cycle .cy:nth-child(5) { animation-delay: .56s; }
@keyframes cyIn { to { opacity: 1; transform: none; } }
@media (prefers-reduced-motion: reduce) { .svc-cycle .cy { opacity: 1; transform: none; animation: none; } }

/* Usage-Box: Split-Media als Spalte stapeln, damit nichts in die nächste Sektion überläuft */
.split-media.has-extra { display: flex; flex-direction: column; gap: 1.1rem; }
.split-media.has-extra .media { height: auto; flex: 1 1 auto; min-height: 300px; }

/* Lesbarkeit der feat-list auf der dunklen Kühlketten-Sektion */
.cc-section .feat-list strong { color: #fff; }
.cc-section .feat-list span { color: rgba(255,255,255,.72); }
.cc-section .feat-list .chk { background: rgba(58,209,58,.16); }
.cc-section .feat-list .chk svg { color: var(--accent-2); }

/* Naht zwischen zwei dunklen Sektionen (Kühlkette → Ablauf) enger ziehen */
.seam-dark-bottom { padding-bottom: clamp(26px, 4vw, 52px) !important; }
.seam-dark-top { padding-top: clamp(22px, 3.5vw, 44px) !important; }

/* ===== Animierter Ablauf (3 Schritte, Endlos-Loop) ===== */
.flowline { position: relative; display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1.2rem, 4vw, 3rem); max-width: 940px; margin: 2.6rem auto 0; }
.flowline .fl-track { position: absolute; top: 28px; left: 16.6%; right: 16.6%; height: 3px; background: rgba(255,255,255,.14); border-radius: 3px; }
.flowline .fl-track::before { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, var(--accent), var(--accent-2)); border-radius: 3px; transform-origin: left; transform: scaleX(0); animation: flFill 6s linear infinite; }
.flowline .fl-dot { position: absolute; top: 50%; left: 0; width: 13px; height: 13px; margin: -6.5px 0 0 -6.5px; border-radius: 50%; background: #fff; box-shadow: 0 0 0 5px rgba(58,209,58,.3), 0 0 16px rgba(58,209,58,.9); animation: flMove 6s linear infinite; }
.flowline .fl-step { position: relative; text-align: center; }
.flowline .fl-node { width: 58px; height: 58px; margin: 0 auto 1.1rem; border-radius: 50%; display: grid; place-items: center; background: var(--ink-2); border: 2px solid rgba(255,255,255,.16); color: rgba(255,255,255,.55); position: relative; z-index: 2; animation: flNode 6s ease-in-out infinite; animation-delay: calc(var(--i, 0) * 2s); }
.flowline .fl-node svg { width: 25px; height: 25px; }
.flowline .fl-num { position: absolute; top: -4px; right: -4px; width: 22px; height: 22px; border-radius: 50%; background: var(--accent); color: #fff; font-family: var(--font-display); font-weight: 700; font-size: .74rem; display: grid; place-items: center; z-index: 3; box-shadow: 0 2px 8px rgba(0,0,0,.4); }
.flowline .fl-step h3 { color: #fff; margin: 0 0 .45rem; font-size: 1.12rem; }
.flowline .fl-step p { color: rgba(255,255,255,.62); font-size: .92rem; margin: 0; line-height: 1.55; }
@keyframes flMove { 0% { left: 0; opacity: 0; } 6% { opacity: 1; } 94% { opacity: 1; } 100% { left: 100%; opacity: 0; } }
@keyframes flFill { 0% { transform: scaleX(0); } 92% { transform: scaleX(1); } 100% { transform: scaleX(1); } }
@keyframes flNode {
  0%   { background: var(--ink-2); border-color: rgba(255,255,255,.16); color: rgba(255,255,255,.55); transform: scale(1); box-shadow: 0 0 0 0 rgba(58,209,58,0); }
  10%  { background: #154a20; border-color: var(--accent-2); color: #fff; transform: scale(1.09); box-shadow: 0 0 0 7px rgba(58,209,58,.16), 0 0 26px rgba(58,209,58,.5); }
  30%  { background: #143f1c; border-color: var(--accent-2); color: #fff; transform: scale(1.05); box-shadow: 0 0 0 5px rgba(58,209,58,.12), 0 0 18px rgba(58,209,58,.36); }
  46%, 100% { background: var(--ink-2); border-color: rgba(255,255,255,.16); color: rgba(255,255,255,.55); transform: scale(1); box-shadow: 0 0 0 0 rgba(58,209,58,0); }
}
@media (max-width: 760px) {
  .flowline { grid-template-columns: 1fr; gap: 1.3rem; max-width: 460px; }
  .flowline .fl-track, .flowline .fl-dot { display: none; }
  .flowline .fl-step { display: flex; gap: 1.1rem; text-align: left; align-items: flex-start; }
  .flowline .fl-node { margin: 0; flex: none; }
}
@media (prefers-reduced-motion: reduce) {
  .flowline .fl-node, .flowline .fl-dot, .flowline .fl-track::before { animation: none; }
  .flowline .fl-node { background: #143f1c; border-color: var(--accent-2); color: #fff; }
  .flowline .fl-track::before { transform: scaleX(1); }
}

/* ===== Standorte: animierte Autobahn-Anbindung ===== */
.ab-shields { display: flex; justify-content: center; flex-wrap: wrap; gap: clamp(.7rem, 2.4vw, 1.5rem); margin-top: 2.4rem; }
.ab-shield { position: relative; display: inline-flex; flex-direction: column; align-items: center; gap: .18rem; background: linear-gradient(168deg, #18a318, var(--accent) 52%, #0a6b0a); border: 2.5px solid #fff; border-radius: 12px; padding: .5rem .9rem .55rem; color: #fff; box-shadow: 0 14px 30px rgba(0,0,0,.26); opacity: 0; transform: translateY(14px); }
.ab-shield::after { content: ""; position: absolute; inset: -3.5px; border-radius: 15px; border: 1px solid rgba(0,0,0,.14); pointer-events: none; }
.ab-shield .ab-sym { width: 27px; height: 19px; fill: #fff; }
.ab-shield .ab-no { font-family: var(--font-display); font-weight: 700; font-size: clamp(1.15rem, 2.7vw, 1.55rem); line-height: 1; letter-spacing: .01em; white-space: nowrap; }
.ab-shields.in .ab-shield { animation: abIn .55s cubic-bezier(.2,.8,.2,1) forwards; animation-delay: calc(var(--d, 0) * .12s); }
@keyframes abIn { to { opacity: 1; transform: none; } }
.ab-road { height: 5px; max-width: 680px; margin: 1.7rem auto 0; border-radius: 5px; background: repeating-linear-gradient(90deg, rgba(58,209,58,.85) 0 24px, rgba(255,255,255,.06) 24px 48px); background-size: 48px 100%; animation: abRoad 1.1s linear infinite; }
@keyframes abRoad { to { background-position: 48px 0; } }
.reach-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(14px, 3vw, 26px); margin-top: 2.6rem; }
.reach { text-align: center; padding: 1.3rem 1rem; background: var(--surface); border: 1px solid var(--hairline); border-radius: var(--radius-lg); box-shadow: var(--shadow); }
.reach .r-t { display: block; font-family: var(--font-display); font-weight: 700; font-size: clamp(1.35rem, 3vw, 1.95rem); color: var(--text); line-height: 1; }
.reach .r-t .u { color: var(--accent-text); }
.reach .r-l { display: block; margin-top: .55rem; color: var(--text-muted); font-size: .9rem; }
@media (max-width: 760px) { .reach-grid { grid-template-columns: repeat(2, 1fr); } }
@media (prefers-reduced-motion: reduce) { .ab-road { animation: none; } .ab-shields .ab-shield { opacity: 1; transform: none; animation: none; } }

/* Karten-Icon Micro-Interaktion */
.card .ic { transition: transform .3s cubic-bezier(.2,.8,.2,1), background .3s ease; }
.card:hover .ic { transform: scale(1.09) rotate(-4deg); background: linear-gradient(135deg, rgba(16,140,16,.24), rgba(16,140,16,.09)); }

/* ===== Karriere: scroll-gezeichnete vertikale Timeline ===== */
.vtimeline { position: relative; display: grid; gap: 2.1rem; }
.vt-rail { position: absolute; left: 26px; top: 14px; bottom: 14px; width: 3px; background: var(--hairline-2); border-radius: 3px; overflow: hidden; }
.vt-rail .vt-fill { position: absolute; left: 0; top: 0; width: 100%; height: 0; background: linear-gradient(var(--accent), var(--accent-2)); border-radius: 3px; transition: height .12s linear; }
.vt-step { position: relative; display: flex; gap: 1.3rem; align-items: flex-start; }
.vt-node { position: relative; z-index: 2; flex: none; width: 54px; height: 54px; border-radius: 50%; display: grid; place-items: center; background: var(--bg); border: 2px solid var(--hairline-2); color: var(--text-muted-2); transition: background .45s ease, border-color .45s ease, color .45s ease, box-shadow .45s ease, transform .45s cubic-bezier(.2,.8,.2,1); }
.vt-node svg { width: 24px; height: 24px; }
.vt-node b { position: absolute; top: -5px; right: -5px; width: 21px; height: 21px; border-radius: 50%; background: var(--hairline-2); color: #fff; font-family: var(--font-display); font-weight: 700; font-size: .72rem; display: grid; place-items: center; transition: background .45s ease; z-index: 1; }
.vt-node::after { content: ""; position: absolute; inset: -2px; border-radius: 50%; border: 2px solid var(--accent); opacity: 0; pointer-events: none; }
.vt-step.reached .vt-node { background: #eaf6ea; border-color: var(--accent); color: var(--accent-text); box-shadow: 0 0 0 5px rgba(0,128,0,.1), 0 10px 22px rgba(0,128,0,.18); transform: scale(1.05); animation: vtPop .5s cubic-bezier(.2,.8,.2,1); }
.vt-step.reached .vt-node::after { animation: vtRing .75s ease-out; }
.vt-step.reached .vt-node b { background: var(--accent); }
@keyframes vtPop { 0% { transform: scale(.82); } 55% { transform: scale(1.18); } 100% { transform: scale(1.05); } }
@keyframes vtRing { 0% { opacity: .55; transform: scale(1); } 100% { opacity: 0; transform: scale(1.55); } }
.vt-c { padding-top: .35rem; }
.vt-c h3 { margin: 0 0 .35rem; }
.vt-c p { color: var(--text-muted); margin: 0; font-size: .98rem; }
@media (prefers-reduced-motion: reduce) { .vt-rail .vt-fill, .vt-node { transition: none; } .vt-step.reached .vt-node, .vt-step.reached .vt-node::after { animation: none; } }

/* ===== Über uns: horizontale Reise-Timeline (Meilensteine) ===== */
.journey { position: relative; display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(1rem, 3vw, 2rem); max-width: 1000px; margin: 3rem auto 0; }
.jy-line { position: absolute; top: 27px; left: 12.5%; right: 12.5%; height: 3px; background: var(--hairline-2); border-radius: 3px; overflow: hidden; }
.jy-fill { position: absolute; inset: 0; background: linear-gradient(90deg, var(--accent), var(--accent-2)); border-radius: 3px; transform-origin: left; transform: scaleX(0); transition: transform 2.1s var(--ease) .15s; }
.journey.drawn .jy-fill { transform: scaleX(1); }
.jy-stop { position: relative; text-align: center; }
.jy-dot { width: 54px; height: 54px; margin: 0 auto 1.1rem; border-radius: 50%; background: var(--bg); border: 2px solid var(--hairline-2); display: grid; place-items: center; position: relative; z-index: 2; color: var(--text-muted-2); transition: border-color .5s ease, background .5s ease, color .5s ease, box-shadow .5s ease, transform .5s cubic-bezier(.2,.8,.2,1); }
.jy-dot svg { width: 24px; height: 24px; }
.jy-card { opacity: 0; transform: translateY(16px); transition: opacity .6s ease, transform .6s cubic-bezier(.2,.8,.2,1); }
.jy-year { font-family: var(--font-display); font-weight: 700; color: var(--accent-text); font-size: 1.12rem; letter-spacing: .02em; }
.jy-card h3 { margin: .25rem 0 .35rem; font-size: 1.1rem; }
.jy-card p { color: var(--text-muted); margin: 0; font-size: .92rem; line-height: 1.55; }
.journey.drawn .jy-dot { border-color: var(--accent); background: #eaf6ea; color: var(--accent-text); box-shadow: 0 0 0 5px rgba(0,128,0,.08); transform: scale(1.06); }
.journey.drawn .jy-card { opacity: 1; transform: none; }
.journey.drawn .jy-stop:nth-child(2) .jy-dot, .journey.drawn .jy-stop:nth-child(2) .jy-card { transition-delay: .25s; }
.journey.drawn .jy-stop:nth-child(3) .jy-dot, .journey.drawn .jy-stop:nth-child(3) .jy-card { transition-delay: .85s; }
.journey.drawn .jy-stop:nth-child(4) .jy-dot, .journey.drawn .jy-stop:nth-child(4) .jy-card { transition-delay: 1.45s; }
.journey.drawn .jy-stop:nth-child(5) .jy-dot, .journey.drawn .jy-stop:nth-child(5) .jy-card { transition-delay: 2.05s; }
@media (max-width: 760px) {
  .journey { grid-template-columns: 1fr; gap: 0; max-width: 480px; }
  .jy-line { left: 27px; right: auto; top: 14px; bottom: 14px; width: 3px; height: auto; }
  .jy-fill { transform-origin: top; transform: scaleY(0); }
  .journey.drawn .jy-fill { transform: scaleY(1); }
  .jy-stop { display: flex; gap: 1.1rem; text-align: left; align-items: flex-start; padding-bottom: 1.9rem; }
  .jy-dot { margin: 0; flex: none; }
}
@media (prefers-reduced-motion: reduce) { .jy-fill, .jy-dot, .jy-card { transition: none; } }

/* ===== Sendungsverfolgung (öffentliches Lookup-Widget) ===== */
.track-widget { background: var(--surface); border: 1px solid var(--hairline); border-radius: var(--radius-xl); box-shadow: var(--shadow); padding: clamp(1.4rem, 3vw, 2rem); }
.tw-head { margin-bottom: 1rem; }
.track-form { display: flex; gap: .6rem; }
.track-form input { flex: 1; min-width: 0; padding: .85rem 1rem; border: 1px solid var(--hairline-2); border-radius: var(--radius-lg); font: inherit; background: var(--bg); color: var(--text); }
.track-form input:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px rgba(16,140,16,.14); }
.track-form .btn { flex: none; white-space: nowrap; }
.track-msg { font-size: .9rem; color: var(--text-muted); margin: .7rem 0 0; min-height: 1.1em; }
.track-msg.bad { color: #c0392b; }
.track-widget .track-card { background: transparent; border: none; box-shadow: none; padding: .8rem 0 0; }
.track-note { margin: 1rem 0 0; padding: .7rem .9rem; background: rgba(16,140,16,.06); border: 1px solid rgba(16,140,16,.18); border-radius: var(--radius-lg); font-size: .9rem; color: var(--text); }
.track-upd { margin: .9rem 0 0; font-size: .78rem; color: var(--text-muted-2); }
.track-hint { margin: 1.1rem 0 0; font-size: .82rem; color: var(--text-muted-2); }
.track-hint a { color: var(--accent-text); text-decoration: underline; text-underline-offset: 3px; }
@media (max-width: 560px) { .track-form { flex-direction: column; } .track-form .btn { width: 100%; justify-content: center; } }

/* Header-Link „Sendung verfolgen" */
.nav-track { display: inline-flex; align-items: center; gap: .4rem; color: #fff; text-decoration: none; font-family: var(--font-display); font-weight: 500; font-size: .9rem; opacity: .82; transition: opacity .2s ease, color .2s ease; white-space: nowrap; }
.nav-track svg { width: 17px; height: 17px; }
.nav-track:hover { opacity: 1; color: var(--accent-2); }
@media (max-width: 1024px) { .nav-track { display: none; } }

/* ===== Lademeter-Rechner ===== */
.calc-wrap{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,4vw,3rem);align-items:start}
@media(max-width:820px){.calc-wrap{grid-template-columns:1fr}}
.calc-form{background:var(--surface);border:1px solid var(--hairline);border-radius:var(--radius-xl);box-shadow:var(--shadow);padding:clamp(1.4rem,3vw,2rem)}
.calc-check{display:flex;align-items:center;gap:.6rem;margin-top:1.1rem;font-size:.92rem;color:var(--text-muted);cursor:pointer}
.calc-check input{width:18px;height:18px;accent-color:var(--accent);flex:none}
.calc-result{background:var(--ink);color:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);padding:clamp(1.6rem,3.5vw,2.3rem);min-height:210px}
.ldm-hint{color:rgba(255,255,255,.6);font-size:.95rem;margin:0}
.ldm-big{display:flex;align-items:baseline;gap:.6rem}
.ldm-num{font-family:var(--font-display);font-weight:700;font-size:clamp(2.6rem,7vw,3.6rem);color:var(--accent-2);line-height:1}
.ldm-unit{font-family:var(--font-display);font-weight:600;color:rgba(255,255,255,.7)}
.ldm-bar{height:14px;background:rgba(255,255,255,.12);border-radius:8px;overflow:hidden;margin:1.3rem 0 .5rem}
.ldm-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-2));border-radius:8px;transition:width .5s cubic-bezier(.2,.8,.2,1)}
.ldm-scale{display:flex;justify-content:space-between;font-size:.76rem;color:rgba(255,255,255,.55)}
.ldm-facts{display:flex;gap:1.6rem;flex-wrap:wrap;margin:1.5rem 0}
.ldm-facts b{font-family:var(--font-display);font-weight:700;font-size:1.5rem;color:#fff;display:block;line-height:1}
.ldm-facts span{font-size:.82rem;color:rgba(255,255,255,.6)}
.ldm-rec{padding:.9rem 1.1rem;border-radius:var(--radius-lg);font-family:var(--font-display);font-weight:600;font-size:1rem}
.ldm-rec.part{background:rgba(58,209,58,.16);color:var(--accent-2)}
.ldm-rec.big{background:rgba(255,200,60,.16);color:#ffd34d}
.ldm-rec.full{background:rgba(255,120,40,.18);color:#ff9a5a}
.ldm-rec.neutral{background:rgba(255,255,255,.08);color:rgba(255,255,255,.75)}
.ldm-note{margin:1rem 0 0;font-size:.76rem;color:rgba(255,255,255,.45)}
.calc-info{margin-top:clamp(3rem,7vw,5rem)}

/* ===== Inline-Editor (nur eingeloggte Taurus-Nutzer) ===== */
.ie-bar{position:fixed;left:18px;bottom:18px;z-index:9500;display:flex;align-items:center;gap:10px;background:var(--ink);color:#fff;border:1px solid rgba(255,255,255,.13);border-radius:14px;padding:9px 11px;box-shadow:0 14px 44px rgba(0,0,0,.4);font-family:var(--font-display);font-size:.86rem;max-width:calc(100vw - 36px)}
.ie-dot{width:9px;height:9px;border-radius:50%;background:#6b7280;flex:none;transition:background .2s,box-shadow .2s}
.ie-bar.ie-editing .ie-dot{background:var(--accent-2);box-shadow:0 0 0 4px rgba(21,160,21,.22)}
.ie-bar.ie-err .ie-dot{background:#ff5a5a}
.ie-bar.ie-good .ie-dot{background:#2bb24a}
.ie-label{font-weight:600;white-space:nowrap}
.ie-bar.ie-err .ie-label{color:#ff9a9a}
.ie-bar.ie-good .ie-label{color:#7be08a}
.ie-info{color:rgba(255,255,255,.6);font-size:.78rem;white-space:nowrap}
.ie-btn{border:0;border-radius:9px;padding:.5rem .85rem;font-family:inherit;font-weight:600;font-size:.82rem;line-height:1;cursor:pointer;background:var(--accent);color:#fff;text-decoration:none;white-space:nowrap;transition:filter .15s,opacity .15s,box-shadow .15s}
.ie-btn:hover{filter:brightness(1.12)}
.ie-btn.ie-ghost{background:rgba(255,255,255,.1)}
.ie-save{background:#2bb24a}
.ie-save[disabled]{opacity:.4;cursor:default;filter:none}
.ie-save.ie-on{box-shadow:0 0 0 0 rgba(43,178,74,.5);animation:iePulse 1.7s ease-in-out infinite}
@keyframes iePulse{0%,100%{box-shadow:0 0 0 0 rgba(43,178,74,.5)}50%{box-shadow:0 0 0 7px rgba(43,178,74,0)}}
.ie-text{outline:2px dashed rgba(21,160,21,.55);outline-offset:3px;border-radius:3px;cursor:text;transition:background .15s,outline-color .15s}
.ie-text:hover{background:rgba(21,160,21,.07)}
.ie-text:focus{outline:2px solid var(--accent);background:rgba(21,160,21,.1)}
.ie-img{outline:3px dashed rgba(21,160,21,.65);outline-offset:-3px;cursor:pointer;transition:filter .15s}
.ie-img:hover{filter:brightness(.82) saturate(1.1)}
body.ie-active{scroll-behavior:auto}
@media(max-width:640px){.ie-info,.ie-dash{display:none}.ie-bar{left:10px;right:10px;bottom:10px;justify-content:center}}

/* ===== Transport-Anfrage (öffentlich) ===== */
.tr-hint{margin-top:.5rem;min-height:1.2em;font-size:.95rem;color:var(--text-muted);font-family:var(--font-display)}
.tr-hint.on{color:var(--accent-text)}
.tr-hint b{color:var(--accent-text)}
.tr-checks{display:flex;flex-direction:column;gap:.6rem;margin-top:.5rem}
.tr-checks label{display:flex;align-items:center;gap:.6rem;font-size:.95rem;color:var(--text);cursor:pointer}
.tr-checks input{width:18px;height:18px;accent-color:var(--accent);flex:none}

/* ===== FAQ ===== */
.faq-list{max-width:840px;margin:0 auto;display:flex;flex-direction:column;gap:.85rem}
.faq-item{border:1px solid var(--hairline);border-radius:var(--radius-lg);background:var(--surface);overflow:hidden;transition:border-color .2s,box-shadow .2s}
.faq-item[open]{border-color:var(--accent);box-shadow:var(--shadow)}
.faq-item summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.15rem 1.35rem;font-family:var(--font-display);font-weight:600;font-size:1.05rem;color:var(--text)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"";width:11px;height:11px;border-right:2.5px solid var(--accent);border-bottom:2.5px solid var(--accent);transform:rotate(45deg) translateY(-2px);transition:transform .25s var(--ease);flex:none}
.faq-item[open] summary::after{transform:rotate(-135deg) translateY(0)}
.faq-item summary:hover{color:var(--accent-text)}
.faq-item .faq-a{padding:0 1.35rem 1.25rem;color:var(--text-muted);line-height:1.75}
.faq-item .faq-a a{color:var(--accent-text);text-decoration:underline;text-underline-offset:2px}
.faq-cta{max-width:840px;margin:clamp(2.5rem,6vw,4rem) auto 0;text-align:center;background:var(--inv-bg);color:var(--inv-text);border:1px solid var(--inv-line);border-radius:var(--radius-xl);padding:clamp(1.8rem,5vw,3rem)}
.faq-cta h2{color:var(--inv-text);margin-bottom:.5rem}
.faq-cta p{color:var(--inv-soft);margin-bottom:1.5rem}
.faq-cta .hero-actions{justify-content:center}

/* Buttons in den Flip-Sektionen: passen sich Hell/Dunkel an (Footer/Mobil-Menü/Showcases bleiben unberührt) */
.hero .btn.on-dark:not(.ghost), .page-hero .btn.on-dark:not(.ghost), .cta-band .btn.on-dark:not(.ghost), .faq-cta .btn.on-dark:not(.ghost) { background: var(--inv-btn-bg); color: var(--inv-btn-text); }
.hero .btn.ghost, .page-hero .btn.ghost, .cta-band .btn.ghost, .faq-cta .btn.ghost { background: transparent; color: var(--inv-text); box-shadow: inset 0 0 0 1.5px var(--inv-ghost-bd); }
.hero .btn.ghost:hover, .page-hero .btn.ghost:hover, .cta-band .btn.ghost:hover, .faq-cta .btn.ghost:hover { background: var(--inv-btn-bg); color: var(--inv-btn-text); }

/* h4→h3-Umstellung (Heading-Order): Größen wie zuvor beibehalten */
.step h3, .vt-c h3 { font-size: 1.1rem; }

/* ===== Theme-Umschalter (Hell/Dunkel) ===== */
.theme-toggle { width: 42px; height: 42px; border-radius: 11px; flex: none; cursor: pointer;
  border: 1px solid rgba(255,255,255,.22); background: rgba(255,255,255,.10);
  -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px);
  color: #fff; display: inline-flex; align-items: center; justify-content: center; transition: background .2s, border-color .2s; }
.theme-toggle:hover { background: rgba(255,255,255,.18); border-color: rgba(255,255,255,.4); }
.theme-toggle svg { width: 18px; height: 18px; }
.theme-toggle .ic-sun { display: none; }
:root[data-theme="dark"] .theme-toggle .ic-sun { display: block; }
:root[data-theme="dark"] .theme-toggle .ic-moon { display: none; }

/* ===== Sprach-Umschalter (DE/EN/ES) ===== */
.lang-switch { display: inline-flex; align-items: center; gap: 2px; padding: 3px;
  background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.20); border-radius: 11px; flex: none; }
.lang-btn { display: inline-flex; align-items: center; gap: .38rem; border: 0; background: none; cursor: pointer;
  color: rgba(255,255,255,.72); font-family: var(--font-display); font-weight: 600; font-size: .78rem;
  padding: .3rem .5rem; border-radius: 8px; transition: background .2s ease, color .2s ease; line-height: 1; }
.lang-btn:hover { color: #fff; }
.lang-btn.active { background: rgba(255,255,255,.16); color: #fff; }
.lang-btn .flag { width: 21px; height: 14px; flex: none; border-radius: 3px; overflow: hidden;
  display: inline-block; box-shadow: 0 0 0 1px rgba(0,0,0,.18); }
.lang-btn .flag svg { width: 100%; height: 100%; display: block; }
.lang-btn .lc { letter-spacing: .02em; }
@media (max-width: 1180px) { .lang-switch .lang-btn .lc { display: none; } .lang-switch .lang-btn { padding: .3rem .42rem; } }
/* Dezenter Sprach-Dropdown im Header */
.lang-dd { position: relative; flex: none; }
.lang-dd-btn { position: relative; display: inline-flex; align-items: center; cursor: pointer;
  border: 0; background: none; padding: 4px; color: inherit; transition: transform .2s ease; }
.lang-dd-btn:hover { background: none; transform: scale(1.14); }
.lang-dd-btn:focus-visible { outline: 2px solid var(--accent-2); outline-offset: 3px; border-radius: 6px; }
.lang-dd-btn .flag { width: 26px; height: 18px; border-radius: 4px; overflow: hidden; display: inline-block; flex: none;
  box-shadow: 0 0 0 1px rgba(255,255,255,.55), 0 2px 7px rgba(0,0,0,.35); transition: box-shadow .2s ease; }
.lang-dd-btn:hover .flag { box-shadow: 0 0 0 1px #fff, 0 3px 10px rgba(0,0,0,.4); }
/* dezenter Klick-Hinweis: sanft pulsierender Ring um die Flagge */
.lang-dd-btn::after { content: ""; position: absolute; left: 4px; top: 4px; right: 4px; bottom: 4px; border-radius: 5px;
  box-shadow: 0 0 0 0 rgba(21,160,21,.55); animation: langPulse 2.6s ease-out infinite; pointer-events: none; }
.lang-dd-btn:hover::after, .lang-dd.open .lang-dd-btn::after { animation: none; }
@keyframes langPulse { 0% { box-shadow: 0 0 0 0 rgba(21,160,21,.5); } 70% { box-shadow: 0 0 0 9px rgba(21,160,21,0); } 100% { box-shadow: 0 0 0 0 rgba(21,160,21,0); } }
@media (prefers-reduced-motion: reduce) { .lang-dd-btn::after { animation: none; box-shadow: 0 0 0 2px rgba(21,160,21,.4); } }
.lang-dd-btn .flag svg { width: 100%; height: 100%; display: block; }
.lang-dd-btn .lc { letter-spacing: .02em; }
.lang-chev { width: 13px; height: 13px; opacity: .7; transition: transform .25s ease; }
.lang-dd.open .lang-chev { transform: rotate(180deg); }
.lang-dd-menu { position: absolute; top: calc(100% + 8px); right: 0; min-width: 178px; padding: .35rem;
  background: var(--surface); border: 1px solid var(--hairline); border-radius: 14px;
  box-shadow: 0 18px 44px rgba(0,0,0,.20); z-index: 120;
  opacity: 0; visibility: hidden; transform: translateY(-6px); transition: opacity .18s ease, transform .18s ease, visibility .18s; }
.lang-dd.open .lang-dd-menu { opacity: 1; visibility: visible; transform: translateY(0); }
.lang-opt { display: flex; align-items: center; gap: .6rem; width: 100%; cursor: pointer; border: 0; background: none;
  color: var(--text); font-family: var(--font-display); font-weight: 500; font-size: .9rem; text-align: left;
  padding: .55rem .6rem; border-radius: 9px; transition: background .15s; }
.lang-opt:hover, .lang-opt.active { background: var(--surface-2); }
.lang-opt .flag { width: 22px; height: 15px; border-radius: 3px; overflow: hidden; display: inline-block; box-shadow: 0 0 0 1px rgba(0,0,0,.15); flex: none; }
.lang-opt .flag svg { width: 100%; height: 100%; display: block; }
.lang-opt .lo-name { flex: 1; }
.lang-opt .lo-code { font-size: .72rem; color: var(--text-muted); font-weight: 600; }
.lang-opt.active .lo-code { color: var(--accent-text); }
@media (max-width: 760px) { .nav-cta .lang-dd { display: none; } }

/* ============ Brandsta-Werbe-Features (dezent & edel) ============ */
.bm-promo { border-top: 1px solid var(--hairline, rgba(0,0,0,.08)); background: var(--surface-2, #f4f5f3); padding: 1.5rem 0; }
.bm-promo-inner { display: flex; align-items: center; gap: 1.4rem; flex-wrap: wrap; }
.bm-promo-tag { display: inline-flex; align-items: center; gap: .45rem; font-family: var(--font-display); font-size: .68rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--text-muted, #6b7280); white-space: nowrap; }
.bm-promo .bm-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--accent-2, #15a015); }
.bm-promo-main { flex: 1; min-width: 240px; }
.bm-promo-h { font-family: var(--font-display); font-weight: 700; font-size: 1.06rem; line-height: 1.25; color: var(--text, #16181a); margin: 0 0 .15rem; }
.bm-promo-t { color: var(--text-muted, #6b7280); font-size: .9rem; line-height: 1.45; margin: 0; }
.bm-promo-cta { display: inline-flex; align-items: center; gap: .45rem; white-space: nowrap; font-family: var(--font-display); font-weight: 600; font-size: .9rem; color: var(--accent-text, #0a6b0a); text-decoration: none; }
.bm-promo-cta svg { width: 18px; height: 18px; transition: transform .2s ease; }
.bm-promo-cta:hover svg { transform: translateX(4px); }
@media (max-width: 640px) { .bm-promo-inner { align-items: flex-start; } .bm-promo-tag { order: -1; } }

/* Footer-Credit */
.fb-credit { color: rgba(255,255,255,.45); font-size: .8rem; }
.fb-credit a { color: rgba(255,255,255,.7); text-decoration: underline; text-underline-offset: 2px; }
.fb-credit a:hover { color: var(--accent-2, #15a015); }

/* Cookie-Banner */
.cc-banner { position: fixed; left: 0; right: 0; bottom: 0; z-index: 9000; transform: translateY(115%); transition: transform .38s cubic-bezier(.16,1,.3,1); }
.cc-banner.show { transform: translateY(0); }
.cc-inner { max-width: 640px; margin: 0 auto 1.4rem; background: var(--ink, #16181a); color: #fff; border: 1px solid rgba(255,255,255,.12); border-radius: 18px; box-shadow: 0 24px 64px rgba(0,0,0,.5); padding: 1.6rem 1.7rem; }
.cc-head { display: flex; align-items: center; gap: .7rem; margin-bottom: .7rem; }
.cc-ico { flex: none; width: 38px; height: 38px; border-radius: 10px; display: grid; place-items: center; background: rgba(21,160,21,.16); color: var(--accent-2, #3ad13a); }
.cc-ico svg { width: 21px; height: 21px; }
.cc-title { font-family: var(--font-display); font-weight: 700; font-size: 1.08rem; }
.cc-desc { font-size: .85rem; line-height: 1.6; color: rgba(255,255,255,.78); margin: 0; }
.cc-desc a { color: var(--accent-2, #3ad13a); }
.cc-opts { margin-top: 1rem; display: grid; gap: .55rem; }
.cc-opts[hidden] { display: none; }
.cc-opt { display: flex; align-items: center; gap: 1rem; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.1); border-radius: 12px; padding: .7rem .9rem; cursor: pointer; }
.cc-opt-lock { cursor: default; }
.cc-opt-i { flex: 1; }
.cc-opt-i b { display: block; font-size: .85rem; }
.cc-opt-i small { display: block; font-size: .73rem; color: rgba(255,255,255,.55); margin-top: .12rem; }
.cc-cb { position: absolute; opacity: 0; width: 1px; height: 1px; pointer-events: none; }
.cc-sw { flex: none; width: 44px; height: 25px; border-radius: 99px; background: rgba(255,255,255,.22); position: relative; transition: background .2s; }
.cc-sw::after { content: ""; position: absolute; top: 3px; left: 3px; width: 19px; height: 19px; border-radius: 50%; background: #fff; transition: transform .2s; box-shadow: 0 1px 3px rgba(0,0,0,.3); }
.cc-cb:checked + .cc-sw { background: var(--accent-2, #15a015); }
.cc-cb:checked + .cc-sw::after { transform: translateX(19px); }
.cc-cb:focus-visible + .cc-sw { outline: 2px solid #fff; outline-offset: 2px; }
.cc-actions { display: flex; align-items: center; gap: .7rem; margin-top: 1.3rem; }
.cc-link { margin-right: auto; cursor: pointer; background: none; border: 0; color: rgba(255,255,255,.7); font-family: var(--font-display); font-weight: 600; font-size: .83rem; text-decoration: underline; text-underline-offset: 3px; padding: .4rem .2rem; }
.cc-link:hover { color: #fff; }
.cc-btns { display: flex; gap: .7rem; }
.cc-decision { cursor: pointer; border: 0; border-radius: 11px; font-family: var(--font-display); font-weight: 700; font-size: .87rem; padding: .72rem 1.1rem; min-width: 150px; text-align: center; transition: filter .2s, transform .15s, background .2s; }
.cc-reject { background: #fff; color: #16181a; }
.cc-reject:hover { background: #e9e9e9; }
.cc-accept { background: var(--accent-2, #15a015); color: #fff; }
.cc-save { background: transparent; color: #fff; box-shadow: inset 0 0 0 1.5px var(--accent-2, #15a015); }
.cc-save:hover { background: rgba(21,160,21,.15); }
.cc-decision:hover { transform: translateY(-1px); }
.cc-accept:hover { filter: brightness(1.08); }
@media (max-width: 600px) { .cc-inner { padding: 1.3rem 1.2rem; } .cc-actions { flex-wrap: wrap; } .cc-link { order: 3; flex-basis: 100%; text-align: center; margin: .3rem 0 0; } .cc-btns { width: 100%; } .cc-decision { flex: 1; min-width: 0; } }

/* Easter-Egg-Toast (Konami) */
.bm-egg { position: fixed; left: 50%; bottom: 26px; transform: translate(-50%, 160%); z-index: 9100; background: var(--ink, #181818); color: #fff; border: 1px solid rgba(255,255,255,.15); border-radius: 12px; padding: .85rem 1.25rem; font-size: .9rem; box-shadow: 0 16px 44px rgba(0,0,0,.45); transition: transform .42s cubic-bezier(.16,1,.3,1); max-width: 92vw; }
.bm-egg.show { transform: translate(-50%, 0); }
.bm-egg a { color: var(--accent-2, #3ad13a); font-weight: 600; }

/* ============ Brandsta-Werbefeatures — pro Seite ein eigenes Erlebnis ============ */
.bm-feat { position: relative; border-top: 1px solid var(--hairline, rgba(0,0,0,.08)); background: var(--surface-2, #f4f5f3); padding: 2.6rem 0; overflow: hidden; }
.bm-tag { display: inline-flex; align-items: center; gap: .45rem; font-family: var(--font-display); font-size: .66rem; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; color: var(--text-muted, #6b7280); }
.bm-tag-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--accent-2, #15a015); animation: bmDot 2s ease-in-out infinite; }
@keyframes bmDot { 0%,100%{opacity:1} 50%{opacity:.3} }
.bm-h { font-family: var(--font-display); font-weight: 800; font-size: clamp(1.3rem,3vw,1.85rem); line-height: 1.12; color: var(--text, #16181a); margin: .55rem 0 .5rem; }
.bm-accent { color: var(--accent-text, #0a6b0a); }
.bm-p { color: var(--text-muted, #555); font-size: .95rem; line-height: 1.55; margin: 0 0 1.1rem; max-width: 48ch; }
.bm-hint { font-size: .8rem; color: var(--text-muted, #888); }
.bm-foot { font-size: .72rem; color: var(--text-muted, #999); margin: .7rem 0 0; }
.bm-cta { display: inline-flex; align-items: center; gap: .45rem; font-family: var(--font-display); font-weight: 700; font-size: .92rem; color: #fff; background: var(--accent-2, #15a015); padding: .72rem 1.25rem; border-radius: 12px; text-decoration: none; box-shadow: 0 8px 22px rgba(21,160,21,.25); transition: transform .2s, filter .2s; }
.bm-cta:hover { transform: translateY(-2px); filter: brightness(1.08); }
.bm-cta svg { width: 18px; height: 18px; transition: transform .2s; }
.bm-cta:hover svg { transform: translateX(3px); }
.bm-col-text { min-width: 0; }

/* — Startseite: 7 Tage — */
.bm-seven-inner { display: grid; grid-template-columns: 1fr 1.15fr; gap: 2.4rem; align-items: center; }
.bm-days { list-style: none; display: flex; gap: .4rem; margin: 0; padding: 0; position: relative; }
.bm-days::before { content: ""; position: absolute; top: 21px; left: 6%; right: 6%; height: 2px; background: var(--hairline, #ddd); }
.bm-days::after { content: ""; position: absolute; top: 21px; left: 6%; width: 0; height: 2px; background: var(--accent-2, #15a015); transition: width 2.4s ease .2s; }
.bm-days.in::after { width: 88%; }
.bm-days li { flex: 1; display: flex; flex-direction: column; align-items: center; gap: .4rem; position: relative; z-index: 1; opacity: 0; transform: translateY(9px); transition: opacity .4s ease, transform .4s ease; transition-delay: calc(var(--i) * .16s + .25s); }
.bm-days.in li { opacity: 1; transform: none; }
.bm-days b { width: 42px; height: 42px; border-radius: 50%; display: grid; place-items: center; font-family: var(--font-display); font-weight: 800; background: var(--surface, #fff); border: 2px solid var(--hairline, #ddd); color: var(--text, #222); cursor: pointer; transition: transform .2s; }
.bm-days li.bm-last b { background: var(--accent-2, #15a015); border-color: var(--accent-2, #15a015); color: #fff; }
.bm-days b:hover { transform: scale(1.14); }
.bm-days span { font-size: .72rem; color: var(--text-muted, #666); white-space: nowrap; }
@media (max-width: 760px) { .bm-seven-inner { grid-template-columns: 1fr; gap: 1.6rem; } .bm-days span { font-size: .58rem; } .bm-days b { width: 36px; height: 36px; } }

/* — Karriere: Recruiting-Smartphone — */
.bm-recruit-grid { display: grid; grid-template-columns: auto 1fr; gap: 2.6rem; align-items: center; }
.bm-phone { position: relative; width: 208px; height: 424px; border-radius: 34px; background: #0d0d10; padding: 9px; box-shadow: 0 26px 60px rgba(0,0,0,.34), inset 0 0 0 2px rgba(255,255,255,.06); cursor: pointer; flex: none; animation: bmFloat 5s ease-in-out infinite; }
@keyframes bmFloat { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-9px)} }
.bm-phone-cam { position: absolute; top: 16px; left: 50%; transform: translateX(-50%); width: 52px; height: 7px; border-radius: 5px; background: #000; z-index: 6; }
.bm-story { position: relative; width: 100%; height: 100%; border-radius: 26px; overflow: hidden; background: linear-gradient(160deg, #0a6b0a, #15a015 55%, #0d2a0d); }
.bm-bars { position: absolute; top: 11px; left: 11px; right: 11px; display: flex; gap: 4px; z-index: 5; }
.bm-bars span { flex: 1; height: 3px; border-radius: 3px; background: rgba(255,255,255,.3); overflow: hidden; position: relative; }
.bm-bars span::after { content: ""; position: absolute; inset: 0; background: #fff; transform: scaleX(0); transform-origin: left; animation: bmBar 9s linear infinite; animation-delay: var(--d); }
@keyframes bmBar { 0%{transform:scaleX(0)} 33.3%,100%{transform:scaleX(1)} }
.bm-story-head { position: absolute; top: 25px; left: 13px; right: 13px; display: flex; align-items: center; gap: 7px; color: #fff; font-size: .72rem; font-weight: 600; z-index: 5; }
.bm-ava { width: 22px; height: 22px; border-radius: 50%; background: #fff; flex: none; box-shadow: 0 0 0 2px rgba(255,255,255,.3); }
.bm-spons { margin-left: auto; font-size: .58rem; opacity: .7; font-weight: 400; }
.bm-slides { position: absolute; inset: 0; display: grid; place-items: center; padding: 1.5rem; text-align: center; }
.bm-slide { position: absolute; opacity: 0; transform: scale(.96); color: #fff; display: flex; flex-direction: column; gap: .5rem; animation: bmSlide 9s ease-in-out infinite; }
.bm-slide-1 { animation-delay: 0s; } .bm-slide-2 { animation-delay: 3s; } .bm-slide-3 { animation-delay: 6s; }
@keyframes bmSlide { 0%{opacity:0;transform:scale(.96)} 4%,29%{opacity:1;transform:scale(1)} 33.3%,100%{opacity:0;transform:scale(.96)} }
.bm-slide .bm-kick { font-size: .66rem; letter-spacing: .12em; text-transform: uppercase; opacity: .85; }
.bm-slide strong { font-family: var(--font-display); font-weight: 800; font-size: 1.25rem; line-height: 1.15; }
.bm-slide em { font-size: .74rem; opacity: .85; font-style: normal; }
.bm-swipe { position: absolute; bottom: 16px; left: 50%; color: #fff; font-size: .78rem; font-weight: 700; display: flex; align-items: center; gap: .35rem; z-index: 5; transform: translateX(-50%); animation: bmSwipe 1.6s ease-in-out infinite; }
@keyframes bmSwipe { 0%,100%{transform:translateX(-50%) translateY(0);opacity:.8} 50%{transform:translateX(-50%) translateY(-5px);opacity:1} }
.bm-hearts { position: absolute; inset: 0; pointer-events: none; z-index: 7; }
.bm-heart { position: absolute; font-size: 22px; color: #ff3b6b; animation: bmHeart 1.2s ease-out forwards; }
@keyframes bmHeart { 0%{opacity:1;transform:translateY(0) scale(.6)} 100%{opacity:0;transform:translateY(-95px) scale(1.35)} }
@media (max-width: 760px) { .bm-recruit-grid { grid-template-columns: 1fr; justify-items: center; gap: 1.8rem; } .bm-recruit-grid .bm-col-text { text-align: center; } }

/* — Über uns: Kino-Teaser — */
.bm-cinema { position: relative; border-radius: 18px; overflow: hidden; min-height: 360px; background-size: cover; background-position: center; display: flex; align-items: flex-end; box-shadow: 0 18px 50px rgba(0,0,0,.28); }
.bm-cinema::before { content: ""; position: absolute; inset: 0; background: linear-gradient(to top, rgba(8,10,8,.88), rgba(8,10,8,.2) 55%, rgba(8,10,8,.55)); }
.bm-lb { position: absolute; left: 0; right: 0; height: 0; background: #000; z-index: 3; transition: height .5s ease; }
.bm-lb-top { top: 0; } .bm-lb-bot { bottom: 0; }
.bm-cinema.playing .bm-lb { height: 12%; }
.bm-grain { position: absolute; inset: 0; z-index: 2; opacity: 0; pointer-events: none; mix-blend-mode: overlay; transition: opacity .4s; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }
.bm-cinema.playing .bm-grain { opacity: .45; animation: bmGrain .3s steps(2) infinite; }
@keyframes bmGrain { 0%{transform:translate(0,0)} 100%{transform:translate(-3%,2%)} }
.bm-play { position: absolute; top: 42%; left: 50%; transform: translate(-50%,-50%); width: 74px; height: 74px; border-radius: 50%; border: 0; background: rgba(255,255,255,.94); color: #0a6b0a; display: grid; place-items: center; cursor: pointer; z-index: 4; animation: bmPulse 2.2s ease-out infinite; transition: transform .2s, opacity .3s; }
.bm-play svg { width: 30px; height: 30px; margin-left: 4px; }
.bm-play:hover { transform: translate(-50%,-50%) scale(1.09); }
.bm-cinema.playing .bm-play { opacity: 0; pointer-events: none; }
@keyframes bmPulse { 0%{box-shadow:0 0 0 0 rgba(255,255,255,.5)} 70%{box-shadow:0 0 0 26px rgba(255,255,255,0)} 100%{box-shadow:0 0 0 0 rgba(255,255,255,0)} }
.bm-cinema-cap { position: relative; z-index: 4; padding: 1.7rem 1.9rem; color: #fff; max-width: 600px; }
.bm-cinema-cap .bm-tag { color: rgba(255,255,255,.8); }
.bm-cinema-cap .bm-h { color: #fff; }
.bm-cinema-cap .bm-p { color: rgba(255,255,255,.85); }
.bm-clap { position: absolute; top: 0; left: 0; right: 0; z-index: 6; background: #111; color: #fff; font-family: var(--font-display); font-weight: 700; letter-spacing: .12em; font-size: .68rem; padding: .55rem 1rem; transform: translateY(-120%); transition: transform .25s; }
.bm-cinema.clap .bm-clap { transform: translateY(0); }
.bm-clap-top { position: absolute; top: -9px; left: 0; right: 0; height: 9px; background: repeating-linear-gradient(115deg, #fff 0 14px, #111 14px 28px); transform-origin: left bottom; }
.bm-cinema.clap .bm-clap-top { animation: bmClap .55s ease; }
@keyframes bmClap { 0%{transform:rotate(-20deg)} 55%{transform:rotate(3deg)} 100%{transform:rotate(0)} }

/* — Leistungen: Social-Feed — */
.bm-social-grid { display: grid; grid-template-columns: 1fr auto; gap: 2.6rem; align-items: center; }
.bm-stats { display: flex; gap: 1.8rem; margin: 0 0 1.2rem; flex-wrap: wrap; }
.bm-stats b { display: block; font-family: var(--font-display); font-weight: 800; font-size: 1.6rem; color: var(--accent-text, #0a6b0a); }
.bm-stats span { font-size: .72rem; color: var(--text-muted, #666); }
.bm-feed { display: grid; grid-template-columns: repeat(2, 110px); grid-auto-rows: 110px; gap: 9px; flex: none; }
.bm-post { position: relative; border-radius: 13px; overflow: hidden; box-shadow: 0 6px 16px rgba(0,0,0,.13); cursor: pointer; }
.bm-post-img { position: absolute; inset: 0; background-size: cover; background-position: center; transition: transform .35s; }
.bm-post:hover .bm-post-img { transform: scale(1.09); }
.bm-like { position: absolute; inset: 0; display: grid; place-items: center; color: #fff; font-size: 32px; opacity: 0; transform: scale(.3); transition: opacity .25s, transform .25s; text-shadow: 0 2px 10px rgba(0,0,0,.5); }
.bm-post:hover .bm-like { opacity: 1; transform: scale(1); }
@media (max-width: 760px) { .bm-social-grid { grid-template-columns: 1fr; } .bm-feed { grid-template-columns: repeat(4, 1fr); grid-auto-rows: 1fr; } .bm-post { aspect-ratio: 1; } }

/* — Standorte: Reichweiten-Radar — */
.bm-radar-grid { display: grid; grid-template-columns: 1fr auto; gap: 2.6rem; align-items: center; }
.bm-radar-num { font-size: .95rem; color: var(--text, #222); margin: .3rem 0 1.1rem; }
.bm-radar-num b { font-family: var(--font-display); font-weight: 800; font-size: 1.5rem; color: var(--accent-text, #0a6b0a); }
.bm-radar-viz { position: relative; width: 200px; height: 200px; flex: none; }
.bm-ring { position: absolute; top: 50%; left: 50%; width: 20px; height: 20px; margin: -10px 0 0 -10px; border-radius: 50%; border: 2px solid var(--accent-2, #15a015); opacity: 0; animation: bmRing 3s ease-out infinite; animation-delay: var(--d); }
@keyframes bmRing { 0%{width:20px;height:20px;margin:-10px 0 0 -10px;opacity:.7} 100%{width:200px;height:200px;margin:-100px 0 0 -100px;opacity:0} }
.bm-radar-pin { position: absolute; top: 50%; left: 50%; width: 16px; height: 16px; border-radius: 50% 50% 50% 0; background: var(--accent-2, #15a015); transform: translate(-50%,-50%) rotate(-45deg); box-shadow: 0 0 0 4px rgba(21,160,21,.22); z-index: 2; }
.bm-radar-sweep { position: absolute; top: 50%; left: 50%; width: 100px; height: 2px; background: linear-gradient(90deg, var(--accent-2, #15a015), transparent); transform-origin: left center; animation: bmSweep 3s linear infinite; }
@keyframes bmSweep { 0%{transform:translateY(-50%) rotate(0)} 100%{transform:translateY(-50%) rotate(360deg)} }
@media (max-width: 760px) { .bm-radar-grid { grid-template-columns: 1fr; justify-items: start; } }

/* — Kontakt/FAQ: Klappe — */
.bm-clap-line { display: flex; align-items: center; gap: 1.1rem; flex-wrap: wrap; }
.bm-clap-mini { width: 48px; height: 38px; background: #111; border-radius: 5px; position: relative; cursor: pointer; flex: none; }
.bm-clap-mini-top { position: absolute; top: -7px; left: 0; right: 0; height: 9px; background: repeating-linear-gradient(115deg, #fff 0 9px, #111 9px 18px); border-radius: 3px 3px 0 0; transform-origin: left bottom; }
.bm-clap-line.snap .bm-clap-mini-top { animation: bmClap .55s ease; }
.bm-clap-line .bm-p { flex: 1; min-width: 200px; margin: 0; }

/* — Konfetti (Easter Egg Startseite) — */
.bm-confetti { position: fixed; width: 9px; height: 9px; border-radius: 2px; z-index: 9200; pointer-events: none; animation: bmConf 1.1s ease-out forwards; }
@keyframes bmConf { 0%{transform:translate(0,0) rotate(0);opacity:1} 100%{transform:translate(var(--tx),var(--ty)) rotate(var(--rot));opacity:0} }

@media (prefers-reduced-motion: reduce) { .bm-phone,.bm-tag-dot,.bm-swipe,.bm-slide,.bm-bars span::after,.bm-play,.bm-ring,.bm-radar-sweep { animation: none !important; } .bm-slide-1 { opacity: 1; transform: none; } }

/* ===== Brandsta Reveal (per Easter Egg ausgelöst — KEINE feste Sektion) ===== */
.bm-reveal { position: fixed; inset: 0; z-index: 9300; display: grid; place-items: center; opacity: 0; transition: opacity .3s ease; padding: 1.2rem; }
.bm-reveal.show { opacity: 1; }
.bm-reveal[hidden] { display: none; }
.bm-reveal-bg { position: absolute; inset: 0; background: rgba(10,12,10,.62); -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px); }
.bm-reveal-card { position: relative; z-index: 1; background: var(--surface, #fff); color: var(--text, #16181a); border-radius: 20px; box-shadow: 0 30px 80px rgba(0,0,0,.5); padding: 2rem 2.1rem; max-width: 460px; width: 100%; transform: translateY(18px) scale(.97); transition: transform .4s cubic-bezier(.16,1,.3,1); }
.bm-reveal.show .bm-reveal-card { transform: none; }
.bm-reveal-recruit { max-width: 740px; display: grid; grid-template-columns: auto 1fr; gap: 2rem; align-items: center; }
.bm-reveal-x { position: absolute; top: .7rem; right: .8rem; z-index: 3; width: 34px; height: 34px; border: 0; border-radius: 50%; background: rgba(0,0,0,.07); color: var(--text, #222); font-size: 22px; line-height: 1; cursor: pointer; transition: background .2s; }
.bm-reveal-x:hover { background: rgba(0,0,0,.14); }
.bm-reveal-text .bm-tag { color: var(--text-muted, #6b7280); }
.bm-reveal-text .bm-h { margin: .55rem 0 .45rem; }
.bm-reveal-text .bm-p { max-width: none; }
.bm-reveal-foot { font-size: .72rem; color: var(--text-muted, #999); margin: 1.1rem 0 0; }
.bm-reveal .bm-phone { margin: 0 auto; }
@media (max-width: 640px) { .bm-reveal-recruit { grid-template-columns: 1fr; gap: 1.2rem; justify-items: center; text-align: center; } .bm-reveal .bm-phone { transform: scale(.82); margin: -28px auto; } }

/* Idle-Nudge (dezenter Easter-Egg-Hinweis) */
.bm-nudge { position: fixed; left: 20px; bottom: 24px; z-index: 9250; display: inline-flex; align-items: center; gap: .5rem; background: var(--ink, #16181a); color: #fff; border: 1px solid rgba(255,255,255,.14); border-radius: 99px; padding: .6rem 1.05rem; font-size: .82rem; font-family: var(--font-display); font-weight: 600; cursor: pointer; box-shadow: 0 12px 34px rgba(0,0,0,.42); transform: translateY(160%); transition: transform .42s cubic-bezier(.16,1,.3,1); }
.bm-nudge.show { transform: translateY(0); }
.bm-nudge:hover { filter: brightness(1.12); }

/* Hero-Wasserzeichen (Stier-Logo) als verstecktes Egg anklickbar */
.hero-bg-mark { pointer-events: auto; }
@media (prefers-reduced-motion: reduce) { .bm-reveal, .bm-reveal-card, .bm-nudge { transition: opacity .2s; } }

/* Thematischer Akzent im Reveal (pro Seite anderes Icon + Animation) */
.bm-ic { width: 60px; height: 60px; border-radius: 17px; display: grid; place-items: center; margin: 0 0 .3rem; background: linear-gradient(135deg, var(--accent-2, #15a015), #0b760b); color: #fff; box-shadow: 0 12px 30px rgba(21,160,21,.32); }
.bm-ic svg { width: 30px; height: 30px; }
.bm-ic-web svg { animation: bmRocket 2.6s ease-in-out infinite; }
.bm-ic-social svg { animation: bmBeat 1.7s ease-in-out infinite; }
.bm-ic-local svg { animation: bmDrop 2.2s ease-in-out infinite; }
.bm-ic-video svg, .bm-ic-ads svg { animation: bmZoom 1.9s ease-in-out infinite; }
@keyframes bmRocket { 0%,100% { transform: translateY(0) rotate(-3deg); } 50% { transform: translateY(-5px) rotate(3deg); } }
@keyframes bmBeat { 0%,100% { transform: scale(1); } 14% { transform: scale(1.18); } 28% { transform: scale(1); } 42% { transform: scale(1.12); } }
@keyframes bmDrop { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-4px); } }
@keyframes bmZoom { 0%,100% { transform: scale(1); opacity: 1; } 50% { transform: scale(1.12); opacity: .82; } }

/* Verstecktes thematisches Spot-Egg (löst das Reveal aus) — Icon + Position je Seite */
.bm-spot { position: fixed; left: 22px; bottom: 150px; z-index: 9200; width: 44px; height: 44px; border-radius: 50%; display: grid; place-items: center; border: 0; cursor: pointer; color: var(--accent-2, #15a015); background: var(--surface, #fff); box-shadow: 0 6px 20px rgba(0,0,0,.18); opacity: .3; transform: scale(.92); transition: opacity .3s ease, transform .3s cubic-bezier(.16,1,.3,1); }
.bm-spot svg { width: 20px; height: 20px; position: relative; z-index: 1; }
.bm-spot:hover, .bm-spot:focus-visible { opacity: 1; transform: scale(1.1); outline: none; }
.bm-spot-ping { position: absolute; inset: 0; border-radius: 50%; border: 2px solid var(--accent-2, #15a015); opacity: 0; animation: bmSpotPing 2.8s ease-out infinite; }
@keyframes bmSpotPing { 0% { transform: scale(1); opacity: .5; } 80%,100% { transform: scale(2.3); opacity: 0; } }
.bm-spot-social { bottom: 210px; }
.bm-spot-local { bottom: 120px; }
.bm-spot-video { bottom: 180px; }
.bm-spot-recruit { bottom: 200px; }
@media (max-width: 760px) { .bm-spot { display: none; } }
@media (prefers-reduced-motion: reduce) { .bm-ic svg, .bm-spot-ping { animation: none; } }

/* Sichtbares Inline-Feature — eingebettet in einen bestehenden Abschnitt (keine eigene Sektion) */
.bm-inl { position: relative; margin-top: 2.6rem; background: var(--surface, #fff); border: 1px solid var(--hairline, rgba(0,0,0,.08)); border-radius: 22px; padding: 2.1rem 2.4rem; display: grid; grid-template-columns: auto minmax(0, 1.35fr) minmax(0, 1fr); gap: 1.8rem 2.6rem; align-items: center; box-shadow: 0 16px 44px rgba(0,0,0,.07); overflow: hidden; }
.bm-inl-visual { display: grid; place-items: center; }
.bm-inl-text .bm-tag { color: var(--text-muted, #6b7280); }
.bm-inl-text .bm-h { margin: .5rem 0 .5rem; font-size: clamp(1.5rem, 2.2vw, 1.9rem); }
.bm-inl-text .bm-p { max-width: none; margin-bottom: 1.4rem; }
.bm-inl .bm-ic { width: 108px; height: 108px; border-radius: 26px; }
.bm-inl .bm-ic svg { width: 52px; height: 52px; }
/* dritte Spalte: Nutzen-Punkte (füllt den rechten Bereich) */
.bm-inl-points { list-style: none; margin: 0; padding: 0 0 0 2.4rem; border-left: 1px solid var(--hairline, rgba(0,0,0,.1)); display: flex; flex-direction: column; gap: 1rem; }
.bm-inl-points li { display: flex; align-items: flex-start; gap: .65rem; font-family: var(--font-display); font-weight: 600; font-size: 1.02rem; line-height: 1.3; color: var(--text, #222); }
.bm-pt-chk { flex: none; width: 25px; height: 25px; border-radius: 50%; display: grid; place-items: center; background: rgba(21,160,21,.14); color: var(--accent-text, #0a6b0a); margin-top: 1px; }
.bm-pt-chk svg { width: 13px; height: 13px; }
@media (max-width: 1000px) {
  .bm-inl { grid-template-columns: auto 1fr; }
  .bm-inl-points { grid-column: 1 / -1; flex-direction: row; flex-wrap: wrap; border-left: 0; border-top: 1px solid var(--hairline, rgba(0,0,0,.1)); padding: 1.3rem 0 0; gap: 1rem 1.6rem; }
  .bm-inl-points li { flex: 1 1 28%; min-width: 180px; }
}
@media (max-width: 760px) {
  .bm-inl { grid-template-columns: 1fr; gap: 1.4rem; padding: 1.6rem; text-align: center; justify-items: center; }
  .bm-inl-points { flex-direction: column; text-align: left; }
  .bm-inl-points li { flex: none; }
}

/* Dezente Schlank-Variante (z. B. Startseite) — eine ruhige Zeile statt großer Karte */
.bm-slim { display: flex; align-items: center; gap: .85rem; flex-wrap: wrap; margin-top: 2.6rem; padding: .8rem 1.2rem; border: 1px solid var(--hairline, rgba(0,0,0,.1)); border-radius: 12px; background: transparent; font-size: .9rem; }
.bm-slim-ic { flex: none; width: 30px; height: 30px; border-radius: 8px; display: grid; place-items: center; background: rgba(21,160,21,.12); color: var(--accent-text, #0a6b0a); }
.bm-slim-ic svg { width: 17px; height: 17px; }
.bm-slim-tag { font-family: var(--font-display); font-weight: 700; font-size: .66rem; letter-spacing: .08em; text-transform: uppercase; color: var(--text-muted, #888); }
.bm-slim-txt { color: var(--text, #2a2d30); }
.bm-slim-link { margin-left: auto; display: inline-flex; align-items: center; gap: .35rem; color: var(--accent-text, #0a6b0a); font-weight: 600; text-decoration: none; white-space: nowrap; transition: color .2s ease; }
.bm-slim-link svg { width: 15px; height: 15px; }
.bm-slim-link:hover { color: var(--accent-2, #15a015); }
@media (max-width: 620px) { .bm-slim-link { margin-left: 0; } .bm-slim-tag { order: -1; } }

/* — Inline-Visuals: Web (Browser-Mockup) — */
.bm-web { width: 232px; background: var(--surface, #fff); border: 1px solid var(--hairline, rgba(0,0,0,.1)); border-radius: 13px; overflow: hidden; box-shadow: 0 12px 30px rgba(0,0,0,.18); position: relative; }
.bm-web-bar { height: 27px; background: var(--surface-2, #eef0ed); display: flex; align-items: center; gap: 5px; padding: 0 11px; }
.bm-web-bar i { width: 8px; height: 8px; border-radius: 50%; background: #ff5f57; }
.bm-web-bar i:nth-child(2) { background: #febc2e; }
.bm-web-bar i:nth-child(3) { background: #28c840; }
.bm-web-body { padding: 14px; display: flex; flex-direction: column; gap: 9px; align-items: flex-start; }
.bm-web-hero { width: 100%; height: 46px; border-radius: 7px; background: linear-gradient(120deg, var(--accent-2, #15a015), #0b760b); transform-origin: left; animation: bmWebIn .7s ease both; }
.bm-web-ln { height: 9px; border-radius: 5px; background: var(--hairline, #e2e5e1); transform-origin: left; animation: bmWebIn .7s ease both; }
.bm-web-ln.a { width: 92%; animation-delay: .45s; }
.bm-web-ln.b { width: 64%; animation-delay: .85s; }
.bm-web-btn { width: 74px; height: 21px; border-radius: 6px; background: var(--accent-2, #15a015); transform-origin: left; animation: bmWebIn .7s ease both 1.25s; }
.bm-web-tag { position: absolute; top: 35px; right: 11px; background: var(--ink, #16181a); color: #fff; font-family: var(--font-display); font-weight: 700; font-size: .62rem; padding: .24rem .55rem; border-radius: 99px; }
@keyframes bmWebIn { from { transform: scaleX(.15); opacity: 0; } to { transform: scaleX(1); opacity: 1; } }

/* — Inline-Visuals: Social (Mini-Feed) — */
.bm-mini-feed { position: relative; display: grid; grid-template-columns: repeat(2, 96px); grid-auto-rows: 96px; gap: 8px; }
.bm-mf { border-radius: 13px; box-shadow: 0 6px 16px rgba(0,0,0,.14); }
.bm-mf.t1 { background: linear-gradient(135deg, #15a015, #0b760b); }
.bm-mf.t2 { background: linear-gradient(135deg, #1e2a1e, #0d0e0f); }
.bm-mf.t3 { background: linear-gradient(135deg, #0a6b0a, #15a015); }
.bm-mf.t4 { background: linear-gradient(135deg, #2a2d30, #45494d); }
.bm-mf-heart { position: absolute; inset: 0; display: grid; place-items: center; font-size: 46px; color: #fff; text-shadow: 0 4px 14px rgba(0,0,0,.45); animation: bmHeartPop 2.8s ease-in-out infinite; }
@keyframes bmHeartPop { 0%,100% { transform: scale(.5); opacity: 0; } 12% { transform: scale(1.12); opacity: 1; } 32% { transform: scale(1); opacity: 1; } 48% { transform: scale(.7); opacity: 0; } }

/* — Inline-Visuals: Video (Film-Frame) — */
.bm-film { position: relative; width: 240px; height: 150px; border-radius: 13px; overflow: hidden; background: linear-gradient(135deg, #11150f, #0a0b09); box-shadow: 0 12px 30px rgba(0,0,0,.3); display: grid; place-items: center; }
.bm-film-lb { position: absolute; left: 0; right: 0; height: 16px; background: #000; }
.bm-film-lb.top { top: 0; }
.bm-film-lb.bot { bottom: 0; }
.bm-film-play { width: 54px; height: 54px; border-radius: 50%; background: rgba(255,255,255,.93); position: relative; animation: bmPlayPulse 2.2s ease-in-out infinite; }
.bm-film-play::after { content: ""; position: absolute; top: 50%; left: 54%; transform: translate(-50%,-50%); border-style: solid; border-width: 9px 0 9px 15px; border-color: transparent transparent transparent #16181a; }
@keyframes bmPlayPulse { 0%,100% { box-shadow: 0 0 0 0 rgba(255,255,255,.45); } 70% { box-shadow: 0 0 0 16px rgba(255,255,255,0); } }
@media (prefers-reduced-motion: reduce) {
  .bm-web-hero, .bm-web-ln, .bm-web-btn { animation: none; transform: none; opacity: 1; }
  .bm-mf-heart { animation: none; opacity: 1; transform: none; }
  .bm-film-play { animation: none; }
}

.legal-lang-note { background: var(--surface-2); border-bottom: 1px solid var(--hairline); }
.legal-lang-note .wrap { padding-top: .9rem; padding-bottom: .9rem; }
.legal-lang-note p { margin: 0; font-size: .92rem; color: var(--text-muted); line-height: 1.5; }

/* Interner Bereich — Lead-Karten (Posteingang) */
.lead-card { text-align: left; }
.lead-card-top { display: flex; align-items: center; justify-content: space-between; gap: .8rem; margin-bottom: .5rem; }
.lead-card-top time { font-size: .8rem; color: var(--text-muted); white-space: nowrap; }
.lead-card .lead-contact { font-size: .9rem; color: var(--text-muted); margin: -.2rem 0 .55rem; }
.lead-card .lead-contact a { color: var(--accent-text); text-decoration: none; }
.lead-card .lead-contact a:hover { text-decoration: underline; }
.lead-details { list-style: none; margin: .5rem 0 0; padding: .6rem 0 0; border-top: 1px solid var(--hairline); font-size: .85rem; color: var(--text-muted); }
.lead-details li { margin: .15rem 0; }
/* Separater „ungekühlt"-Block (Tiernahrung & Futtermittel), abgesetzt von der Frischelogistik */
.dry-note { display: flex; align-items: flex-start; gap: .85rem; margin-top: 1.3rem; padding: 1rem 1.2rem;
  background: var(--surface-2); border: 1px solid var(--hairline); border-left: 3px solid var(--accent); border-radius: var(--radius-lg); }
.dry-note .dry-ic { flex: none; width: 34px; height: 34px; border-radius: 9px; display: inline-flex; align-items: center; justify-content: center;
  background: rgba(0,0,0,.04); color: var(--accent-text); }
:root[data-theme="dark"] .dry-note .dry-ic { background: rgba(255,255,255,.06); }
.dry-note .dry-ic svg { width: 18px; height: 18px; }
.dry-note p { margin: 0; font-size: .95rem; color: var(--text-muted); line-height: 1.5; }
.dry-note p strong { color: var(--text); display: block; font-family: var(--font-display); }
/* Regionen-Karten (Wo wir fahren) */
.region-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.1rem; }
.region { background: var(--surface); border: 1px solid var(--hairline); border-left: 3px solid var(--accent); border-radius: var(--radius-xl); padding: 1.5rem 1.6rem; box-shadow: var(--shadow-sm); }
.region h3 { font-family: var(--font-display); font-size: 1.2rem; margin: 0 0 .25rem; color: var(--text); }
.region .r-countries { color: var(--accent-text); font-weight: 600; font-size: .9rem; margin-bottom: .6rem; }
.region p { margin: 0; color: var(--text-muted); font-size: .95rem; line-height: 1.55; }
@media (max-width: 860px) { .region-grid { grid-template-columns: 1fr; } }

/* ===== Import/Export-Routen-Visual ===== */
.intl-lanes { display: flex; flex-direction: column; gap: 1.1rem; width: 100%; }
.intl-lanes .lane { position: relative; overflow: hidden; background: var(--surface); border: 1px solid var(--hairline); border-radius: var(--radius-xl); padding: 1.4rem 1.6rem; box-shadow: var(--shadow-sm); }
.intl-lanes .lane::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 4px; background: var(--accent); }
.intl-lanes .lane-dir { display: flex; align-items: center; gap: .7rem; flex-wrap: wrap; font-family: var(--font-display); font-weight: 600; color: var(--text); }
.intl-lanes .lane-tag { font-size: .7rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; padding: .22rem .65rem; border-radius: 100px; }
.intl-lanes .lane-tag.out { background: rgba(0,128,0,.12); color: var(--accent-text); }
.intl-lanes .lane-tag.in { background: rgba(21,160,21,.18); color: var(--accent-text); }
.intl-lanes .lane-dest { margin: .55rem 0 .2rem; font-family: var(--font-display); font-size: 1.1rem; color: var(--text); }
.intl-lanes .lane-goods { color: var(--text-muted); font-size: .95rem; }
