/* ============================================================
   JONASAREA — global styles v2 — voller Yana-Style-Ausbau
   ============================================================ */

*{margin:0;padding:0;box-sizing:border-box}

:root{
  --bg:#f5f3ee;
  --bg-2:#ffffff;
  --bg-3:#ece9e2;
  --bg-warm:#efe9dd;
  --fg:#0e0e0e;
  --fg-soft:#1a1a1a;
  --muted:#6b6b6b;
  --muted-2:#9a9a9a;
  --line:rgba(14,14,14,0.1);
  --line-soft:rgba(14,14,14,0.06);
  --accent:#0e0e0e;

  --shadow:0 4px 24px rgba(14,14,14,0.08), 0 1px 0 rgba(14,14,14,0.04);
  --shadow-btn:0 6px 16px rgba(14,14,14,0.12), 0 2px 0 rgba(14,14,14,0.04);
  --shadow-card:0 8px 32px rgba(14,14,14,0.08), 0 2px 0 rgba(14,14,14,0.03);
  --shadow-lg:0 20px 60px rgba(14,14,14,0.15);
  --shadow-xl:0 30px 80px rgba(14,14,14,0.2);

  --radius-sm:10px;
  --radius:16px;
  --radius-lg:24px;
  --radius-xl:32px;

  --font-sans:'Inter Tight', -apple-system, sans-serif;
  --font-script:'Caveat', cursive;

  --container:1320px;
  --pad-x:2.5rem;

  --ease-out:cubic-bezier(0.2, 0.8, 0.2, 1);
  --ease-spring:cubic-bezier(0.16, 1, 0.3, 1);
}

html, body{
  background:var(--bg);
  color:var(--fg);
  font-family:var(--font-sans);
  overflow-x:hidden;
  font-weight:400;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}

a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
img{max-width:100%;display:block}
h1,h2,h3,h4{letter-spacing:-0.02em;font-weight:700;line-height:1.1}

/* Custom Cursor: Standard ausblenden auf Desktop */
@media(hover: hover) and (pointer: fine){
  html, body, a, button, [data-link], input, textarea, select{cursor:none}
}

/* =============================================================
   INTRO LOADER
   ============================================================= */
.loader{
  position:fixed;inset:0;z-index:9999;background:var(--bg);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:2rem;transition:opacity 0.6s, visibility 0.6s;
}
.loader.done{opacity:0;visibility:hidden;pointer-events:none}
.loader-text{
  display:flex;gap:0.5rem;
  font-weight:800;font-size:clamp(2rem, 6vw, 4rem);
  letter-spacing:-0.04em;text-transform:uppercase;
  overflow:hidden;
}
.loader-text span{
  display:inline-block;
  transform:translateY(110%);
  animation:loaderTextIn 0.8s var(--ease-spring) forwards;
}
.loader-text span:nth-child(2){animation-delay:0.15s}
@keyframes loaderTextIn{to{transform:translateY(0)}}
.loader-bar{
  width:240px;height:2px;background:var(--line);overflow:hidden;border-radius:2px;
}
.loader-bar span{
  display:block;height:100%;width:0;background:var(--fg);
  animation:loaderBar 1.8s ease-out 0.3s forwards;
}
@keyframes loaderBar{to{width:100%}}

/* =============================================================
   CUSTOM CURSOR (Bergspitze)
   ============================================================= */
.cursor{
  position:fixed;left:0;top:0;z-index:9000;pointer-events:none;
  display:none;
  width:32px;height:32px;
  margin-left:-16px;margin-top:-16px;
  transition:transform 0.4s var(--ease-out), opacity 0.3s;
}
.cursor.show{display:block}
.cursor-peak{
  position:absolute;inset:0;width:100%;height:100%;
  color:var(--fg);
  transition:transform 0.3s var(--ease-spring), opacity 0.3s, color 0.25s var(--ease-out);
}
.cursor-ring{
  position:absolute;inset:0;
  border:1.5px solid var(--fg);
  border-radius:50%;
  opacity:0;transform:scale(0.4);
  transition:opacity 0.3s, transform 0.4s var(--ease-spring), background 0.3s, border-color 0.25s var(--ease-out);
}
/* Hover-State: Bergspitze klein, Ring groß */
body.cursor-hover .cursor{transform:scale(1.4)}
body.cursor-hover .cursor-peak{opacity:0;transform:scale(0.3)}
body.cursor-hover .cursor-ring{opacity:1;transform:scale(1.4);background:rgba(14,14,14,0.08)}

/* Light-Variante: Cursor wird hell wenn er über dunklen Sektionen ist (Footer etc.) */
body.cursor-light .cursor-peak{color:var(--bg)}
body.cursor-light .cursor-ring{border-color:var(--bg)}
body.cursor-light.cursor-hover .cursor-ring{background:rgba(245,243,238,0.12)}

@media(hover: none){.cursor{display:none !important}}

/* ===== utility ===== */
.container{max-width:var(--container);margin:0 auto;padding:0 var(--pad-x)}
.eyebrow{
  font-family:var(--font-script);font-weight:600;
  font-size:1.5rem;color:var(--muted);
  display:inline-block;margin-bottom:0.6rem;
  transform:rotate(-1.5deg);
}
.section-title{
  font-size:clamp(2rem, 5vw, 3.6rem);
  font-weight:800;letter-spacing:-0.03em;
  text-transform:uppercase;line-height:0.95;
  margin-bottom:1.2rem;
}
.section-title em{
  font-style:normal;font-family:var(--font-script);
  font-weight:600;text-transform:none;letter-spacing:0;
  color:var(--muted);font-size:0.85em;display:inline-block;
  transform:translateY(-0.05em);
}
.section-lead{
  font-size:1.1rem;color:var(--muted);max-width:60ch;line-height:1.7;
}

/* ===== Headline mit gesplitteten Zeilen für Stagger-Reveal ===== */
.split-line{display:block;overflow:hidden}
.split-line > span{display:inline-block;transform:translateY(110%);will-change:transform}

/* ===== buttons ===== */
.btn{
  display:inline-flex;align-items:center;gap:0.7rem;
  padding:0.95rem 1.6rem;border-radius:100px;
  font-size:0.78rem;letter-spacing:0.12em;text-transform:uppercase;
  font-weight:600;border:1px solid transparent;
  box-shadow:var(--shadow-btn);
  transition:transform 0.3s var(--ease-out),
             box-shadow 0.3s,
             background 0.3s,
             color 0.3s;
  white-space:nowrap;position:relative;overflow:hidden;
}
.btn:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(14,14,14,0.18),0 2px 0 rgba(14,14,14,0.04)}
.btn .arrow{
  width:24px;height:24px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  flex-shrink:0;transition:transform 0.3s var(--ease-out);
}
.btn:hover .arrow{transform:translateX(3px)}
.btn .arrow svg{width:11px;height:11px}

.btn-primary{background:var(--fg);color:var(--bg);border-color:var(--fg)}
.btn-primary .arrow{background:var(--bg);color:var(--fg)}

.btn-secondary{background:var(--bg-2);color:var(--fg);border-color:var(--line)}
.btn-secondary:hover{border-color:var(--fg)}
.btn-secondary .arrow{background:var(--fg);color:var(--bg)}

/* =============================================================
   TOP NAV
   ============================================================= */
nav.top{
  position:fixed;top:0;left:0;right:0;z-index:60;
  display:flex;justify-content:space-between;align-items:center;
  padding:1.2rem 2.5rem;
  background:rgba(245,243,238,0.65);
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  border-bottom:1px solid var(--line-soft);
  transition:transform 0.4s var(--ease-out), padding 0.3s;
}
nav.top.hide{transform:translateY(-100%)}
nav.top.shrunk{padding:0.7rem 2.5rem;background:rgba(245,243,238,0.85)}
.nav-links{
  display:flex;align-items:center;gap:0.3rem;
  font-size:0.78rem;text-transform:uppercase;
  letter-spacing:0.12em;font-weight:500;
}
.nav-links > a, .nav-links > .has-dropdown > button{
  color:var(--fg);
  padding:0.6rem 1rem;border-radius:8px;
  transition:background 0.25s;
  display:inline-flex;align-items:center;gap:0.4rem;
  text-transform:inherit;letter-spacing:inherit;font:inherit;
  position:relative;
}
.nav-links > a::after{
  content:'';position:absolute;left:1rem;right:1rem;bottom:0.4rem;
  height:1px;background:var(--fg);transform:scaleX(0);
  transform-origin:right;transition:transform 0.4s var(--ease-out);
}
.nav-links > a:hover::after, .nav-links > a.active::after{
  transform:scaleX(1);transform-origin:left;
}
.nav-links > a:hover, .nav-links > .has-dropdown > button:hover{
  background:rgba(14,14,14,0.04);
}

.has-dropdown{position:relative}
.dropdown-arrow{font-size:0.6rem;opacity:0.6;transition:transform 0.25s}
.has-dropdown:hover .dropdown-arrow{transform:rotate(180deg)}
.dropdown{
  position:absolute;top:100%;left:50%;
  transform:translateX(-50%) translateY(8px);
  background:var(--bg-2);border:1px solid var(--line);
  border-radius:14px;box-shadow:var(--shadow-lg);
  padding:0.5rem;min-width:260px;
  opacity:0;pointer-events:none;transition:all 0.3s var(--ease-out);
}
.has-dropdown:hover .dropdown,
.has-dropdown:focus-within .dropdown{
  opacity:1;pointer-events:auto;
  transform:translateX(-50%) translateY(0);
}
.dropdown a{
  display:block;padding:0.75rem 1rem;font-size:0.75rem;
  text-transform:uppercase;letter-spacing:0.1em;border-radius:8px;
  color:var(--fg);transition:background 0.2s;
}
.dropdown a:hover{background:rgba(14,14,14,0.05)}
.dropdown-divider{display:block;height:1px;background:var(--line);margin:0.4rem 0}
.dropdown-all{color:var(--muted);font-weight:600}

.logo{
  font-family:var(--font-sans);font-weight:800;font-size:1rem;
  letter-spacing:0.02em;display:flex;align-items:center;gap:0.55rem;
  text-transform:uppercase;
  margin-right:60px; /* Platz für Burger auf Mobile */
}
.logo-mark{
  width:18px;height:18px;
  color:var(--fg);
  flex-shrink:0;
  transition:transform 0.4s var(--ease-out);
}
.logo:hover .logo-mark{transform:translateY(-2px)}

/* =============================================================
   RIGHT SOCIAL RAIL
   ============================================================= */
.side-rail{
  position:fixed;right:1.2rem;top:50%;
  transform:translateY(-50%);z-index:55;
  display:flex;flex-direction:column;gap:0.5rem;align-items:center;
  background:rgba(255,255,255,0.7);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border:1px solid var(--line-soft);
  border-radius:100px;
  padding:0.8rem 0.6rem;
  box-shadow:var(--shadow);
}
.side-rail a{
  width:38px;height:38px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--fg);transition:all 0.3s;background:transparent;
}
.side-rail a:hover{background:var(--fg);color:var(--bg);transform:scale(1.08)}
.side-rail svg{width:16px;height:16px}
.side-rail .divider{width:18px;height:1px;background:var(--line);margin:0.2rem 0}

/* =============================================================
   MOBILE BURGER + MENU
   ============================================================= */
.burger{
  display:none;position:fixed;top:1rem;right:1rem;z-index:80;
  width:44px;height:44px;border-radius:50%;
  background:var(--bg-2);border:1px solid var(--line);
  box-shadow:var(--shadow);
  flex-direction:column;justify-content:center;align-items:center;gap:5px;
}
.burger span{
  width:18px;height:2px;background:var(--fg);
  border-radius:2px;transition:all 0.3s;
}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.mobile-menu{
  display:none;position:fixed;inset:0;z-index:70;
  background:var(--bg);
  flex-direction:column;justify-content:center;align-items:center;
  gap:1.5rem;
  opacity:0;pointer-events:none;transition:opacity 0.4s;
}
.mobile-menu.open{opacity:1;pointer-events:auto}
.mobile-menu a{
  font-size:1.6rem;font-weight:700;text-transform:uppercase;
  letter-spacing:-0.01em;color:var(--fg);
}

/* =============================================================
   PAGE TRANSITIONS
   ============================================================= */
#app{min-height:100vh}
/* page-Enter: nur opacity damit kein transform-containing-block für sticky-Children entsteht */
.page{animation:pageEnter 0.8s var(--ease-out) both}
@keyframes pageEnter{
  from{opacity:0}
  to{opacity:1}
}

/* =============================================================
   HERO — Yana-Style: Split-Grid, Wordmark links, Foto rechts
   ============================================================= */
/* =============================================================
   HERO — Yana-Style v2: Intro-Drop + seitliche Aufteilung + sanftes Schweben
   - Phase 1 (0-15%): Karten fliegen von oben rein, stapeln sich
   - Phase 2 (15-30%): Karten teilen sich zur Seite auf (4 links / 4 rechts)
   - Phase 3 (30-100%): Karten schweben sanft auf/ab mit leichter Rotation
   JONAS AREA bleibt zentral gut lesbar (Karten gehen seitlich, nicht dahinter)
   ============================================================= */
.hero{
  position:relative;
  padding:7rem var(--pad-x) 4rem;
  display:flex;flex-direction:column;
  overflow:hidden;
  min-height:auto;
}

.hero-eyebrow-top{
  font-size:0.95rem;font-weight:500;
  text-align:center;color:var(--fg);
  letter-spacing:-0.01em;line-height:1.4;
  max-width:600px;margin:0 auto 2rem;
  opacity:0;animation:heroEyebrowIn 0.8s 0.3s var(--ease-out) forwards;
}
@keyframes heroEyebrowIn{
  from{opacity:0;transform:translateY(-10px)}
  to{opacity:1;transform:translateY(0)}
}

.hero-stage{
  position:relative;
  height:auto;min-height:520px;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:2rem;
  padding:3.5rem 0;
  /* overflow:hidden ENTFERNT damit Karten nicht abgeschnitten werden */
}

/* Wordmark fix in der Mitte, IMMER VOR den Karten */
.hero-wordmark-wrap{
  position:relative;z-index:5;
  text-align:center;pointer-events:none;
}
.hero-we-are{
  font-family:var(--font-script);
  font-weight:600;font-size:1.4rem;
  color:var(--muted);
  margin-bottom:0.4rem;
  opacity:0;animation:fadeUp2 0.8s 0.4s var(--ease-out) forwards;
}
.wordmark{
  font-family:var(--font-sans);font-weight:800;
  /* Cap bei 8.5rem damit auch auf 4K-Displays kompakt bleibt und Karten genug Platz haben */
  font-size:clamp(4.5rem, 9vw, 8.5rem);
  line-height:0.85;letter-spacing:-0.05em;
  text-transform:uppercase;
  color:var(--fg);
  text-align:center;margin:0;
}
.wordmark-2{margin-top:-0.18em}
.wordmark .split-line{display:block;overflow:hidden}
.wordmark .split-line > span{
  display:inline-block;transform:translateY(110%);will-change:transform;
  animation:wmLine 1.2s 0.5s var(--ease-spring) forwards;
}
.wordmark-2 .split-line > span{animation-delay:0.7s}
@keyframes wmLine{to{transform:translateY(0)}}

/* Karten-Container */
.hero-cards{
  position:absolute;inset:0;
  z-index:2;
  pointer-events:none;
}

/* Einzelne Karten - Intro einmalig, dann sanftes Wandern auf Ellipse */
.hero-card{
  position:absolute;
  top:50%;left:50%;
  width:140px;height:180px;
  margin-left:-70px;margin-top:-90px;
  background-size:cover;background-position:center;
  border-radius:12px;
  box-shadow:0 16px 40px rgba(14,14,14,0.18), 0 4px 10px rgba(14,14,14,0.06);
  opacity:0;
  will-change:transform,opacity;
  /* Intro 5s einmalig + endloses Wandern auf Ellipse */
  animation:
    cardIntro 5s var(--card-delay,0s) cubic-bezier(.65,.05,.36,1) forwards,
    cardWander 16s calc(var(--card-delay,0s) + 5s) ease-in-out infinite;
}

/* Intro: Drop von oben → Stapel mittig → Aufteilung */
@keyframes cardIntro{
  0%{
    opacity:0;
    transform:translate3d(0, -100vh, 0) rotate(var(--enter-rot,0deg));
  }
  10%{opacity:0}
  20%{
    opacity:1;
    transform:translate3d(0, 0, 0) rotate(var(--stack-rot,0deg));
  }
  55%{
    opacity:1;
    transform:translate3d(0, 0, 0) rotate(var(--stack-rot,0deg));
  }
  100%{
    opacity:1;
    transform:translate3d(var(--final-x), var(--final-y), 0) rotate(var(--final-rot,0deg));
  }
}

/* Wander-Animation: Karte bewegt sich in einer kleinen Ellipse um ihre Final-Position
   Verschiedene Karten haben verschiedene wander-deltas damit's lebendig wirkt */
@keyframes cardWander{
  0%{
    transform:translate3d(var(--final-x), var(--final-y), 0) rotate(var(--final-rot,0deg));
  }
  25%{
    transform:translate3d(calc(var(--final-x) + var(--wx,15px)), calc(var(--final-y) - 12px), 0) rotate(calc(var(--final-rot,0deg) + 1.5deg));
  }
  50%{
    transform:translate3d(calc(var(--final-x) + var(--wx,15px) - 8px), calc(var(--final-y) + 8px), 0) rotate(calc(var(--final-rot,0deg) - 0.8deg));
  }
  75%{
    transform:translate3d(calc(var(--final-x) - var(--wx,15px) / 2), calc(var(--final-y) + 14px), 0) rotate(calc(var(--final-rot,0deg) + 0.5deg));
  }
  100%{
    transform:translate3d(var(--final-x), var(--final-y), 0) rotate(var(--final-rot,0deg));
  }
}

/*
  Pro Karte:
  - card-delay: wann die Karte beim Drop reinfliegt (gestaffelt 0.3s)
  - enter-rot: Startrotation oben in der Luft
  - stack-rot: Mini-Rotation im Stapel
  - final-x/y: Endposition (4 links / 4 rechts vom Wordmark)
  - final-rot: leichte Tilt-Rotation auf Endposition
  - float-delay: wann das sanfte Schweben startet (nach 32% von 14s ≈ 4.5s + card-delay)
*/

/* Karten-Positionen: skalieren mit Viewport (vw) damit sie immer außerhalb vom Wordmark bleiben.
   Wordmark wächst auch mit vw (clamp(4.5rem, 14vw, 13rem)).
   Karten landen klar links/rechts vom Wordmark egal wie breit der Browser ist.
   JavaScript überschreibt diese Werte mit pixelgenauen Berechnungen, falls JS aktiv. */

/* LINKS vom Wordmark (4 Karten, gestaffelt) */
.hc-1{
  --card-delay:0.5s;
  --enter-rot:-8deg;--stack-rot:-3deg;
  --final-x:clamp(-720px, -42vw, -420px);--final-y:-130px;--final-rot:-7deg;
}
.hc-2{
  --card-delay:0.7s;
  --enter-rot:-4deg;--stack-rot:-1deg;
  --final-x:clamp(-580px, -34vw, -340px);--final-y:50px;--final-rot:-3deg;
}
.hc-3{
  --card-delay:0.9s;
  --enter-rot:5deg;--stack-rot:2deg;
  --final-x:clamp(-720px, -42vw, -420px);--final-y:90px;--final-rot:5deg;
}
.hc-4{
  --card-delay:1.1s;
  --enter-rot:-2deg;--stack-rot:-1deg;
  --final-x:clamp(-580px, -34vw, -340px);--final-y:-110px;--final-rot:3deg;
}
/* RECHTS vom Wordmark (4 Karten) */
.hc-5{
  --card-delay:1.3s;
  --enter-rot:3deg;--stack-rot:1deg;
  --final-x:clamp(340px, 34vw, 580px);--final-y:50px;--final-rot:3deg;
}
.hc-6{
  --card-delay:1.5s;
  --enter-rot:6deg;--stack-rot:3deg;
  --final-x:clamp(420px, 42vw, 720px);--final-y:-130px;--final-rot:-5deg;
}
.hc-7{
  --card-delay:1.7s;
  --enter-rot:-3deg;--stack-rot:-1deg;
  --final-x:clamp(340px, 34vw, 580px);--final-y:-110px;--final-rot:7deg;
}
.hc-8{
  --card-delay:1.9s;
  --enter-rot:7deg;--stack-rot:2deg;
  --final-x:clamp(420px, 42vw, 720px);--final-y:90px;--final-rot:-3deg;
}

/* Hero-Bottom */
.hero-bottom{
  text-align:center;max-width:680px;margin:0 auto;
  padding-top:1rem;
}
.hero-bottom-eyebrow{
  font-size:0.78rem;letter-spacing:0.18em;
  text-transform:uppercase;font-weight:600;
  color:var(--muted);margin-bottom:0.8rem;
  opacity:0;animation:fadeUp2 1s 2.4s var(--ease-out) forwards;
}
.hero-headline{
  font-size:clamp(1.8rem,3.6vw,2.8rem);
  font-weight:800;letter-spacing:-0.02em;
  text-transform:uppercase;line-height:1.05;
  margin-bottom:1rem;
  opacity:0;animation:fadeUp2 1s 2.6s var(--ease-out) forwards;
}
.hero-headline em{
  font-style:normal;font-family:var(--font-script);
  font-weight:600;text-transform:none;
  color:var(--muted);font-size:0.85em;
  display:inline-block;letter-spacing:-0.01em;
}
.hero-sub{
  font-size:1rem;color:var(--muted);
  line-height:1.6;max-width:48ch;margin:0 auto 2rem;
  opacity:0;animation:fadeUp2 1s 2.8s var(--ease-out) forwards;
}
.hero-actions{
  display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;
  opacity:0;animation:fadeUp2 1s 3s var(--ease-out) forwards;
}
@keyframes fadeUp2{from{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}

/* =============================================================
   TICKER MARQUEE
   ============================================================= */
.ticker{
  position:relative;z-index:10;
  border-top:1px solid var(--line-soft);
  border-bottom:1px solid var(--line-soft);
  padding:1.2rem 0;overflow:hidden;
  white-space:nowrap;background:var(--bg-2);
}
.ticker-track{
  display:inline-block;
  animation:tickerSlide 38s linear infinite;
}
.ticker:hover .ticker-track{animation-play-state:paused}
.ticker span{
  font-family:var(--font-sans);font-weight:600;
  font-size:1.3rem;letter-spacing:-0.01em;
  margin:0 1.8rem;text-transform:uppercase;
}
.ticker span.script{
  font-family:var(--font-script);font-weight:600;
  text-transform:none;color:var(--muted);font-size:1.6rem;
}
.ticker span.dot{
  color:var(--fg);
  display:inline-block;width:6px;height:6px;
  background:var(--fg);border-radius:50%;
  margin:0 1rem;vertical-align:middle;
}
@keyframes tickerSlide{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* =============================================================
   TRUST / KUNDEN — Wall mit Bild-Reveal-Cards
   ============================================================= */
.trust-wall{
  padding:5rem 0 5rem;text-align:center;background:var(--bg);
  overflow:hidden;
  position:relative;
}
.trust-wall-head{padding:0 var(--pad-x);margin-bottom:3.5rem}
.trust-wall-head .eyebrow{margin-bottom:0.3rem}
.trust-wall-head h2{
  font-size:clamp(1.6rem,3vw,2.4rem);font-weight:700;
  letter-spacing:-0.02em;text-transform:uppercase;line-height:1;
}
.trust-track-wrap{
  position:relative;
  mask-image:linear-gradient(to right, transparent, black 6%, black 94%, transparent);
  -webkit-mask-image:linear-gradient(to right, transparent, black 6%, black 94%, transparent);
  /* Höhe für die Cards (mit Vergrößerung) */
  padding:3rem 0;
}
.trust-track{
  display:flex;gap:2rem;animation:trustSlide 110s linear infinite;
  width:max-content;
  align-items:center;
}
/* Pause der Auto-Animation: SOFORT wenn Maus die ganze Wall betritt
   (nicht erst beim Card-Hover - sonst kollidiert es mit der laufenden translateX) */
.trust-wall:hover .trust-track,
.trust-wall.paused .trust-track{
  animation-play-state:paused;
}

/* Trust-Card: Standard-Größe = klein, Hover/Active = scaled (KEIN Reflow!) */
.trust-card{
  flex-shrink:0;
  width:340px;height:200px;
  border-radius:var(--radius);
  background:var(--bg-2);
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  position:relative;
  overflow:hidden;
  cursor:pointer;
  transform-origin:center center;
  /* Nur scale + box-shadow animieren - kein width/height (würde Reflow auslösen) */
  transition:
    transform 1s cubic-bezier(.22,.61,.36,1),
    box-shadow 1s cubic-bezier(.22,.61,.36,1);
}

/* Bild-Background: standardmäßig unsichtbar */
.trust-card-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  opacity:0;
  transition:opacity 1s cubic-bezier(.22,.61,.36,1);
  z-index:1;
}
/* Dunkler Verlauf für Text-Lesbarkeit (nur wenn Bild aktiv) */
.trust-card-bg::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to top,
    rgba(0,0,0,0.85) 0%,
    rgba(0,0,0,0.3) 35%,
    rgba(0,0,0,0.1) 70%,
    rgba(0,0,0,0.4) 100%);
  opacity:0;
  transition:opacity 1s cubic-bezier(.22,.61,.36,1);
}

/* Body: Standard zentral, im Active-Modus klein in der Ecke */
.trust-card-body{
  position:absolute;inset:0;
  padding:1.8rem 2rem;
  display:flex;flex-direction:column;justify-content:center;gap:0.6rem;
  z-index:2;
  text-align:left;
  transition:
    padding 1s cubic-bezier(.22,.61,.36,1),
    justify-content 1s cubic-bezier(.22,.61,.36,1),
    gap 1s cubic-bezier(.22,.61,.36,1);
}
.trust-card-name{
  font-weight:700;text-transform:uppercase;
  letter-spacing:-0.01em;font-size:1.1rem;
  color:var(--fg);
  transition:color 1s cubic-bezier(.22,.61,.36,1);
}
.trust-card-role{
  font-family:var(--font-script);font-weight:500;
  font-size:1rem;color:var(--muted);
  transition:color 1s cubic-bezier(.22,.61,.36,1);
}
.trust-card-quote{
  font-size:0.9rem;color:var(--muted);line-height:1.5;
  font-style:italic;
  transition:color 1s cubic-bezier(.22,.61,.36,1);
}

/* ACTIVE STATE: Card per scale vergrößert (kein Reflow), Bild sichtbar.
   :hover greift nur auf echten Hover-Geräten (Desktop mit Maus).
   Touch-Geräte (Mobile/Tablet) nutzen ausschließlich .is-active via JS.
   .trust-track Selector erhöht Spezifität gegen andere transform-Regeln. */
.trust-track .trust-card.is-active{
  transform:scale(1.18);
  z-index:10;
  box-shadow:0 24px 48px rgba(14,14,14,0.18), 0 6px 12px rgba(14,14,14,0.06);
}
.trust-card.is-active .trust-card-bg{opacity:1}
.trust-card.is-active .trust-card-bg::after{opacity:1}
.trust-card.is-active .trust-card-body{
  justify-content:flex-end;
  padding:1.2rem 1.4rem;
  gap:0.25rem;
}
.trust-card.is-active .trust-card-name{color:#fff}
.trust-card.is-active .trust-card-role{color:rgba(255,255,255,0.85)}
.trust-card.is-active .trust-card-quote{color:rgba(255,255,255,0.9);max-width:75%}

@media(hover:hover) and (pointer:fine){
  .trust-track .trust-card:hover{
    transform:scale(1.18);
    z-index:10;
    box-shadow:0 24px 48px rgba(14,14,14,0.18), 0 6px 12px rgba(14,14,14,0.06);
  }
  .trust-card:hover .trust-card-bg{opacity:1}
  .trust-card:hover .trust-card-bg::after{opacity:1}
  .trust-card:hover .trust-card-body{
    justify-content:flex-end;
    padding:1.2rem 1.4rem;
    gap:0.25rem;
  }
  .trust-card:hover .trust-card-name{color:#fff}
  .trust-card:hover .trust-card-role{color:rgba(255,255,255,0.85)}
  .trust-card:hover .trust-card-quote{color:rgba(255,255,255,0.9);max-width:75%}
}

@keyframes trustSlide{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* =============================================================
   SECTION-INTRO mit Animation-Wrapper
   ============================================================= */
.section-intro{
  display:flex;justify-content:space-between;align-items:flex-end;
  margin-bottom:3rem;flex-wrap:wrap;gap:1.5rem;
}

/* =============================================================
   SERVICES PREVIEW (auf Home) — verbessert mit Bild-Reveal
   ============================================================= */
.services-preview{padding:7rem var(--pad-x) 5rem}
.services-grid{
  display:grid;grid-template-columns:repeat(3, 1fr);gap:1.5rem;
}
.service-card{
  background:var(--bg-2);border:1px solid var(--line);
  border-radius:var(--radius-lg);padding:2rem;
  box-shadow:var(--shadow-card);
  transition:transform 0.5s var(--ease-out),box-shadow 0.5s;
  display:flex;flex-direction:column;justify-content:space-between;
  min-height:380px;position:relative;overflow:hidden;
}
.service-card::before{
  content:'';position:absolute;inset:0;
  background-image:var(--bg-img);background-size:cover;background-position:center;
  opacity:0;transition:opacity 0.5s, transform 0.8s var(--ease-out);
  transform:scale(1.1);
}
.service-card::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to bottom, rgba(14,14,14,0.0) 0%, rgba(14,14,14,0.85) 100%);
  opacity:0;transition:opacity 0.5s;
}
.service-card:hover{transform:translateY(-8px);box-shadow:0 30px 60px rgba(14,14,14,0.15)}
.service-card:hover::before{opacity:1;transform:scale(1)}
.service-card:hover::after{opacity:1}
.service-card > *{position:relative;z-index:2;transition:color 0.5s}
.service-card:hover h3,
.service-card:hover .service-num,
.service-card:hover .service-link{color:var(--bg)}
.service-card:hover p{color:rgba(245,243,238,0.85)}
.service-card:hover .service-link .arrow{background:var(--bg);color:var(--fg)}

.service-num{
  font-family:var(--font-script);font-weight:600;
  font-size:1.3rem;color:var(--muted);
}
.service-card h3{
  font-size:1.7rem;font-weight:700;text-transform:uppercase;
  letter-spacing:-0.01em;margin:1rem 0 0.6rem;line-height:1;
}
.service-card p{
  color:var(--muted);font-size:0.95rem;line-height:1.6;
  margin-bottom:1.5rem;
}
.service-link{
  display:inline-flex;align-items:center;gap:0.6rem;
  font-size:0.78rem;text-transform:uppercase;letter-spacing:0.1em;
  font-weight:600;color:var(--fg);
}
.service-link .arrow{
  width:32px;height:32px;border-radius:50%;
  background:var(--fg);color:var(--bg);
  display:inline-flex;align-items:center;justify-content:center;
  transition:transform 0.3s, background 0.5s, color 0.5s;
}
.service-card:hover .service-link .arrow{transform:translateX(4px)}
.service-link svg{width:13px;height:13px}

/* =============================================================
   PROZESS / WORKFLOW — Sticky Scroll-Sektion
   ============================================================= */
.process{
  padding:7rem var(--pad-x);background:var(--bg-2);
  border-top:1px solid var(--line-soft);
  border-bottom:1px solid var(--line-soft);
}
.process-inner{max-width:var(--container);margin:0 auto;display:grid;grid-template-columns:1fr 1.3fr;gap:5rem;align-items:flex-start}
.process-sticky{
  position:sticky;top:8rem;
}
.process-sticky h2{
  font-size:clamp(2.2rem,5vw,4rem);font-weight:800;
  letter-spacing:-0.03em;text-transform:uppercase;line-height:0.95;
  margin-bottom:1.5rem;
}
.process-sticky h2 em{
  font-style:normal;font-family:var(--font-script);font-weight:600;
  text-transform:none;color:var(--muted);font-size:0.7em;
  display:inline-block;
}
.process-sticky p{font-size:1.05rem;color:var(--muted);line-height:1.7;max-width:42ch}
.process-counter{
  margin-top:2.5rem;padding:1rem 1.4rem;
  background:var(--bg);border:1px solid var(--line);border-radius:100px;
  display:inline-flex;align-items:center;gap:0.6rem;
  font-size:0.8rem;letter-spacing:0.12em;text-transform:uppercase;font-weight:600;
}
.process-counter strong{font-size:1rem}
.process-steps{display:flex;flex-direction:column;gap:1.5rem}
.process-step{
  background:var(--bg);border:1px solid var(--line);
  border-radius:var(--radius-lg);padding:2rem 2.2rem;
  box-shadow:var(--shadow-card);
  position:relative;overflow:hidden;
}
.process-step-num{
  position:absolute;right:2rem;top:1.5rem;
  font-family:var(--font-script);font-weight:600;
  font-size:1.6rem;color:var(--muted-2);line-height:1;
}
.process-step h3{
  font-size:1.5rem;font-weight:700;text-transform:uppercase;
  letter-spacing:-0.01em;margin-bottom:0.6rem;line-height:1;
}
.process-step p{color:var(--muted);font-size:0.98rem;line-height:1.6;margin-bottom:1rem}
.process-step ul{list-style:none;display:flex;flex-direction:column;gap:0.4rem}
.process-step li{
  font-size:0.85rem;color:var(--fg);font-weight:500;
  display:flex;align-items:center;gap:0.5rem;
}
.process-step li::before{
  content:'';width:5px;height:5px;background:var(--fg);
  border-radius:50%;flex-shrink:0;
}

/* =============================================================
   VALUES BAND (statt Counter-Stats)
   ============================================================= */
.stats-band{
  background:var(--fg);color:var(--bg);
  padding:6rem var(--pad-x);
  position:relative;overflow:hidden;
}
.stats-band::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(circle at 80% 30%,rgba(245,243,238,0.05),transparent 50%),
    radial-gradient(circle at 20% 80%,rgba(245,243,238,0.04),transparent 50%);
}
.stats-band-eyebrow{
  position:relative;z-index:1;text-align:center;
  font-family:var(--font-script);font-weight:600;
  font-size:1.4rem;color:var(--muted-2);margin-bottom:0.5rem;
}
.stats-band h2{
  position:relative;z-index:1;text-align:center;
  font-size:clamp(2rem,4vw,3.4rem);font-weight:700;
  text-transform:uppercase;letter-spacing:-0.02em;line-height:1;margin-bottom:4rem;
}
.stats-band h2 em{
  font-style:normal;font-family:var(--font-script);font-weight:600;
  text-transform:none;letter-spacing:-0.01em;color:var(--muted-2);
  font-size:0.7em;display:inline-block;
}
.stats-grid{
  display:grid;grid-template-columns:repeat(4, 1fr);gap:1px;
  background:rgba(245,243,238,0.1);
  position:relative;z-index:1;max-width:var(--container);margin:0 auto;
  border:1px solid rgba(245,243,238,0.1);
}
.stat-item{
  text-align:left;padding:2.2rem 1.8rem;
  background:var(--fg);
  display:flex;flex-direction:column;gap:0.6rem;
  min-height:240px;
}
.stat-num{
  font-family:var(--font-script);font-weight:600;
  font-size:1.6rem;color:var(--muted-2);
  line-height:1;margin-bottom:0.3rem;
}
.stat-label{
  font-size:1.15rem;font-weight:700;
  text-transform:uppercase;letter-spacing:-0.005em;line-height:1.2;
  color:var(--bg);
}
.stat-desc{
  font-size:0.92rem;color:var(--muted-2);
  line-height:1.55;margin-top:auto;
}

/* =============================================================
   LATEST WORK SLIDER (Home) — horizontal scroll, kein Y-Wackeln
   ============================================================= */
/* =============================================================
   LATEST WORK SLIDER (Home) — Editorial-Showcase mit Overlay-Text
   ============================================================= */
.latest-work{
  padding:7rem 0 6rem;background:var(--bg-2);
  overflow:hidden;
  position:relative;
}
.latest-work::before{
  content:'';position:absolute;
  top:-1px;left:0;right:0;height:60px;
  background:linear-gradient(to bottom, var(--bg) 0%, transparent 100%);
  z-index:1;pointer-events:none;
}
.latest-work .section-intro{
  padding:0 var(--pad-x);max-width:var(--container);
  margin-left:auto;margin-right:auto;margin-bottom:3rem;
  position:relative;z-index:2;
}
/* Work-Controls: Pfeile + "Alle ansehen" Button */
.work-controls{
  display:flex;align-items:center;gap:0.7rem;
}
.work-nav-btn{
  width:46px;height:46px;border-radius:50%;
  background:var(--bg);border:1.5px solid var(--line);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--fg);
  transition:all 0.25s var(--ease-out);
}
.work-nav-btn:hover:not(:disabled){
  background:var(--fg);color:var(--bg);border-color:var(--fg);
  transform:scale(1.05);
}
.work-nav-btn:disabled{
  opacity:0.3;cursor:not-allowed;
}
.work-nav-btn svg{width:18px;height:18px}

/* Slider-Wrap: Container für sauberes Spacing */
.work-slider-wrap{
  position:relative;
}
.work-slider{
  display:flex;gap:1.8rem;
  /* Padding-left = pad-x damit erster Slide bündig mit section-intro startet */
  padding:0 var(--pad-x) 2rem;
  overflow-x:auto;
  /* scroll-snap-type:none — kein Snap mehr (sonst überschreibt es padding-left) */
  -webkit-overflow-scrolling:touch;
  overscroll-behavior-x:contain;
  overscroll-behavior-y:auto;
  scrollbar-width:none;
  cursor:grab;
  scroll-behavior:smooth;
}
.work-slider::-webkit-scrollbar{display:none}
.work-slider:active{cursor:grabbing}
/* Pseudo-Spacer am Ende damit letzter Slide nicht am Rand klebt */
.work-slider::after{
  content:'';flex:0 0 calc(var(--pad-x) - 1.8rem);
}

.work-slide{
  flex:0 0 540px;
  /* scroll-snap-align ENTFERNT damit erster Slide nicht an Padding-Rand snappt */
  border-radius:var(--radius-lg);overflow:hidden;
  position:relative;
  background:#1a1a1a;
  aspect-ratio:4/5;
  box-shadow:var(--shadow-card);
}

@media(hover: hover){
  .work-slide{transition:transform 0.5s var(--ease-out),box-shadow 0.5s}
  .work-slide:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
  .work-slide:hover .work-slide-img{transform:scale(1.05)}
  .work-slide:hover .work-slide-arrow{
    background:var(--fg);color:var(--bg);transform:rotate(45deg);
  }
}

/* Bild als Hintergrund für Overlay-Effekt */
.work-slide-img{
  position:absolute;inset:0;
  background:#222 center/cover no-repeat;
  transition:transform 1s var(--ease-out);
  z-index:1;
}
/* Dunkler Verlauf unten für Text-Lesbarkeit */
.work-slide-img::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to top,
    rgba(0,0,0,0.85) 0%,
    rgba(0,0,0,0.55) 25%,
    rgba(0,0,0,0.15) 50%,
    transparent 75%);
  z-index:1;
  pointer-events:none;
}

/* Text-Overlay unten links auf dem Bild */
.work-slide-body{
  position:absolute;
  bottom:0;left:0;right:0;
  padding:1.8rem 2rem;
  z-index:2;
  color:#fff;
}
.work-slide-meta{
  display:flex;gap:1rem;align-items:center;
  font-size:0.7rem;text-transform:uppercase;
  letter-spacing:0.18em;color:rgba(255,255,255,0.75);
  margin-bottom:0.6rem;font-weight:500;
}
.work-slide-meta span:first-child::after{
  content:'·';margin-left:1rem;color:rgba(255,255,255,0.4);
}
.work-slide h3{
  font-size:1.6rem;font-weight:700;text-transform:uppercase;
  letter-spacing:-0.01em;line-height:1.05;margin-bottom:0.6rem;
  color:#fff;
}
.work-slide p{
  color:rgba(255,255,255,0.78);font-size:0.92rem;line-height:1.55;
  max-width:90%;
}

/* Arrow-Indikator oben rechts */
.work-slide-arrow{
  position:absolute;
  top:1.4rem;right:1.4rem;
  width:42px;height:42px;
  border-radius:50%;
  background:rgba(255,255,255,0.15);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,0.3);
  display:flex;align-items:center;justify-content:center;
  z-index:3;
  color:#fff;
  transition:all 0.4s var(--ease-out);
}
.work-slide-arrow svg{width:18px;height:18px}

/* =============================================================
   PARTNER / WEGDESIGN — Vermittlung
   ============================================================= */
.partner-section{
  padding:7rem var(--pad-x);background:var(--bg);
  position:relative;
}
.partner-inner{
  max-width:var(--container);margin:0 auto;
  display:grid;grid-template-columns:1.1fr 0.9fr;
  gap:5rem;align-items:center;
}
.partner-text{}
.partner-text .eyebrow{margin-bottom:0.6rem;display:inline-block}
.partner-text .section-title{margin-bottom:1.5rem}
.partner-lead{
  font-size:1.05rem;line-height:1.7;color:var(--fg);
  margin-bottom:1.2rem;
}
.partner-lead strong{font-weight:600}
.partner-detail{
  font-size:0.95rem;line-height:1.65;color:var(--muted);
  margin-bottom:2rem;
}
.partner-section .btn-primary{align-self:flex-start}

/* Partner-Card: editorial Visiting-Card-Look */
.partner-visual{
  display:flex;align-items:center;justify-content:center;
}
.partner-card{
  background:var(--bg-2);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:2.5rem 2.2rem;
  width:100%;max-width:420px;
  box-shadow:var(--shadow-card);
  position:relative;
  transition:transform 0.4s var(--ease-out),box-shadow 0.4s;
}
.partner-card::before{
  content:'';position:absolute;
  top:1.6rem;right:1.6rem;
  width:38px;height:38px;
  border-radius:50%;
  background:var(--fg);
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23f5f3ee' stroke-width='2.5'><path d='M7 17L17 7M9 7h8v8'/></svg>");
  background-repeat:no-repeat;background-position:center;
  background-size:18px;
  transition:transform 0.4s var(--ease-out);
}
@media(hover:hover){
  .partner-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
  .partner-card:hover::before{transform:rotate(45deg)}
}
.partner-card-eyebrow{
  font-size:0.72rem;letter-spacing:0.18em;
  text-transform:uppercase;color:var(--muted);
  margin-bottom:0.5rem;font-weight:600;
}
.partner-card-name{
  font-family:var(--font-sans);font-weight:800;
  font-size:2.2rem;letter-spacing:-0.02em;
  text-transform:uppercase;line-height:0.95;
  margin-bottom:0.6rem;
}
.partner-card-meta{
  font-size:0.85rem;color:var(--muted);
  letter-spacing:0.02em;line-height:1.5;
  padding-bottom:1.4rem;margin-bottom:1.4rem;
  border-bottom:1px solid var(--line);
}
.partner-card-list{
  list-style:none;padding:0;margin:0;
  display:flex;flex-direction:column;gap:0.6rem;
}
.partner-card-list li{
  font-size:0.9rem;color:var(--fg);
  padding-left:1.4rem;position:relative;
  line-height:1.4;
}
.partner-card-list li::before{
  content:'→';position:absolute;left:0;
  color:var(--muted);font-weight:600;
}

/* =============================================================
   PERSON / DER MENSCH DAHINTER (Home)
   ============================================================= */
.person-section{
  padding:7rem var(--pad-x);background:var(--bg);
  position:relative;overflow:hidden;
}
.person-section::before{
  content:'';position:absolute;left:-5%;top:50%;
  transform:translateY(-50%);
  font-family:var(--font-script);font-weight:600;
  font-size:clamp(8rem,18vw,16rem);color:var(--bg-3);
  letter-spacing:-0.02em;line-height:0.85;
  pointer-events:none;user-select:none;z-index:0;
  opacity:0.5;white-space:nowrap;
}
.person-inner{
  max-width:var(--container);margin:0 auto;
  display:grid;grid-template-columns:1.05fr 1fr;gap:5rem;
  align-items:center;position:relative;z-index:1;
}
.person-image{
  position:relative;
  aspect-ratio:4/5;
  border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--shadow-lg);
  transform:translateY(20px);
}
.person-image img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1.2s var(--ease-out);
}
.person-image:hover img{transform:scale(1.04)}
.person-image-tag{
  position:absolute;bottom:1.2rem;left:1.2rem;
  font-family:var(--font-script);font-size:1.05rem;
  color:rgba(255,255,255,0.95);
  text-shadow:0 1px 4px rgba(0,0,0,0.6);
  background:rgba(14,14,14,0.4);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  padding:0.4rem 0.9rem;border-radius:100px;
}
.person-text{padding-right:1rem}
.person-text .eyebrow{margin-bottom:0.6rem}
.person-text .section-title{
  font-size:clamp(2rem,4.4vw,3.4rem);
  margin-bottom:1.8rem;
}
.person-text p{
  color:var(--muted);font-size:1.05rem;line-height:1.75;
  margin-bottom:1.2rem;
}
.person-text p strong{color:var(--fg);font-weight:600}
.person-text .btn{margin-top:1rem}


.testimonial-section{
  padding:7rem var(--pad-x);background:var(--bg-warm);
}
.testimonial-inner{max-width:1000px;margin:0 auto;text-align:center}
.testimonial-quote{
  font-family:var(--font-script);font-weight:500;
  font-size:clamp(2rem,4vw,3.4rem);
  color:var(--fg);line-height:1.3;margin:2rem 0;
  min-height:220px;display:flex;align-items:center;justify-content:center;
  position:relative;
}
.testimonial-quote-text{
  transition:opacity 0.5s, transform 0.5s var(--ease-out);
}
.testimonial-quote-text.fade-out{opacity:0;transform:translateY(-10px)}
.testimonial-stars{
  display:inline-flex;gap:0.3rem;margin-bottom:1rem;color:var(--fg);font-size:1.2rem;
}
.testimonial-author{
  font-weight:700;text-transform:uppercase;letter-spacing:0.05em;
  font-size:0.95rem;
}
.testimonial-role{
  font-family:var(--font-script);font-weight:500;font-size:1.1rem;
  color:var(--muted);margin-top:0.2rem;
}
.testimonial-controls{
  display:flex;gap:0.6rem;justify-content:center;margin-top:2.5rem;
}
.testimonial-controls button{
  width:48px;height:48px;border-radius:50%;
  border:1px solid var(--line);background:var(--bg-2);
  display:flex;align-items:center;justify-content:center;
  transition:all 0.3s;
}
.testimonial-controls button:hover{background:var(--fg);color:var(--bg);border-color:var(--fg)}
.testimonial-controls svg{width:18px;height:18px}
.testimonial-dots{
  display:flex;gap:0.5rem;justify-content:center;margin-top:1.5rem;
}
.testimonial-dots span{
  width:6px;height:6px;border-radius:50%;
  background:var(--muted-2);transition:all 0.3s;
}
.testimonial-dots span.active{background:var(--fg);transform:scale(1.5)}

/* =============================================================
   BIG CTA BAND
   ============================================================= */
.cta-band{
  padding:7rem var(--pad-x);text-align:center;background:var(--bg);
  position:relative;overflow:hidden;
}
.cta-band-inner{max-width:900px;margin:0 auto;position:relative;z-index:2}
.cta-band h2{
  font-size:clamp(2.5rem,7vw,5.5rem);font-weight:800;
  letter-spacing:-0.03em;text-transform:uppercase;line-height:0.95;
  margin-bottom:1.5rem;
}
.cta-band h2 em{
  font-style:normal;font-family:var(--font-script);
  font-weight:600;text-transform:none;letter-spacing:-0.01em;
  color:var(--muted);font-size:0.7em;display:inline-block;
  transform:translateY(-0.05em);
}
.cta-band p{
  font-size:1.15rem;color:var(--muted);max-width:55ch;
  margin:0 auto 2.5rem;line-height:1.6;
}
.cta-band-bg{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  display:flex;align-items:center;justify-content:center;
  font-weight:900;font-size:clamp(8rem,22vw,22rem);
  letter-spacing:-0.05em;color:transparent;
  -webkit-text-stroke:1px var(--line);
  white-space:nowrap;text-transform:uppercase;
  opacity:0.7;
}

/* =============================================================
   ÜBER-MICH PAGE
   ============================================================= */
.page-hero{
  padding:9rem var(--pad-x) 4rem;
  max-width:var(--container);margin:0 auto;
}
.page-hero-eyebrow{
  font-family:var(--font-script);font-weight:600;
  font-size:1.6rem;color:var(--muted);margin-bottom:0.6rem;
}
.page-hero h1{
  font-size:clamp(3rem,8vw,7rem);font-weight:800;
  letter-spacing:-0.04em;text-transform:uppercase;line-height:0.92;
}
.page-hero h1 em{
  font-style:normal;font-family:var(--font-script);font-weight:600;
  text-transform:none;letter-spacing:-0.01em;color:var(--muted);
  font-size:0.65em;display:inline-block;transform:translateY(-0.1em);
}

.about-grid{
  display:grid;grid-template-columns:1.1fr 1fr;gap:4rem;
  padding:3rem var(--pad-x) 6rem;
  max-width:var(--container);margin:0 auto;align-items:center;
}
.about-portrait{
  aspect-ratio:4/5;border-radius:var(--radius-lg);
  background:#ddd center/cover no-repeat;
  box-shadow:var(--shadow-lg);
  position:relative;overflow:hidden;
}
.about-portrait img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1s var(--ease-out);
}
.about-portrait:hover img{transform:scale(1.04)}
.about-portrait::before{
  content:attr(data-label);
  position:absolute;bottom:1rem;left:1rem;z-index:2;
  font-family:var(--font-script);font-size:1rem;
  color:rgba(255,255,255,0.85);
  text-shadow:0 1px 4px rgba(0,0,0,0.5);
}
.about-text h2{
  font-size:clamp(2rem,4vw,3rem);font-weight:800;
  letter-spacing:-0.02em;text-transform:uppercase;
  line-height:1;margin-bottom:1.5rem;
}
.about-text p{
  font-size:1.05rem;color:var(--muted);line-height:1.75;
  margin-bottom:1.2rem;
}
.about-text p strong{color:var(--fg);font-weight:600}
.about-signature{
  font-family:var(--font-script);font-weight:600;
  font-size:2rem;color:var(--fg);margin-top:2rem;
  transform:rotate(-3deg);display:inline-block;
}

.about-facts{
  background:var(--bg-2);padding:5rem var(--pad-x);
  border-top:1px solid var(--line-soft);
  border-bottom:1px solid var(--line-soft);
}
.facts-grid{
  display:grid;grid-template-columns:repeat(4, 1fr);gap:2rem;
  max-width:var(--container);margin:0 auto;
}
.fact{
  border:1px solid var(--line);border-radius:var(--radius);
  padding:1.5rem;background:var(--bg);
  box-shadow:var(--shadow);
  transition:transform 0.4s, box-shadow 0.4s;
}
.fact:hover{transform:translateY(-4px);box-shadow:var(--shadow-card)}
.fact-label{
  font-family:var(--font-script);font-weight:600;
  font-size:1.1rem;color:var(--muted);margin-bottom:0.4rem;
}
.fact-value{
  font-size:1.4rem;font-weight:700;letter-spacing:-0.01em;
  text-transform:uppercase;line-height:1.1;
}

/* =============================================================
   LEISTUNGEN PAGE
   ============================================================= */
.services-page{padding:9rem var(--pad-x) 6rem;max-width:var(--container);margin:0 auto}
.services-list{
  display:flex;flex-direction:column;gap:1.5rem;margin-top:3rem;
}
.service-row{
  display:grid;grid-template-columns:80px 1fr auto;gap:2rem;
  align-items:center;padding:2rem;
  background:var(--bg-2);border:1px solid var(--line);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-card);
  transition:transform 0.4s,box-shadow 0.4s;
  position:relative;overflow:hidden;
}
.service-row:hover{
  transform:translateY(-4px);
  box-shadow:0 20px 40px rgba(14,14,14,0.1);
}
.service-row-num{
  font-family:var(--font-script);font-weight:600;
  font-size:2.4rem;color:var(--muted);line-height:1;
}
.service-row h3{
  font-size:1.8rem;font-weight:700;text-transform:uppercase;
  letter-spacing:-0.01em;margin-bottom:0.4rem;line-height:1;
}
.service-row p{color:var(--muted);font-size:0.98rem;line-height:1.6}
.service-row .btn-arrow{
  width:48px;height:48px;border-radius:50%;
  background:var(--fg);color:var(--bg);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;transition:transform 0.3s;
}
.service-row:hover .btn-arrow{transform:translateX(6px)}
.service-row .btn-arrow svg{width:16px;height:16px}

/* =============================================================
   LEISTUNGEN-DETAIL PAGE
   ============================================================= */
.detail-hero{
  padding:9rem var(--pad-x) 5rem;
  max-width:var(--container);margin:0 auto;
}
.breadcrumb{
  display:flex;gap:0.5rem;font-size:0.78rem;
  text-transform:uppercase;letter-spacing:0.12em;
  color:var(--muted);margin-bottom:1.5rem;
}
.breadcrumb a{color:var(--muted)}
.breadcrumb a:hover{color:var(--fg)}
.breadcrumb .sep{color:var(--muted-2)}

.detail-grid{
  display:grid;grid-template-columns:1.4fr 1fr;gap:4rem;
  align-items:start;
}
.detail-text h1{
  font-size:clamp(2.5rem,6vw,5rem);font-weight:800;
  letter-spacing:-0.03em;text-transform:uppercase;
  line-height:0.95;margin-bottom:1.5rem;
}
.detail-text h1 em{
  font-style:normal;font-family:var(--font-script);font-weight:600;
  text-transform:none;letter-spacing:-0.01em;color:var(--muted);
  font-size:0.65em;display:inline-block;
}
.detail-lead{
  font-size:1.2rem;color:var(--muted);line-height:1.65;margin-bottom:2rem;
}
.detail-body p{
  font-size:1.05rem;color:var(--muted);line-height:1.75;margin-bottom:1.2rem;
}
.detail-body p strong{color:var(--fg);font-weight:600}
.detail-body ul{
  list-style:none;margin:1.5rem 0;
}
.detail-body li{
  padding:0.7rem 0;border-bottom:1px solid var(--line-soft);
  display:flex;align-items:center;gap:0.8rem;color:var(--fg);
  font-weight:500;
}
.detail-body li::before{
  content:'';width:6px;height:6px;background:var(--fg);
  border-radius:50%;flex-shrink:0;
}
.detail-side{
  background:var(--bg-2);border:1px solid var(--line);
  border-radius:var(--radius-lg);padding:2rem;
  box-shadow:var(--shadow-card);position:sticky;top:6rem;
}
.detail-side h4{
  font-family:var(--font-script);font-weight:600;
  font-size:1.2rem;color:var(--muted);margin-bottom:0.4rem;
}
.detail-side .price{
  font-size:2.2rem;font-weight:800;letter-spacing:-0.02em;
  margin-bottom:0.5rem;line-height:1;
}
.detail-side .price-note{
  font-size:0.9rem;color:var(--muted);margin-bottom:1.5rem;
}
.detail-side .feature-row{
  display:flex;justify-content:space-between;
  padding:0.8rem 0;border-top:1px solid var(--line-soft);
  font-size:0.95rem;
}
.detail-side .feature-row span:first-child{color:var(--muted)}
.detail-side .feature-row span:last-child{font-weight:600}
.detail-side .btn{width:100%;justify-content:center;margin-top:1.5rem}

/* =============================================================
   TIMELINE / STRATEGIE & BERATUNG
   Scroll-jacking: Stage sticky im Viewport, Cards faden zwischen Steps
   ============================================================= */

.timeline-intro{
  max-width:780px;
}
.timeline-intro .eyebrow{margin-bottom:0.6rem}
.timeline-h1{
  font-size:clamp(2.6rem,7vw,5.5rem);
  font-weight:800;
  letter-spacing:-0.03em;
  text-transform:uppercase;
  line-height:0.95;
  margin-bottom:1.5rem;
}
.timeline-h1 em{
  font-style:normal;font-family:var(--font-script);font-weight:600;
  text-transform:none;letter-spacing:-0.01em;color:var(--muted);
  font-size:0.6em;display:inline-block;
}
.timeline-lead{
  font-size:clamp(1.05rem,1.4vw,1.2rem);
  color:var(--muted);
  line-height:1.6;
  max-width:640px;
  margin-bottom:2.5rem;
}
.timeline-meta{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(180px, 1fr));
  gap:1px;
  background:var(--line-soft);
  border:1px solid var(--line-soft);
  border-radius:var(--radius);
  overflow:hidden;
  margin-bottom:2.5rem;
}
.timeline-meta .feature-row{
  background:var(--bg);
  padding:1rem 1.2rem;
  display:flex;flex-direction:column;gap:0.3rem;
  font-size:0.88rem;
}
.timeline-meta .feature-row span:first-child{
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:0.08em;
  font-size:0.75rem;
}
.timeline-meta .feature-row span:last-child{font-weight:600}

.timeline-scroll-hint{
  display:flex;align-items:center;gap:0.8rem;
  font-size:0.85rem;color:var(--muted);
  text-transform:uppercase;letter-spacing:0.08em;
  margin-top:1rem;
}
.timeline-scroll-hint svg{
  width:18px;height:18px;
  animation:scrollHint 2s ease-in-out infinite;
}
@keyframes scrollHint{
  0%, 100%{transform:translateY(0);opacity:0.5}
  50%{transform:translateY(8px);opacity:1}
}

/* ===== TLC: Timeline-Card-Section (Scroll-Jacking) ===== */

/* Section: gibt die Gesamthöhe vor via inline-style. */
.tlc-section{
  position:relative;
}

/* Stage: per JS auf position:fixed gesetzt während im Section-Bereich.
   Standardmäßig static, JS pinnt. */
.tlc-stage{
  width:100%;
  height:100vh;
  display:grid;
  grid-template-columns:140px 1fr;
  align-items:center;
  padding:0 var(--pad-x);
  background:var(--bg);
}
/* Pinned-State: fixed im Viewport */
.tlc-stage.is-pinned{
  position:fixed;
  top:0;
  left:0;right:0;
  z-index:5;
}
/* Bottom-State: am unteren Ende der Section absolut */
.tlc-stage.is-end{
  position:absolute;
  bottom:0;
  left:0;right:0;
}

/* Vertikale Linie mit Dots */
.tlc-rail{
  position:relative;
  height:60vh;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:space-between;
  padding:0;
}
.tlc-rail-line{
  position:absolute;
  left:50%;
  top:0;
  bottom:0;
  width:2px;
  background:var(--line);
  transform:translateX(-50%);
}
.tlc-rail-line-fill{
  position:absolute;
  left:0;top:0;
  width:100%;
  height:0%;
  background:var(--fg);
  transition:height 0.4s cubic-bezier(.22,.61,.36,1);
}
.tlc-rail-dots{
  position:relative;
  height:100%;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  align-items:center;
  z-index:2;
}
.tlc-dot{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:0.4rem;
  position:relative;
  transition:transform 0.4s cubic-bezier(.22,.61,.36,1);
}
.tlc-dot-circle{
  width:14px;height:14px;
  border-radius:50%;
  background:var(--bg);
  border:2px solid var(--line);
  transition:all 0.4s cubic-bezier(.22,.61,.36,1);
}
.tlc-dot.is-passed .tlc-dot-circle,
.tlc-dot.is-active .tlc-dot-circle{
  background:var(--fg);
  border-color:var(--fg);
}
.tlc-dot.is-active{
  transform:scale(1.3);
}
.tlc-dot.is-active .tlc-dot-circle{
  box-shadow:0 0 0 6px rgba(14,14,14,0.08);
}
.tlc-dot-label{
  position:absolute;
  left:24px;top:50%;
  transform:translateY(-50%);
  font-size:0.78rem;
  font-weight:600;
  color:var(--muted);
  white-space:nowrap;
  font-feature-settings:"tnum" 1;
  letter-spacing:0.05em;
  transition:color 0.4s var(--ease-out);
}
.tlc-dot.is-active .tlc-dot-label,
.tlc-dot.is-passed .tlc-dot-label{color:var(--fg)}

/* Card-Stack: alle Cards übereinander, eine sichtbar */
.tlc-card-stack{
  position:relative;
  height:60vh;
  width:100%;
  max-width:680px;
}
.tlc-card{
  position:absolute;
  top:0;left:0;right:0;bottom:0;
  background:var(--bg-2);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:3rem 3rem 2.5rem;
  box-shadow:0 20px 60px rgba(14,14,14,0.08);
  display:flex;
  flex-direction:column;
  gap:1rem;
  /* Standard: unsichtbar und leicht nach unten verschoben */
  opacity:0;
  transform:translateY(40px) scale(0.96);
  pointer-events:none;
  transition:opacity 0.6s cubic-bezier(.22,.61,.36,1),
             transform 0.6s cubic-bezier(.22,.61,.36,1);
}
.tlc-card.is-active{
  opacity:1;
  transform:translateY(0) scale(1);
  pointer-events:auto;
}
.tlc-card-num{
  font-size:0.85rem;
  font-weight:600;
  color:var(--muted);
  letter-spacing:0.12em;
  text-transform:uppercase;
  font-feature-settings:"tnum" 1;
}
.tlc-card-meta{
  font-family:var(--font-script);
  font-size:1.2rem;
  color:var(--muted);
  margin-top:-0.4rem;
}
.tlc-card-title{
  font-size:clamp(2rem, 3.5vw, 3rem);
  font-weight:800;
  letter-spacing:-0.02em;
  text-transform:uppercase;
  line-height:1;
  margin:0.4rem 0 0;
}
.tlc-card-text{
  font-size:1.05rem;
  line-height:1.65;
  color:var(--fg);
  margin:0;
}
.tlc-card-details{
  font-size:0.92rem;
  line-height:1.65;
  color:var(--muted);
  padding:1.2rem 1.4rem;
  background:var(--bg);
  border-left:2px solid var(--fg);
  border-radius:0 var(--radius) var(--radius) 0;
  margin-top:auto;
}

.tl-finish{
  text-align:center;
  max-width:680px;
  margin:5rem auto;
  padding:0 var(--pad-x);
}
.tl-finish .eyebrow{margin-bottom:0.8rem}
.tl-finish h2{
  font-size:clamp(2rem,4.5vw,3.6rem);
  font-weight:800;
  letter-spacing:-0.03em;
  text-transform:uppercase;
  line-height:0.95;
  margin-bottom:1rem;
}
.tl-finish h2 em{
  font-style:normal;font-family:var(--font-script);font-weight:600;
  text-transform:none;letter-spacing:-0.01em;color:var(--muted);
}
.tl-finish p{
  font-size:1.05rem;
  color:var(--muted);
  line-height:1.65;
  margin-bottom:2rem;
}

/* Mobile Timeline */
@media (max-width:900px){
  .tlc-stage{
    grid-template-columns:60px 1fr;
    padding:0 1rem;
    gap:0.5rem;
  }
  .tlc-rail{height:55vh}
  .tlc-card-stack{height:55vh}
  .tlc-card{
    padding:1.8rem 1.6rem 1.6rem;
    border-radius:var(--radius);
  }
  .tlc-card-title{font-size:1.6rem}
  .tlc-card-text{font-size:0.95rem}
  .tlc-card-details{
    padding:1rem 1.2rem;
    font-size:0.85rem;
  }
  .tlc-dot-label{
    font-size:0.65rem;
    left:20px;
  }
  .timeline-meta{
    grid-template-columns:1fr 1fr;
  }
  .timeline-scroll-hint{
    font-size:0.78rem;
  }
}

/* =============================================================
   ERFOLGE PAGE
   ============================================================= */
.works-grid{
  display:grid;grid-template-columns:repeat(2, 1fr);gap:1.5rem;
  padding:3rem var(--pad-x) 6rem;
  max-width:var(--container);margin:0 auto;
}
.work-card{
  background:var(--bg-2);border:1px solid var(--line);
  border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--shadow-card);
  transition:transform 0.5s var(--ease-out),box-shadow 0.5s;
  display:flex;flex-direction:column;
}
.work-card:hover{
  transform:translateY(-8px);
  box-shadow:0 30px 60px rgba(14,14,14,0.15);
}
.work-image{
  aspect-ratio:16/10;background:#ddd center/cover no-repeat;
  position:relative;overflow:hidden;
}
.work-image::after{
  content:attr(data-img);
  position:absolute;bottom:0.8rem;left:0.8rem;
  font-family:var(--font-script);font-size:0.9rem;
  color:rgba(255,255,255,0.75);
  text-shadow:0 1px 4px rgba(0,0,0,0.5);
}
.work-image img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 0.8s var(--ease-out);
}
.work-card:hover .work-image img{transform:scale(1.06)}
.work-content{padding:1.8rem;display:flex;flex-direction:column;gap:0.6rem}
.work-meta{
  display:flex;justify-content:space-between;
  font-size:0.78rem;text-transform:uppercase;
  letter-spacing:0.12em;color:var(--muted);
}
.work-content h3{
  font-size:1.6rem;font-weight:700;text-transform:uppercase;
  letter-spacing:-0.01em;line-height:1;
}
.work-content p{color:var(--muted);font-size:0.95rem;line-height:1.5}
.work-stats{
  display:flex;gap:1.2rem;margin-top:0.6rem;
  padding-top:1rem;border-top:1px solid var(--line-soft);
}
.work-stat{flex:1}
.work-stat strong{
  display:block;font-size:1.4rem;font-weight:800;letter-spacing:-0.02em;
}
.work-stat span{
  font-size:0.78rem;color:var(--muted);
  text-transform:uppercase;letter-spacing:0.05em;
}

/* =============================================================
   STUDIO PAGE
   ============================================================= */
.studio-hero{
  position:relative;padding:9rem var(--pad-x) 4rem;
  max-width:var(--container);margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;
}
.studio-image{
  aspect-ratio:4/5;border-radius:var(--radius-lg);
  background:#ddd center/cover no-repeat;
  box-shadow:var(--shadow-lg);position:relative;overflow:hidden;
}
.studio-image img{width:100%;height:100%;object-fit:cover}
.studio-image::after{
  content:attr(data-label);
  position:absolute;bottom:1rem;left:1rem;
  font-family:var(--font-script);font-size:1rem;
  color:rgba(255,255,255,0.85);
  text-shadow:0 1px 4px rgba(0,0,0,0.5);
}
.studio-equipment{
  background:var(--bg-2);padding:5rem var(--pad-x);
  border-top:1px solid var(--line-soft);
}
.equip-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;
  max-width:var(--container);margin:3rem auto 0;
}
.equip-card{
  background:var(--bg);border:1px solid var(--line);
  border-radius:var(--radius);padding:1.8rem;
  box-shadow:var(--shadow);
  transition:transform 0.4s,box-shadow 0.4s;
}
.equip-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-card)}
.equip-card h4{
  font-size:0.78rem;text-transform:uppercase;letter-spacing:0.12em;
  color:var(--muted);margin-bottom:0.8rem;
}
.equip-card ul{list-style:none}
.equip-card li{
  font-size:0.98rem;padding:0.5rem 0;
  border-bottom:1px solid var(--line-soft);font-weight:500;
}
.equip-card li:last-child{border-bottom:none}

/* =============================================================
   KONTAKT PAGE
   ============================================================= */
.contact-page{padding:9rem var(--pad-x) 6rem;max-width:var(--container);margin:0 auto}
.contact-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:4rem;margin-top:3rem;
}
.contact-form{
  background:var(--bg-2);border:1px solid var(--line);
  border-radius:var(--radius-lg);padding:2.5rem;
  box-shadow:var(--shadow-card);
}
.form-row{display:flex;gap:1rem;margin-bottom:1.2rem}
.form-field{flex:1;display:flex;flex-direction:column;gap:0.4rem;margin-bottom:1.2rem}
.form-field label{
  font-size:0.78rem;text-transform:uppercase;letter-spacing:0.12em;
  font-weight:600;color:var(--muted);
}
.form-field input,
.form-field textarea,
.form-field select{
  padding:0.9rem 1rem;border:1px solid var(--line);
  border-radius:12px;font:inherit;font-size:0.98rem;
  background:var(--bg);color:var(--fg);
  transition:border-color 0.2s,box-shadow 0.2s;
}
.form-field input:focus,
.form-field textarea:focus,
.form-field select:focus{
  outline:none;border-color:var(--fg);
  box-shadow:0 0 0 3px rgba(14,14,14,0.06);
}
.form-field textarea{resize:vertical;min-height:120px;font-family:inherit}

.contact-info{display:flex;flex-direction:column;gap:1.5rem}
.contact-info-card{
  background:var(--bg-2);border:1px solid var(--line);
  border-radius:var(--radius);padding:1.8rem;
  box-shadow:var(--shadow);
}
.contact-info-card h4{
  font-family:var(--font-script);font-weight:600;
  font-size:1.3rem;color:var(--muted);margin-bottom:0.4rem;
}
.contact-info-card .value{font-size:1.2rem;font-weight:600;letter-spacing:-0.01em}
.contact-info-card a{display:block;margin-top:0.3rem;color:var(--fg)}
.contact-info-card a:hover{text-decoration:underline}

/* =============================================================
   FOOTER mit riesigem Outline-Wordmark
   ============================================================= */
footer{
  background:var(--fg);color:var(--bg);
  padding:5rem var(--pad-x) 2rem;margin-top:0;
  position:relative;overflow:hidden;
}
.footer-mark{
  position:absolute;left:0;right:0;bottom:-2.5rem;
  font-size:clamp(8rem,22vw,22rem);
  font-weight:900;letter-spacing:-0.05em;text-transform:uppercase;
  color:transparent;-webkit-text-stroke:1px rgba(245,243,238,0.2);
  text-align:center;line-height:0.85;
  pointer-events:none;user-select:none;
  white-space:nowrap;
}
.footer-grid{
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:3rem;
  max-width:var(--container);margin:0 auto;
  position:relative;z-index:2;
}
.footer-logo{
  font-weight:800;font-size:1.4rem;letter-spacing:0.02em;
  text-transform:uppercase;display:flex;align-items:center;gap:0.6rem;
  margin-bottom:1rem;
}
.footer-logo .logo-mark{
  width:24px;height:24px;color:var(--bg);
}
.footer-tag{
  font-family:var(--font-script);font-weight:500;font-size:1.2rem;
  color:var(--muted-2);line-height:1.4;
}
.footer-col h4{
  font-size:0.78rem;text-transform:uppercase;letter-spacing:0.12em;
  font-weight:600;margin-bottom:1.2rem;color:var(--bg);
}
.footer-col a, .footer-col span{
  display:block;color:var(--muted-2);font-size:0.95rem;
  padding:0.4rem 0;transition:color 0.2s;
}
.footer-col a:hover{color:var(--bg)}
.footer-social{display:flex;gap:0.5rem;margin-top:1rem}
.footer-social a{
  width:36px;height:36px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(245,243,238,0.2);padding:0;
  transition:all 0.2s;
}
.footer-social a:hover{background:var(--bg);color:var(--fg)}
.footer-social svg{width:14px;height:14px}

.footer-bottom{
  max-width:var(--container);margin:3rem auto 0;padding-top:2rem;
  border-top:1px solid rgba(245,243,238,0.1);
  display:flex;justify-content:space-between;align-items:center;
  font-size:0.85rem;color:var(--muted-2);
  position:relative;z-index:2;
}
.footer-legal{display:flex;gap:1.5rem}
.footer-legal a{color:var(--muted-2);transition:color 0.2s}
.footer-legal a:hover{color:var(--bg)}

/* =============================================================
   SCROLL REVEAL — von GSAP gesteuert, hier nur Initial-State
   ============================================================= */
.reveal{opacity:0;transform:translateY(30px)}
.reveal.in{opacity:1;transform:translateY(0);transition:opacity 0.8s var(--ease-out), transform 0.8s var(--ease-out)}

/* =============================================================
   RESPONSIVE
   ============================================================= */
@media(max-width:1100px){
  .services-grid{grid-template-columns:1fr 1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2.5rem}
  .equip-grid{grid-template-columns:1fr 1fr}
  .facts-grid{grid-template-columns:1fr 1fr}
  .process-inner{grid-template-columns:1fr;gap:3rem}
  .process-sticky{position:static}
  .work-slide{flex-basis:440px}
}
@media(max-width:900px){
  :root{--pad-x:1.4rem}
  nav.top{padding:1rem 1.4rem}
  .nav-links{display:none}
  .burger{display:flex}
  .mobile-menu{display:flex}
  .side-rail{display:none}

  /* Hero Mobile: Karten OBEN + UNTEN vom Wordmark, NICHT dahinter */
  .hero{padding:5rem 1rem 3rem;min-height:auto}
  .hero-eyebrow-top{font-size:0.85rem;margin-bottom:1.5rem}
  .hero-stage{min-height:520px;padding:1rem 0}
  .wordmark{font-size:clamp(3.4rem,15vw,5.5rem)}
  .hero-card{
    width:80px;height:104px;
    margin-left:-40px;margin-top:-52px;
    border-radius:8px;
    box-shadow:0 8px 20px rgba(14,14,14,0.16);
  }
  /* Mobile: 4 Karten OBEN vom Wordmark, 4 Karten UNTEN (nicht seitlich!) */
  /* Oben links/rechts vom Wordmark (über JONAS) */
  .hc-1{--final-x:-115px;--final-y:-180px;--final-rot:-12deg}
  .hc-2{--final-x:-50px;--final-y:-200px;--final-rot:-4deg}
  .hc-3{--final-x:50px;--final-y:-200px;--final-rot:6deg}
  .hc-4{--final-x:115px;--final-y:-180px;--final-rot:10deg}
  /* Unten links/rechts vom Wordmark (unter AREA) */
  .hc-5{--final-x:-115px;--final-y:180px;--final-rot:-10deg}
  .hc-6{--final-x:-50px;--final-y:200px;--final-rot:-3deg}
  .hc-7{--final-x:50px;--final-y:200px;--final-rot:5deg}
  .hc-8{--final-x:115px;--final-y:180px;--final-rot:12deg}

  .hero-headline{font-size:clamp(1.4rem,5vw,2rem)}
  .services-grid{grid-template-columns:1fr}

  /* Trust-Wall Mobile: Auto-Animation läuft endlos.
     overflow-x wird dynamisch durch JS aktiviert wenn User touchst. */
  .trust-wall{padding:4rem 0 4rem}
  .trust-wall-head{margin-bottom:2.5rem}
  .trust-track-wrap{
    padding:2.5rem 0;
    /* overflow-x wird per JS gesetzt bei Touch — initial NICHT gesetzt damit Auto-Animation läuft */
    scrollbar-width:none;
    -webkit-overflow-scrolling:touch;
  }
  .trust-track-wrap::-webkit-scrollbar{display:none}
  .trust-track{gap:1.2rem;animation-duration:50s}
  .trust-card{
    width:260px;height:170px;
    scroll-snap-align:center;
  }
  .trust-track .trust-card.is-active{
    transform:scale(1.12) !important;
  }
  .trust-card-name{font-size:1rem}
  .trust-card-role{font-size:0.9rem}
  .trust-card-quote{font-size:0.85rem}

  .stats-grid{grid-template-columns:1fr;gap:1px}
  .stat-item{min-height:auto;padding:1.8rem 1.5rem}
  .about-grid,.studio-hero,.detail-grid,.contact-grid{grid-template-columns:1fr;gap:2.5rem}
  .person-inner{grid-template-columns:1fr;gap:2.5rem}
  .person-text{padding-right:0}
  .person-section{padding:5rem var(--pad-x)}
  /* Partner-Sektion Mobile */
  .partner-inner{grid-template-columns:1fr;gap:2.5rem}
  .partner-section{padding:5rem var(--pad-x)}
  .partner-card{padding:2rem 1.5rem}
  .partner-card-name{font-size:1.8rem}
  .detail-side{position:static}
  .works-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:2rem}
  .footer-bottom{flex-direction:column;gap:1rem;text-align:center}
  .service-row{grid-template-columns:1fr;text-align:left}
  .service-row .btn-arrow{justify-self:start}
  .form-row{flex-direction:column;gap:0;margin-bottom:0}
  .equip-grid,.facts-grid{grid-template-columns:1fr}
  /* Slider Mobile: kein Snap, sanfteres Scrollen */
  .work-slide{flex-basis:82%}
  .work-slide-body{padding:1.4rem 1.4rem}
  .work-slide h3{font-size:1.3rem}
  .work-slide-arrow{width:36px;height:36px;top:1rem;right:1rem}
  .work-slider{
    scroll-snap-type:none;
    padding-bottom:1rem;
  }
  .testimonial-quote{min-height:280px}
  .footer-mark{font-size:6rem;bottom:0.5rem}
  /* Mobile: kein Custom Cursor */
  html, body, a, button{cursor:auto}
  .cursor{display:none !important}
}

@media(prefers-reduced-motion:reduce){
  .orbit,.ticker-track,.trust-track{animation:none}
  .reveal{opacity:1;transform:none;transition:none}
  /* Loader bleibt auf Mobile sichtbar */
}
