/* ==========================================================
   Trailfracht — Theme-aware (Mint + Black) ⇄ (Mint + White)
   ========================================================== */
:root, [data-theme="dark"] {
  --bg: #07111f;
  --bg-2: #0c1a2e;
  --bg-3: #112540;
  --surface: #0f1d33;
  --section-alt: #0a1628;
  --line: rgba(255,255,255,0.08);
  --text: #eaf2ff;
  --text-dim: #9bb0c9;
  --muted: #6c809a;
  --card-bg: rgba(255,255,255,0.04);
  --card-bg-hover: rgba(77,195,167,0.06);
  --field-bg: rgba(255,255,255,0.03);
  --footer-bg: #050b16;
  --map-bg: radial-gradient(ellipse at center, #0d1d36 0%, #07111f 70%);
  --mint: #4dc3a7;
  --mint-2: #6bd9bf;
  --mint-glow: rgba(77,195,167,0.45);
}
[data-theme="light"] {
  --bg: #ffffff;
  --bg-2: #f7f9fc;
  --bg-3: #eef2f7;
  --surface: #ffffff;
  --section-alt: #f4f7fb;
  --line: rgba(7,17,31,0.1);
  --text: #07111f;
  --text-dim: #4a5b73;
  --muted: #6c809a;
  --card-bg: #ffffff;
  --card-bg-hover: #f0fbf7;
  --field-bg: #ffffff;
  --footer-bg: #07111f;
  --map-bg: linear-gradient(135deg, #f7f9fc, #eef2f7);
}

*, *::before, *::after { box-sizing: border-box; }
* { -webkit-font-smoothing: antialiased; }
html, body { background: var(--bg); color: var(--text); }
html { scroll-behavior: smooth; }
body {
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  margin: 0;
  overflow-x: hidden;
}

h1, h2, h3, h4, .display {
  font-family: 'Manrope', 'Inter', sans-serif;
  letter-spacing: -0.025em;
  color: var(--text);
}

::selection { background: var(--mint); color: #07111f; }

/* ---------- Scroll progress ---------- */
.scroll-progress {
  position: fixed; top: 0; left: 0;
  height: 2px; width: 0%;
  background: linear-gradient(90deg, var(--mint), var(--mint-2));
  z-index: 100;
  box-shadow: 0 0 12px var(--mint-glow);
  transition: width .08s linear;
}

/* ---------- Cursor follower ---------- */
.cursor-blob {
  position: fixed; pointer-events: none;
  width: 380px; height: 380px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(77,195,167,0.16), transparent 60%);
  filter: blur(40px);
  transform: translate(-50%, -50%);
  transition: transform 0.4s cubic-bezier(.2,.7,.2,1);
  z-index: 1;
  mix-blend-mode: screen;
}
@media (max-width: 1024px) { .cursor-blob { display: none; } }

/* ---------- Reveal ---------- */
.reveal {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 1.1s cubic-bezier(.2,.7,.2,1), transform 1.1s cubic-bezier(.2,.7,.2,1);
  will-change: opacity, transform;
}
.reveal.in { opacity: 1; transform: none; }
.reveal-left { transform: translateX(-50px); }
.reveal-left.in { transform: none; }
.reveal-right { transform: translateX(50px); }
.reveal-right.in { transform: none; }
.reveal-clip {
  clip-path: inset(0 100% 0 0);
  opacity: 1; transform: none;
  transition: clip-path 1.4s cubic-bezier(.7,0,.2,1);
}
.reveal-clip.in { clip-path: inset(0 0 0 0); }
.delay-1 { transition-delay: .08s; }
.delay-2 { transition-delay: .16s; }
.delay-3 { transition-delay: .24s; }
.delay-4 { transition-delay: .32s; }
.delay-5 { transition-delay: .42s; }
.delay-6 { transition-delay: .54s; }

/* Split-text character reveal */
.split-char {
  display: inline-block;
  opacity: 0;
  transform: translateY(60%) rotate(8deg);
  transition: opacity .9s cubic-bezier(.2,.7,.2,1), transform .9s cubic-bezier(.2,.7,.2,1);
}
.split.in .split-char { opacity: 1; transform: none; }

/* ---------- Navbar (minimal, premium, always fixed top) ---------- */
.nav {
  position: fixed !important;
  top: 0; left: 0; right: 0;
  z-index: 50;
  /* Solid bg from the start so it always reads as a real bar, not invisible on hero */
  background: rgba(7,17,31,0.55);
  backdrop-filter: saturate(160%) blur(14px);
  -webkit-backdrop-filter: saturate(160%) blur(14px);
  transition: background .4s, backdrop-filter .4s, border-color .4s, padding .3s;
  border-bottom: 1px solid transparent;
}
.nav.scrolled {
  background: rgba(7,17,31,0.92);
  backdrop-filter: saturate(180%) blur(22px);
  -webkit-backdrop-filter: saturate(180%) blur(22px);
  border-bottom-color: var(--line);
}
[data-theme="light"] .nav {
  /* Über dem Hero-Foto bleibt sie dunkel-transparent damit die weiße Schrift lesbar bleibt */
  background: rgba(7,17,31,0.45);
}
[data-theme="light"] .nav.scrolled {
  /* Sobald gescrollt wird (weiße Sektionen darunter) wechselt sie auf weiß */
  background: rgba(255,255,255,0.95);
  border-bottom-color: rgba(7,17,31,0.08);
}
.nav-brand {
  display: inline-flex; align-items: center;
  text-decoration: none;
}
.nav-brand img {
  height: 36px;
  width: auto;
  display: block;
}
.nav-link {
  position: relative;
  color: rgba(234,242,255,0.78);
  font-size: .88rem;
  font-weight: 500;
  transition: color .25s;
  padding: .25rem 0;
}
.nav-link::after {
  content: ""; position: absolute; left: 0; bottom: -6px;
  width: 0; height: 2px; background: var(--mint);
  transition: width .4s cubic-bezier(.2,.7,.2,1);
}
.nav-link:hover { color: #fff; }
.nav-link:hover::after { width: 100%; }

/* ---------- Hero Inline-Stats (Glass-Pills) ---------- */
.hero-stats {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
  margin-top: 2rem;
  max-width: 700px;
}
.hero-stat-pill {
  padding: .55rem 1.1rem;
  background: rgba(7,17,31,0.5);
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 999px;
  font-size: .88rem;
  font-weight: 600;
  color: rgba(255,255,255,0.92);
  letter-spacing: -0.005em;
  backdrop-filter: blur(10px) saturate(160%);
  -webkit-backdrop-filter: blur(10px) saturate(160%);
  transition: border-color .25s, transform .25s;
  white-space: nowrap;
}
.hero-stat-pill:hover {
  border-color: rgba(77,195,167,0.5);
  transform: translateY(-1px);
}
.hero-stat-pill strong {
  color: var(--mint);
  font-weight: 800;
  margin-right: 5px;
}

/* ---------- Hero USP pills ---------- */
.usp-pill {
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  padding: .55rem 1.05rem;
  background: rgba(7,17,31,0.55);
  backdrop-filter: blur(10px) saturate(160%);
  -webkit-backdrop-filter: blur(10px) saturate(160%);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 999px;
  font-size: .85rem;
  font-weight: 600;
  color: white;
  letter-spacing: -0.005em;
  white-space: nowrap;
  transition: border-color .25s, transform .25s;
}
.usp-pill:hover {
  border-color: rgba(77,195,167,0.5);
  transform: translateY(-1px);
}
.usp-pill svg { color: var(--mint); flex-shrink: 0; }
.usp-pill strong {
  font-weight: 800;
  background: linear-gradient(110deg, var(--mint) 0%, var(--mint-2) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  margin-right: 2px;
}

/* Larger primary CTA — wenn die "Anfrage stellen" prominent rausstechen soll */
.btn-primary-xl {
  padding: 1.1rem 2.1rem !important;
  font-size: 1rem !important;
  letter-spacing: 0.005em;
  box-shadow: 0 14px 38px -8px var(--mint-glow), 0 0 0 0 var(--mint-glow) !important;
  animation: ctaPulse 2.6s ease-in-out infinite;
}
/* Hero-CTA — extra prominent, der Klick-Anker schlechthin */
.btn-primary-hero {
  padding: 1.4rem 3rem !important;
  font-size: 1.15rem !important;
  font-weight: 800 !important;
  letter-spacing: 0.01em;
  gap: .8rem !important;
  box-shadow: 0 18px 48px -10px var(--mint-glow) !important;
  animation: ctaPulseLarge 2.8s ease-in-out infinite;
}
@keyframes ctaPulse {
  0%, 100% { box-shadow: 0 14px 38px -8px var(--mint-glow), 0 0 0 0 rgba(77,195,167,0.4); }
  50%      { box-shadow: 0 14px 38px -8px var(--mint-glow), 0 0 0 8px rgba(77,195,167,0); }
}
@keyframes ctaPulseLarge {
  0%, 100% { box-shadow: 0 18px 48px -10px var(--mint-glow), 0 0 0 0 rgba(77,195,167,0.45); }
  50%      { box-shadow: 0 18px 48px -10px var(--mint-glow), 0 0 0 14px rgba(77,195,167,0); }
}

/* ---------- Buttons ---------- */
.btn-primary {
  position: relative;
  display: inline-flex; align-items: center; gap: .6rem;
  background: linear-gradient(135deg, var(--mint) 0%, var(--mint-2) 100%);
  color: #07111f;
  padding: .95rem 1.7rem;
  border-radius: 999px;
  font-weight: 700;
  font-size: .9rem;
  letter-spacing: .01em;
  box-shadow: 0 12px 30px -8px var(--mint-glow);
  transition: transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s, background .35s;
  overflow: hidden;
}
.btn-primary::before {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(120deg, transparent 0%, rgba(255,255,255,.5) 50%, transparent 100%);
  transform: translateX(-110%);
  transition: transform .8s cubic-bezier(.2,.7,.2,1);
}
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 18px 40px -8px var(--mint-glow); }
.btn-primary:hover::before { transform: translateX(110%); }

.btn-ghost {
  display: inline-flex; align-items: center; gap: .6rem;
  border: 1px solid rgba(255,255,255,0.18);
  color: white;
  padding: .95rem 1.7rem;
  border-radius: 999px;
  font-weight: 600;
  font-size: .9rem;
  transition: background .25s, border-color .25s, transform .25s;
  background: rgba(255,255,255,0.02);
  backdrop-filter: blur(8px);
}
.btn-ghost:hover {
  background: rgba(255,255,255,0.07);
  border-color: var(--mint);
  transform: translateY(-2px);
}

.magnetic { transition: transform .3s cubic-bezier(.2,.7,.2,1); }

/* ---------- Hero (full viewport, image cover) ---------- */
.hero-scene {
  position: relative;
  width: 100%;
  height: 100vh;
  min-height: 620px;
  background: #050b16;
}
.hero-stage {
  position: relative;
  height: 100%;
  overflow: hidden;
  isolation: isolate;
  background: #050b16;
}
/* Sauberer Cut: keine Übergangs-Effekte, klare Trennung Foto ↔ Sektion */
.hero-stage::after { display: none; }
[data-theme="light"] { --bg-rgb: 255, 255, 255; }
[data-theme="dark"]  { --bg-rgb: 7, 17, 31; }

.scene-photo {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  filter: saturate(1.05) contrast(1.05) brightness(1.05);
  animation: heroKenBurns 36s ease-in-out infinite alternate;
}
.scene-photo.hero-master {
  background-image: url('../img/scene/hero-mobile.webp');
  background-position: center center;
}
@media (min-width: 768px) {
  .scene-photo.hero-master {
    background-image: url('../img/scene/hero.webp');
  }
}

@keyframes heroKenBurns {
  0%   { transform: scale(1.0) translate(0, 0); }
  100% { transform: scale(1.03) translate(-0.6%, 0.4%); }
}

/* Light overlay — darkens left for text legibility, lets the photo breathe on the right */
.scene-overlay {
  position: absolute;
  inset: 0;
  z-index: 10;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(5,11,22,0.78) 0%, rgba(5,11,22,0.38) 35%, rgba(5,11,22,0) 65%),
    linear-gradient(180deg, rgba(5,11,22,0.45) 0%, transparent 25%, transparent 70%, rgba(5,11,22,0.55) 100%);
}
.scene-grain { display: none; }

/* Mode badge in lower-right (icon of current phase) */
.scene-badge {
  position: absolute;
  z-index: 12;
  bottom: 8vh;
  right: max(2rem, calc((100vw - 1280px) / 2));
  display: flex; align-items: center; gap: .9rem;
  padding: .85rem 1.3rem;
  background: rgba(7,17,31,0.5);
  border: 1px solid var(--line);
  border-radius: 999px;
  backdrop-filter: blur(14px);
  font-weight: 600;
  font-size: .85rem;
}
.scene-badge .icon {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: var(--mint);
  color: #07111f;
  display: flex; align-items: center; justify-content: center;
}
.scene-badge .icon svg { display: none; }
.scene-badge[data-active="1"] .icon-truck,
.scene-badge[data-active="2"] .icon-ship,
.scene-badge[data-active="3"] .icon-plane { display: block; }
.scene-badge .label-text {
  display: none;
}
.scene-badge[data-active="1"] .label-1,
.scene-badge[data-active="2"] .label-2,
.scene-badge[data-active="3"] .label-3 { display: inline; }
@media (max-width: 768px) { .scene-badge { display: none; } }

/* Hero overlay content — vertically centered, left aligned */
.hero-content {
  position: absolute;
  inset: 0;
  z-index: 20;
  display: flex;
  flex-direction: column;
  justify-content: center;
  pointer-events: none;
}
.hero-content > div { pointer-events: auto; }

.hero-tag {
  display: inline-flex; align-items: center; gap: .55rem;
  padding: .5rem 1rem;
  border-radius: 999px;
  background: rgba(77,195,167,0.08);
  border: 1px solid rgba(77,195,167,0.25);
  color: var(--mint-2);
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .14em;
  font-weight: 600;
}
.hero-tag .dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--mint);
  box-shadow: 0 0 10px var(--mint);
  animation: pulseDot 2s ease-in-out infinite;
}
@keyframes pulseDot { 50% { opacity: .4; } }

.hero-content h1 {
  font-size: clamp(3rem, 8vw, 6.5rem);
  line-height: .98;
  font-weight: 800;
  letter-spacing: -0.04em;
  color: white !important;        /* hero headline is always white, regardless of theme */
  text-shadow: 0 4px 30px rgba(0,0,0,0.55), 0 1px 2px rgba(0,0,0,0.6);
}
.hero-content h1 .accent {
  /* Brand-Türkis (gleiche Farbe wie Logo & überall sonst) */
  color: var(--mint) !important;
  background: none !important;
  -webkit-background-clip: initial !important;
  background-clip: initial !important;
}
.hero-content p,
.hero-content .hero-tag {
  color: rgba(255,255,255,0.85) !important;
  text-shadow: 0 2px 16px rgba(0,0,0,0.6);
}
.hero h1 .accent {
  background: linear-gradient(110deg, var(--mint) 0%, var(--mint-2) 50%, #aef0e0 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

/* Phase indicator (cinema progress 01/02/03) */
.phase-rail {
  display: flex; align-items: center; gap: 1.2rem;
  padding: .8rem 1.4rem;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--line);
  border-radius: 999px;
  backdrop-filter: blur(10px);
  width: fit-content;
}
.phase-step {
  display: flex; align-items: center; gap: .55rem;
  font-size: .78rem; font-weight: 600;
  color: rgba(234,242,255,0.45);
  transition: color .3s;
}
.phase-step .num {
  font-family: 'Manrope', sans-serif;
  font-weight: 700;
  font-size: .68rem;
  width: 22px; height: 22px;
  border-radius: 50%;
  border: 1px solid currentColor;
  display: flex; align-items: center; justify-content: center;
  transition: background .3s, color .3s, border-color .3s;
}
.phase-step.active {
  color: var(--mint-2);
}
.phase-step.active .num {
  background: var(--mint);
  color: #07111f;
  border-color: var(--mint);
  box-shadow: 0 0 14px var(--mint-glow);
}
.phase-divider {
  width: 18px; height: 1px;
  background: rgba(255,255,255,0.15);
}

/* Phase tagline below headline */
.phase-tagline {
  position: relative;
  height: 1.7em;
  overflow: hidden;
  font-family: 'Manrope', sans-serif;
  font-weight: 700;
  font-size: clamp(1.1rem, 2.2vw, 1.7rem);
  color: var(--mint-2);
}
.phase-tagline span {
  position: absolute;
  left: 0;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity .5s, transform .5s;
}
.phase-tagline span.active {
  opacity: 1;
  transform: none;
}

/* Mode chips floating */
.mode-pill {
  position: relative;
  display: inline-flex; align-items: center; gap: .55rem;
  padding: .55rem 1.1rem;
  border-radius: 999px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.1);
  color: var(--text);
  font-weight: 600;
  font-size: .85rem;
  backdrop-filter: blur(10px);
  transition: all .35s;
}
.mode-pill svg { color: var(--mint); }
.mode-pill:hover {
  border-color: rgba(77,195,167,0.6);
  background: rgba(77,195,167,0.08);
  transform: translateY(-2px);
}

/* Scroll indicator */
.scroll-indicator {
  position: absolute; bottom: 2.5rem; left: 50%;
  transform: translateX(-50%);
  color: rgba(234,242,255,0.5);
  font-size: .7rem;
  letter-spacing: .25em;
  text-transform: uppercase;
  display: flex; flex-direction: column; align-items: center; gap: .75rem;
}
.scroll-line {
  width: 1px; height: 50px;
  background: linear-gradient(to bottom, transparent, var(--mint));
  animation: scrollLine 2s ease-in-out infinite;
  transform-origin: top;
}
@keyframes scrollLine {
  0% { transform: scaleY(0); transform-origin: top; }
  50% { transform: scaleY(1); transform-origin: top; }
  51% { transform-origin: bottom; }
  100% { transform: scaleY(0); transform-origin: bottom; }
}

/* ---------- Philosophy Quote ---------- */
.philosophy-section {
  padding: 4rem 1.5rem 5rem;
  text-align: center;
  position: relative;
}
.philosophy-wrap {
  max-width: 760px;
  margin: 0 auto;
}
.philosophy-mark {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 1.8rem;
}
.philosophy-mark span {
  display: block;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--mint);
  opacity: 0.4;
}
.philosophy-mark span:nth-child(2) { opacity: 1; transform: scale(1.2); }
.philosophy-quote {
  font-family: 'Manrope', sans-serif;
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: -0.02em;
  color: var(--text);
  margin: 0;
}
.philosophy-attr {
  margin-top: 1.6rem;
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--mint);
}

/* ---------- Section-dark (auch im Light-Theme dunkel — z.B. für Kontakt) ---------- */
.section-dark {
  background: linear-gradient(180deg, #07111f 0%, #0a1628 100%);
  color: #eaf2ff;
  position: relative;
}
.section-dark .section-title { color: white; }
.section-dark .section-kicker { color: var(--mint-2); }
.section-dark .text-\[color\:var\(--text-dim\)\] { color: rgba(234,242,255,0.7) !important; }
.section-dark a:hover { color: var(--mint); }
.section-dark .border-\[color\:var\(--line\)\] { border-color: rgba(255,255,255,0.1) !important; }
[data-theme="light"] .section-dark .text-\[color\:var\(--text\)\],
.section-dark strong.text-\[color\:var\(--text\)\] { color: white !important; }

/* Form-Karte auf dunklem Hintergrund */
.contact-form-card {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.1);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  box-shadow: 0 24px 60px -20px rgba(0,0,0,0.5);
  color: #eaf2ff;
}
.contact-form-card h3 { color: white; }
.contact-form-card label { color: rgba(234,242,255,0.7) !important; }
.contact-form-card .field {
  background: rgba(255,255,255,0.05);
  border-color: rgba(255,255,255,0.12);
  color: white;
}
.contact-form-card .field:focus {
  background: rgba(77,195,167,0.06);
  border-color: var(--mint);
  box-shadow: 0 0 0 4px rgba(77,195,167,0.15);
}
.contact-form-card .field::placeholder { color: rgba(234,242,255,0.4); }
.contact-form-card select.field option {
  background: #0a1628;
  color: white;
}
.contact-form-card label.flex {
  color: rgba(234,242,255,0.7);
}

/* Icon containers in dark section */
.section-dark .bg-mint\/10 { background: rgba(77,195,167,0.15) !important; }

/* ---------- Sub-page hero (für Unterseiten wie /leistungen, /kontakt etc.) ---------- */
.sub-hero {
  position: relative;
  min-height: 380px;
  height: 50vh;
  display: flex;
  align-items: center;
  overflow: hidden;
  background: #050b16;
}
.sub-hero-bg {
  position: absolute; inset: 0;
  background-size: cover;
  background-position: center;
  filter: saturate(0.85) brightness(0.7);
}
.sub-hero::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(90deg, rgba(7,17,31,0.85) 0%, rgba(7,17,31,0.45) 55%, rgba(7,17,31,0.15) 100%);
}
.sub-hero-content {
  position: relative; z-index: 5;
  width: 100%;
  padding-top: 5rem;
}
.sub-hero h1 {
  font-family: 'Manrope', sans-serif;
  font-weight: 800;
  font-size: clamp(2.5rem, 5vw, 4.2rem);
  letter-spacing: -0.03em;
  color: white !important;
  text-shadow: 0 2px 20px rgba(0,0,0,0.5);
  margin: 0;
  line-height: 1;
}
.sub-hero p {
  margin-top: 1.2rem;
  max-width: 620px;
  color: rgba(255,255,255,0.88);
  font-size: 1.15rem;
  line-height: 1.5;
  text-shadow: 0 1px 10px rgba(0,0,0,0.4);
}
.breadcrumb {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  margin-bottom: 1.2rem;
}
.breadcrumb a { color: rgba(255,255,255,0.6); text-decoration: none; transition: color .2s; }
.breadcrumb a:hover { color: var(--mint); }
.breadcrumb-sep { color: rgba(255,255,255,0.3); }
.breadcrumb .current { color: var(--mint-2); }

/* Active nav link */
.nav-link.active { color: white; }
.nav-link.active::after { width: 100%; background: var(--mint); }
[data-theme="light"] .nav.scrolled .nav-link.active { color: var(--text); }

/* ---------- Sections ---------- */
.section { padding: 6rem 0; position: relative; }
.section-light { background: #f6f8fb; color: #0a1628; }
.section-light h1, .section-light h2, .section-light h3, .section-light h4 { color: #07111f; }
.section-light .section-kicker { color: #0a8a6e; }
.section-light .text-dim { color: #4a5b73; }

.section-kicker {
  display: inline-block;
  text-transform: uppercase;
  letter-spacing: .22em;
  font-size: 1rem;
  font-weight: 700;
  color: var(--mint-2);
  margin-bottom: 1rem;
  padding-left: 2rem;
  position: relative;
}
.section-kicker::before {
  content: "";
  position: absolute; left: 0; top: 50%;
  width: 1.4rem; height: 1px;
  background: var(--mint);
  transform: translateY(-50%);
}
.section-title {
  font-size: clamp(2.2rem, 5vw, 3.8rem);
  font-weight: 800;
  line-height: 1.05;
  margin: 0;
}

/* ---------- Modes (Air / Sea / Truck) ---------- */
.modes {
  background: linear-gradient(180deg, #07111f 0%, #0a1628 100%);
  position: relative;
}
.mode-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5rem;
  align-items: center;
  padding: 6rem 0;
  border-bottom: 1px solid var(--line);
}
.mode-row:last-child { border-bottom: none; }
.mode-row.reverse { direction: rtl; }
.mode-row.reverse > * { direction: ltr; }
@media (max-width: 1024px) {
  .mode-row { grid-template-columns: 1fr; gap: 2rem; padding: 4rem 0; }
  .mode-row.reverse { direction: ltr; }
}

/* Compact mode teaser cards (Startseite Vorschau) */
.mode-teaser {
  display: block;
  background: var(--card-bg);
  border: 1px solid var(--line);
  border-radius: 18px;
  overflow: hidden;
  transition: transform .35s cubic-bezier(.2,.7,.2,1), border-color .35s, box-shadow .35s;
  text-decoration: none;
  color: inherit;
}
.mode-teaser:hover {
  transform: translateY(-4px);
  border-color: rgba(77,195,167,0.45);
  box-shadow: 0 24px 60px -28px var(--mint-glow);
}
.mode-teaser-img {
  position: relative;
  aspect-ratio: 16/10;
  overflow: hidden;
  background: #0a1628;
}
.mode-teaser-img img {
  width: 100%; height: 100%;
  object-fit: cover;
  filter: saturate(0.9) contrast(1.05);
  transition: transform 6s ease-out;
}
.mode-teaser:hover .mode-teaser-img img { transform: scale(1.06); }
.mode-teaser-img::after {
  content: "";
  position: absolute; inset: 0; pointer-events: none;
  background: linear-gradient(180deg, transparent 60%, rgba(7,17,31,0.55) 100%);
}
.mode-teaser-body {
  padding: 1.6rem 1.6rem 1.8rem;
}
.mode-teaser-body .mode-title {
  font-size: 1.35rem;
  margin-top: .3rem;
}
.mode-teaser-body .mode-desc {
  font-size: .95rem;
  margin-top: .6rem;
  color: var(--text-dim);
  line-height: 1.55;
}
.mode-link {
  display: inline-flex; align-items: center; gap: .4rem;
  margin-top: 1.2rem;
  font-size: .85rem;
  font-weight: 600;
  color: var(--mint);
  letter-spacing: .02em;
  transition: gap .25s;
}
.mode-teaser:hover .mode-link { gap: .7rem; }

.mode-visual {
  position: relative;
  aspect-ratio: 4/3;
  border-radius: 22px;
  overflow: hidden;
  background: #0a1628;
  border: 1px solid var(--line);
}
.mode-visual img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center;
  filter: saturate(0.9) contrast(1.05);
  transition: transform 8s ease-out;
}
.mode-visual:hover img { transform: scale(1.06); }
.mode-visual::after {
  content: "";
  position: absolute; inset: 0;
  pointer-events: none;
  background: linear-gradient(135deg, rgba(7,17,31,0.55) 0%, rgba(7,17,31,0.1) 50%, rgba(77,195,167,0.18) 100%);
}
.mode-num {
  font-family: 'Manrope', sans-serif;
  font-size: clamp(5rem, 14vw, 9rem);
  font-weight: 800;
  line-height: 1;
  background: linear-gradient(180deg, rgba(77,195,167,0.4), rgba(77,195,167,0));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  letter-spacing: -.05em;
}

.mode-label {
  display: inline-flex; align-items: center; gap: .5rem;
  font-size: .75rem;
  text-transform: uppercase;
  letter-spacing: .2em;
  color: var(--mint-2);
  font-weight: 700;
}
.mode-label::before {
  content: ""; display: inline-block;
  width: 28px; height: 1px;
  background: var(--mint);
}
.mode-title {
  font-size: clamp(2rem, 4.5vw, 3rem);
  font-weight: 800;
  line-height: 1.05;
  margin: .8rem 0 1.2rem;
}
.mode-desc { color: var(--text-dim); font-size: 1.05rem; line-height: 1.7; max-width: 500px; }

.mode-features {
  margin-top: 2rem;
  display: grid; gap: .75rem;
}
.mode-features li {
  display: flex; align-items: center; gap: .75rem;
  color: var(--text);
  font-weight: 500;
}
.mode-features li::before {
  content: "";
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--mint);
  box-shadow: 0 0 6px var(--mint-glow);
}

/* Mode visual SVG container */
.mode-canvas {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
}
.mode-canvas .moving-icon {
  animation: moveAcross 8s linear infinite;
}
@keyframes moveAcross {
  0% { offset-distance: 0%; }
  100% { offset-distance: 100%; }
}

/* ---------- Stats: floating cards overlapping the hero ---------- */
.stats-overlap {
  position: relative;
  z-index: 30;
  margin-top: clamp(-160px, -16vh, -100px);
  padding: 0 1.5rem 4rem;
}
.stats-card-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  max-width: 80rem;
  margin: 0 auto;
}
.stat-card {
  background: white;
  border-radius: 18px;
  padding: 2rem 1.5rem;
  text-align: center;
  border: 1px solid rgba(7,17,31,0.06);
  box-shadow: 0 24px 60px -22px rgba(7,17,31,0.45), 0 4px 12px -6px rgba(7,17,31,0.15);
  transition: transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s;
}
.stat-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 30px 70px -22px rgba(7,17,31,0.5), 0 6px 16px -6px rgba(77,195,167,0.25);
}
.stat-card .stat-label {
  font-size: .78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--muted);
  margin-top: .65rem;
}
[data-theme="dark"] .stat-card {
  background: rgba(15,29,51,0.92);
  border-color: rgba(255,255,255,0.08);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  box-shadow: 0 24px 60px -22px rgba(0,0,0,0.7), 0 4px 12px -6px rgba(0,0,0,0.4);
}
[data-theme="dark"] .stat-card .stat-label { color: var(--text-dim); }
@media (max-width: 900px) {
  .stats-overlap { margin-top: -50px; padding-bottom: 3rem; }
  .stats-card-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .stat-card { padding: 1.5rem 1rem; }
}

/* ---------- Stats ---------- */
.stat-num {
  font-family: 'Manrope', sans-serif;
  font-size: clamp(2.5rem, 5vw, 4rem);
  font-weight: 800;
  line-height: 1;
  background: linear-gradient(135deg, var(--mint) 0%, var(--mint-2) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  letter-spacing: -.02em;
}
/* Variante für Text-Statement (z.B. "Konzern­unabhängig") — passt in dieselbe Höhe wie Zahlen */
.stat-num.stat-num-text {
  font-size: clamp(1.3rem, 2.4vw, 1.85rem);
  line-height: 1.05;
  letter-spacing: -0.015em;
}

/* ---------- Service cards (3D tilt) ---------- */
.service-grid { perspective: 1200px; }
.service-card {
  position: relative;
  background: var(--card-bg);
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 2rem;
  overflow: hidden;
  transform-style: preserve-3d;
  transition: transform .15s cubic-bezier(.2,.7,.2,1), border-color .35s, background .35s;
}
.service-card::before {
  content: "";
  position: absolute; top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--mint), transparent);
  opacity: 0;
  transition: opacity .35s;
}
.service-card::after {
  content: "";
  position: absolute; inset: 0;
  background: radial-gradient(circle 200px at var(--mx,50%) var(--my,50%), rgba(77,195,167,0.12), transparent 50%);
  opacity: 0;
  transition: opacity .35s;
  pointer-events: none;
}
.service-card:hover { border-color: rgba(77,195,167,0.35); background: linear-gradient(160deg, rgba(77,195,167,0.06) 0%, rgba(255,255,255,0.02) 100%); }
.service-card:hover::before { opacity: 1; }
.service-card:hover::after { opacity: 1; }

.service-icon {
  width: 52px; height: 52px;
  border-radius: 12px;
  background: rgba(77,195,167,0.1);
  border: 1px solid rgba(77,195,167,0.2);
  color: var(--mint);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 1.4rem;
  transition: transform .3s, background .3s;
  transform: translateZ(20px);
}
.service-card:hover .service-icon {
  transform: translateZ(30px) scale(1.05);
  background: rgba(77,195,167,0.18);
}
.service-card h3 { font-size: 1.15rem; font-weight: 700; margin: 0 0 .5rem; transform: translateZ(15px); }
.service-card p { color: var(--text-dim); font-size: .92rem; line-height: 1.6; margin: 0; transform: translateZ(8px); }

/* ---------- Region marquee ---------- */
.marquee {
  overflow: hidden;
  -webkit-mask-image: linear-gradient(90deg, transparent, black 10%, black 90%, transparent);
  mask-image: linear-gradient(90deg, transparent, black 10%, black 90%, transparent);
  padding: 1rem 0;
}
.marquee-track {
  display: flex;
  align-items: center;
  gap: 3rem;
  animation: scroll 40s linear infinite;
  width: max-content;
}
.marquee-track:hover { animation-play-state: paused; }
.marquee-track > span {
  font-family: 'Manrope', sans-serif;
  font-size: clamp(1.8rem, 3.5vw, 2.6rem);
  font-weight: 700;
  white-space: nowrap;
  color: rgba(234,242,255,0.4);
  -webkit-text-stroke: 1px rgba(77,195,167,0.5);
  text-stroke: 1px rgba(77,195,167,0.5);
}
.marquee-track .dot { color: var(--mint); -webkit-text-stroke: 0; }
@keyframes scroll { to { transform: translateX(-50%); } }

/* ---------- Global network map (real geopolitical SVG with borders) ---------- */
.global-map {
  position: relative;
  width: 100%;
  aspect-ratio: 2752 / 1520;
  max-width: 1200px;
  margin: 0 auto;
  background: radial-gradient(ellipse at center, #0d1d36 0%, #07111f 70%);
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid var(--line);
}
/* Soft vignetting (subtile Randabdunklung für cleaneren Look) */
.global-map::after {
  content: "";
  position: absolute; inset: 0;
  pointer-events: none;
  background: radial-gradient(ellipse at center, transparent 55%, rgba(7,17,31,0.7) 100%);
  border-radius: inherit;
  z-index: 1;
}
.global-map > * { position: relative; z-index: 0; }
.global-map .map-overlay { z-index: 2; }
.map-base {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
}
.map-base svg {
  width: 100%; height: 100%;
}
/* Country layer — soft, technical chart look */
.map-base svg path,
.map-base svg polygon {
  fill: rgba(155, 200, 230, 0.075) !important;     /* Land: leicht heller als Wasser-BG */
  stroke: rgba(155, 200, 230, 0.30) !important;    /* Borders: 30 % opacity */
  stroke-width: 0.4px !important;                  /* dünner */
  vector-effect: non-scaling-stroke;
}
.map-base svg circle { fill: rgba(155, 200, 230, 0.075) !important; }

/* Antarktis komplett ausblenden (zusätzlich zum viewBox-Crop) */
.map-base svg #aq,
.map-base svg [id="aq"],
.map-base svg .aq,
.map-base svg .land.coast.aq { display: none !important; }
.map-overlay {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  pointer-events: none;
}
.map-overlay * { vector-effect: non-scaling-stroke; }

/* Two-Click Google Maps Consent */
.maps-wrapper { background: var(--bg-2); }
.maps-consent {
  min-height: 450px;
  display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, #0a1628 0%, #112540 100%);
  position: relative;
  padding: 2rem;
}
.maps-consent::before {
  content: ""; position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(155,200,230,0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(155,200,230,0.06) 1px, transparent 1px);
  background-size: 40px 40px;
  pointer-events: none;
}
.maps-consent-inner { position: relative; text-align: center; max-width: 480px; }

/* Partner / Schwesterunternehmen — dezent, zwischen Hauptcontent und Footer */
.partner-section {
  padding: 5rem 0 5.5rem;
  background: linear-gradient(180deg, transparent 0%, rgba(7,17,31,0.4) 100%);
  border-top: 1px solid var(--line);
}
.partner-grid {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 3.5rem;
  align-items: center;
}
@media (max-width: 900px) {
  .partner-grid { grid-template-columns: 1fr; gap: 2.5rem; }
}
.partner-intro .section-kicker { margin-bottom: 0.8rem; }
.partner-title {
  font-family: 'Manrope', sans-serif;
  font-size: clamp(1.6rem, 3vw, 2.1rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.15;
  color: var(--text);
  margin-bottom: 0.9rem;
}
.partner-lead {
  font-size: 0.95rem;
  line-height: 1.6;
  color: var(--text-dim);
  max-width: 38ch;
}
.partner-lead strong { color: var(--mint-2); font-weight: 600; }

.partner-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}
@media (max-width: 600px) {
  .partner-cards { grid-template-columns: 1fr; }
}
.partner-card {
  display: flex; flex-direction: column;
  padding: 1.5rem 1.5rem 1.4rem;
  background: rgba(255,255,255,0.025);
  border: 1px solid var(--line);
  border-radius: 14px;
  color: inherit;
  transition: transform 0.3s cubic-bezier(.2,.7,.2,1), border-color 0.3s, background 0.3s;
}
.partner-card:hover {
  transform: translateY(-3px);
  border-color: rgba(77,195,167,0.45);
  background: rgba(77,195,167,0.04);
}
.partner-card-icon {
  width: 38px; height: 38px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 10px;
  background: rgba(77,195,167,0.12);
  border: 1px solid rgba(77,195,167,0.25);
  color: var(--mint-2);
  margin-bottom: 1rem;
}
.partner-card-label {
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--mint-2);
  margin-bottom: 0.4rem;
}
.partner-card-name {
  font-family: 'Manrope', sans-serif;
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--text);
  letter-spacing: -0.01em;
  margin-bottom: 1rem;
}
.partner-card-contact {
  padding: 0.9rem 0 1rem;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  margin-bottom: 1rem;
}
.partner-contact-role {
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--muted);
  margin-bottom: 0.3rem;
}
.partner-contact-name {
  font-weight: 600;
  color: var(--text);
  font-size: 0.95rem;
  margin-bottom: 0.55rem;
}
.partner-contact-list {
  list-style: none;
  display: flex; flex-direction: column;
  gap: 0.3rem;
  margin: 0; padding: 0;
}
.partner-contact-list a {
  display: inline-flex; align-items: center; gap: 0.45rem;
  font-size: 0.82rem;
  color: var(--text-dim);
  text-decoration: none;
  transition: color 0.2s;
}
.partner-contact-list a:hover { color: var(--mint-2); }
.partner-contact-list svg { color: var(--mint); flex-shrink: 0; }
.partner-card-link {
  margin-top: auto;
  display: inline-flex; align-items: center; gap: 0.35rem;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--mint);
  letter-spacing: 0.02em;
  transition: gap 0.25s;
  text-decoration: none;
}
.partner-card-link:hover { gap: 0.55rem; }

/* Story-Sektion auf partner.html mit Hintergrundbild (Lager-Aerial) */
.partner-story {
  position: relative;
  overflow: hidden;
  padding: 7rem 0 7.5rem;
  isolation: isolate;
}
.partner-story-bg {
  position: absolute; inset: 0;
  background-size: cover;
  background-position: center;
  filter: saturate(0.85) contrast(1.05);
  z-index: 0;
}
.partner-story-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(7,17,31,0.78) 0%, rgba(7,17,31,0.92) 100%);
  z-index: 1;
}
[data-theme="light"] .partner-story-overlay {
  background: linear-gradient(180deg, rgba(7,17,31,0.85) 0%, rgba(7,17,31,0.95) 100%);
}
.partner-story .section-kicker { color: var(--mint-2); }
.partner-story h2,
.partner-story p { color: white; }
.partner-story p { color: rgba(255,255,255,0.85); }

/* Detail-Karten auf partner.html — größer, mit Feature-Liste */
.partner-detail-card {
  display: flex; flex-direction: column;
  padding: 2.4rem 2.4rem 2.2rem;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--line);
  border-radius: 18px;
  transition: border-color 0.3s, transform 0.3s;
}
.partner-detail-card:hover {
  border-color: rgba(77,195,167,0.35);
  transform: translateY(-2px);
}
.partner-detail-card .partner-card-icon {
  width: 52px; height: 52px;
  margin-bottom: 1.4rem;
}
.partner-detail-card .partner-legal-suffix {
  display: inline-block;
  font-size: 0.7em;
  font-weight: 500;
  color: var(--text-dim);
  letter-spacing: 0;
  margin-top: 0.15em;
}
.partner-detail-name { margin-bottom: 0.4rem; }
.partner-detail-card .partner-card-label { margin-bottom: 1.2rem; }
.partner-legal-suffix {
  display: inline-block;
  font-size: 0.7em;
  font-weight: 500;
  color: var(--text-dim);
  letter-spacing: 0;
  margin-top: 0.15em;
}
.partner-detail-name {
  font-family: 'Manrope', sans-serif;
  font-size: 1.45rem;
  line-height: 1.2;
  font-weight: 700;
  color: var(--text);
  letter-spacing: -0.015em;
  margin-bottom: 1rem;
}
.partner-detail-desc {
  font-size: 1rem;
  color: var(--text-dim);
  line-height: 1.6;
  margin-bottom: 1.4rem;
}
.partner-detail-features {
  list-style: none;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.5rem 1rem;
  margin: 0 0 1.6rem;
  padding: 0;
}
.partner-detail-features li {
  position: relative;
  padding-left: 1.3rem;
  font-size: 0.9rem;
  color: var(--text-dim);
  line-height: 1.5;
}
.partner-detail-features li::before {
  content: ""; position: absolute;
  left: 0; top: 0.6em;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--mint);
}
.partner-detail-card .partner-card-contact {
  border-top: 1px solid var(--line);
  border-bottom: none;
  padding: 1.2rem 0 1.4rem;
  margin-bottom: 1.5rem;
  margin-top: auto;  /* drückt Kontakt + Button nach unten → symmetrisch zwischen beiden Karten */
}
.partner-detail-card .btn-ghost {
  align-self: flex-start;  /* Button nicht volle Breite */
}

/* Rechtsseiten (Impressum, Datenschutz, AGB) — Lesetypografie */
.legal-prose { color: var(--text); font-size: 1rem; line-height: 1.7; }
.legal-prose h2 {
  font-family: 'Manrope', sans-serif; font-weight: 700;
  font-size: 1.4rem; letter-spacing: -0.01em;
  margin-top: 2.6rem; margin-bottom: 0.9rem;
  color: var(--text);
}
.legal-prose h2:first-child { margin-top: 0; }
.legal-prose p { margin-bottom: 1.1rem; color: var(--text-dim); }
.legal-prose strong { color: var(--text); font-weight: 600; }
.legal-prose a { color: var(--mint); text-decoration: underline; text-decoration-color: rgba(77,195,167,0.4); text-underline-offset: 3px; transition: color .2s, text-decoration-color .2s; }
.legal-prose a:hover { color: var(--mint-2); text-decoration-color: var(--mint); }
.legal-prose ul { list-style: disc; padding-left: 1.5rem; margin-bottom: 1.1rem; color: var(--text-dim); }
.legal-prose ul li { margin-bottom: 0.4rem; }
.legal-prose .legal-meta {
  margin-top: 3rem; padding-top: 1.2rem;
  border-top: 1px solid var(--line);
  font-size: 0.82rem; color: var(--muted);
}
.legal-table {
  width: 100%; border-collapse: collapse;
  margin: 1rem 0 1.5rem;
  font-size: 0.92rem;
}
.legal-table th, .legal-table td {
  text-align: left; padding: 0.7rem 0.9rem;
  border-bottom: 1px solid var(--line);
  vertical-align: top;
}
.legal-table th {
  font-weight: 600; color: var(--text);
  background: rgba(255,255,255,0.02);
  font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.05em;
}
.legal-table td { color: var(--text-dim); }
.legal-table td:first-child { font-family: monospace; color: var(--mint-2); white-space: nowrap; }

/* Untertitel unter der Karte */
.map-caption {
  font-size: 0.8rem;
  letter-spacing: 0.04em;
  color: rgba(148, 163, 184, 0.85);
  font-weight: 500;
}

/* Ambient lines — permanent dezent, eines der 24 Vienna→City-Pfade */
.route-ambient {
  fill: none;
  stroke: rgba(77,195,167,0.16);
  stroke-width: 0.7;
  stroke-linecap: round;
}

/* Pulse line — eine helle, animierte Linie (d-Attribut von JS gesetzt) */
.route-pulse {
  fill: none;
  stroke: rgba(107,217,191,0.95);
  stroke-width: 1.8;
  stroke-linecap: round;
  filter: drop-shadow(0 0 3px rgba(77,195,167,0.7));
  opacity: 0; /* JS steuert */
  pointer-events: none;
}

/* Aktiver Ziel-Hub während Pulse-Animation */
.hub-group.pulse-active .hub {
  animation: pinScale 1.2s ease-in-out infinite;
  transform-origin: center;
  transform-box: fill-box;
}
@keyframes pinScale {
  0%, 100% { transform: scale(1); }
  50%      { transform: scale(1.25); }
}
.hub-group.pulse-active .hub-label {
  fill: #ffffff;
  fill-opacity: 1;
  font-size: 22px;
}

@media (prefers-reduced-motion: reduce) {
  .route-ambient { stroke-opacity: 0.4; }
  .route-pulse   { display: none; }
  .hub-group.pulse-active .hub { animation: none; }
}

@media (max-width: 768px) {
  .route-ambient { stroke-opacity: 0.10; stroke-width: 0.5; }
}

/* Mobile: kleinere Labels, noch dünnere Linien — Pins aber sichtbar */
@media (max-width: 768px) {
  .hub-label { font-size: 26px; letter-spacing: .04em; }
  .hub-label-origin { font-size: 30px; }
  .route { stroke-width: 1.4; stroke-dasharray: 4 5; }
}
@media (max-width: 480px) {
  /* Auf sehr kleinen Screens nur Origin- und Haupt-Hub-Labels zeigen */
  .hubs .hub-label { display: none; }
}
.hub {
  fill: var(--mint);
  stroke: rgba(7,17,31,0.95);
  stroke-width: 1.5;
  transition: r 0.3s, fill 0.3s;
}
/* Hierarchie: Tier-1-Hubs etwas heller, Tier-2 dezenter */
.hub-tier1 .hub { fill: var(--mint); }
.hub-tier2 .hub { fill: rgba(77,195,167,0.78); }
.hub-origin {
  fill: var(--mint-2);     /* hellster Türkis-Ton */
  stroke: white;
  stroke-width: 1.5;
}
.hub-pulse {
  fill: var(--mint);
  opacity: 0.35;
  transform-origin: center;
  transform-box: fill-box;
  animation: hubPulse 3.2s ease-out infinite;
}
@keyframes hubPulse {
  0%   { transform: scale(0.5); opacity: 0.35; }
  100% { transform: scale(1.8); opacity: 0; }
}
.flying-icon { display: none; }
.hub-label {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 18px;
  font-weight: 600;
  fill: rgba(234,242,255,0.95);
  fill-opacity: 0.6;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  pointer-events: none;
  transition: fill 0.3s, fill-opacity 0.3s, font-size 0.3s;
}
.hub-label-origin {
  font-size: 22px;
  fill: var(--mint-2);
  fill-opacity: 1;
  font-weight: 700;
  letter-spacing: 0.1em;
}
[data-theme="light"] .hub-label { fill: rgba(7,17,31,0.7); }
[data-theme="light"] .hub { stroke: rgba(255,255,255,0.95); }
[data-theme="light"] .route { stroke: rgba(77,195,167,0.7); }

/* Große Zertifikats-Bilder (auf Zertifikate-Seite) */
.cert-large-img {
  background: white;
  border-radius: 22px;
  padding: 3rem 2rem;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  text-align: center;
  border: 1px solid rgba(7,17,31,0.06);
  box-shadow: 0 24px 60px -22px rgba(7,17,31,0.25);
  min-height: 280px;
}
.cert-large-img img { max-width: 220px; height: auto; }
.cert-large-tuv { background: white; }
[data-theme="dark"] .cert-large-img {
  background: rgba(255,255,255,0.04);
  border-color: rgba(255,255,255,0.08);
  box-shadow: 0 24px 60px -22px rgba(0,0,0,0.5);
}

/* Check-Icons in Zertifikatsbeschreibungen */
.check-icon {
  flex-shrink: 0;
  display: inline-flex; align-items: center; justify-content: center;
  width: 28px; height: 28px;
  border-radius: 50%;
  background: rgba(77,195,167,0.12);
  color: var(--mint);
  font-weight: 800;
  font-size: .9rem;
  border: 1px solid rgba(77,195,167,0.3);
}

/* Region pills (für Netzwerk-Seite) */
.region-pill {
  display: inline-flex; align-items: center; gap: .55rem;
  padding: .65rem 1.2rem;
  border-radius: 999px;
  background: rgba(77,195,167,0.06);
  border: 1px solid rgba(77,195,167,0.25);
  font-size: .9rem;
  font-weight: 600;
  color: var(--text);
  transition: background .2s, border-color .2s, transform .2s;
}
.region-pill:hover {
  background: rgba(77,195,167,0.12);
  border-color: rgba(77,195,167,0.5);
  transform: translateY(-2px);
}
.region-pill .dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--mint);
  box-shadow: 0 0 8px var(--mint);
}

/* Stats pills under map */
.network-pills {
  display: flex; flex-wrap: wrap; gap: .75rem; justify-content: center;
  margin-top: 2.5rem;
}
.network-pill {
  display: inline-flex; align-items: center; gap: .55rem;
  padding: .55rem 1.1rem;
  border-radius: 999px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--line);
  font-size: .82rem;
  font-weight: 600;
  color: var(--text);
  backdrop-filter: blur(10px);
}
.network-pill .dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--mint);
  box-shadow: 0 0 8px var(--mint);
}

/* ---------- Certificates ---------- */
.cert-card {
  background: var(--card-bg);
  border: 1px solid var(--line);
  border-radius: 20px;
  padding: 2.2rem;
  text-align: center;
  transition: transform .35s, border-color .35s, background .35s;
}
.cert-card:hover {
  transform: translateY(-6px);
  border-color: rgba(77,195,167,0.35);
  background: rgba(77,195,167,0.05);
}
.cert-card .cert-img-wrap {
  background: white;
  border-radius: 14px;
  padding: 1rem;
  margin-bottom: 1.2rem;
  display: flex; align-items: center; justify-content: center;
  height: 160px;
}
.cert-card img { max-height: 130px; max-width: 100%; object-fit: contain; }
.cert-placeholder {
  background: rgba(255,255,255,0.02);
  border: 1px dashed rgba(255,255,255,0.15);
  display: flex; align-items: center; justify-content: center;
  height: 160px;
  border-radius: 14px;
  color: var(--muted);
  font-size: .85rem;
  font-style: italic;
  margin-bottom: 1.2rem;
}

/* ---------- Form ---------- */
.field {
  width: 100%;
  background: var(--field-bg);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 1rem 1.1rem;
  font-size: .95rem;
  color: var(--text);
  font-family: inherit;
  transition: border-color .25s, background .25s, box-shadow .25s;
}
.field::placeholder { color: var(--muted); }
.field:focus {
  outline: none;
  border-color: var(--mint);
  background: rgba(77,195,167,0.04);
  box-shadow: 0 0 0 4px rgba(77,195,167,0.1);
}

/* ---------- Footer ---------- */
.footer {
  background: var(--footer-bg);
  border-top: 1px solid var(--line);
  color: var(--text-dim);
}
.footer a { color: var(--text-dim); transition: color .2s; }
.footer a:hover { color: var(--mint); }

/* ---------- Lang switcher ---------- */
.lang-group {
  display: inline-flex;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 3px;
}
.lang-btn {
  padding: .35rem .8rem;
  border-radius: 999px;
  font-size: .72rem;
  letter-spacing: .12em;
  color: var(--text-dim);
  font-weight: 700;
  transition: all .25s;
  border: none;
  background: transparent;
  cursor: pointer;
}
.lang-btn.active {
  background: var(--mint);
  color: #07111f;
  box-shadow: 0 4px 12px var(--mint-glow);
}

/* ---------- Floating Phone CTA (always visible) ---------- */
.fab-phone {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 45;
  display: inline-flex;
  align-items: center;
  gap: .8rem;
  padding: .85rem 1.4rem .85rem 1.05rem;
  background: var(--mint);
  color: #07111f;
  font-weight: 700;
  font-size: .92rem;
  text-decoration: none;
  border-radius: 999px;
  box-shadow: 0 12px 36px -8px var(--mint-glow), 0 4px 14px rgba(0,0,0,0.25);
  transition: transform .3s cubic-bezier(.2,.7,.2,1), box-shadow .3s;
  max-width: 64px;
  overflow: hidden;
  white-space: nowrap;
}
.fab-phone:hover {
  max-width: 320px;
  transform: translateY(-2px);
  box-shadow: 0 18px 48px -8px var(--mint-glow), 0 6px 18px rgba(0,0,0,0.3);
}
.fab-phone .icon {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: rgba(7,17,31,0.12);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  animation: phonePulse 2.2s ease-in-out infinite;
}
@keyframes phonePulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.08); }
}
.fab-phone .label { padding-right: .25rem; }
@media (max-width: 640px) {
  .fab-phone { bottom: 16px; right: 16px; padding: .65rem 1.1rem .65rem .8rem; font-size: .85rem; }
  .fab-phone .icon { width: 30px; height: 30px; }
}

/* ---------- Hero Quick-Nav (gläserne Bar am unteren Hero-Rand) ---------- */
.hero-quick-nav {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  z-index: 18;
  /* Sanfter Verlauf von transparent oben zur Hero-/Site-Hintergrundfarbe unten — keine harte Kante */
  background: linear-gradient(180deg, rgba(7,17,31,0.0) 0%, rgba(7,17,31,0.55) 50%, rgba(7,17,31,1) 100%);
}
.hero-quick-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 14px;
  padding: 22px clamp(16px, 3vw, 36px);
  max-width: 90rem;
  margin: 0 auto;
}
@media (max-width: 1100px) {
  .hero-quick-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 700px) {
  .hero-quick-grid { grid-template-columns: repeat(2, 1fr); }
}
.hero-quick-item {
  padding: 1.6rem 1.3rem;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 1rem;
  color: white;
  text-decoration: none;
  background: rgba(7,17,31,0.55);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 14px;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  transition: background .3s, border-color .3s, transform .3s;
  min-width: 0;
}
.hero-quick-item:hover {
  background: rgba(77,195,167,0.12);
  border-color: rgba(77,195,167,0.5);
  transform: translateY(-3px);
}
.hero-quick-item:hover .qi-arrow { transform: translateX(5px); color: var(--mint); opacity: 1; }
.qi-icon {
  width: 54px; height: 54px;
  border-radius: 14px;
  background: rgba(77,195,167,0.18);
  border: 1px solid rgba(77,195,167,0.4);
  color: var(--mint);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  transition: transform .3s cubic-bezier(.2,.7,.2,1);
}
.qi-icon svg { width: 26px; height: 26px; }
.hero-quick-item:hover .qi-icon { transform: scale(1.06) rotate(-3deg); }
.qi-body { min-width: 0; width: 100%; }
.qi-title {
  font-family: 'Manrope', sans-serif;
  font-weight: 700;
  font-size: 1.08rem;
  display: flex; align-items: center; gap: .4rem;
  letter-spacing: -0.015em;
}
.qi-arrow {
  color: rgba(255,255,255,0.5);
  font-size: .9em;
  transition: transform .3s, color .3s, opacity .3s;
}
.qi-desc {
  font-size: .82rem;
  color: rgba(255,255,255,0.7);
  margin-top: .35rem;
  line-height: 1.4;
}
@media (max-width: 768px) {
  .hero-quick-grid { grid-template-columns: 1fr; }
  .hero-quick-item { border-right: none; border-bottom: 1px solid rgba(255,255,255,0.08); padding: 1rem 1.2rem; }
  .hero-quick-item:last-child { border-bottom: none; }
  .qi-icon { width: 38px; height: 38px; }
  .qi-desc { font-size: .72rem; }
}

/* Hero text vertically centered, no quick-nav at bottom */
.hero-content { padding-bottom: 0; }

/* ---------- Quick frachtarten teaser (right after hero) ---------- */
.quick-modes {
  background: var(--bg);
  border-bottom: 1px solid var(--line);
}
.quick-modes-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
}
@media (max-width: 768px) {
  .quick-modes-grid { grid-template-columns: 1fr; }
}
.quick-mode {
  position: relative;
  padding: 2.2rem 2rem;
  display: flex; align-items: center; gap: 1.1rem;
  border-right: 1px solid var(--line);
  text-decoration: none;
  color: inherit;
  transition: background .3s;
}
.quick-mode:last-child { border-right: none; }
@media (max-width: 768px) {
  .quick-mode { border-right: none; border-bottom: 1px solid var(--line); }
  .quick-mode:last-child { border-bottom: none; }
}
.quick-mode:hover { background: rgba(77,195,167,0.05); }
.quick-mode:hover .qm-icon { transform: scale(1.06) rotate(-3deg); }
.quick-mode:hover .qm-arrow { transform: translateX(4px); color: var(--mint); }
.qm-icon {
  width: 52px; height: 52px;
  flex-shrink: 0;
  border-radius: 14px;
  background: rgba(77,195,167,0.1);
  border: 1px solid rgba(77,195,167,0.25);
  color: var(--mint);
  display: flex; align-items: center; justify-content: center;
  transition: transform .3s cubic-bezier(.2,.7,.2,1);
}
.qm-body { flex: 1; min-width: 0; }
.qm-title {
  font-family: 'Manrope', sans-serif;
  font-weight: 700;
  font-size: 1.05rem;
  color: var(--text);
  display: flex; align-items: center; gap: .4rem;
}
.qm-arrow {
  display: inline-block;
  color: var(--text-dim);
  transition: transform .3s, color .3s;
}
.qm-desc {
  color: var(--text-dim);
  font-size: .88rem;
  margin-top: .2rem;
}

/* SQAS trust badge in stats bar */
.trust-badge {
  display: inline-flex; align-items: center; gap: .55rem;
  padding: .4rem 1rem;
  border-radius: 999px;
  background: rgba(77,195,167,0.08);
  border: 1px solid rgba(77,195,167,0.3);
  font-size: .75rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  color: var(--mint-2);
}
.trust-badge svg { color: var(--mint); }

/* ---------- Mobile menu ---------- */
.mobile-menu {
  position: fixed; inset: 0;
  background: rgba(7,17,31,0.97);
  backdrop-filter: blur(24px);
  z-index: 60;
  opacity: 0; pointer-events: none;
  transition: opacity .35s;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 1.8rem;
}
.mobile-menu.open { opacity: 1; pointer-events: auto; }
.mobile-menu a { color: white; font-size: 1.6rem; font-weight: 700; font-family: 'Manrope', sans-serif; }
.mobile-menu-controls {
  display: flex;
  align-items: center;
  gap: 1.2rem;
}
.mobile-menu-controls .theme-toggle {
  display: inline-flex !important;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  align-items: center;
  justify-content: center;
  /* Mobile-Menu hat immer dunklen Hintergrund — Icon muss immer hell sein */
  background: rgba(255,255,255,0.08) !important;
  border: 1px solid rgba(255,255,255,0.15) !important;
  color: white !important;
}
.mobile-menu-controls .theme-toggle svg { stroke: white; }

/* ========== Themed sections (work in both light + dark) ========== */
.section-themed { background: var(--section-alt); }
[data-theme="dark"] .section-themed#services { background: linear-gradient(180deg, #07111f 0%, #0a1628 100%); }
[data-theme="dark"] .section-themed#regions  { background: linear-gradient(180deg, #0a1628 0%, #07111f 100%); }
[data-theme="dark"] .section-themed#contact  { background: linear-gradient(180deg, #07111f 0%, #050b16 100%); }
[data-theme="light"] .section-themed#services { background: #ffffff; }
[data-theme="light"] .section-themed#regions  { background: #f7f9fc; }
[data-theme="light"] .section-themed#contact  { background: #ffffff; }

/* ========== LIGHT-THEME OVERRIDES (Türkis + Weiß) ========== */
[data-theme="light"] body { background: var(--bg); color: var(--text); }
[data-theme="light"] section.modes,
[data-theme="light"] .modes {
  background: var(--bg) !important;
}

/* Section borders */
[data-theme="light"] section.border-y,
[data-theme="light"] .border-\[color\:var\(--line\)\] {
  border-color: var(--line) !important;
}

/* Region cards (Tailwind bg-white/[0.03]) — make solid white */
[data-theme="light"] #regions .bg-white\/\[0\.03\] {
  background: white !important;
  border-color: var(--line) !important;
}
[data-theme="light"] #regions .group:hover .text-mint { color: var(--mint); }

/* Contact icons + form */
[data-theme="light"] .bg-white\/\[0\.04\] {
  background: white !important;
  border-color: var(--line) !important;
}
[data-theme="light"] form#contact-form {
  background: white !important;
  border-color: var(--line) !important;
}

/* Section titles, headlines */
[data-theme="light"] .section-title,
[data-theme="light"] .stat-num { color: var(--text); }
[data-theme="light"] .stat-num {
  background: linear-gradient(135deg, var(--mint), #2a9d85);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

/* Service-card hover background tint stays mint-ish */
[data-theme="light"] .service-card:hover {
  background: var(--card-bg-hover);
  border-color: rgba(77,195,167,0.4);
  box-shadow: 0 16px 40px -12px rgba(77,195,167,0.18);
}
[data-theme="light"] .service-card h3 { color: var(--text); }
[data-theme="light"] .service-card p { color: var(--text-dim); }
[data-theme="light"] .text-\[color\:var\(--text-dim\)\] { color: var(--text-dim) !important; }

/* World map */
[data-theme="light"] .global-map { background: var(--map-bg); border-color: var(--line); }
[data-theme="light"] .map-base svg path,
[data-theme="light"] .map-base svg polygon {
  fill: rgba(7,17,31,0.06) !important;
  stroke: rgba(7,17,31,0.16) !important;
}

/* Modes section — keep dark cinematic look or invert? Invert with subtle gray. */
[data-theme="light"] #modes { background: var(--section-alt) !important; }
[data-theme="light"] #modes .section-title,
[data-theme="light"] #modes .mode-title { color: var(--text); }
[data-theme="light"] #modes .mode-features li { color: var(--text); }

/* Stats kicker text */
[data-theme="light"] .text-\[color\:var\(--text-dim\)\] { color: var(--text-dim) !important; }

/* Navbar background when scrolled — keep dark for contrast OR make white? Make white for true light theme */
[data-theme="light"] .nav.scrolled {
  background: rgba(255,255,255,0.92) !important;
  border-bottom-color: var(--line) !important;
}
/* Light theme + scrolled (über weißen Sektionen): dunkler Text */
[data-theme="light"] .nav.scrolled .nav-link { color: rgba(7,17,31,0.78); }
[data-theme="light"] .nav.scrolled .nav-link:hover { color: var(--text); }
[data-theme="light"] .nav.scrolled #burger { color: var(--text); }
[data-theme="light"] .nav.scrolled .lang-btn { color: rgba(7,17,31,0.55); }
[data-theme="light"] .nav.scrolled .lang-btn.active { color: #07111f; }
[data-theme="light"] .nav.scrolled .lang-group { background: rgba(7,17,31,0.05); border-color: rgba(7,17,31,0.1); }
[data-theme="light"] .nav.scrolled .theme-toggle { background: rgba(7,17,31,0.04); border-color: rgba(7,17,31,0.1); color: var(--text); }

/* Light theme + nicht gescrollt (über Hero-Foto): heller Text */
[data-theme="light"] .nav:not(.scrolled) .nav-link { color: rgba(255,255,255,0.85); }
[data-theme="light"] .nav:not(.scrolled) .nav-link:hover { color: white; }
[data-theme="light"] .nav:not(.scrolled) #burger { color: white; }
[data-theme="light"] .nav:not(.scrolled) .lang-btn { color: rgba(255,255,255,0.7); }
[data-theme="light"] .nav:not(.scrolled) .lang-group { background: rgba(255,255,255,0.08); border-color: rgba(255,255,255,0.15); }
[data-theme="light"] .nav:not(.scrolled) .theme-toggle { background: rgba(255,255,255,0.08); border-color: rgba(255,255,255,0.15); color: white; }

/* Footer — keep dark in light theme too, looks more anchored */
[data-theme="light"] .footer { background: var(--footer-bg); }

/* Theme toggle button */
.theme-toggle {
  display: inline-flex; align-items: center; justify-content: center;
  width: 36px; height: 36px;
  border-radius: 50%;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--line);
  color: var(--text);
  cursor: pointer;
  transition: background .25s, border-color .25s, color .25s;
}
.theme-toggle:hover {
  background: rgba(77,195,167,0.1);
  border-color: rgba(77,195,167,0.4);
  color: var(--mint-2);
}
[data-theme="light"] .theme-toggle {
  background: rgba(7,17,31,0.04);
}
.theme-toggle .icon-sun  { display: none; }
.theme-toggle .icon-moon { display: block; }
[data-theme="light"] .theme-toggle .icon-sun  { display: block; }
[data-theme="light"] .theme-toggle .icon-moon { display: none; }

/* Hero text in light theme — overlay still keeps left dark for headline legibility */

/* ---------- Responsive ---------- */
@media (max-width: 768px) {
  .section { padding: 5rem 0; }
  .hero { min-height: 90vh; }
  .hero h1 { font-size: clamp(2.5rem, 12vw, 4rem); }
}
