/* ============================================================
   Enarex — Interaktive Sales-Funnels
   Baut auf site.css (Tokens, .btn, .shot, .eyebrow, .mono, .wrap).
   Operativer B2B-SaaS-Look: dicht, belegt, ohne Marketing-Fluff.
   ============================================================ */

.funnels-body {
  background: var(--dark-canvas);
  color: var(--dark-ink);
  min-height: 100vh;
}

/* ---- Slim Nav (Variante auf dunkel) -------------------------------- */
.fx-nav {
  position: sticky; top: 0; z-index: 60;
  height: 60px; display: flex; align-items: center;
  background: rgba(20,22,27,.86);
  -webkit-backdrop-filter: blur(12px); backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--dark-line);
  color: #fff;
}
.fx-nav .wrap { display: flex; align-items: center; gap: 20px; width: 100%; }
.fx-nav .nav-logo { color: #fff; font-size: 18px; }
.fx-nav .nav-logo .tile { width: 28px; height: 28px; }
.fx-crumb {
  font-family: var(--mono); font-size: 12px; letter-spacing: .04em;
  color: var(--dark-ink-3); display: flex; align-items: center; gap: 9px;
}
.fx-crumb b { color: var(--dark-ink-2); font-weight: 500; }
.fx-crumb .sep { color: var(--dark-line); }
.fx-nav .spacer { margin-left: auto; }
.fx-nav .btn-ghost { border-color: rgba(255,255,255,.22); color: #fff; }
.fx-nav .btn-ghost:hover { border-color: rgba(255,255,255,.5); background: rgba(255,255,255,.06); }

/* ============================================================
   ENTRY SELECTOR — "Was wollen Sie beheben?"
   ============================================================ */
.fx-selector { position: relative; overflow: hidden; padding: calc(var(--nav-h) + 72px) 0 110px; }
.fx-selector::before {
  content: ""; position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);
  background-size: 46px 46px;
  -webkit-mask-image: radial-gradient(ellipse 80% 70% at 50% 0%, #000 35%, transparent 78%);
  mask-image: radial-gradient(ellipse 80% 70% at 50% 0%, #000 35%, transparent 78%);
  pointer-events: none;
}
.fx-selector::after {
  content: ""; position: absolute; left: 50%; top: -160px; transform: translateX(-50%);
  width: 900px; height: 420px; border-radius: 50%;
  background: radial-gradient(closest-side, color-mix(in oklab, var(--accent) 34%, transparent), transparent 72%);
  filter: blur(48px); pointer-events: none;
}
.fx-sel-head { position: relative; z-index: 1; text-align: center; max-width: 760px; margin: 0 auto 52px; }
.fx-sel-head .eyebrow { color: color-mix(in oklab, var(--accent) 48%, #ffffff); }
.fx-sel-head h1 {
  font-size: clamp(34px, 4.4vw, 56px); line-height: 1.05; letter-spacing: -0.032em;
  font-weight: 700; color: #fff; margin: 16px 0 18px; text-wrap: balance;
}
.fx-sel-head p { font-size: 18.5px; color: var(--dark-ink-2); margin: 0 auto; max-width: 600px; text-wrap: pretty; }

.fx-grid {
  position: relative; z-index: 1;
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px;
}
.fx-card {
  position: relative; text-align: left; cursor: pointer;
  background: linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.02));
  border: 1px solid var(--dark-line); border-radius: var(--r-lg);
  padding: 24px 24px 22px; color: var(--dark-ink);
  font-family: var(--font);
  display: flex; flex-direction: column; gap: 14px;
  transition: border-color .2s, transform .2s, box-shadow .2s, background .2s;
}
.fx-card:hover {
  transform: translateY(-3px);
  border-color: color-mix(in oklab, var(--accent) 55%, var(--dark-line));
  background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.025));
  box-shadow: 0 18px 44px -16px rgba(0,0,0,.6);
}
.fx-card .top { display: flex; align-items: center; justify-content: space-between; }
.fx-card .num { font-family: var(--mono); font-size: 12.5px; color: var(--dark-ink-3); letter-spacing: .04em; }
.fx-card .tag {
  font-family: var(--mono); font-size: 10.5px; letter-spacing: .08em; text-transform: uppercase;
  color: color-mix(in oklab, var(--accent) 42%, #ffffff);
  border: 1px solid color-mix(in oklab, var(--accent) 40%, var(--dark-line));
  border-radius: 99px; padding: 3px 9px; background: color-mix(in oklab, var(--accent) 14%, transparent);
}
.fx-card .ic {
  width: 42px; height: 42px; border-radius: 11px;
  background: color-mix(in oklab, var(--accent) 22%, transparent);
  color: color-mix(in oklab, var(--accent) 35%, #ffffff);
  display: grid; place-items: center;
}
.fx-card h3 { font-size: 18.5px; line-height: 1.25; letter-spacing: -0.018em; margin: 0; color: #fff; text-wrap: pretty; }
.fx-card p { font-size: 14.5px; line-height: 1.5; color: var(--dark-ink-3); margin: 0; flex: 1; }
.fx-card .go {
  display: inline-flex; align-items: center; gap: 7px;
  font-size: 13.5px; font-weight: 600; color: color-mix(in oklab, var(--accent) 40%, #ffffff);
  margin-top: 2px;
}
.fx-card .go .arr { transition: transform .2s; }
.fx-card:hover .go .arr { transform: translateX(4px); }

.fx-sel-foot {
  position: relative; z-index: 1; text-align: center; margin-top: 40px;
  font-size: 14px; color: var(--dark-ink-3);
}
.fx-sel-foot a { color: var(--dark-ink-2); text-decoration: underline; text-underline-offset: 3px; }

/* ============================================================
   FUNNEL VIEW
   ============================================================ */
.fx-funnel { display: none; background: var(--surface); color: var(--ink); }
.fx-funnel.active { display: block; }
body.in-funnel { background: var(--surface); }

/* Funnel header band (dark) */
.fx-fhead { background: var(--dark-canvas); color: #fff; position: relative; overflow: hidden; }
.fx-fhead::after {
  content: ""; position: absolute; right: -160px; top: -180px;
  width: 540px; height: 540px; border-radius: 50%;
  background: radial-gradient(closest-side, color-mix(in oklab, var(--accent) 24%, transparent), transparent 72%);
  filter: blur(34px); pointer-events: none;
}
.fx-fhead .wrap { position: relative; z-index: 1; padding: calc(var(--nav-h) + 30px) 28px 38px; }
.fx-back {
  display: inline-flex; align-items: center; gap: 8px;
  background: none; border: 0; cursor: pointer; font-family: var(--font);
  font-size: 13.5px; font-weight: 500; color: var(--dark-ink-2);
  padding: 0; margin-bottom: 22px; transition: color .15s;
}
.fx-back:hover { color: #fff; }
.fx-back .arr { transition: transform .15s; }
.fx-back:hover .arr { transform: translateX(-3px); }
.fx-fhead .eyebrow { color: color-mix(in oklab, var(--accent) 46%, #ffffff); }
.fx-fhead h2 {
  font-size: clamp(28px, 3.4vw, 42px); line-height: 1.08; letter-spacing: -0.03em;
  font-weight: 700; color: #fff; margin: 12px 0 16px; max-width: 760px; text-wrap: balance;
}
.fx-personas { display: flex; flex-wrap: wrap; gap: 9px; }
.fx-personas .p {
  font-size: 13px; color: var(--dark-ink-2);
  border: 1px solid var(--dark-line); border-radius: 99px; padding: 5px 13px;
  background: rgba(255,255,255,.03);
}

/* Body grid: side rail + content */
.fx-body { display: grid; grid-template-columns: 232px 1fr; gap: 0; }

/* ---- Side rail (sticky progress) ---------------------------------- */
.fx-rail { border-right: 1px solid var(--line); background: var(--surface-2); }
.fx-rail-inner { position: sticky; top: var(--nav-h); padding: 34px 26px 34px 28px; }
.fx-rail .lab { font-family: var(--mono); font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: var(--ink-4); margin: 0 0 20px; }
.fx-stages { list-style: none; margin: 0 0 26px; padding: 0; position: relative; }
.fx-stages::before {
  content: ""; position: absolute; left: 9px; top: 10px; bottom: 14px; width: 2px;
  background: var(--line-strong);
}
.fx-stage {
  position: relative; padding: 0 0 22px 30px; cursor: pointer;
  font-size: 14px; font-weight: 500; color: var(--ink-3);
  transition: color .2s;
}
.fx-stage:last-child { padding-bottom: 0; }
.fx-stage .dot {
  position: absolute; left: 2px; top: 2px; width: 16px; height: 16px; border-radius: 50%;
  background: var(--surface); border: 2px solid var(--line-strong); z-index: 1;
  transition: border-color .2s, background .2s, box-shadow .2s;
}
.fx-stage.done .dot { background: var(--accent); border-color: var(--accent); }
.fx-stage.active { color: var(--ink); font-weight: 600; }
.fx-stage.active .dot { border-color: var(--accent); box-shadow: 0 0 0 4px var(--accent-weak); }
.fx-stage small { display: block; font-size: 11.5px; font-weight: 400; color: var(--ink-4); margin-top: 1px; }

.fx-rail .rail-cta { display: grid; gap: 9px; }
.fx-rail .rail-cta .btn { width: 100%; font-size: 14px; padding: 11px 16px; }
.fx-rail .switch {
  background: none; border: 0; cursor: pointer; font-family: var(--font);
  font-size: 13px; color: var(--ink-3); padding: 4px 0; text-align: left;
  text-decoration: underline; text-underline-offset: 3px; transition: color .15s;
}
.fx-rail .switch:hover { color: var(--accent); }

/* ---- Content column ----------------------------------------------- */
.fx-content { min-width: 0; }
.fx-sec { padding: 56px 56px; border-bottom: 1px solid var(--line); scroll-margin-top: 72px; }
.fx-sec:last-child { border-bottom: 0; }
.fx-sec.tint { background: var(--surface-2); }
.fx-kicker {
  font-family: var(--mono); font-size: 12px; letter-spacing: .12em; text-transform: uppercase;
  font-weight: 500; color: var(--accent); display: inline-flex; align-items: center; gap: 9px;
}
.fx-kicker .n { color: var(--ink-4); }
.fx-sec h3 {
  font-size: clamp(24px, 2.4vw, 31px); line-height: 1.14; letter-spacing: -0.025em;
  font-weight: 700; margin: 14px 0 14px; text-wrap: pretty; max-width: 720px;
}
.fx-sec .lede { font-size: 17.5px; line-height: 1.55; color: var(--ink-2); margin: 0; max-width: 660px; text-wrap: pretty; }

/* Problem — pain points */
.fx-points { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin: 30px 0 0; }
.fx-point {
  display: flex; gap: 13px; padding: 18px 20px;
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-md);
}
.fx-funnel .fx-sec.tint .fx-point { background: var(--surface); }
.fx-point .mk {
  flex: none; width: 26px; height: 26px; border-radius: 7px;
  background: var(--accent-weak); color: var(--accent);
  display: grid; place-items: center; font-family: var(--mono); font-size: 12px; font-weight: 600;
}
.fx-point p { margin: 0; font-size: 14.5px; line-height: 1.5; color: var(--ink-2); }
.fx-point b { color: var(--ink); font-weight: 600; }

/* What goes wrong — failure grid */
.fx-wrong { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin: 30px 0 0; }
.fx-wrong .row {
  display: flex; gap: 15px; align-items: flex-start;
  background: var(--surface); border: 1px solid var(--line); border-left: 3px solid var(--risk);
  border-radius: var(--r-md); padding: 17px 20px;
}
.fx-wrong .ico {
  flex: none; width: 30px; height: 30px; border-radius: 8px; margin-top: 1px;
  background: color-mix(in oklab, var(--risk) 12%, #ffffff); color: var(--risk);
  display: grid; place-items: center;
}
.fx-wrong h4 { margin: 0 0 4px; font-size: 15.5px; letter-spacing: -0.01em; }
.fx-wrong p { margin: 0; font-size: 14px; color: var(--ink-3); line-height: 1.5; }

/* Workflow steps */
.fx-flow { display: grid; gap: 0; margin: 32px 0 0; }
.fx-workflow-journey {
  display: grid;
  grid-template-columns: minmax(0, .95fr) minmax(360px, 1fr);
  gap: 38px;
  align-items: start;
  margin: 32px 0 0;
}
.fx-workflow-journey .fx-flow { margin: 0; }
.fx-flow .step {
  display: grid; grid-template-columns: 56px 1fr; gap: 18px;
  padding: 0 0 26px; position: relative;
  transition: opacity .2s;
}
.fx-flow .step:last-child { padding-bottom: 0; }
.fx-flow .step::before {
  content: ""; position: absolute; left: 19px; top: 40px; bottom: 0; width: 2px; background: var(--line);
}
.fx-flow .step:last-child::before { display: none; }
.fx-flow .num {
  width: 40px; height: 40px; border-radius: 10px; z-index: 1;
  background: var(--accent); color: #fff;
  display: grid; place-items: center; font-family: var(--mono); font-weight: 600; font-size: 15px;
  transition: background .2s, box-shadow .2s, color .2s;
}
.fx-flow .step.s-soft .num { background: var(--accent-weak2); color: var(--accent-deep); }
.fx-flow .step.active .num {
  background: var(--accent);
  color: #fff;
  box-shadow: 0 0 0 5px var(--accent-weak);
}
.fx-flow .step.active .bd {
  background: var(--surface-2);
  border-color: var(--accent-line);
}
.fx-flow .bd { padding-top: 7px; }
.fx-workflow-journey .fx-flow .bd {
  border: 1px solid transparent;
  border-radius: var(--r-md);
  padding: 14px 16px 16px;
  margin: -7px 0 0 -16px;
  transition: border-color .2s, background .2s;
}
.fx-flow h4 { margin: 0 0 5px; font-size: 17px; letter-spacing: -0.015em; }
.fx-flow p { margin: 0; font-size: 14.5px; color: var(--ink-3); line-height: 1.5; max-width: 560px; }
.fx-flow .tagrow { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 9px; }
.fx-flow .ref {
  font-family: var(--mono); font-size: 11px; color: var(--ink-2);
  background: var(--surface-3); border: 1px solid var(--line); border-radius: 5px; padding: 2px 8px;
}
.fx-flow-visual {
  min-width: 0;
  align-self: stretch;
}
.fx-flow-sticky {
  position: sticky;
  top: 88px;
}
.fx-wf-shot {
  display: none;
}
.fx-wf-shot.active {
  display: block;
  animation: fxWfIn .2s ease-out;
}
.fx-wf-shot .mbody {
  aspect-ratio: 16 / 10;
}
.fx-wf-shot figcaption {
  display: flex;
  gap: 9px;
  align-items: flex-start;
  border-top: 1px solid var(--line);
  background: var(--surface);
  padding: 12px 14px;
  font-size: 12.5px;
  color: var(--ink-3);
  line-height: 1.45;
}
.fx-wf-shot figcaption span {
  flex: none;
  font-family: var(--mono);
  font-size: 10.5px;
  color: var(--accent);
  border: 1px solid var(--accent-line);
  border-radius: 4px;
  padding: 1px 6px;
}
@keyframes fxWfIn {
  from { opacity: 0; transform: translateY(6px); }
  to { opacity: 1; transform: translateY(0); }
}

/* ---- Screenshot strip ------------------------------------------------ */
.fx-strip-head { display: flex; align-items: baseline; justify-content: space-between; gap: 16px; margin: 0 0 22px; flex-wrap: wrap; }
.fx-strip-head h4 { margin: 0; font-size: 16px; letter-spacing: -0.01em; }
.fx-strip-head .meta { font-size: 13px; color: var(--ink-4); }
.fx-strip { display: grid; gap: 20px; }
.fx-shotwrap { }
.fx-shotwrap .cap {
  display: flex; gap: 9px; align-items: baseline;
  margin: 11px 2px 0; font-size: 13px; color: var(--ink-3); line-height: 1.45;
}
.fx-shotwrap .cap .ix {
  font-family: var(--mono); font-size: 11px; color: var(--accent);
  border: 1px solid var(--accent-line); border-radius: 4px; padding: 1px 6px; flex: none;
}
.fx-strip.two { grid-template-columns: 1fr 1fr; }

/* Browser frame for real workspace screenshots and compact fallback mockups */
.mock {
  border-radius: 10px; overflow: hidden;
  background: var(--surface); border: 1px solid var(--line-strong);
  box-shadow: var(--shadow-pop);
}
.mock .mbar {
  display: flex; align-items: center; gap: 6px; height: 30px; padding: 0 12px;
  background: var(--surface-2); border-bottom: 1px solid var(--line);
}
.mock .mbar i { width: 8px; height: 8px; border-radius: 50%; background: var(--line-strong); }
.mock .mbar .u {
  margin-left: 8px; font-family: var(--mono); font-size: 10.5px; color: var(--ink-4);
  background: var(--surface-3); border-radius: 5px; padding: 2px 10px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.mock .mbody { padding: 16px; }
.mock.real .mbody {
  padding: 0;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: var(--surface-3);
}
.mock.real img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top left;
  cursor: zoom-in;
}

/* ---- Screenshot lightbox ------------------------------------------ */
.fx-lightbox {
  position: fixed;
  inset: 0;
  z-index: 90;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 4vh 4vw;
  background: rgba(15,17,22,.9);
  -webkit-backdrop-filter: blur(6px);
  backdrop-filter: blur(6px);
  cursor: zoom-out;
}
.fx-lightbox.open { display: flex; }
.fx-lightbox img {
  max-width: 100%;
  max-height: 100%;
  border-radius: 10px;
  box-shadow: var(--shadow-shot);
  background: var(--surface);
}
.fx-lightbox-close {
  position: absolute;
  top: 18px;
  right: 18px;
  width: 38px;
  height: 38px;
  border: 1px solid rgba(255,255,255,.2);
  border-radius: 99px;
  background: rgba(20,22,27,.72);
  color: #fff;
  font-size: 24px;
  line-height: 1;
  cursor: pointer;
}
.fx-lightbox-close:hover { background: rgba(255,255,255,.12); }
body.fx-lightbox-open { overflow: hidden; }

@media (max-width: 680px) {
  .fx-lightbox { padding: 68px 14px 18px; }
  .fx-lightbox-close { top: 14px; right: 14px; }
}

/* generic mockup primitives */
.mk-top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.mk-title { font-size: 13.5px; font-weight: 700; letter-spacing: -0.01em; display: flex; align-items: center; gap: 8px; }
.mk-title .k { font-family: var(--mono); font-size: 9.5px; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-4); font-weight: 500; display: block; margin-bottom: 2px; }
.mk-kpis { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; margin-bottom: 14px; }
.mk-kpi { border: 1px solid var(--line); border-radius: 7px; padding: 9px 11px; background: var(--surface); }
.mk-kpi .l { font-family: var(--mono); font-size: 8.5px; letter-spacing: .07em; text-transform: uppercase; color: var(--ink-4); display: flex; gap: 5px; align-items: center; margin-bottom: 5px; }
.mk-kpi .v { font-family: var(--mono); font-size: 19px; font-weight: 600; letter-spacing: -0.02em; line-height: 1; color: var(--ink); }
.mk-kpi .v.accent { color: var(--accent); }
.mk-kpi .v.risk { color: var(--risk); }
.mk-kpi .v.ok { color: var(--ok); }
.mk-kpi .v.warn { color: var(--warn); }
.mk-kpi .s { font-size: 9.5px; color: var(--ink-4); margin-top: 4px; }

.mk-rows { display: grid; gap: 7px; }
.mk-row {
  display: flex; align-items: center; gap: 10px;
  border: 1px solid var(--line); border-left-width: 3px; border-radius: 7px;
  padding: 9px 12px; background: var(--surface);
}
.mk-row.l-risk { border-left-color: var(--risk); }
.mk-row.l-warn { border-left-color: var(--warn); }
.mk-row.l-ok { border-left-color: var(--ok); }
.mk-row.l-acc { border-left-color: var(--accent); }
.mk-ico {
  flex: none; width: 24px; height: 24px; border-radius: 6px; display: grid; place-items: center;
  background: var(--surface-3); color: var(--ink-3); font-size: 11px;
}
.mk-row .tx { flex: 1; min-width: 0; }
.mk-row .tx .t { font-size: 12px; font-weight: 600; color: var(--ink); letter-spacing: -0.005em; }
.mk-row .tx .d { font-size: 10.5px; color: var(--ink-4); margin-top: 1px; }
.mk-row .act {
  font-family: var(--mono); font-size: 10px; color: var(--ink-2);
  border: 1px solid var(--line-strong); border-radius: 5px; padding: 3px 9px; flex: none;
}
.mk-pill {
  font-family: var(--mono); font-size: 9px; letter-spacing: .04em; text-transform: uppercase;
  border-radius: 99px; padding: 2px 8px; flex: none; font-weight: 600;
}
.mk-pill.ok { background: var(--ok-weak); color: var(--ok); }
.mk-pill.risk { background: color-mix(in oklab, var(--risk) 13%, #fff); color: var(--risk); }
.mk-pill.warn { background: color-mix(in oklab, var(--warn) 15%, #fff); color: var(--warn); }
.mk-pill.acc { background: var(--accent-weak2); color: var(--accent-deep); }
.mk-pill.muted { background: var(--surface-3); color: var(--ink-3); }

/* tabs inside mockup */
.mk-tabs { display: flex; gap: 4px; margin-bottom: 13px; flex-wrap: wrap; }
.mk-tab {
  font-size: 10.5px; font-weight: 500; color: var(--ink-3);
  border: 1px solid var(--line); border-radius: 6px; padding: 4px 10px; background: var(--surface);
}
.mk-tab.on { background: var(--accent); border-color: var(--accent); color: #fff; }

/* bar list (cost-style) */
.mk-bars { display: grid; gap: 11px; }
.mk-bar .top { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 5px; }
.mk-bar .nm { font-size: 11.5px; color: var(--ink-2); display: flex; align-items: center; gap: 7px; }
.mk-bar .nm i { width: 8px; height: 8px; border-radius: 2px; background: var(--accent); flex: none; }
.mk-bar .val { font-family: var(--mono); font-size: 11.5px; font-weight: 600; color: var(--ink); }
.mk-bar .track { height: 6px; border-radius: 3px; background: var(--surface-3); overflow: hidden; }
.mk-bar .fill { height: 100%; border-radius: 3px; background: var(--accent); }

/* journey timeline */
.mk-jy { display: flex; align-items: flex-start; gap: 0; }
.mk-jy .node { flex: 1; text-align: center; position: relative; padding-top: 22px; }
.mk-jy .node::before {
  content: ""; position: absolute; top: 6px; left: 50%; right: -50%; height: 2px; background: var(--line-strong);
}
.mk-jy .node:last-child::before { display: none; }
.mk-jy .node .pt {
  position: absolute; top: 0; left: 50%; transform: translateX(-50%);
  width: 13px; height: 13px; border-radius: 50%; background: var(--surface); border: 2px solid var(--line-strong); z-index: 1;
}
.mk-jy .node.done .pt { background: var(--accent); border-color: var(--accent); }
.mk-jy .node.done::before { background: var(--accent); }
.mk-jy .node.now .pt { background: #fff; border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-weak); }
.mk-jy .node .dt { font-family: var(--mono); font-size: 8.5px; color: var(--ink-4); }
.mk-jy .node .nm { font-size: 10px; font-weight: 600; color: var(--ink); line-height: 1.2; margin-top: 2px; }

/* option comparison (path eval sliders) */
.mk-opts { display: grid; gap: 9px; }
.mk-opt { border: 1px solid var(--line); border-radius: 8px; padding: 11px 13px; background: var(--surface); }
.mk-opt.win { border-color: var(--accent-line); background: var(--accent-weak); box-shadow: 0 0 0 2px var(--accent-weak2); }
.mk-opt .oh { display: flex; align-items: center; justify-content: space-between; margin-bottom: 8px; }
.mk-opt .on { font-size: 12px; font-weight: 600; color: var(--ink); }
.mk-opt .sc { font-family: var(--mono); font-size: 12.5px; font-weight: 600; color: var(--ink-3); }
.mk-opt.win .sc { color: var(--accent); }
.mk-opt .seg { display: flex; gap: 3px; }
.mk-opt .seg i { height: 5px; flex: 1; border-radius: 2px; background: var(--surface-3); }
.mk-opt .seg i.on { background: var(--accent); }
.mk-opt .seg i.mid { background: var(--accent-line); }

/* decision detail */
.mk-dec .dh { display: flex; align-items: center; gap: 8px; margin-bottom: 10px; }
.mk-dec .id { font-family: var(--mono); font-size: 11px; font-weight: 600; color: var(--accent); }
.mk-dec .ti { font-size: 13px; font-weight: 700; letter-spacing: -0.01em; line-height: 1.25; margin: 0 0 10px; }
.mk-meta { display: grid; gap: 6px; margin-bottom: 11px; }
.mk-meta .m { display: flex; justify-content: space-between; font-size: 11px; padding: 5px 0; border-bottom: 1px dashed var(--line); }
.mk-meta .m .k { color: var(--ink-4); font-family: var(--mono); font-size: 10px; letter-spacing: .04em; text-transform: uppercase; }
.mk-meta .m .v { color: var(--ink); font-weight: 500; }
.mk-evi { display: grid; gap: 5px; }
.mk-evi .e { display: flex; gap: 8px; align-items: center; font-size: 11px; color: var(--ink-2); }
.mk-evi .e svg { flex: none; color: var(--ok); }

/* matrix / register table */
.mk-table { width: 100%; border-collapse: collapse; }
.mk-table th { text-align: left; font-family: var(--mono); font-size: 8.5px; letter-spacing: .07em; text-transform: uppercase; color: var(--ink-4); font-weight: 500; padding: 0 8px 8px; border-bottom: 1px solid var(--line); }
.mk-table td { font-size: 11px; color: var(--ink-2); padding: 8px; border-bottom: 1px solid var(--line); vertical-align: middle; }
.mk-table tr:last-child td { border-bottom: 0; }
.mk-table td .id { font-family: var(--mono); font-weight: 600; color: var(--ink); font-size: 10.5px; }
.mk-table td .nm { font-weight: 600; color: var(--ink); }

/* kanban / board columns */
.mk-board { display: grid; grid-template-columns: repeat(3, 1fr); gap: 9px; }
.mk-col .ch { font-family: var(--mono); font-size: 9px; letter-spacing: .06em; text-transform: uppercase; color: var(--ink-4); margin-bottom: 7px; display: flex; justify-content: space-between; }
.mk-col .ch .ct { background: var(--surface-3); border-radius: 99px; padding: 0 6px; color: var(--ink-3); }
.mk-card2 { background: var(--surface); border: 1px solid var(--line); border-radius: 6px; padding: 8px 9px; margin-bottom: 6px; }
.mk-card2 .t { font-size: 10.5px; font-weight: 600; color: var(--ink); line-height: 1.3; }
.mk-card2 .m { font-family: var(--mono); font-size: 8.5px; color: var(--ink-4); margin-top: 4px; display: flex; justify-content: space-between; }

/* radar / quadrant */
.mk-quad { position: relative; aspect-ratio: 16/10; border: 1px solid var(--line); border-radius: 8px; overflow: hidden; background:
  linear-gradient(90deg, color-mix(in oklab, var(--accent) 5%, #fff) 50%, color-mix(in oklab, var(--ok) 6%, #fff) 50%); }
.mk-quad .gl { position: absolute; background: var(--line); }
.mk-quad .gl.h { left: 0; right: 0; top: 50%; height: 1px; }
.mk-quad .gl.v { top: 0; bottom: 0; left: 50%; width: 1px; }
.mk-quad .bub {
  position: absolute; border-radius: 50%; transform: translate(-50%, -50%);
  display: grid; place-items: center; font-family: var(--mono); font-size: 9px; font-weight: 600; color: #fff;
  border: 1.5px solid #fff;
}
.mk-quad .ql { position: absolute; font-family: var(--mono); font-size: 8px; letter-spacing: .06em; text-transform: uppercase; color: var(--ink-4); }

/* TIME portfolio grid */
.mk-time { display: grid; grid-template-columns: repeat(2,1fr); grid-template-rows: repeat(2,1fr); gap: 6px; aspect-ratio: 3/2; }
.mk-time .q { border-radius: 7px; padding: 9px 10px; border: 1px solid var(--line); position: relative; }
.mk-time .q .ql { font-size: 10px; font-weight: 700; letter-spacing: -0.01em; }
.mk-time .q .qs { font-family: var(--mono); font-size: 8.5px; color: var(--ink-4); }
.mk-time .q .dots { display: flex; flex-wrap: wrap; gap: 4px; margin-top: 8px; }
.mk-time .q .dots i { width: 16px; height: 16px; border-radius: 4px; display: grid; place-items: center; font-family: var(--mono); font-size: 7px; font-weight: 600; color: #fff; }
.mk-time .q.tol { background: color-mix(in oklab, var(--warn) 7%, #fff); }
.mk-time .q.inv { background: color-mix(in oklab, var(--ok) 7%, #fff); }
.mk-time .q.mig { background: color-mix(in oklab, var(--accent) 7%, #fff); }
.mk-time .q.eli { background: color-mix(in oklab, var(--risk) 7%, #fff); }

/* roadmap gantt */
.mk-gantt { display: grid; gap: 7px; }
.mk-gantt .lane { display: grid; grid-template-columns: 92px 1fr; gap: 9px; align-items: center; }
.mk-gantt .ln { font-size: 10.5px; color: var(--ink-2); font-weight: 500; text-align: right; }
.mk-gantt .tr { position: relative; height: 16px; background: var(--surface-3); border-radius: 4px; }
.mk-gantt .seg { position: absolute; top: 0; bottom: 0; border-radius: 4px; display: flex; align-items: center; padding: 0 7px; font-family: var(--mono); font-size: 8px; color: #fff; font-weight: 600; }
.mk-gantt .seg.a { background: var(--accent); }
.mk-gantt .seg.b { background: color-mix(in oklab, var(--accent) 55%, #fff); color: var(--accent-deep); }
.mk-gantt .seg.r { background: var(--risk); }
.mk-gantt .axis { display: grid; grid-template-columns: 92px repeat(4,1fr); gap: 9px; font-family: var(--mono); font-size: 8px; color: var(--ink-4); margin-top: 2px; }
.mk-gantt .axis span:first-child { grid-column: 1; }

/* current vs potential automation */
.mk-cvp { display: grid; gap: 13px; }
.mk-cvp .row { }
.mk-cvp .lab { display: flex; justify-content: space-between; font-size: 11px; margin-bottom: 5px; color: var(--ink-2); }
.mk-cvp .lab b { font-family: var(--mono); }
.mk-cvp .track2 { height: 9px; border-radius: 5px; background: var(--surface-3); position: relative; overflow: hidden; }
.mk-cvp .cur { position: absolute; left: 0; top: 0; bottom: 0; background: var(--accent-line); border-radius: 5px; }
.mk-cvp .pot { position: absolute; left: 0; top: 0; bottom: 0; background: var(--accent); border-radius: 5px; }
.mk-cvp .legend { display: flex; gap: 16px; margin-top: 4px; font-size: 10px; color: var(--ink-4); }
.mk-cvp .legend span { display: flex; align-items: center; gap: 6px; }
.mk-cvp .legend i { width: 10px; height: 8px; border-radius: 2px; }

/* attestation donut + list */
.mk-attest { display: grid; grid-template-columns: auto 1fr; gap: 16px; align-items: center; }
.mk-donut { width: 92px; height: 92px; border-radius: 50%; display: grid; place-items: center; flex: none; position: relative; }
.mk-donut .hole { width: 58px; height: 58px; border-radius: 50%; background: var(--surface); display: grid; place-items: center; text-align: center; }
.mk-donut .hole b { font-family: var(--mono); font-size: 17px; font-weight: 600; color: var(--ink); display: block; line-height: 1; }
.mk-donut .hole s { font-size: 8px; color: var(--ink-4); text-decoration: none; }
.mk-leg { display: grid; gap: 7px; }
.mk-leg .li { display: flex; align-items: center; gap: 8px; font-size: 11px; color: var(--ink-2); }
.mk-leg .li i { width: 9px; height: 9px; border-radius: 2px; flex: none; }
.mk-leg .li .vv { margin-left: auto; font-family: var(--mono); font-weight: 600; color: var(--ink); }

/* ---- Proof metrics band ------------------------------------------- */
.fx-proof { background: var(--dark-canvas); color: #fff; border-bottom: 1px solid var(--dark-line); }
.fx-proof .inner { padding: 48px 56px; }
.fx-proof .fx-kicker { color: color-mix(in oklab, var(--accent) 46%, #ffffff); }
.fx-proof h3 { color: #fff; }
.fx-proof .lede { color: var(--dark-ink-2); }
.fx-metrics { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin: 28px 0 0; }
.fx-metric { border: 1px solid var(--dark-line); border-radius: var(--r-lg); background: rgba(255,255,255,.025); padding: 22px 20px; }
.fx-metric .v { font-family: var(--mono); font-size: clamp(24px, 2.3vw, 31px); font-weight: 600; letter-spacing: -0.02em; color: #fff; line-height: 1.1; display: block; }
.fx-metric .v em { font-style: normal; color: color-mix(in oklab, var(--accent) 42%, #ffffff); }
.fx-metric .l { font-size: 13px; color: var(--dark-ink-3); line-height: 1.45; display: block; margin-top: 8px; }

/* ---- Before / With comparison ------------------------------------- */
.fx-compare { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin: 30px 0 0; }
.fx-col { border-radius: var(--r-lg); border: 1px solid var(--line); overflow: hidden; }
.fx-col .ch { padding: 15px 22px; font-size: 13px; font-weight: 700; letter-spacing: .02em; display: flex; align-items: center; gap: 9px; }
.fx-col.before .ch { background: var(--surface-3); color: var(--ink-2); }
.fx-col.after .ch { background: var(--accent); color: #fff; }
.fx-col .ch .tg { font-family: var(--mono); font-size: 10px; font-weight: 500; letter-spacing: .06em; text-transform: uppercase; opacity: .8; margin-left: auto; }
.fx-col ul { list-style: none; margin: 0; padding: 8px 22px 18px; display: grid; gap: 1px; }
.fx-col li { display: flex; gap: 11px; padding: 11px 0; font-size: 14px; line-height: 1.45; color: var(--ink-2); border-bottom: 1px solid var(--line); }
.fx-col li:last-child { border-bottom: 0; }
.fx-col li .ic { flex: none; margin-top: 2px; }
.fx-col.before { background: var(--surface); }
.fx-col.before li .ic { color: var(--risk); }
.fx-col.after { background: var(--surface); }
.fx-col.after li .ic { color: var(--ok); }
.fx-col.after li b { color: var(--ink); font-weight: 600; }

/* ---- Tailored CTA ------------------------------------------------- */
.fx-cta { background: var(--surface-2); }
.fx-cta .inner { padding: 56px; display: grid; grid-template-columns: 1.1fr .9fr; gap: 48px; align-items: center; }
.fx-cta h3 { font-size: clamp(25px, 2.6vw, 34px); line-height: 1.1; letter-spacing: -0.025em; margin: 14px 0 14px; text-wrap: balance; }
.fx-cta .lede { margin-bottom: 24px; }
.fx-cta-actions { display: flex; flex-wrap: wrap; gap: 12px; }
.fx-cta .switch2 {
  background: none; border: 0; cursor: pointer; font-family: var(--font);
  font-size: 14px; color: var(--ink-3); padding: 13px 6px; text-decoration: underline; text-underline-offset: 3px;
  transition: color .15s;
}
.fx-cta .switch2:hover { color: var(--accent); }
.fx-cta-card {
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-xl);
  box-shadow: var(--shadow-pop); padding: 26px;
}
.fx-cta-card .ph { font-family: var(--mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-4); margin: 0 0 14px; }
.fx-cta-card .deliv { display: grid; gap: 11px; }
.fx-cta-card .deliv li { display: flex; gap: 11px; font-size: 14px; color: var(--ink-2); line-height: 1.45; }
.fx-cta-card .deliv li svg { flex: none; margin-top: 3px; color: var(--accent); }
.fx-cta-card .foot { margin: 18px 0 0; padding-top: 16px; border-top: 1px solid var(--line); font-size: 12.5px; color: var(--ink-4); }

/* ============================================================
   CROSS-PATH — "Ein Modell verbindet diese Workflows"
   ============================================================ */
.fx-mesh { background: var(--dark-canvas); color: #fff; padding: 96px 0; position: relative; overflow: hidden; }
.fx-mesh::after {
  content: ""; position: absolute; left: 50%; bottom: -200px; transform: translateX(-50%);
  width: 880px; height: 460px; border-radius: 50%;
  background: radial-gradient(closest-side, color-mix(in oklab, var(--accent) 26%, transparent), transparent 72%);
  filter: blur(46px); pointer-events: none;
}
.fx-mesh .wrap { position: relative; z-index: 1; }
.fx-mesh-head { text-align: center; max-width: 720px; margin: 0 auto 52px; }
.fx-mesh-head .eyebrow { color: color-mix(in oklab, var(--accent) 46%, #ffffff); }
.fx-mesh-head h2 { font-size: clamp(28px, 3.2vw, 40px); line-height: 1.1; letter-spacing: -0.028em; color: #fff; margin: 14px 0 16px; text-wrap: balance; }
.fx-mesh-head p { font-size: 18px; color: var(--dark-ink-2); margin: 0 auto; max-width: 580px; text-wrap: pretty; }
.fx-nodes { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.fx-node {
  border: 1px solid var(--dark-line); border-radius: var(--r-lg);
  background: rgba(255,255,255,.03); padding: 20px 20px;
  transition: border-color .2s, background .2s, transform .2s; cursor: pointer;
}
.fx-node:hover { border-color: color-mix(in oklab, var(--accent) 50%, var(--dark-line)); background: rgba(255,255,255,.055); transform: translateY(-2px); }
.fx-node .ni {
  width: 38px; height: 38px; border-radius: 10px; margin-bottom: 14px;
  background: color-mix(in oklab, var(--accent) 20%, transparent); color: color-mix(in oklab, var(--accent) 38%, #ffffff);
  display: grid; place-items: center;
}
.fx-node h4 { margin: 0 0 5px; font-size: 15px; color: #fff; letter-spacing: -0.01em; }
.fx-node p { margin: 0; font-size: 12.5px; color: var(--dark-ink-3); line-height: 1.45; }
.fx-mesh-foot { text-align: center; margin-top: 44px; display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }

/* ---- Footer (reuse marketing footer look) -------------------------- */
.fx-foot { background: #0f1115; color: var(--dark-ink-3); padding: 40px 0; font-size: 13.5px; border-top: 1px solid var(--dark-line); }
.fx-foot .wrap { display: flex; align-items: center; justify-content: space-between; gap: 20px; flex-wrap: wrap; }
.fx-foot .nav-logo { color: #fff; font-size: 16px; }
.fx-foot .links { display: flex; gap: 22px; }
.fx-foot a { text-decoration: none; transition: color .15s; }
.fx-foot a:hover { color: #fff; }

/* ---- Cards: visible by default; lift on hover only (no timeline-gated entrance) ---- */

/* ---- Responsive --------------------------------------------------- */
@media (max-width: 1040px) {
  .fx-grid { grid-template-columns: 1fr 1fr; }
  .fx-body { grid-template-columns: 1fr; }
  .fx-rail { border-right: 0; border-bottom: 1px solid var(--line); }
  .fx-rail-inner { position: static; padding: 22px 28px; }
  .fx-stages { display: flex; flex-wrap: wrap; gap: 6px 18px; margin-bottom: 18px; }
  .fx-stages::before { display: none; }
  .fx-stage { padding: 0 0 0 24px; }
  .fx-stage small { display: none; }
  .fx-rail .rail-cta { grid-auto-flow: column; }
  .fx-sec, .fx-proof .inner, .fx-cta .inner, .fx-strip.two { padding-left: 28px; padding-right: 28px; }
  .fx-strip.two { grid-template-columns: 1fr; }
  .fx-workflow-journey { grid-template-columns: 1fr; gap: 26px; }
  .fx-flow-visual { order: -1; }
  .fx-flow-sticky { position: static; }
  .fx-cta .inner { grid-template-columns: 1fr; gap: 32px; padding: 44px 28px; }
  .fx-nodes { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 680px) {
  .fx-nav .wrap { gap: 12px; }
  .fx-nav .btn-ghost, .fx-crumb { display: none !important; }
  .fx-nav .btn-sm { padding: 8px 12px; font-size: 13px; }
  .fx-grid, .fx-points, .fx-wrong, .fx-compare, .fx-metrics, .fx-nodes, .mk-board { grid-template-columns: 1fr; }
  .fx-metrics { grid-template-columns: 1fr 1fr; }
  .fx-sec { padding: 40px 20px; }
  .fx-workflow-journey .fx-flow .bd { margin-left: -10px; padding: 12px 12px 14px; }
  .fx-wf-shot figcaption { font-size: 12px; }
  .mk-kpis { grid-template-columns: 1fr 1fr; }
}
