/* =======================================================================
   Viktor Torno AI Consulting — Website
   Builds on _ds tokens (colors_and_type.css). Monochrome ink-on-paper,
   single forest-green accent, hairlines, oversized type, generous space.
   ======================================================================= */

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

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

body {
  margin: 0;
  background: var(--vt-paper);
  color: var(--vt-fg);
  font-family: var(--vt-font-sans);
  font-size: var(--vt-size-base);
  line-height: var(--vt-lh-normal);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}

/* Lenis smooth-scroll guards */
html.lenis, html.lenis body { height: auto; }
.lenis.lenis-smooth { scroll-behavior: auto !important; }

::selection { background: var(--vt-signal); color: var(--vt-paper); }

a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }

:focus-visible { outline: 2px solid var(--vt-ink); outline-offset: 2px; }

/* ---------- Layout primitives ---------- */
.container {
  width: 100%;
  max-width: var(--vt-container);
  margin-inline: auto;
  padding-inline: var(--vt-gutter);
}
.container-wide { max-width: var(--vt-container-wide); }

.section { padding-block: clamp(4rem, 9vw, 8rem); position: relative; }
.section--tight { padding-block: clamp(3rem, 6vw, 5rem); }
/* hairline divider where two light sections meet (engineering-spec rhythm) */
.section--rule { border-top: 1px solid var(--vt-border); }

.hairline { border: 0; border-top: 1px solid var(--vt-border); margin: 0; }

.eyebrow {
  font-family: var(--vt-font-mono);
  font-size: var(--vt-size-sm);
  font-weight: 500;
  letter-spacing: var(--vt-track-wider);
  text-transform: uppercase;
  color: var(--vt-fg-muted);
  display: inline-flex;
  align-items: center;
  gap: .6rem;
}
.eyebrow::before {
  content: "";
  width: 28px;
  height: 1px;
  background: var(--vt-signal);
  display: inline-block;
}
.eyebrow .sec {
  color: var(--vt-signal);
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  letter-spacing: var(--vt-track-wider);
}

.section-head { display: flex; flex-direction: column; gap: 1.25rem; max-width: 64rem; }
.section-head .num {
  font-family: var(--vt-font-mono);
  font-size: var(--vt-size-sm);
  letter-spacing: var(--vt-track-wide);
  color: var(--vt-fg-subtle);
}

/* ---------- Brand-green § markers + the headline under them ---------- */
/* heading green = the hero „Keine KI-Strategie“ box colour (--vt-signal) */
:root { --vt-green-head: var(--vt-signal); --vt-green-bright: #4FBE86; --vt-canvas-green: #0E3A2C; }
.eyebrow:has(.sec) { color: var(--vt-green-head); }
.eyebrow:has(.sec)::before { background: var(--vt-green-head); }
.eyebrow .sec { color: var(--vt-green-head); }
.section-head:has(.sec) .vt-h2,
.section-head:has(.sec) .vt-h3 { color: var(--vt-green-head); }
/* on ink (dark) sections use a brighter green so it stays legible */
/* dark sections (black ink + green band): WHITE § markers + WHITE headlines
   — the brand green #0F3B2E is reserved for light grounds where it reads */
.ink .eyebrow:has(.sec),
.ink .eyebrow:has(.sec) .sec,
.greenband .eyebrow:has(.sec),
.greenband .eyebrow:has(.sec) .sec { color: var(--vt-paper); }
.ink .eyebrow:has(.sec)::before,
.greenband .eyebrow:has(.sec)::before { background: rgba(245,244,240,.55); }
.ink .section-head:has(.sec) .vt-h2,
.ink .section-head:has(.sec) .vt-h3,
.greenband .section-head:has(.sec) .vt-h2,
.greenband .section-head:has(.sec) .vt-h3 { color: var(--vt-paper) !important; }

/* ---------- §02 dark band (black) ---------- */
.greenband { background: var(--vt-ink); color: var(--vt-paper); border-top: 0 !important; }
.greenband .vt-lead { color: rgba(245,244,240,.72); }
/* §02 benefit cards — white icons + text on green */
.greenband .vgrid { background: rgba(245,244,240,.2); border-color: rgba(245,244,240,.26); }
.greenband .vben { background: var(--vt-ink); }
.greenband .vben:hover { background: rgba(255,255,255,.045); }
.greenband .vben__check { background: rgba(245,244,240,.1); border-color: rgba(245,244,240,.3); color: var(--vt-paper); }
.greenband .vben:hover .vben__check { background: var(--vt-paper); color: var(--vt-ink); border-color: var(--vt-paper); }
.greenband .vben__title { color: var(--vt-paper); }
.greenband .vben__desc { color: rgba(245,244,240,.64); }
/* §04 process flow on green */
.greenband .flow__step:not(:last-child) .flow__rail::before { background: rgba(245,244,240,.25); }
.greenband .flow__node { background: rgba(245,244,240,.06); border-color: rgba(245,244,240,.5); color: var(--vt-paper); }
.greenband .flow__arrow { background: var(--vt-canvas-green); color: var(--vt-paper); }
.greenband .flow__title { color: var(--vt-paper); }
.greenband .flow__desc { color: rgba(245,244,240,.66); }
.greenband .flow__icon { color: rgba(245,244,240,.5); }
.greenband .flow__step:hover .flow__node { background: var(--vt-paper); color: var(--vt-canvas-green); border-color: var(--vt-paper); }
.greenband .flow__step:hover .flow__icon { color: var(--vt-paper); }

/* ---------- Buttons ---------- */
.btn {
  --btn-bg: var(--vt-ink);
  --btn-fg: var(--vt-paper);
  display: inline-flex;
  align-items: center;
  gap: .6rem;
  font-family: var(--vt-font-sans);
  font-weight: 600;
  font-size: var(--vt-size-base);
  letter-spacing: -.01em;
  padding: .95rem 1.6rem;
  border-radius: var(--vt-radius-pill);
  background: var(--btn-bg);
  color: var(--btn-fg);
  border: 1px solid var(--vt-ink);
  cursor: pointer;
  position: relative;
  overflow: hidden;
  transition: transform var(--vt-dur-fast) var(--vt-ease),
              color var(--vt-dur-base) var(--vt-ease);
  isolation: isolate;
}
.btn::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--vt-signal);
  transform: translateY(101%);
  transition: transform var(--vt-dur-base) var(--vt-ease);
  z-index: -1;
}
.btn:hover::before { transform: translateY(0); }
.btn:hover { color: var(--vt-paper); border-color: var(--vt-signal); }
.btn:active { transform: scale(.98); }
.btn .lucide { width: 18px; height: 18px; }
.btn .arrow { transition: transform var(--vt-dur-base) var(--vt-ease); }
.btn:hover .arrow { transform: translateX(4px); }

.btn--ghost {
  --btn-bg: transparent;
  --btn-fg: var(--vt-ink);
  background: transparent;
  color: var(--vt-ink);
}
.btn--ghost::before { display: none; }
.btn--ghost:hover { color: var(--vt-ink); background: var(--vt-chalk); border-color: var(--vt-ink); }
/* ghost button that fills brand-green on hover (e.g. hero „Leistungen ansehen“) */
.btn--ghost.btn--fill::before { display: block; }
.btn--ghost.btn--fill:hover { color: var(--vt-paper); background: transparent; border-color: var(--vt-signal); }

.btn--lg { padding: 1.15rem 2rem; font-size: var(--vt-size-md); }

.btn--on-ink { border-color: var(--vt-paper); }
.btn--on-ink.btn--ghost { color: var(--vt-paper); }
.btn--on-ink.btn--ghost:hover { background: rgba(245,244,240,.1); color: var(--vt-paper); }
.btn--fill::before { display: block; }
.btn--on-ink.btn--ghost.btn--fill:hover { background: transparent; color: var(--vt-paper); border-color: var(--vt-signal); }

.textlink {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-weight: 600;
  border-bottom: 1px solid currentColor;
  padding-bottom: 2px;
  transition: gap var(--vt-dur-base) var(--vt-ease);
}
.textlink:hover { gap: .75rem; }
.textlink .lucide { width: 16px; height: 16px; }

/* ============================================================
   NAV
   ============================================================ */
.nav {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 100;
  height: 76px;
  display: flex;
  align-items: center;
  transition: background var(--vt-dur-base) var(--vt-ease),
              border-color var(--vt-dur-base) var(--vt-ease);
  border-bottom: 1px solid transparent;
}
.nav.is-stuck {
  background: rgba(245, 244, 240, 0.97);
  border-bottom: 1px solid var(--vt-border);
}
.nav__progress {
  position: absolute;
  left: 0; right: 0; bottom: -1px;
  height: 2px;
  background: transparent;
  pointer-events: none;
}
.nav__progress span {
  display: block;
  height: 100%;
  width: 0;
  background: var(--vt-signal);
  transition: width .1s linear;
}
.nav__inner {
  width: 100%;
  max-width: var(--vt-container-wide);
  margin-inline: auto;
  padding-inline: var(--vt-gutter);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;
}
.brand { display: flex; align-items: center; gap: .7rem; }
.brand img { height: 30px; width: auto; }
.brand__wm {
  font-family: var(--vt-font-display);
  font-weight: 600;
  font-size: 1.05rem;
  letter-spacing: -.02em;
  line-height: 1;
}
.brand__wm small {
  display: block;
  font-family: var(--vt-font-mono);
  font-size: 9px;
  letter-spacing: .18em;
  color: var(--vt-fg-muted);
  font-weight: 500;
  margin-top: 2px;
}
.nav__links { display: flex; align-items: center; gap: 1.15rem; }
.nav__links a {
  font-family: var(--vt-font-mono);
  font-size: 11.5px;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--vt-green-head);
  padding: 4px 0;
  position: relative;
  transition: color var(--vt-dur-base) var(--vt-ease);
}
.nav__links a::after {
  content: "";
  position: absolute;
  left: 0; bottom: -2px;
  width: 100%; height: 1px;
  background: var(--vt-signal);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--vt-dur-base) var(--vt-ease);
}
.nav__links a:hover { color: var(--vt-ink); }
.nav__links a:hover::after, .nav__links a.is-active::after { transform: scaleX(1); }
.nav__cta { display: flex; align-items: center; gap: 1rem; }
.nav__cta .btn { padding: .65rem 1.2rem; font-size: 13px; }

.nav__burger {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: none; border: none; cursor: pointer;
  padding: 8px;
}
.nav__burger span { width: 24px; height: 2px; background: var(--vt-ink); transition: transform var(--vt-dur-base) var(--vt-ease), opacity var(--vt-dur-fast); }
.nav__burger.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav__burger.is-open span:nth-child(2) { opacity: 0; }
.nav__burger.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

.mobile-menu {
  position: fixed; inset: 0; z-index: 99;
  background: var(--vt-paper);
  display: flex; flex-direction: column; justify-content: flex-start;
  padding: 100px var(--vt-gutter) 40px;
  gap: .5rem;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  transform: translateY(-100%);
  transition: transform var(--vt-dur-slow) var(--vt-ease);
}
.mobile-menu.is-open { transform: translateY(0); }
.mobile-menu a {
  font-family: var(--vt-font-display);
  font-size: clamp(2rem, 9vw, 3rem);
  font-weight: 500;
  letter-spacing: -.03em;
  padding: .3rem 0;
  border-bottom: 1px solid var(--vt-divider);
}
.mobile-menu a .mm-num { font-family: var(--vt-font-mono); font-size: 13px; color: var(--vt-signal); margin-right: 1rem; vertical-align: super; }

/* ============================================================
   HERO
   ============================================================ */
.hero {
  min-height: 100svh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding-top: 110px;
  position: relative;
}
.hero__meta {
  position: absolute;
  top: 96px; right: var(--vt-gutter);
  font-family: var(--vt-font-mono);
  font-size: 11px;
  letter-spacing: .1em;
  color: var(--vt-fg-subtle);
  text-align: right;
  line-height: 1.8;
  text-transform: uppercase;
  white-space: pre-line;
}
.hero__eyebrow { margin-bottom: 2.2rem; }

/* two-column hero */
.hero__grid {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: center;
}
.hero__col { min-width: 0; }
.hero__panel { min-width: 0; display: flex; flex-direction: column; gap: .8rem; }
/* Variant-C scenario tabs above the live terminal */
.term-tabs { display: flex; gap: .5rem; }
.term-tab {
  flex: 1; font-family: var(--vt-font-mono); font-size: 11px; letter-spacing: .06em;
  text-transform: uppercase; font-weight: 500; padding: .62rem .5rem; border-radius: 8px;
  border: 1px solid var(--vt-border); background: var(--vt-paper-pure); color: var(--vt-fg-muted);
  cursor: pointer; transition: background .2s var(--vt-ease), color .2s var(--vt-ease), border-color .2s var(--vt-ease);
}
.term-tab:hover { color: var(--vt-ink); border-color: var(--vt-ink); }
.term-tab.is-on { background: var(--vt-ink); color: var(--vt-paper); border-color: var(--vt-ink); }
@media (min-width: 961px) {
  /* Panel oben ausrichten: Oberkante des Terminals auf Höhe der Zeile "Beratung, Schulung" */
  .hero__grid { align-items: start; }
  /* Versatz = Höhe der 1. H1-Zeile (line-height .98 + 2×2px .neg-Padding) minus Tabs (≈37px) + Gap (.8rem) */
  .hero__panel { margin-top: calc(0.98 * clamp(2.5rem, 5.4vw, 5.4rem) + 4px - 49.5px); }
}
@media (max-width: 960px) {
  /* Hero auf Mobil als eine Flex-Spalte – erlaubt freie Reihenfolge inkl. Stat-Strip */
  .hero { display: flex; flex-direction: column; gap: 1.5rem; }
  .hero__grid { display: contents; }
  .hero__col { display: contents; }
  .hero__panel { max-width: 520px; }

  .hero__meta { order: 1; }
  .hero__grid h1 { order: 2; }
  .hero__lead { order: 3; margin-top: 0; }
  .hero__panel { order: 4; margin-top: 0; }
  .hero__cta { order: 5; margin-top: 0; }
  .cta-meta { order: 6; }
  .stat-strip { order: 7; margin-top: 0; }
  /* Signatur ganz nach unten – unter den 24/7-Stat */
  .hero__sig { order: 8; margin-top: 0; }

  /* "KI" bündig mit den Zeilen darunter (vermeintliches Leerzeichen weg) */
  .hero h1 .neg { margin-left: -17px; }

  /* Team-Fotos auf Mobil direkt in Farbe (kein Hover) */
  .member__photo img { filter: grayscale(0) contrast(1.03); }
}

/* ---------- Live system panel (dark) ---------- */
.term {
  position: relative;
  border: 1px solid rgba(245,244,240,.12);
  background: var(--vt-ink);
  border-radius: 16px;
  box-shadow: 0 30px 70px -32px rgba(14,30,24,.6), 0 1px 0 rgba(245,244,240,.05) inset;
  display: flex;
  flex-direction: column;
  font-family: var(--vt-font-mono);
  overflow: hidden;
  color: var(--vt-paper);
}
.term::before {
  content: "";
  position: absolute; inset: 0 0 auto 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(245,244,240,.22), transparent);
}
.term__bar {
  display: flex; align-items: center; justify-content: space-between;
  padding: .9rem 1.1rem;
  border-bottom: 1px solid rgba(245,244,240,.1);
}
.term__id { font-size: 12px; letter-spacing: .05em; color: rgba(245,244,240,.85); display: flex; align-items: center; gap: .6rem; }
.term__glyph {
  display: inline-grid; place-items: center;
  width: 22px; height: 22px; border-radius: 6px;
  background: rgba(31,138,91,.16); color: var(--vt-signal);
  border: 1px solid rgba(31,138,91,.38);
  font-weight: 700; font-size: 10px; letter-spacing: 0;
}
.term__status {
  font-size: 10px; letter-spacing: .16em; color: var(--vt-signal);
  display: flex; align-items: center; gap: .45rem;
  background: rgba(31,138,91,.12);
  border: 1px solid rgba(31,138,91,.3);
  padding: .28rem .6rem; border-radius: 999px;
}
.term__pulse { width: 6px; height: 6px; border-radius: 50%; background: var(--vt-signal); position: relative; }
.term__pulse::after { content: ""; position: absolute; inset: -4px; border-radius: 50%; border: 1px solid var(--vt-signal); animation: termPulse 1.8s ease-out infinite; }
@keyframes termPulse { 0% { transform: scale(.5); opacity: .9; } 100% { transform: scale(1.7); opacity: 0; } }

.term__body {
  position: relative;
  padding: 1.3rem 1.25rem 1.15rem;
  font-size: 12.5px;
  line-height: 1.4;
  min-height: 244px;
  display: flex; flex-direction: column;
  gap: .8rem;
}
/* pipeline track */
.term__body::before {
  content: "";
  position: absolute;
  left: calc(1.25rem + 8px);
  top: 1.5rem; bottom: 1.35rem;
  width: 1px;
  background: rgba(245,244,240,.1);
}
.term__line {
  display: grid;
  grid-template-columns: 16px auto 1fr;
  gap: .7rem;
  align-items: baseline;
  position: relative;
  opacity: 0; transform: translateY(4px);
}
.term__line.show { opacity: 1; transform: none; transition: opacity .3s ease, transform .3s ease; }
.term__node {
  position: relative;
  width: 9px; height: 9px; margin-top: .25rem;
  border-radius: 50%;
  border: 1px solid rgba(245,244,240,.4);
  background: var(--vt-ink);
  justify-self: center;
}
.term__line.is-cmd .term__node { background: var(--vt-signal); border-color: var(--vt-signal); box-shadow: 0 0 0 3px rgba(31,138,91,.18); }
.term__line.is-done .term__node { background: var(--vt-signal); border-color: var(--vt-signal); box-shadow: 0 0 0 3px rgba(31,138,91,.18); }
.term__t { color: rgba(245,244,240,.4); font-size: 10.5px; letter-spacing: .02em; }
.term__txt { color: rgba(245,244,240,.6); }
.term__line.is-cmd .term__txt { color: var(--vt-paper); font-weight: 500; }
.term__line.is-cmd .term__t { color: var(--vt-signal); }
.term__txt b { color: var(--vt-paper); font-weight: 600; }
.term__ok {
  color: var(--vt-signal); font-weight: 600;
  display: inline-flex; align-items: center; justify-content: center;
  width: 15px; height: 15px; margin-left: .35rem;
  border-radius: 4px; background: rgba(31,138,91,.16);
  border: 1px solid rgba(31,138,91,.35);
  font-size: 10px; vertical-align: middle;
}
.term__line.is-done .term__txt { color: var(--vt-paper); }

.term__foot {
  display: flex; align-items: center; justify-content: space-between;
  padding: .8rem 1.1rem;
  border-top: 1px solid rgba(245,244,240,.1);
  font-size: 10px; letter-spacing: .12em;
}
.term__metric {
  color: var(--vt-signal); font-weight: 600;
  background: rgba(31,138,91,.12);
  border: 1px solid rgba(31,138,91,.28);
  padding: .32rem .65rem; border-radius: 999px;
}
.term__live { color: rgba(245,244,240,.4); display: flex; align-items: center; gap: .4rem; }
.term__live::first-letter { color: var(--vt-signal); }

/* busy state — line "arbeitet" with pulsing dots before it resolves */
.term__line.is-busy .term__txt { color: rgba(245,244,240,.42); }
.term__line.is-busy .term__node { border-color: rgba(79,190,134,.7); }
.term__line.is-busy .term__node::after {
  content: ""; position: absolute; inset: -4px; border-radius: 50%;
  border: 1px solid rgba(79,190,134,.6);
  animation: termPulse 1.1s ease-out infinite;
}
.term__dots { display: inline-flex; gap: 3px; margin-left: .4rem; vertical-align: middle; }
.term__dots i { width: 3px; height: 3px; border-radius: 50%; background: rgba(245,244,240,.55); animation: termDot 1s ease-in-out infinite; }
.term__dots i:nth-child(2) { animation-delay: .18s; }
.term__dots i:nth-child(3) { animation-delay: .36s; }
@keyframes termDot { 0%, 100% { opacity: .15; } 50% { opacity: 1; } }
@media (prefers-reduced-motion: reduce) {
  .term__dots i, .term__line.is-busy .term__node::after { animation: none; }
}

/* result card — fills the bottom of the panel with the outcome */
.term__result {
  margin-top: auto; position: relative; z-index: 1;
  display: flex; align-items: baseline; gap: .9rem;
  border: 1px solid rgba(31,138,91,.34);
  background: rgba(31,138,91,.09);
  border-radius: 10px; padding: .85rem 1rem;
  opacity: 0; transform: translateY(8px);
}
.term__result.show { opacity: 1; transform: none; transition: opacity .45s var(--vt-ease), transform .45s var(--vt-ease); }
.term__result-big {
  font-family: var(--vt-font-display); font-weight: 600;
  font-size: 1.5rem; letter-spacing: -.02em; line-height: 1;
  color: #4FBE86; white-space: nowrap;
}
.term__result-sub { font-size: 11px; line-height: 1.45; letter-spacing: .02em; color: rgba(245,244,240,.58); }
.hero h1 {
  font-family: var(--vt-font-display);
  font-weight: 500;
  font-size: clamp(2.5rem, 5.4vw, 5.4rem);
  line-height: .98;
  letter-spacing: -.035em;
  margin: 0;
  max-width: 18ch;
}
.hero h1 .neg {
  color: var(--vt-paper);
  background: var(--vt-signal);
  padding: .02em .2em;
  border-radius: 5px;
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
}
.hero h1 .aff { color: var(--vt-ink); }
.hero h1 .aff em {
  font-style: normal;
  position: relative;
  white-space: nowrap;
}
.hero h1 .aff em::after {
  content: "";
  position: absolute;
  left: 0; bottom: .08em;
  width: 100%; height: .07em;
  background: var(--vt-signal);
}
.hero__lead { margin-top: 2.4rem; font-size: clamp(1.05rem, 1.6vw, var(--vt-size-md)); max-width: 52ch; color: var(--vt-fg-muted); }
.hero__cta { margin-top: 2.6rem; display: flex; flex-wrap: wrap; gap: 1rem; }

/* hero word reveal */
.reveal-line { overflow: hidden; display: block; }
.reveal-line > span { display: inline-block; }

/* ---------- Stat strip ---------- */
.stat-strip {
  margin-top: clamp(3rem, 7vw, 6rem);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border-top: 1px solid var(--vt-border);
}
.stat {
  padding: 1.6rem 1.4rem 0 0;
  border-left: 1px solid var(--vt-divider);
  padding-left: 1.4rem;
}
.stat:first-child { border-left: 0; padding-left: 0; }
.stat__num {
  font-family: var(--vt-font-display);
  font-weight: 500;
  font-size: clamp(1.8rem, 3.4vw, 3rem);
  line-height: 1;
  letter-spacing: -.03em;
  color: var(--vt-signal);
}
.stat__num .u { color: var(--vt-signal); }
.stat__label {
  margin-top: .7rem;
  font-family: var(--vt-font-sans);
  font-size: var(--vt-size-sm);
  font-weight: 600;
  letter-spacing: -.01em;
  color: var(--vt-fg);
  line-height: 1.3;
}
.stat__detail {
  margin-top: .4rem;
  font-family: var(--vt-font-mono);
  font-size: 10.5px;
  letter-spacing: .02em;
  color: var(--vt-fg-muted);
  line-height: 1.5;
  max-width: 22ch;
}

/* ============================================================
   MARQUEE meta band
   ============================================================ */
.marquee {
  background: var(--vt-ink);
  color: var(--vt-paper);
  overflow: hidden;
  padding-block: 1.5rem;
  white-space: nowrap;
}
.marquee__track {
  display: inline-flex;
  gap: 0;
  flex-wrap: nowrap;
  will-change: transform;
  animation: marqueeFlow 38s linear infinite;
}
.marquee:hover .marquee__track { animation-play-state: paused; }
@keyframes marqueeFlow {
  from { transform: translateX(-50%); }
  to   { transform: translateX(0); }
}
.marquee__track span {
  font-family: var(--vt-font-mono);
  font-size: 13px;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding-inline: 2rem;
  display: inline-flex; align-items: center; gap: 2rem;
  flex: none;
}
.marquee__track span::after {
  content: "";
  width: 4px; height: 4px;
  border-radius: 50%;
  background: rgba(245, 244, 240, .35);
  flex: none;
}

/* ============================================================
   KUNDEN-LOGOS — colored wall
   ============================================================ */
.logos {
  margin-top: clamp(2rem, 4vw, 3rem);
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 1px;
  background: var(--vt-border);
  border: 1px solid var(--vt-border);
}
.logos__cell {
  background: #fff;
  display: grid; place-items: center;
  padding: 1.5rem 1.3rem;
  min-height: 116px;
}
.logos__cell img {
  max-height: 46px;
  max-width: 80%;
  width: auto;
  object-fit: contain;
  opacity: 1;
  transition: transform .3s var(--vt-ease);
}
.logos__cell:hover img { transform: translateY(-2px); }
.logos__cell--dark { background: var(--vt-ink); }
/* fillers keep the mobile 3-col grid's last row white instead of showing the dark hairline backdrop */
.logos__cell--filler { display: none; background: #fff; }
@media (max-width: 1024px) { .logos__cell--filler { display: grid; } }
.logos__cell--stack img { max-height: 76px; max-width: 70%; }
.logos__cell--more span {
  font-family: var(--vt-font-mono);
  font-size: 11px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--vt-fg-subtle);
  text-align: center;
  line-height: 1.5;
}

/* ============================================================
   KI-VORTEILE — benefit grid
   ============================================================ */
.vgrid {
  margin-top: clamp(2.5rem, 5vw, 4rem);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--vt-border);
  border: 1px solid var(--vt-border);
}
.vben {
  background: var(--vt-paper);
  padding: clamp(1.5rem, 2.4vw, 2.2rem);
  display: flex; flex-direction: column; gap: 1rem;
  min-height: 210px;
  transition: background var(--vt-dur-base) var(--vt-ease);
}
.vben:hover { background: var(--vt-paper-pure); }
.vben__check {
  width: 40px; height: 40px;
  border-radius: 9px;
  background: rgba(31,138,91,.1);
  border: 1px solid rgba(31,138,91,.32);
  color: var(--vt-signal);
  display: grid; place-items: center;
  transition: background var(--vt-dur-base) var(--vt-ease), color var(--vt-dur-base);
}
.vben:hover .vben__check { background: var(--vt-signal); color: var(--vt-paper); border-color: var(--vt-signal); }
.vben__check .lucide { width: 20px; height: 20px; stroke-width: 1.6; }
.vben__title { font-family: var(--vt-font-display); font-weight: 500; font-size: var(--vt-size-lg); letter-spacing: -.02em; margin-top: auto; }
.vben__desc { color: var(--vt-fg-muted); font-size: var(--vt-size-sm); line-height: 1.5; }

/* ============================================================
   PROBLEM — indexed list
   ============================================================ */
.idx-list { margin-top: clamp(2.5rem, 5vw, 4rem); border-top: 1px solid var(--vt-border); }
.idx-row {
  display: grid;
  grid-template-columns: 5.5rem 1fr;
  gap: 1.5rem 2rem;
  padding: clamp(1.5rem, 3vw, 2.4rem) 0;
  border-bottom: 1px solid var(--vt-divider);
  align-items: start;
  transition: background var(--vt-dur-base) var(--vt-ease), padding-left var(--vt-dur-base) var(--vt-ease);
}
.idx-row:hover { background: var(--vt-paper-pure); padding-left: 1rem; }
.idx-row__num {
  font-family: var(--vt-font-mono);
  font-size: 1rem;
  color: var(--vt-fg-subtle);
  letter-spacing: .04em;
  padding-top: .35rem;
  transition: color var(--vt-dur-base) var(--vt-ease);
}
.idx-row:hover .idx-row__num { color: var(--vt-signal); }
.idx-row__body { display: grid; grid-template-columns: minmax(0, 26ch) 1fr; gap: 1.5rem 3rem; align-items: baseline; }
.idx-row__title { font-family: var(--vt-font-display); font-weight: 500; font-size: clamp(1.3rem, 2.2vw, var(--vt-size-xl)); letter-spacing: -.02em; line-height: 1.15; }
.idx-row__desc { color: var(--vt-fg-muted); font-size: var(--vt-size-md); max-width: 48ch; }

/* ============================================================
   SERVICES — bento grid
   ============================================================ */
.bento {
  margin-top: clamp(2.5rem, 5vw, 4rem);
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 1px;
  background: var(--vt-border);
  border: 1px solid var(--vt-border);
}
.svc {
  background: var(--vt-paper);
  padding: clamp(1.5rem, 2.4vw, 2.3rem);
  display: flex;
  flex-direction: column;
  gap: 1rem;
  min-height: 230px;
  position: relative;
  overflow: hidden;
  grid-column: span 2;
  transition: background var(--vt-dur-base) var(--vt-ease);
}
.svc:hover { background: var(--vt-paper-pure); }
/* bento rhythm: make a few cards wider */
.svc--wide { grid-column: span 3; }
.svc--feature { grid-column: span 3; }
.svc--full { grid-column: 1 / -1; min-height: 0; }
.svc--full .svc__title { font-size: clamp(1.7rem, 3.6vw, var(--vt-size-2xl)); max-width: 16ch; margin-top: 0; }
.svc--full .svc__desc { max-width: 56ch; font-size: var(--vt-size-md); }
.svc--full .svc__arrow { position: static; opacity: 1; transform: none; }
@media (min-width: 861px) {
  .svc--full { display: grid; grid-template-columns: 1.15fr 1fr; gap: 2.5rem 3rem; align-items: center; padding-block: clamp(2rem, 3.5vw, 3rem); }
  .svc--full .svc__top { grid-column: 1 / -1; }
  .svc--full .svc__cta { display: flex; justify-content: flex-end; }
}
.svc__top { display: flex; align-items: center; justify-content: space-between; }
.svc__num { font-family: var(--vt-font-mono); font-size: 12px; color: var(--vt-fg-subtle); letter-spacing: .08em; }
.svc__icon {
  width: 46px; height: 46px;
  border: 1px solid var(--vt-border);
  border-radius: var(--vt-radius-sm);
  display: grid; place-items: center;
  color: var(--vt-ink);
  transition: background var(--vt-dur-base) var(--vt-ease), color var(--vt-dur-base) var(--vt-ease);
}
.svc__icon .lucide { width: 22px; height: 22px; stroke-width: 1.5; }
.svc:hover .svc__icon { background: var(--vt-signal); color: var(--vt-paper); border-color: var(--vt-signal); }
.svc__title { font-family: var(--vt-font-display); font-weight: 500; font-size: var(--vt-size-lg); letter-spacing: -.02em; line-height: 1.12; margin-top: auto; }
.svc__desc { color: var(--vt-fg-muted); font-size: var(--vt-size-sm); line-height: 1.5; }
.svc__arrow {
  position: absolute;
  bottom: clamp(1.5rem, 2.4vw, 2.3rem);
  right: clamp(1.5rem, 2.4vw, 2.3rem);
  color: var(--vt-fg-subtle);
  opacity: 0;
  cursor: pointer;
  padding: 10px; margin: -10px;
  transform: translate(-6px, 6px);
  transition: opacity var(--vt-dur-base) var(--vt-ease), transform var(--vt-dur-base) var(--vt-ease), color var(--vt-dur-base);
}
.svc__arrow:hover { color: var(--vt-signal); }
@media (hover: none) { .svc__arrow { opacity: .5; transform: none; } }
.svc:hover .svc__arrow { opacity: 1; transform: translate(0,0); color: var(--vt-signal); }
.svc__arrow .lucide { width: 20px; height: 20px; }

/* ============================================================
   ABLAUF — process steps
   ============================================================ */
.flow { list-style: none; margin: clamp(2.5rem, 5vw, 4rem) 0 0; padding: 0; max-width: 60rem; }
.flow__step {
  display: grid;
  grid-template-columns: clamp(58px, 7vw, 74px) 1fr;
  gap: clamp(1rem, 2.6vw, 2.2rem);
  padding-bottom: clamp(1.9rem, 3.6vw, 3rem);
  position: relative;
}
.flow__step:last-child { padding-bottom: 0; }
.flow__rail { position: relative; display: flex; justify-content: center; }
.flow__step:not(:last-child) .flow__rail::before {
  content: "";
  position: absolute;
  top: 25px; bottom: calc(-25px - clamp(1.9rem, 3.6vw, 3rem));
  left: 50%; transform: translateX(-50%);
  width: 1px; background: var(--vt-border);
}
.flow__node {
  position: relative; z-index: 2;
  width: 50px; height: 50px; border-radius: 50%;
  border: 1px solid var(--vt-ink);
  background: var(--vt-paper-pure);
  display: grid; place-items: center;
  font-family: var(--vt-font-display); font-weight: 500;
  font-size: 1.35rem; letter-spacing: -.02em;
  color: var(--vt-signal);
  transition: background var(--vt-dur-base) var(--vt-ease), color var(--vt-dur-base), border-color var(--vt-dur-base);
}
.flow__arrow {
  position: absolute; z-index: 2;
  left: 50%; transform: translateX(-50%);
  bottom: calc(0px - clamp(1.9rem, 3.6vw, 3rem) / 2 - 13px);
  width: 26px; height: 26px; border-radius: 50%;
  background: var(--vt-paper);
  display: grid; place-items: center;
  color: var(--vt-signal);
}
.flow__arrow .lucide { width: 18px; height: 18px; stroke-width: 2; }
.flow__body { padding-top: .35rem; }
.flow__top { display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.flow__title { font-family: var(--vt-font-display); font-weight: 600; font-size: var(--vt-size-lg); letter-spacing: -.01em; line-height: 1.15; }
.flow__icon { flex: none; color: var(--vt-fg-subtle); transition: color var(--vt-dur-base) var(--vt-ease); }
.flow__icon .lucide { width: 26px; height: 26px; stroke-width: 1.5; }
.flow__desc { color: var(--vt-fg-muted); font-size: var(--vt-size-base); margin: .6rem 0 0; max-width: 54ch; line-height: 1.6; }
.flow__step:hover .flow__node { background: var(--vt-signal); color: var(--vt-paper); border-color: var(--vt-signal); }
.flow__step:hover .flow__icon { color: var(--vt-signal); }

/* ============================================================
   INK / quote panels
   ============================================================ */
.ink { background: var(--vt-ink); color: var(--vt-paper); }
.ink .eyebrow { color: var(--vt-fog); }
.ink .eyebrow::before { background: var(--vt-signal); }
.quote-panel { text-align: left; }
.quote-panel blockquote {
  font-family: var(--vt-font-serif);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(1.9rem, 5.2vw, 4.4rem);
  line-height: 1.08;
  letter-spacing: -.01em;
  margin: 0;
  max-width: 20ch;
  color: var(--vt-paper);
}
.quote-panel blockquote .hl { color: var(--vt-signal); font-style: italic; }
.quote-panel .attr {
  margin-top: 2.2rem;
  display: flex; align-items: center; gap: 1rem;
  font-family: var(--vt-font-mono);
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--vt-fog);
}
.quote-panel .attr img { height: 40px; filter: invert(1) brightness(2); opacity: .9; }

/* ---------- Leitsatz — pinned scroll-reveal (line by line) ---------- */
.leit { position: relative; background: var(--vt-ink); color: var(--vt-paper); height: 320vh; }
.leit__sticky { position: sticky; top: 0; height: 100vh; display: flex; align-items: center; overflow: hidden; }
.leit__inner { width: 100%; }
.leit__eyebrow { display: inline-flex; align-items: center; gap: .7rem; color: var(--vt-fog); margin-bottom: clamp(1.6rem, 3vw, 2.6rem); font-family: var(--vt-font-mono); font-size: 11px; font-weight: 500; letter-spacing: .16em; text-transform: uppercase; }
.leit__eyebrow::before { content: ""; width: 26px; height: 1px; background: #5FBF92; }
.leit__quote { font-family: var(--vt-font-serif); font-style: italic; font-weight: 400; font-size: clamp(2.2rem, 6.4vw, 5.4rem); line-height: 1.05; letter-spacing: -.02em; margin: 0; max-width: 24ch; color: var(--vt-paper); }
.leit__line { display: block; }
.leit__quote .hl { color: #5FBF92; font-style: italic; }
.leit__attr { margin-top: clamp(1.8rem, 4vw, 2.8rem); font-family: var(--vt-font-mono); font-size: 12px; letter-spacing: .14em; text-transform: uppercase; color: var(--vt-fog); }
.no-anim .leit { height: auto; }
.no-anim .leit__sticky { position: static; height: auto; min-height: 0; padding-block: clamp(4rem, 10vw, 8rem); }

/* ============================================================
   RESULTS — case studies
   ============================================================ */
.cases { margin-top: clamp(2.5rem, 5vw, 4rem); display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.5rem; }
.case {
  border: 1px solid var(--vt-border);
  background: var(--vt-paper-pure);
  padding: clamp(1.8rem, 3vw, 2.6rem);
  display: flex; flex-direction: column; gap: 1.6rem;
}
.case__head { display: flex; align-items: baseline; justify-content: space-between; gap: 1rem; }
.case__name { font-family: var(--vt-font-display); font-weight: 600; font-size: var(--vt-size-xl); letter-spacing: -.02em; }
.case__tag { font-family: var(--vt-font-mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--vt-fg-muted); }
.case__story { display: grid; gap: 1.1rem; padding-bottom: .2rem; border-bottom: 1px solid var(--vt-divider); }
.case__block { display: grid; gap: .35rem; }
.case__label { font-family: var(--vt-font-mono); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--vt-fg-subtle); }
.case__label--sol { color: var(--vt-signal); }
.case__text { margin: 0; color: var(--vt-fg-muted); font-size: var(--vt-size-sm); line-height: 1.58; }
.case__metrics { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; background: var(--vt-divider); border: 1px solid var(--vt-divider); }
.case__metric { background: var(--vt-paper-pure); padding: 1.2rem 1.2rem; }
.case__metric .v { font-family: var(--vt-font-display); font-weight: 500; font-size: clamp(1.6rem, 3vw, 2.4rem); letter-spacing: -.03em; line-height: 1; }
.case__metric .v .u { color: var(--vt-signal); }
.case__metric .v--green { color: var(--vt-green-head); }
.case__metric .k { margin-top: .5rem; font-family: var(--vt-font-mono); font-size: 11px; letter-spacing: .04em; text-transform: uppercase; color: var(--vt-fg-muted); line-height: 1.4; }

/* ============================================================
   SHOWREEL — video (ink)
   ============================================================ */
.reels { margin-top: clamp(2.5rem, 5vw, 4rem); display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.5rem; }
.reel {
  position: relative;
  aspect-ratio: 16 / 10;
  border: 1px solid rgba(245,244,240,.22);
  background: #111;
  overflow: hidden;
  cursor: pointer;
  display: flex; align-items: flex-end;
  padding: 1.6rem;
}
.reel__bg { position: absolute; inset: 0; background-size: cover; background-position: center; opacity: .42; transition: opacity var(--vt-dur-slow), transform 1.2s var(--vt-ease); }
.reel:hover .reel__bg { opacity: .55; transform: scale(1.04); }
.reel__grad { position: absolute; inset: 0; background: linear-gradient(to top, rgba(10,10,10,.85), rgba(10,10,10,.1)); }
.reel__play {
  position: absolute; top: 1.4rem; right: 1.4rem;
  width: 58px; height: 58px; border-radius: 50%;
  border: 1px solid var(--vt-paper);
  display: grid; place-items: center;
  color: var(--vt-paper);
  transition: background var(--vt-dur-base) var(--vt-ease), color var(--vt-dur-base), transform var(--vt-dur-base);
}
.reel:hover .reel__play { background: var(--vt-signal); border-color: var(--vt-signal); transform: scale(1.06); }
.reel__play .lucide { width: 22px; height: 22px; margin-left: 2px; }
.reel__cap { position: relative; color: var(--vt-paper); }
.reel__cap .t { font-family: var(--vt-font-display); font-weight: 500; font-size: var(--vt-size-lg); letter-spacing: -.02em; }
.reel__cap .m { font-family: var(--vt-font-mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--vt-fog); margin-top: .3rem; }

/* video modal */
.vmodal {
  position: fixed; inset: 0; z-index: 200;
  background: rgba(10,10,10,.92);
  display: none; align-items: center; justify-content: center;
  padding: var(--vt-gutter);
  opacity: 0;
  transition: opacity var(--vt-dur-base) var(--vt-ease);
}
.vmodal.is-open { display: flex; opacity: 1; }
.vmodal__frame { width: min(1100px, 100%); aspect-ratio: 16/9; background: #000; border: 1px solid rgba(245,244,240,.3); }
.vmodal__frame iframe { width: 100%; height: 100%; border: 0; }
.vmodal__close {
  position: absolute; top: 1.5rem; right: 1.5rem;
  background: none; border: 1px solid var(--vt-paper); color: var(--vt-paper);
  width: 46px; height: 46px; border-radius: 50%; cursor: pointer;
  display: grid; place-items: center;
  transition: background var(--vt-dur-base), color var(--vt-dur-base);
}
.vmodal__close:hover { background: var(--vt-signal); border-color: var(--vt-signal); }

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.tgrid { margin-top: clamp(2.5rem, 5vw, 4rem); display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.tcard {
  border: 1px solid var(--vt-border);
  background: var(--vt-paper);
  padding: 1.8rem;
  display: flex; flex-direction: column; gap: 1.4rem;
  transition: background var(--vt-dur-base) var(--vt-ease);
}
.tcard:hover { background: var(--vt-paper-pure); }
.tcard__quote { font-size: var(--vt-size-md); line-height: 1.5; color: var(--vt-fg); display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 4; overflow: hidden; }
.tcard.is-open .tcard__quote { -webkit-line-clamp: unset; overflow: visible; }
.tcard__more { align-self: flex-start; margin-top: -.7rem; background: none; border: 0; padding: 0; cursor: pointer; font-family: var(--vt-font-mono); font-size: 11px; letter-spacing: .08em; text-transform: uppercase; color: var(--vt-signal); transition: color var(--vt-dur-base) var(--vt-ease); }
.tcard__more:hover { text-decoration: underline; text-underline-offset: 3px; }
.tcard__more[hidden] { display: none; }
.tcard__who { display: flex; align-items: center; gap: .9rem; margin-top: auto; }
.tcard__who img { width: 44px; height: 44px; border-radius: 50%; object-fit: cover; filter: grayscale(1) contrast(1.05); }
.tcard__name { font-weight: 600; font-size: var(--vt-size-sm); }
.tcard__role { font-family: var(--vt-font-mono); font-size: 10.5px; letter-spacing: .06em; text-transform: uppercase; color: var(--vt-fg-muted); margin-top: 2px; }

/* Video on case cards */
.case { position: relative; }
.case__video {
  margin-top: auto;
  display: flex; align-items: center; gap: .9rem;
  width: 100%; text-align: left;
  border: 1px solid var(--vt-border);
  background: var(--vt-paper);
  padding: .85rem 1rem;
  font: inherit; color: inherit;
  cursor: default;
  transition: background var(--vt-dur-base) var(--vt-ease), border-color var(--vt-dur-base);
}
.case.has-video .case__video { cursor: pointer; }
.case.has-video .case__video:hover { background: var(--vt-ink); border-color: var(--vt-ink); color: var(--vt-paper); }
.case__vplay {
  flex: none; width: 38px; height: 38px; border-radius: 50%;
  border: 1px solid var(--vt-border);
  display: grid; place-items: center; color: var(--vt-fg-muted);
  transition: background var(--vt-dur-base) var(--vt-ease), border-color var(--vt-dur-base), color var(--vt-dur-base);
}
.case.has-video .case__vplay { color: var(--vt-paper); background: var(--vt-signal); border-color: var(--vt-signal); }
.case__vplay .lucide { width: 17px; height: 17px; margin-left: 1px; }
.case__vmeta { display: flex; flex-direction: column; gap: 1px; min-width: 0; }
.case__vtitle { font-family: var(--vt-font-display); font-weight: 500; font-size: var(--vt-size-base); letter-spacing: -.01em; }
.case:not(.has-video) .case__vtitle { color: var(--vt-fg-muted); }
.case__vsub { font-family: var(--vt-font-mono); font-size: 10px; letter-spacing: .08em; text-transform: uppercase; color: var(--vt-fg-subtle); }
.case.has-video .case__video:hover .case__vsub { color: var(--vt-fog); }
.case:not(.has-video) .case__vsub--live { display: none; }
.case.has-video .case__vsub--soon { display: none; }
.case__varrow { flex: none; margin-left: auto; color: var(--vt-fg-subtle); opacity: 0; transform: translate(-4px,4px); transition: opacity var(--vt-dur-base) var(--vt-ease), transform var(--vt-dur-base), color var(--vt-dur-base); }
.case.has-video .case__video:hover .case__varrow { opacity: 1; transform: translate(0,0); color: var(--vt-paper); }
.case__varrow .lucide { width: 18px; height: 18px; }

/* ============================================================
   TEAM
   ============================================================ */
.team { margin-top: clamp(2.5rem, 5vw, 4rem); display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; }
.member { display: flex; flex-direction: column; gap: 1.1rem; }
.member__photo {
  aspect-ratio: 1;
  border-radius: 50%;
  overflow: hidden;
  background: var(--vt-chalk);
  border: 1px solid var(--vt-divider);
}
.member__photo img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(1) contrast(1.03); transition: filter var(--vt-dur-slow) var(--vt-ease), transform 1s var(--vt-ease); }
.member:hover .member__photo img { filter: grayscale(0); transform: scale(1.03); }
.member__name { font-family: var(--vt-font-display); font-weight: 600; font-size: var(--vt-size-lg); letter-spacing: -.02em; }
.member__role { font-family: var(--vt-font-mono); font-size: 11px; letter-spacing: .08em; text-transform: uppercase; color: var(--vt-signal); margin-top: .2rem; }
.member__quote { color: var(--vt-fg-muted); font-size: var(--vt-size-sm); line-height: 1.5; margin-top: .3rem; }
.member__sig { height: 40px; width: auto; max-width: 160px; object-fit: contain; object-position: left; opacity: .82; margin-top: .9rem; }
.founder__sig { height: 54px; width: auto; max-width: 210px; object-fit: contain; object-position: left; margin-top: 1.5rem; opacity: .92; }

/* ============================================================
   CERT / trust
   ============================================================ */
.cert { display: grid; grid-template-columns: 260px 1fr; gap: clamp(2rem, 5vw, 4rem); align-items: center; }
.cert__badges { display: flex; gap: 1.4rem; align-items: center; flex-wrap: wrap; }
.cert__badges img { width: 118px; height: auto; }
.cert__badge { width: 100%; max-width: 200px; }
.cert__copy h3 { font-family: var(--vt-font-display); font-weight: 500; font-size: clamp(1.6rem, 3vw, var(--vt-size-2xl)); letter-spacing: -.02em; line-height: 1.1; margin: 0 0 1rem; }
.cert__copy p { color: var(--vt-fg-muted); font-size: var(--vt-size-md); max-width: 52ch; }

/* ---------- Founder spotlight ---------- */
.founder { display: grid; grid-template-columns: .76fr 1.24fr; gap: clamp(2rem, 5vw, 4.5rem); align-items: center; }
.founder__photo { aspect-ratio: 4 / 5; border: 1px solid var(--vt-border); overflow: hidden; background: var(--vt-chalk); }
.founder__photo img { width: 100%; height: 100%; object-fit: cover; object-position: center top; filter: grayscale(1) contrast(1.03); transition: filter var(--vt-dur-slow) var(--vt-ease), transform 1s var(--vt-ease); }
.founder:hover .founder__photo img { filter: grayscale(0); transform: scale(1.02); }
.founder__role { font-family: var(--vt-font-mono); font-size: 11px; letter-spacing: .08em; text-transform: uppercase; color: var(--vt-signal); margin-top: .9rem; }
.founder__h { font-family: var(--vt-font-display); font-weight: 500; font-size: clamp(1.9rem, 3.6vw, 3rem); letter-spacing: -.03em; line-height: 1.02; margin: .7rem 0 0; color: var(--vt-ink); }
.founder__h em { font-style: normal; position: relative; white-space: nowrap; }
.founder__h em::after { content: ""; position: absolute; left: 0; bottom: .06em; width: 100%; height: .07em; background: var(--vt-signal); }
.founder__bio { margin: 1.4rem 0 0; max-width: 56ch; }
.founder__bio p { color: var(--vt-fg-muted); font-size: var(--vt-size-md); line-height: 1.65; margin: 0 0 .9rem; }
.founder__bio p:last-child { margin-bottom: 0; }
.founder__stats { margin-top: 2rem; display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid var(--vt-border); }
.fstat { padding: 1.3rem 1.2rem 0 0; border-left: 1px solid var(--vt-divider); padding-left: 1.2rem; }
.fstat:first-child { border-left: 0; padding-left: 0; }
.fstat__n { font-family: var(--vt-font-display); font-weight: 500; font-size: clamp(1.5rem, 3vw, 2.2rem); line-height: 1; letter-spacing: -.03em; color: var(--vt-ink); }
.fstat__n .u { color: var(--vt-signal); }
.fstat__l { margin-top: .5rem; font-family: var(--vt-font-mono); font-size: 10px; letter-spacing: .04em; line-height: 1.5; color: var(--vt-fg-muted); text-transform: uppercase; }
@media (max-width: 820px) { .founder { grid-template-columns: 1fr; gap: 2rem; } .founder__photo { max-width: 320px; } }
@media (max-width: 520px) { .founder__stats { grid-template-columns: 1fr 1fr; gap: 1px; background: var(--vt-divider); border: 0; border-top: 1px solid var(--vt-border); } .fstat { background: var(--vt-paper); border-left: 0; padding: 1.1rem; } }

/* ---------- Qualifications grid ---------- */
.quals { margin-top: clamp(2rem, 4vw, 3rem); display: grid; grid-template-columns: repeat(4, 1fr); gap: .8rem; }
.qual { display: flex; flex-direction: column; gap: .55rem; min-height: 124px; padding: 1.3rem 1.25rem; border: 1px solid var(--vt-border); border-radius: var(--vt-radius-sm); background: var(--vt-paper); transition: background var(--vt-dur-base) var(--vt-ease), transform .12s var(--vt-ease); }
.qual:hover { background: var(--vt-paper-pure); transform: translateY(-2px); }
.qual__issuer { font-family: var(--vt-font-mono); font-size: 10.5px; letter-spacing: .1em; text-transform: uppercase; color: var(--vt-signal); }
.qual__title { font-family: var(--vt-font-display); font-weight: 500; font-size: var(--vt-size-lg); letter-spacing: -.01em; line-height: 1.12; color: var(--vt-ink); margin: auto 0 0; }
.qual__soon { font-family: var(--vt-font-mono); font-size: 9.5px; letter-spacing: .1em; text-transform: uppercase; color: var(--vt-fg-subtle); border: 1px solid var(--vt-divider); border-radius: 999px; padding: .15rem .5rem; align-self: flex-start; }
@media (max-width: 900px) { .quals { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 460px) { .quals { grid-template-columns: 1fr; } }

/* merged founder + qualifications — two columns (story left, proof right) */
.fmerge { display: grid; grid-template-columns: 1.08fr .92fr; gap: clamp(2rem, 5vw, 4rem); align-items: start; }
.fmerge__story { display: flex; flex-direction: column; gap: 1.4rem; }
.qpanel { border: 1px solid var(--vt-border); background: var(--vt-paper-pure); padding: clamp(1.6rem, 2.6vw, 2.2rem); }
.qpanel > .eyebrow { color: var(--vt-signal); }
.qpanel__h { font-family: var(--vt-font-display); font-weight: 500; font-size: clamp(1.35rem, 2.2vw, 1.8rem); letter-spacing: -.02em; line-height: 1.08; margin: .7rem 0 .35rem; color: var(--vt-ink); }
.qpanel__p { color: var(--vt-fg-muted); font-size: var(--vt-size-sm); line-height: 1.55; margin: 0; max-width: 40ch; }
.qpanel__badges { display: flex; gap: 1.6rem; align-items: center; margin: 1.5rem 0 0; padding-bottom: 1.4rem; border-bottom: 1px solid var(--vt-border); flex-wrap: wrap; }
.qpanel__badges img { height: 60px; width: auto; }
/* credentials as a clean hairline ledger (not boxed cards) */
.qpanel .quals { display: flex; flex-direction: column; grid-template-columns: none; gap: 0; margin-top: .2rem; }
.qpanel .qual { display: flex; flex-wrap: wrap; align-items: baseline; gap: .35rem 1rem; min-height: 0; padding: .9rem 0; border: 0; border-bottom: 1px solid var(--vt-divider); border-radius: 0; background: transparent; transition: none; }
.qpanel .qual:hover { background: transparent; transform: none; }
.qpanel .qual:last-child { border-bottom: 0; }
.qpanel .qual__title { order: 1; font-family: var(--vt-font-display); font-weight: 500; font-size: var(--vt-size-base); letter-spacing: -.01em; line-height: 1.2; margin: 0; color: var(--vt-ink); }
.qpanel .qual__issuer { order: 2; margin-left: auto; text-align: right; color: var(--vt-signal); white-space: nowrap; }
.qpanel .qual__soon { order: 3; flex-basis: 100%; margin-top: .1rem; }
.qnorms { margin-top: 1.4rem; padding-top: 1.3rem; border-top: 1px solid var(--vt-border); }
.qnorms__label { font-family: var(--vt-font-mono); font-size: 10.5px; letter-spacing: .1em; text-transform: uppercase; color: var(--vt-fg-muted); }
.qnorms__list { display: flex; flex-wrap: wrap; gap: .5rem; margin-top: .8rem; }
.qnorm { font-family: var(--vt-font-mono); font-size: 11px; letter-spacing: .02em; color: var(--vt-fg); border: 1px solid var(--vt-border); border-radius: 999px; padding: .34rem .75rem; }
@media (max-width: 900px) { .fmerge { grid-template-columns: 1fr; gap: 2rem; } }
@media (max-width: 460px) { .qpanel .quals { grid-template-columns: 1fr; } }

/* ============================================================
   FAQ
   ============================================================ */
.faq { margin-top: clamp(2.5rem, 5vw, 4rem); border-top: 1px solid var(--vt-border); }
.faq__item { border-bottom: 1px solid var(--vt-divider); }
.faq__q {
  width: 100%; background: none; border: 0; cursor: pointer;
  display: flex; align-items: center; gap: 2rem; justify-content: space-between;
  padding: clamp(1.3rem, 2.6vw, 2rem) 0;
  text-align: left;
  font-family: var(--vt-font-display);
  font-weight: 500;
  font-size: clamp(1.15rem, 2vw, var(--vt-size-xl));
  letter-spacing: -.02em;
  color: var(--vt-ink);
}
.faq__icon { flex: none; width: 28px; height: 28px; position: relative; }
.faq__icon::before, .faq__icon::after { content: ""; position: absolute; background: var(--vt-signal); transition: transform var(--vt-dur-base) var(--vt-ease); }
.faq__icon::before { left: 0; top: 50%; width: 100%; height: 2px; transform: translateY(-50%); }
.faq__icon::after { top: 0; left: 50%; height: 100%; width: 2px; transform: translateX(-50%); }
.faq__item.is-open .faq__icon::after { transform: translateX(-50%) scaleY(0); }
.faq__a { overflow: hidden; height: 0; }
.faq__a-inner { padding: 0 0 clamp(1.3rem, 2.6vw, 2rem); color: var(--vt-fg-muted); font-size: var(--vt-size-md); max-width: 66ch; line-height: 1.6; }
.faq__p { margin: 0 0 1.2rem; }
.faq__opts { display: grid; gap: 1px; background: var(--vt-border); border: 1px solid var(--vt-border); margin: 0 0 1.2rem; }
.faq__opt { background: var(--vt-paper); display: grid; grid-template-columns: minmax(88px, auto) 1fr; gap: 1.4rem; padding: 1rem 1.2rem; align-items: baseline; }
.faq__opt-tag { font-family: var(--vt-font-mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--vt-signal); white-space: nowrap; }
.faq__opt-body { color: var(--vt-fg-muted); }
.faq__opt-body strong { color: var(--vt-fg); font-weight: 600; }
.faq__note { margin: 0; padding-left: 1rem; border-left: 2px solid var(--vt-signal); color: var(--vt-fg); }

/* categorised FAQ groups */
.faq-cats { margin-top: clamp(2.5rem, 5vw, 4rem); }
.faq-group { display: grid; grid-template-columns: .42fr 1.58fr; gap: clamp(1.2rem, 4vw, 3rem); padding: clamp(1.6rem, 3vw, 2.4rem) 0; border-top: 1px solid var(--vt-border); }
.faq-group:last-child { border-bottom: 1px solid var(--vt-border); }
@media (max-width: 760px) { .faq-group { grid-template-columns: 1fr; gap: .8rem; } }
.faq-group__num { font-family: var(--vt-font-mono); font-size: 12px; letter-spacing: .1em; color: var(--vt-signal); }
.faq-group__name { font-family: var(--vt-font-display); font-weight: 500; font-size: clamp(1.2rem, 2.2vw, 1.55rem); letter-spacing: -.02em; line-height: 1.1; margin-top: .4rem; color: var(--vt-ink); }
.faq-group__meta { font-family: var(--vt-font-mono); font-size: 10.5px; letter-spacing: .04em; color: var(--vt-fg-subtle); margin-top: .55rem; }
.faq-group__list .faq__item:first-child { border-top: 1px solid var(--vt-divider); }

/* ============================================================
   CONTACT / CTA
   ============================================================ */
.cta-final h2 {
  font-family: var(--vt-font-display);
  font-weight: 500;
  font-size: clamp(2.4rem, 7vw, 6rem);
  line-height: 1;
  letter-spacing: -.035em;
  margin: 0;
  max-width: 16ch;
  color: var(--vt-paper);
}
.cta-final h2 em { font-style: normal; color: var(--vt-signal); }
.contact-grid { margin-top: clamp(2.5rem, 5vw, 4rem); display: grid; grid-template-columns: 1.4fr 1fr; gap: clamp(2rem, 5vw, 4rem); align-items: end; }
.contact-actions { display: flex; flex-wrap: wrap; gap: 1rem; }
.contact-list { display: grid; gap: 0; border-top: 1px solid rgba(245,244,240,.2); }
.contact-list a, .contact-list div {
  display: flex; align-items: center; gap: 1rem;
  padding: 1.1rem 0;
  border-bottom: 1px solid rgba(245,244,240,.2);
  font-family: var(--vt-font-mono);
  font-size: 13px;
  letter-spacing: .04em;
  color: var(--vt-paper);
}
.contact-list .lucide { width: 18px; height: 18px; color: var(--vt-signal); stroke-width: 1.5; }
.contact-list a:hover { color: var(--vt-fog); }

/* Erwartungs-Klarheit — was im Erstgespräch passiert */
.expect { margin-top: clamp(2.2rem, 4.5vw, 3.4rem); }
.expect__label { font-family: var(--vt-font-mono); font-size: 14px; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; color: var(--vt-fog); margin-bottom: 1.1rem; }
.expect__grid { display: grid; grid-template-columns: repeat(3, 1fr); border-top: 1px solid rgba(245,244,240,.2); }
.expect__step { padding: 1.5rem clamp(1.1rem, 1.8vw, 1.6rem) .2rem clamp(1.5rem, 2.6vw, 2.2rem); border-left: 1px solid rgba(245,244,240,.13); }
.expect__step:first-child { border-left: 0; padding-left: 0; }
.expect__num { font-family: var(--vt-font-mono); font-size: 13px; letter-spacing: .12em; color: #2E9E70; margin-bottom: .85rem; }
.expect__t { font-family: var(--vt-font-display); font-weight: 500; font-size: clamp(1.05rem, 1.7vw, 1.3rem); letter-spacing: -.02em; color: var(--vt-paper); line-height: 1.15; }
.expect__d { margin-top: .55rem; color: rgba(245,244,240,.6); font-size: var(--vt-size-sm); line-height: 1.55; max-width: 32ch; }
@media (max-width: 760px) {
  .expect__grid { grid-template-columns: 1fr; }
  .expect__step { border-right: 0; border-left: 0; border-bottom: 1px solid rgba(245,244,240,.13); padding: 1.2rem 0; }
  .expect__step:last-child { border-bottom: 0; }
  .expect__d { max-width: none; }
}

/* Vertrauens-Zusicherungen unter dem CTA */
.contact-assure { display: flex; flex-wrap: wrap; gap: .6rem 1.5rem; width: 100%; margin-top: .5rem; }
.contact-assure__item { display: inline-flex; align-items: center; gap: .55rem; font-family: var(--vt-font-mono); font-size: 11.5px; letter-spacing: .03em; color: rgba(245,244,240,.66); }
.contact-assure .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--vt-signal); flex: none; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer { background: var(--vt-ink); color: var(--vt-fog); padding-block: clamp(3rem, 6vw, 5rem); border-top: 1px solid rgba(245,244,240,.14); }
.footer__grid {
  display: grid;
  grid-template-columns: 1.1fr 1fr 1.4fr 1.3fr;
  gap: clamp(2rem, 4vw, 3.5rem);
}
.footer__h {
  font-family: var(--vt-font-mono);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--vt-paper);
  margin: 0 0 1.4rem;
  font-weight: 500;
}
.footer__col { display: flex; flex-direction: column; gap: .85rem; }
.footer__col a, .footer__col span { font-size: var(--vt-size-sm); color: var(--vt-fog); }
.footer__col a { display: inline-flex; align-items: center; gap: .5rem; width: fit-content; transition: color var(--vt-dur-base) var(--vt-ease), gap var(--vt-dur-base) var(--vt-ease); }
.footer__col a::before { content: "→"; color: var(--vt-fg-subtle); transition: color var(--vt-dur-base) var(--vt-ease); }
.footer__col a:hover { color: var(--vt-paper); gap: .7rem; }
.footer__col a:hover::before { color: var(--vt-signal); }

.footer__contacts { display: flex; flex-direction: column; gap: 1.2rem; }
.footer__contact { display: flex; gap: .9rem; align-items: flex-start; }
.footer__ci {
  flex: none; width: 36px; height: 36px;
  border: 1px solid rgba(245,244,240,.18);
  border-radius: 8px;
  display: grid; place-items: center;
  color: var(--vt-paper);
}
.footer__ci .lucide { width: 17px; height: 17px; stroke-width: 1.6; }
.footer__ck { font-family: var(--vt-font-mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: var(--vt-fg-subtle); margin-bottom: .25rem; }
.footer__contact a, .footer__contact span { color: var(--vt-paper); font-size: var(--vt-size-sm); }
.footer__contact a::before { content: none; }
.footer__contact a:hover { color: var(--vt-signal); }

.footer__brandcol { display: flex; flex-direction: column; align-items: flex-start; gap: 1.4rem; }
.footer__brandcol .brand img { height: 38px; }
.footer__brandcol .brand__wm { color: var(--vt-paper); }
.footer__tag {
  font-family: var(--vt-font-serif);
  font-style: italic;
  font-size: var(--vt-size-md);
  color: var(--vt-fog);
  border-bottom: 1px solid rgba(245,244,240,.55);
  padding-bottom: 3px;
}
.footer__tag:hover { color: var(--vt-paper); }
.footer__social { display: flex; gap: .7rem; margin-top: .2rem; }
.footer__social a {
  width: 40px; height: 40px;
  border: 1px solid rgba(245,244,240,.18);
  border-radius: 8px;
  display: grid; place-items: center;
  color: var(--vt-fog);
  transition: background var(--vt-dur-base) var(--vt-ease), color var(--vt-dur-base), border-color var(--vt-dur-base);
}
.footer__social a:hover { background: var(--vt-signal); color: var(--vt-paper); border-color: var(--vt-signal); }
.footer__social .lucide { width: 18px; height: 18px; }
.footer__social svg { width: 17px; height: 17px; }

.footer__bottom {
  margin-top: clamp(2.5rem, 5vw, 4rem);
  padding-top: 1.6rem;
  border-top: 1px solid rgba(245,244,240,.1);
  display: flex; flex-direction: column; gap: .4rem;
  text-align: center;
}
.footer__copy { font-family: var(--vt-font-mono); font-size: 11px; letter-spacing: .06em; color: var(--vt-fog); }
.footer__hinweis { font-size: 11.5px; line-height: 1.6; color: var(--vt-steel); max-width: 96ch; margin: 0 auto; }

/* ---------- Footer: light theme (breaks the long black after the CTA) ---------- */
.footer { background: var(--vt-paper); color: var(--vt-fg-muted); border-top: 1px solid var(--vt-border); }
.footer__h { color: var(--vt-fg-subtle); }
.footer__col a, .footer__col span { color: var(--vt-fg-muted); }
.footer__col a::before { color: var(--vt-fg-subtle); }
.footer__col a:hover { color: var(--vt-ink); }
.footer__col a:hover::before { color: var(--vt-signal); }
.footer__ci { border-color: var(--vt-border); color: var(--vt-ink); }
.footer__ck { color: var(--vt-fg-subtle); }
.footer__contact a, .footer__contact span { color: var(--vt-ink); }
.footer__contact a:hover { color: var(--vt-signal); }
.footer__brandcol .brand__wm { color: var(--vt-ink); }
.footer__tag { color: var(--vt-fg-muted); }
.footer__tag:hover { color: var(--vt-ink); }
.footer__social a { border-color: var(--vt-border); color: var(--vt-ink); }
.footer__social a:hover { background: var(--vt-signal); color: var(--vt-paper); border-color: var(--vt-signal); }
.footer__bottom { border-top: 1px solid var(--vt-divider); }
.footer__copy { color: var(--vt-fg-muted); }
.footer__hinweis { color: var(--vt-fg-subtle); }

/* ---------- Über Viktor — dark (continuous black with the Team section) ---------- */
#ueber-viktor.ink .founder__h { color: var(--vt-paper); }
#ueber-viktor.ink .founder__h em { color: var(--vt-paper); }
#ueber-viktor.ink .founder__h em::after { background: #4FBE86; }
#ueber-viktor.ink .founder__role { color: rgba(245,244,240,.62); }
#ueber-viktor.ink .founder__bio p { color: rgba(245,244,240,.72); }
#ueber-viktor.ink .founder__stats { border-top-color: rgba(245,244,240,.2); }
#ueber-viktor.ink .fstat { border-left-color: rgba(245,244,240,.16); }
#ueber-viktor.ink .fstat__n { color: var(--vt-paper); }
#ueber-viktor.ink .fstat__n .u { color: #4FBE86; }
#ueber-viktor.ink .fstat__l { color: rgba(245,244,240,.55); }
@media (max-width: 520px) { #ueber-viktor.ink .fstat { background: transparent; } }

/* Team + Über Viktor read as ONE continuous black region:
   halve the doubled padding at their shared edge + a faint divider */
#team { padding-bottom: clamp(2.6rem, 5vw, 4rem); }
#ueber-viktor.ink { padding-top: clamp(2.8rem, 5.5vw, 4.5rem); border-top: 1px solid rgba(245,244,240,.12); }

/* ============================================================
   SCROLL REVEAL (GSAP sets final; this is fallback initial)
   ============================================================ */
.r { opacity: 0; transform: translateY(26px); }
/* will-change bewusst NICHT global gesetzt — GSAP promotet nur kurz während der Animation.
   (Dauerhaftes will-change auf ~90 Elementen erzeugt sonst ebenso viele GPU-Ebenen -> Scroll-Ruckeln.) */
/* if JS fails / reduced motion, show everything */
.no-anim .r, html:not(.is-ready) .r { opacity: 1; transform: none; }

@media (prefers-reduced-motion: reduce) {
  .r { opacity: 1 !important; transform: none !important; }
  .marquee__track { animation: none !important; }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
  .svc--feature, .svc--wide { grid-column: span 3; }
  .tgrid { grid-template-columns: repeat(2, 1fr); }
  .team { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 1080px) {
  .nav__links { display: none; }
  .nav__cta .btn { display: none; }
  .nav__burger { display: flex; }
}
@media (max-width: 860px) {
  .nav__links { display: none; }
  .nav__cta .btn { display: none; }
  .nav__burger { display: flex; }
  .stat-strip { grid-template-columns: repeat(2, 1fr); }
  .stat { border-left: 0; padding-left: 0; padding-top: 1.6rem; border-top: 1px solid var(--vt-divider); }
  .stat:nth-child(-n+2) { border-top: 0; }
  .bento { grid-template-columns: repeat(2, 1fr); }
  .vgrid { grid-template-columns: repeat(2, 1fr); }
  .logos { grid-template-columns: repeat(3, 1fr); }
  .svc, .svc--wide, .svc--feature { grid-column: span 1; }
  .steps { grid-template-columns: 1fr; }
  .cases, .reels { grid-template-columns: 1fr; }
  .case__metrics { grid-template-columns: repeat(2,1fr); }
  .contact-grid { grid-template-columns: 1fr; align-items: start; }
  .footer__grid { grid-template-columns: 1fr 1fr; gap: 2.5rem 2rem; }
  .footer__brandcol { grid-column: 1 / -1; }
  .idx-row { grid-template-columns: 3.5rem 1fr; }
  .idx-row__body { grid-template-columns: 1fr; gap: .6rem; }
  .hero__meta { display: none; }
}
@media (max-width: 560px) {
  .tgrid { grid-template-columns: 1fr; }
  .term-tab { padding: .85rem .5rem; }
  .team { grid-template-columns: 1fr 1fr; }
  .bento { grid-template-columns: 1fr; }
  .vgrid { grid-template-columns: 1fr; }
  .cert { grid-template-columns: 1fr; text-align: left; }
  .cert__badge { max-width: 140px; }
  .logos { grid-template-columns: repeat(3, 1fr); }
  .footer__grid { grid-template-columns: 1fr; gap: 2.4rem; }
}
@media (max-width: 700px) {
  /* Footer auf Mobil: Meta-Zeile raus + unten Platz, damit die schwebenden
     Buttons (WhatsApp / Sprachassistent) das Logo nicht überdecken */
  .footer__metastrip { display: none; }
  .footer { padding-bottom: 104px; }
}

/* ============================================================
   CTA BAND — inline conversion prompts between sections
   ============================================================ */
.ctaband {
  display: flex; align-items: center; justify-content: space-between;
  gap: clamp(1.5rem, 4vw, 3rem);
  padding-block: clamp(2.2rem, 4.5vw, 3.4rem);
  border-top: 1px solid var(--vt-border);
  /* untere Linie entfernt – der folgende Abschnitt (.section--rule) zeichnet
     bereits seine eigene Trennlinie; sonst entsteht ein Doppelstrich */
}
.ctaband__kick {
  font-family: var(--vt-font-mono); font-size: 11px; font-weight: 500;
  letter-spacing: .16em; text-transform: uppercase; color: var(--vt-signal);
  display: inline-flex; align-items: center; gap: .7rem;
}
.ctaband__kick::before { content: ""; width: 28px; height: 1px; background: var(--vt-signal); }
.ctaband__line {
  font-family: var(--vt-font-display); font-weight: 500;
  font-size: clamp(1.35rem, 2.8vw, 2.1rem); letter-spacing: -.02em;
  line-height: 1.12; margin: .8rem 0 0; max-width: 32ch; color: var(--vt-ink);
}
.ctaband .btn { flex: none; }
@media (max-width: 680px) {
  .ctaband { flex-direction: column; align-items: flex-start; gap: 1.5rem; }
}

/* ============================================================
   VERDICT — the turning-point statement before the final CTA
   (deliberately distinct from the ink serif Leitsatz:
    paper ground, left-aligned display sans, outlined contrast)
   ============================================================ */
.verdict { border-top: 1px solid var(--vt-border); }
.verdict__inner { max-width: 66rem; }
.verdict__eyebrow {
  font-family: var(--vt-font-mono); font-size: 11px; font-weight: 500;
  letter-spacing: .16em; text-transform: uppercase; color: var(--vt-signal);
  display: inline-flex; align-items: center; gap: .7rem;
}
.verdict__eyebrow::before { content: ""; width: 28px; height: 1px; background: var(--vt-signal); }
.verdict__statement {
  font-family: var(--vt-font-display); font-weight: 500;
  font-size: clamp(2.1rem, 6vw, 4.6rem); line-height: 1.03;
  letter-spacing: -.03em; margin: clamp(1.8rem, 3.4vw, 2.6rem) 0 0;
  max-width: 16ch;
}
.verdict__lead { display: block; color: var(--vt-fg-subtle); }
.verdict__turn { display: block; color: var(--vt-ink); margin-top: .1em; }
.verdict__you { color: var(--vt-signal); position: relative; }
.verdict__you::before {
  content: ""; position: absolute; left: -.03em; right: -.03em; bottom: .04em; height: .12em;
  background: var(--vt-signal); transform: scaleX(0); transform-origin: left;
  transition: transform 1s cubic-bezier(.2,.7,.2,1) .15s;
}
.verdict.is-in .verdict__you::before { transform: scaleX(1); }
.verdict__or {
  color: var(--vt-paper);
  -webkit-text-stroke: 1.4px var(--vt-concrete);
  text-stroke: 1.4px var(--vt-concrete);
}
@supports not ((-webkit-text-stroke: 1px black) or (text-stroke: 1px black)) {
  .verdict__or { color: var(--vt-fog); }
}
.verdict__cta { margin-top: clamp(2.2rem, 4vw, 3.2rem); }

/* contact positioning kicker */
.cta-final__lead {
  margin-top: clamp(1.2rem, 2vw, 1.6rem); max-width: 44ch;
  color: rgba(245, 244, 240, .72); font-size: var(--vt-size-md); line-height: 1.6;
}

/* ============================================================
   WHATSAPP FLOATING BUTTON (sits above the ElevenLabs widget)
   ============================================================ */
.wa-fab {
  position: fixed;
  left: 22px; bottom: 22px;
  z-index: 2147483000;
  width: 56px; height: 56px;
  border-radius: 50%;
  background: #25D366; color: #fff;
  display: grid; place-items: center;
  box-shadow: 0 6px 20px -8px rgba(10,10,10,.45);
  transition: transform var(--vt-dur-base) var(--vt-ease), background var(--vt-dur-base) var(--vt-ease), box-shadow var(--vt-dur-base);
}
.wa-fab:hover { transform: scale(1.06); background: #1ebe5b; box-shadow: 0 10px 26px -8px rgba(10,10,10,.5); }
.wa-fab:active { transform: scale(.97); }
.wa-fab:focus-visible { outline: 2px solid var(--vt-ink); outline-offset: 2px; }
.wa-fab svg { width: 30px; height: 30px; }
@media (max-width: 560px) {
  .wa-fab { left: 16px; bottom: 16px; width: 52px; height: 52px; }
  .wa-fab svg { width: 27px; height: 27px; }
}
