/* =======================================================================
   Viktor Torno AI Consulting — Leistungen (Voll-Katalog)
   Loads AFTER colors_and_type.css and vt-pages.css.
   ======================================================================= */

/* intro lead under the hero headline */
.lv-intro {
  font-family: var(--vt-font-sans);
  font-size: clamp(16px, 1.6vw, 19px);
  line-height: 1.6;
  color: var(--vt-fg-muted);
  max-width: 54ch;
  margin: 26px 0 0;
}

/* category kicker shown in the left tag column */
.vt-section-tag .kick {
  display: block;
  margin-top: 8px;
  font-family: var(--vt-font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--vt-fog);
  line-height: 1.4;
}

/* service rows — engineering spec list */
.lv-list { margin-top: 2px; }
.lv-item {
  display: grid;
  grid-template-columns: minmax(180px, 15rem) 1fr;
  gap: 6px 44px;
  padding: 17px 0;
  border-top: 1px solid var(--vt-divider);
  align-items: baseline;
}
.lv-item:first-child { border-top: none; padding-top: 2px; }
.lv-item__name {
  font-family: var(--vt-font-display);
  font-weight: 600;
  font-size: 17px;
  letter-spacing: -0.01em;
  color: var(--vt-ink);
  line-height: 1.25;
}
.lv-item__desc {
  margin: 0;
  font-size: 14.5px;
  line-height: 1.65;
  color: var(--vt-fg-muted);
  text-wrap: pretty;
}
@media (max-width: 620px) {
  .lv-item { grid-template-columns: 1fr; gap: 3px; }
}

/* ───────────────────── CONTACT / CTA (ink) — mirrors homepage ───────────────────── */
.lv-cta { background: var(--vt-ink); color: var(--vt-paper); }
.lv-cta .vt-wrap {
  padding-top: clamp(56px, 7vw, 92px);
  padding-bottom: clamp(56px, 7vw, 92px);
}
.lv-cta__eyebrow {
  display: inline-flex; align-items: center; gap: .7rem;
  font-family: var(--vt-font-mono); font-size: 12px;
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--vt-fog);
}
.lv-cta__eyebrow::before { content: ""; width: 28px; height: 1px; background: #2E9E70; }
.lv-cta h2 {
  font-family: var(--vt-font-display); font-weight: 500;
  font-size: clamp(34px, 5vw, 64px); letter-spacing: -0.03em; line-height: 1.02;
  margin: 22px 0 0; color: var(--vt-paper);
}
.lv-cta h2 em { font-style: normal; color: #2E9E70; }

/* expect strip */
.lv-expect { margin-top: clamp(2.2rem, 4.5vw, 3.4rem); }
.lv-expect__label {
  font-family: var(--vt-font-mono); font-size: 11px; letter-spacing: .16em;
  text-transform: uppercase; color: var(--vt-fog); margin-bottom: 1.1rem;
}
.lv-expect__grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  border-top: 1px solid rgba(245,244,240,.2);
}
.lv-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);
}
.lv-expect__step:first-child { border-left: 0; padding-left: 0; }
.lv-expect__num { font-family: var(--vt-font-mono); font-size: 13px; letter-spacing: .12em; color: #2E9E70; margin-bottom: .85rem; }
.lv-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; }
.lv-expect__d { margin: .55rem 0 0; color: rgba(245,244,240,.6); font-size: 13px; line-height: 1.55; max-width: 32ch; }
@media (max-width: 760px) {
  .lv-expect__grid { grid-template-columns: 1fr; }
  .lv-expect__step { border-left: 0; border-bottom: 1px solid rgba(245,244,240,.13); padding: 1.2rem 0; }
  .lv-expect__step:last-child { border-bottom: 0; }
  .lv-expect__d { max-width: none; }
}

/* actions + contact */
.lv-contact-grid {
  display: grid; grid-template-columns: 1.4fr 1fr;
  gap: clamp(2rem, 5vw, 4rem); align-items: end;
  margin-top: clamp(2.4rem, 5vw, 3.6rem);
}
@media (max-width: 760px) { .lv-contact-grid { grid-template-columns: 1fr; align-items: start; } }
.lv-actions { display: flex; flex-wrap: wrap; gap: 1rem; }
.lv-btn {
  display: inline-flex; align-items: center; gap: .6rem;
  font-family: var(--vt-font-sans); font-weight: 600; font-size: 18px; letter-spacing: -.01em;
  padding: 1.05rem 1.9rem; border-radius: 999px;
  background: var(--vt-ink); color: var(--vt-paper);
  border: 1px solid var(--vt-paper); text-decoration: none;
  position: relative; overflow: hidden; isolation: isolate; cursor: pointer;
  transition: color var(--vt-dur-base) var(--vt-ease), transform var(--vt-dur-fast) var(--vt-ease);
}
.lv-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;
}
.lv-btn:hover::before { transform: translateY(0); }
.lv-btn:hover { color: var(--vt-paper); border-color: var(--vt-signal); }
.lv-btn:active { transform: scale(.98); }
.lv-btn--ghost { background: transparent; }
.lv-btn .arrow { transition: transform var(--vt-dur-base) var(--vt-ease); }
.lv-btn:hover .arrow { transform: translateX(4px); }
.lv-assure { display: flex; flex-wrap: wrap; gap: .6rem 1.5rem; width: 100%; margin-top: .5rem; }
.lv-assure span { 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); }
.lv-assure span::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: #2E9E70; flex: none; }
.lv-info { display: grid; gap: 0; border-top: 1px solid rgba(245,244,240,.2); }
.lv-info a, .lv-info div {
  display: flex; align-items: center; gap: 1rem; padding: 1.1rem 0;
  border-bottom: 1px solid rgba(245,244,240,.12);
  font-family: var(--vt-font-mono); font-size: 14px; letter-spacing: .02em;
  color: var(--vt-paper); text-decoration: none;
}
.lv-info svg { width: 18px; height: 18px; color: #2E9E70; stroke-width: 1.5; flex: none; }
.lv-info a:hover { color: var(--vt-fog); }

/* ───────────────────── HOMEPAGE-MATCHED CHROME ───────────────────── */
/* selection → brand green */
::selection { background: #0F3B2E; color: var(--vt-paper); }

/* nav brand wordmark (1:1 with homepage) */
.vt-brand img { width: auto; height: 30px; }
.vt-brand__wm { font-family: var(--vt-font-display); font-weight: 600; font-size: 1.05rem; letter-spacing: -.02em; line-height: 1; color: var(--vt-ink); }
.vt-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 → green mono, underline accent (1:1 with homepage) */
.vt-navlinks { gap: 1.15rem; }
.vt-navlinks a {
  font-family: var(--vt-font-mono); font-size: 11.5px; font-weight: 500;
  letter-spacing: .06em; text-transform: uppercase; color: #0F3B2E;
  border-bottom: 0; padding: 4px 0; position: relative;
}
.vt-navlinks 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);
}
.vt-navlinks a:hover { color: var(--vt-ink); }
.vt-navlinks a:hover::after, .vt-navlinks a[aria-current="page"]::after { transform: scaleX(1); }

/* "Termin buchen" → rounded pill with green-fill hover (like homepage CTA) */
.vt-nav-cta {
  font-family: var(--vt-font-sans); font-weight: 600; font-size: 13px;
  padding: .65rem 1.2rem; border-radius: 999px;
  background: var(--vt-ink); color: var(--vt-paper); border: 1px solid var(--vt-ink);
  position: relative; overflow: hidden; isolation: isolate;
  transition: color var(--vt-dur-base) var(--vt-ease), border-color var(--vt-dur-base) var(--vt-ease);
}
.vt-nav-cta::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;
}
.vt-nav-cta:hover { background: var(--vt-ink); color: var(--vt-paper); border-color: var(--vt-signal); }
.vt-nav-cta:hover::before { transform: translateY(0); }

/* contact positioning kicker (mirrors homepage) */
.lv-cta__lead { margin: 1.3rem 0 0; max-width: 46ch; color: rgba(245,244,240,.72); font-size: clamp(16px,1.6vw,19px); line-height: 1.6; }
.lv-expect__label { font-size: 14px; font-weight: 700; }

/* footer divider directly under the Kontakt block */
.vt-footer { border-top: 1px solid rgba(245,244,240,.18); }

/* ───────────────────── HERO SYSTEM-MAP (Blueprint, static + pulses) ───────────────────── */
/* give the headline the left half, the map the right */
.vt-hero h1 { font-size: clamp(38px, 5.4vw, 74px); max-width: 56%; }
.lv-intro { max-width: 46ch; }
.lv-hero-map {
  position: absolute; right: 1.5%; top: 50%; transform: translateY(-50%);
  width: min(38%, 440px); aspect-ratio: 1; z-index: 0; pointer-events: none;
  -webkit-mask-image: radial-gradient(130% 100% at 70% 50%, #000 62%, transparent 100%);
  mask-image: radial-gradient(130% 100% at 70% 50%, #000 62%, transparent 100%);
}
.lv-map { width: 100%; height: 100%; display: block; overflow: visible; }
.bp-wire { fill: none; stroke: var(--vt-ink-soft); stroke-width: 1; opacity: .3; transition: stroke .3s, opacity .3s, stroke-width .3s; }
.bp-wire.is-active, .bp-wire.is-hover { stroke: var(--vt-signal); stroke-width: 1.4; opacity: .85; }
.bp-pulse { fill: var(--vt-signal); }
.bp-ring { fill: var(--vt-paper); stroke: var(--vt-ink-soft); stroke-width: 1.3; transition: stroke .25s, stroke-width .25s; }
.bp-core { fill: var(--vt-ink-soft); transition: fill .25s; }
.bp-label { font-family: var(--vt-font-mono); font-size: 11px; letter-spacing: .12em; fill: var(--vt-fg-muted); text-anchor: middle; transition: fill .25s; }
.bp-node--hub rect { fill: var(--vt-ink); stroke: var(--vt-signal); stroke-width: 1.4; transition: stroke-width .3s, filter .3s; }
.bp-anchor { fill: var(--vt-signal); }
.bp-hublabel { font-family: var(--vt-font-display); font-size: 16px; font-weight: 600; letter-spacing: -.01em; fill: var(--vt-paper); text-anchor: middle; }
.bp-hubsub { font-family: var(--vt-font-mono); font-size: 9px; letter-spacing: .14em; fill: #7FD3A6; text-anchor: middle; }

/* interaktive zustände der systemkarte */
.lv-map .bp-node { cursor: pointer; outline: none; transform-box: fill-box; transform-origin: center; transition: transform .25s var(--vt-ease); }
.lv-map .bp-node:hover, .lv-map .bp-node.is-near { transform: scale(1.14); }
.lv-map .bp-node--hub:hover { transform: scale(1.05); }
.lv-map:hover .bp-wire { opacity: .55; }
.lv-map .bp-node:hover .bp-ring, .lv-map .bp-node:focus-visible .bp-ring, .lv-map .bp-node.is-hot .bp-ring, .lv-map .bp-node.is-near .bp-ring { stroke: var(--vt-signal); stroke-width: 2.2; }
.lv-map .bp-node:hover .bp-core, .lv-map .bp-node.is-hot .bp-core, .lv-map .bp-node.is-near .bp-core { fill: var(--vt-signal); }
.lv-map .bp-node:hover .bp-label, .lv-map .bp-node:focus-visible .bp-label, .lv-map .bp-node.is-hot .bp-label, .lv-map .bp-node.is-near .bp-label { fill: var(--vt-signal); }
.lv-map .bp-node--hub:hover rect, .lv-map .bp-node--hub:focus-visible rect, .lv-map.is-thinking .bp-node--hub rect { stroke-width: 2.2; filter: drop-shadow(0 0 12px rgba(31,138,91,.45)); }
.lv-map.is-thinking .bp-hubsub { fill: #2FA56F; }
.bp-result {
  font-family: var(--vt-font-mono); font-size: 10px; letter-spacing: .1em;
  fill: #1F8A5B; text-anchor: middle; text-transform: uppercase;
  opacity: 0; transition: opacity .35s ease;
}
.bp-result.show { opacity: 1; }

/* maus-spiel: cursor-linie, endpunkt & punkte-spur
   (keine opacity-Transition: der rAF-Loop schreibt jeden Frame Attribute,
   was laufende Transitions endlos neu starten würde — Werte stehen sofort) */
.bp-mousewire {
  fill: none; stroke: var(--vt-signal); stroke-width: 1.2;
  stroke-dasharray: 4 5; opacity: 0; transition: none;
}
.lv-map.has-mouse .bp-mousewire { opacity: .75; animation: bpMarch .6s linear infinite; }
@keyframes bpMarch { to { stroke-dashoffset: -9; } }
.bp-mousedot { fill: var(--vt-signal); opacity: 0; transition: none; }
.lv-map.has-mouse .bp-mousedot { opacity: 1; }
.bp-trail { fill: var(--vt-signal); animation: bpTrail .9s ease-out forwards; }
@keyframes bpTrail { from { opacity: .55; } to { opacity: 0; r: 0.4; } }
@media (prefers-reduced-motion: reduce) {
  .lv-map.has-mouse .bp-mousewire { animation: none; }
  .bp-trail { display: none; }
}
@media (prefers-reduced-motion: reduce) { .bp-pulse { display: none; } }
@media (max-width: 860px) { .lv-hero-map { display: none; } }
