/* ==========================================================================
   OMM AI Hub — Landing page styles
   Foundation: tokens.css. This file extends them with marketing-page
   patterns: bigger type, rhythm, sections.
   ========================================================================== */

:root {
  /* Marketing-tuned accents. Default = "royal".
     Switch via [data-accent] on <html> if needed.                 */

  /* Royal — deep saturated indigo-blue with violet undertone. */
  --accent-from: #2a3b8f;
  --accent-to:   #4f63c9;
  --accent-soft: #eef0fb;
  --accent-tint: rgba(42,59,143,.08);
  --accent-line: rgba(42,59,143,.20);

  --warm-cream: #f7f1e3;
  --warm-cream-2: #ede4cc;

  --serif: "Source Serif 4", "Iowan Old Style", Georgia, serif;

  --page-max: 1240px;
  --section-y: clamp(72px, 9vw, 128px);
}

[data-accent="atlantic"] {
  --accent-from: #0d4f6b;
  --accent-to:   #2598b8;
  --accent-soft: #e8f4f8;
  --accent-tint: rgba(13,79,107,.10);
  --accent-line: rgba(13,79,107,.22);
}
[data-accent="slate"] {
  --accent-from: #334155;
  --accent-to:   #5b7290;
  --accent-soft: #eef1f5;
  --accent-tint: rgba(51,65,85,.08);
  --accent-line: rgba(51,65,85,.18);
}
[data-accent="sage"] {
  --accent-from: #2e5d56;
  --accent-to:   #5b9181;
  --accent-soft: #ecf2ef;
  --accent-tint: rgba(46,93,86,.10);
  --accent-line: rgba(46,93,86,.20);
}
[data-accent="bauhaus"] {
  --accent-from: #1f2c54;
  --accent-to:   #c46a4f;
  --accent-soft: #faf0ea;
  --accent-tint: rgba(196,106,79,.10);
  --accent-line: rgba(31,44,84,.18);
}
[data-accent="ink"] {
  --accent-from: #18181b;
  --accent-to:   #3b6cf2;
  --accent-soft: #f0f3fc;
  --accent-tint: rgba(24,24,27,.06);
  --accent-line: rgba(24,24,27,.14);
}

* { box-sizing: border-box; }

html, body {
  margin: 0; padding: 0;
  font-family: var(--omm-font-sans);
  color: var(--omm-fg);
  background: #ffffff;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

img { max-width: 100%; display: block; }

a { color: inherit; text-decoration: none; }

/* ============================================================
   LANGUAGE TOGGLE — render both languages, show one
   ============================================================ */
html[data-lang="de"] [data-lang-content="en"],
html:not([data-lang="en"]) [data-lang-content="en"] { display: none; }
html[data-lang="en"] [data-lang-content="de"] { display: none; }

/* ============================================================
   PAGE SHELL
   ============================================================ */

.page {
  min-height: 100vh;
  background:
    radial-gradient(1200px 600px at 85% -100px, var(--accent-soft), transparent 60%),
    radial-gradient(900px 500px at -10% 280px, var(--warm-cream), transparent 55%),
    #ffffff;
  overflow: clip;
}

.container {
  width: 100%;
  max-width: var(--page-max);
  margin: 0 auto;
  padding: 0 clamp(20px, 4vw, 40px);
}

.section {
  padding: var(--section-y) 0;
  position: relative;
}

.section + .section {
  border-top: 1px solid var(--omm-zinc-200);
}

/* ============================================================
   NAV
   ============================================================ */

.nav {
  position: sticky;
  top: 0;
  z-index: 50;
  backdrop-filter: saturate(140%) blur(12px);
  -webkit-backdrop-filter: saturate(140%) blur(12px);
  background: rgba(255,255,255,0.78);
  border-bottom: 1px solid rgba(228,228,231,0.7);
}

.nav-inner {
  display: flex; align-items: center; gap: 24px;
  padding: 14px 0;
}

.brand {
  display: flex; align-items: center; gap: 10px;
  font-family: var(--serif);
  font-size: 22px;
  font-weight: 600;
  color: var(--omm-zinc-900);
  letter-spacing: -0.01em;
}

.brand-mark {
  width: 30px; height: 30px;
  border-radius: 9px;
  background: linear-gradient(135deg, var(--accent-from), var(--accent-to));
  display: inline-flex; align-items: center; justify-content: center;
  color: #fff;
  font-family: var(--serif); font-weight: 700; font-size: 16px;
  letter-spacing: -0.02em;
  box-shadow: 0 4px 12px var(--accent-line);
}

.brand small {
  display: block;
  font-family: var(--omm-font-sans);
  font-size: 11px;
  font-weight: 500;
  color: var(--omm-zinc-500);
  letter-spacing: 0.02em;
  margin-top: -2px;
}

.nav-links {
  display: flex; align-items: center; gap: 4px;
  margin-left: auto;
}

.nav-link {
  padding: 8px 14px;
  font-size: 14px;
  color: var(--omm-zinc-700);
  border-radius: 9999px;
  transition: all 200ms var(--omm-ease-standard);
}
.nav-link:hover { background: var(--omm-zinc-100); color: var(--omm-zinc-900); }

.nav-cta {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 16px;
  font-size: 14px;
  font-weight: 500;
  border-radius: 9999px;
  background: var(--omm-zinc-900);
  color: #fff;
  transition: all 200ms var(--omm-ease-standard);
}
.nav-cta:hover {
  background: var(--accent-from);
  box-shadow: 0 8px 24px var(--accent-line);
  transform: translateY(-1px);
}
.nav-cta .material-symbols-rounded { font-size: 18px; }

.nav-lang {
  display: inline-flex; align-items: center;
  background: var(--omm-zinc-100);
  border-radius: 9999px;
  padding: 3px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.02em;
}
.nav-lang button {
  border: 0; background: transparent;
  padding: 5px 12px;
  border-radius: 9999px;
  color: var(--omm-zinc-500);
  cursor: pointer;
  font: inherit;
  transition: all 180ms var(--omm-ease-standard);
}
.nav-lang button.active {
  background: #fff;
  color: var(--omm-zinc-900);
  box-shadow: var(--omm-shadow-sm);
}

/* ============================================================
   HERO
   ============================================================ */

.hero {
  padding: clamp(56px, 8vw, 96px) 0 clamp(48px, 7vw, 80px);
  position: relative;
}

.hero-eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 14px 6px 6px;
  border-radius: 9999px;
  background: rgba(255,255,255,0.7);
  border: 1px solid var(--omm-zinc-200);
  box-shadow: var(--omm-shadow-card);
  font-size: 13px;
  color: var(--omm-zinc-700);
  margin-bottom: 24px;
}
.hero-eyebrow .pill {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 10px;
  border-radius: 9999px;
  background: linear-gradient(135deg, var(--accent-from), var(--accent-to));
  color: #fff;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.hero h1 {
  font-family: var(--serif);
  font-size: clamp(40px, 5.5vw, 76px);
  font-weight: 600;
  line-height: 1.02;
  letter-spacing: -0.025em;
  color: var(--omm-zinc-900);
  margin: 0 0 24px;
  max-width: 18ch;
  text-wrap: balance;
}
.hero h1 em {
  font-style: italic;
  font-weight: 500;
  background: linear-gradient(110deg, var(--accent-from), var(--accent-to));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.hero-sub {
  font-size: clamp(17px, 1.4vw, 20px);
  line-height: 1.55;
  color: var(--omm-zinc-600);
  max-width: 56ch;
  margin: 0 0 32px;
  text-wrap: pretty;
}

.hero-cta-row {
  display: flex; align-items: center; gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 36px;
}

.btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 13px 22px;
  font-size: 15px;
  font-weight: 500;
  border-radius: 9999px;
  border: 1px solid transparent;
  cursor: pointer;
  font-family: inherit;
  transition: all 200ms var(--omm-ease-standard);
  text-decoration: none;
}
.btn .material-symbols-rounded { font-size: 18px; }

.btn-primary {
  background: var(--omm-zinc-900);
  color: #fff;
  box-shadow: 0 1px 0 rgba(255,255,255,0.1) inset, 0 8px 20px rgba(0,0,0,0.15);
}
.btn-primary:hover {
  background: linear-gradient(135deg, var(--accent-from), var(--accent-to));
  transform: translateY(-1px);
  box-shadow: 0 14px 30px var(--accent-line);
}

.btn-ghost {
  background: rgba(255,255,255,0.6);
  color: var(--omm-zinc-800);
  border-color: var(--omm-zinc-200);
}
.btn-ghost:hover {
  background: #fff;
  border-color: var(--omm-zinc-300);
  transform: translateY(-1px);
}

.hero-trust {
  display: flex; align-items: center; gap: 18px;
  flex-wrap: wrap;
  font-size: 13px;
  color: var(--omm-zinc-600);
}
.hero-trust .item {
  display: inline-flex; align-items: center; gap: 6px;
}
.hero-trust .material-symbols-rounded {
  font-size: 18px;
  color: var(--omm-success);
  background: var(--omm-success-50);
  border-radius: 9999px;
  padding: 2px;
  font-variation-settings: "FILL" 1;
}

/* ============================================================
   HERO VISUAL
   ============================================================ */

.hero-visual {
  position: relative;
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(255,255,255,0.9), rgba(248,244,236,0.6));
  border: 1px solid var(--omm-zinc-200);
  box-shadow:
    0 30px 80px -20px rgba(30,58,138,0.20),
    0 8px 20px -4px rgba(0,0,0,0.05);
  overflow: hidden;
  padding: 18px;
}
.hero-visual::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(600px 300px at 80% 0%, var(--accent-tint), transparent 70%),
    radial-gradient(400px 200px at 0% 100%, rgba(201,169,110,0.10), transparent 60%);
  pointer-events: none;
}

.hero-grid {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: clamp(32px, 5vw, 64px);
  align-items: center;
}

@media (max-width: 980px) {
  .hero-grid { grid-template-columns: 1fr; }
}

/* ============================================================
   SECTION HEADERS
   ============================================================ */

.section-eyebrow {
  display: inline-block;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--accent-from);
  margin-bottom: 14px;
}

.section-title {
  font-family: var(--serif);
  font-size: clamp(32px, 4vw, 52px);
  font-weight: 600;
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: var(--omm-zinc-900);
  margin: 0 0 20px;
  text-wrap: balance;
  max-width: 22ch;
}

.section-sub {
  font-size: clamp(16px, 1.2vw, 19px);
  line-height: 1.6;
  color: var(--omm-zinc-600);
  max-width: 60ch;
  margin: 0;
}

.section-head {
  margin-bottom: clamp(40px, 5vw, 64px);
}

.section-head.center {
  text-align: center;
}
.section-head.center .section-title,
.section-head.center .section-sub { margin-left: auto; margin-right: auto; }

/* ============================================================
   TOOLS — focus layout (conversion-optimized, default)
   ============================================================ */

.tools-section {
  padding-top: clamp(80px, 10vw, 140px);
  padding-bottom: clamp(80px, 10vw, 140px);
  position: relative;
  overflow: hidden;
}
.tools-section::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(900px 500px at 90% 12%, color-mix(in oklch, var(--accent-from) 8%, transparent), transparent 60%),
    radial-gradient(700px 420px at 5% 95%, color-mix(in oklch, var(--accent-from) 5%, transparent), transparent 65%);
  pointer-events: none;
  z-index: 0;
}
.tools-section > .container { position: relative; z-index: 1; }

/* Reveal-on-scroll */
.reveal {
  opacity: 0;
  transform: translateY(14px);
  transition:
    opacity 700ms var(--omm-ease-standard) var(--reveal-delay, 0ms),
    transform 700ms var(--omm-ease-standard) var(--reveal-delay, 0ms);
  will-change: opacity, transform;
}
.reveal.is-revealed {
  opacity: 1;
  transform: translateY(0);
}
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
}

.section-head-narrow {
  max-width: 720px;
  margin-bottom: clamp(56px, 7vw, 96px);
}
.section-head-narrow .section-title {
  font-size: clamp(36px, 5vw, 64px);
  line-height: 1.05;
  letter-spacing: -0.02em;
}
.section-head-narrow .section-eyebrow {
  font-family: var(--omm-font-mono);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--omm-zinc-500);
}

.tools-focus .section-head-narrow .section-title { font-size: clamp(34px, 4.6vw, 56px); }

/* persona tabs */
.focus-personas {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 4px;
  padding: 4px;
  background: var(--omm-zinc-100);
  border: 1px solid var(--omm-zinc-200);
  border-radius: 9999px;
  margin-bottom: clamp(28px, 4vw, 44px);
}
.focus-persona {
  appearance: none;
  border: 0;
  background: transparent;
  font: inherit;
  font-size: 13.5px;
  font-weight: 500;
  letter-spacing: 0;
  color: var(--omm-zinc-600);
  padding: 9px 18px;
  border-radius: 9999px;
  cursor: pointer;
  transition: color 220ms var(--omm-ease-standard), background 220ms var(--omm-ease-standard), box-shadow 280ms var(--omm-ease-standard);
}
.focus-persona:hover { color: var(--omm-zinc-900); }
.focus-persona.is-active {
  background: #fff;
  color: var(--omm-zinc-900);
  box-shadow: 0 1px 2px rgb(0 0 0 / 0.05), 0 4px 14px -8px rgb(0 0 0 / 0.15);
}

/* row list */
.focus-list {
  display: flex;
  flex-direction: column;
  border-top: 1px solid var(--omm-zinc-200);
}
.focus-list-rest { border-top: 0; margin-top: 4px; }

.focus-row {
  position: relative;
  display: grid;
  grid-template-columns: 36px 44px 1fr auto auto;
  align-items: center;
  gap: 24px;
  padding: 22px 8px;
  border-bottom: 1px solid var(--omm-zinc-200);
  transition: background 320ms var(--omm-ease-standard), padding-left 320ms var(--omm-ease-standard);
  text-decoration: none;
  color: inherit;
}
.focus-row::after {
  content: "";
  position: absolute;
  left: 0; bottom: -1px;
  height: 1px; width: 0;
  background: linear-gradient(90deg, var(--accent-from), var(--accent-to));
  transition: width 540ms var(--omm-ease-standard);
}
.focus-row:hover { background: color-mix(in oklch, var(--accent-from) 4%, transparent); padding-left: 16px; }
.focus-row:hover::after { width: 100%; }

@media (max-width: 760px) {
  .focus-row {
    grid-template-columns: 36px 1fr auto;
    grid-template-areas:
      "num   icon  cta"
      "body  body  body"
      "metric metric metric";
    row-gap: 10px;
    padding: 18px 4px;
  }
  .focus-num    { grid-area: num; }
  .focus-icon   { grid-area: icon; justify-self: end; }
  .focus-body   { grid-area: body; }
  .focus-metric { grid-area: metric; justify-self: start; }
  .focus-cta    { grid-area: cta; }
}

.focus-num {
  font-family: var(--omm-font-mono);
  font-size: 12px;
  color: var(--omm-zinc-400);
  letter-spacing: 0.04em;
}
.focus-icon {
  width: 44px; height: 44px;
  border-radius: 12px;
  background: var(--accent-soft);
  color: var(--accent-from);
  display: inline-flex; align-items: center; justify-content: center;
  transition: transform 320ms var(--omm-ease-standard), box-shadow 320ms var(--omm-ease-standard);
}
.focus-icon .material-symbols-rounded { font-size: 22px; font-variation-settings: "FILL" 1; }
.focus-row:hover .focus-icon {
  transform: rotate(-3deg) scale(1.05);
  box-shadow: 0 8px 22px -8px color-mix(in oklch, var(--accent-from) 50%, transparent);
}

.focus-body { min-width: 0; display: flex; flex-direction: column; gap: 4px; }
.focus-outcome {
  font-family: var(--serif);
  font-size: clamp(20px, 2vw, 26px);
  font-weight: 500;
  line-height: 1.18;
  letter-spacing: -0.015em;
  color: var(--omm-zinc-900);
  margin: 0;
  text-wrap: balance;
}
.focus-proof {
  font-family: var(--omm-font-mono);
  font-size: 11.5px;
  letter-spacing: 0.04em;
  color: var(--omm-zinc-500);
}

.focus-metric {
  font-size: 13px;
  font-weight: 600;
  letter-spacing: -0.005em;
  color: var(--accent-from);
  padding: 6px 12px;
  border-radius: 9999px;
  background: var(--accent-soft);
  white-space: nowrap;
}

.focus-cta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 600;
  color: var(--omm-zinc-900);
  padding: 9px 14px;
  border: 1px solid var(--omm-zinc-300);
  border-radius: 9999px;
  text-decoration: none;
  transition: all 280ms var(--omm-ease-standard);
}
.focus-cta .material-symbols-rounded { font-size: 16px; transition: transform 280ms var(--omm-ease-standard); }
.focus-cta:hover {
  background: var(--omm-zinc-900);
  color: #fff;
  border-color: var(--omm-zinc-900);
}
.focus-cta:hover .material-symbols-rounded { transform: translateX(3px); }

.focus-tag {
  position: absolute;
  top: 14px;
  left: 70px;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 9999px;
  background: linear-gradient(135deg, var(--accent-from), var(--accent-to));
  color: #fff;
}

/* "more" toggle */
.focus-more { margin-top: 28px; }
.focus-more-toggle {
  appearance: none;
  width: 100%;
  display: flex;
  align-items: center;
  gap: 16px;
  background: transparent;
  border: 0;
  padding: 14px 0;
  cursor: pointer;
  font: inherit;
}
.focus-more-line {
  flex: 1; height: 1px;
  background: var(--omm-zinc-200);
}
.focus-more-label {
  font-family: var(--omm-font-mono);
  font-size: 12.5px;
  letter-spacing: 0.06em;
  color: var(--omm-zinc-700);
  white-space: nowrap;
  transition: color 240ms var(--omm-ease-standard);
}
.focus-more-chev {
  font-size: 20px;
  color: var(--omm-zinc-500);
  transition: transform 320ms var(--omm-ease-standard), color 240ms var(--omm-ease-standard);
}
.focus-more.is-open .focus-more-chev { transform: rotate(180deg); color: var(--accent-from); }
.focus-more-toggle:hover .focus-more-label { color: var(--accent-from); }
.focus-more-toggle:hover .focus-more-chev { color: var(--accent-from); }

.focus-list-rest { display: none; }
.focus-more.is-open .focus-list-rest { display: flex; }

/* footer CTA */
.focus-foot {
  margin-top: clamp(40px, 6vw, 72px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding-top: 28px;
  border-top: 1px solid var(--omm-zinc-200);
  flex-wrap: wrap;
}
.focus-foot-text {
  font-family: var(--serif);
  font-size: clamp(20px, 2.2vw, 26px);
  font-weight: 500;
  color: var(--omm-zinc-900);
  margin: 0;
  letter-spacing: -0.015em;
}

/* ============================================================
   TRUST / COMPLIANCE BAND
   ============================================================ */

.trust-band {
  background: linear-gradient(180deg, var(--warm-cream) 0%, #fdfaf2 100%);
  border-top: 1px solid var(--omm-zinc-200);
  border-bottom: 1px solid var(--omm-zinc-200);
}

.trust-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  margin-top: 40px;
}
@media (max-width: 980px) {
  .trust-grid { grid-template-columns: repeat(2, 1fr); }
}

.trust-item {
  text-align: left;
}
.trust-item .icon {
  width: 48px; height: 48px;
  border-radius: 14px;
  background: #fff;
  border: 1px solid var(--omm-zinc-200);
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--omm-zinc-900);
  margin-bottom: 14px;
}
.trust-item .icon .material-symbols-rounded { font-size: 22px; }
.trust-item h4 {
  font-family: var(--serif);
  font-size: 19px;
  font-weight: 600;
  letter-spacing: -0.005em;
  color: var(--omm-zinc-900);
  margin: 0 0 6px;
}
.trust-item p {
  font-size: 14px;
  line-height: 1.55;
  color: var(--omm-zinc-600);
  margin: 0;
}

.compliance-badges {
  display: flex; flex-wrap: wrap; gap: 10px;
  margin-top: 28px;
}
.badge {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 14px;
  background: #fff;
  border: 1px solid var(--omm-zinc-200);
  border-radius: 9999px;
  font-size: 13px;
  font-weight: 500;
  color: var(--omm-zinc-700);
  box-shadow: var(--omm-shadow-card);
}
.badge .material-symbols-rounded {
  font-size: 16px;
  color: var(--accent-from);
  font-variation-settings: "FILL" 1;
}

/* ============================================================
   USE CASES
   ============================================================ */

.usecase-tabs {
  display: inline-flex;
  background: #fff;
  border: 1px solid var(--omm-zinc-200);
  border-radius: 9999px;
  padding: 4px;
  gap: 2px;
  margin-bottom: 32px;
  box-shadow: var(--omm-shadow-card);
}
.usecase-tabs button {
  padding: 9px 18px;
  border-radius: 9999px;
  border: 0;
  background: transparent;
  font: inherit;
  font-size: 14px;
  font-weight: 500;
  color: var(--omm-zinc-600);
  cursor: pointer;
  transition: all 200ms var(--omm-ease-standard);
}
.usecase-tabs button.active {
  background: var(--omm-zinc-900);
  color: #fff;
}

.usecase-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
@media (max-width: 900px) { .usecase-grid { grid-template-columns: 1fr; } }

.usecase {
  background: #fff;
  border: 1px solid var(--omm-zinc-200);
  border-radius: 18px;
  padding: 26px;
  transition: all 250ms var(--omm-ease-standard);
}
.usecase:hover {
  border-color: var(--accent-line);
  box-shadow: 0 16px 32px -16px var(--accent-line);
  transform: translateY(-2px);
}
.usecase .role {
  display: inline-block;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent-from);
  margin-bottom: 8px;
}
.usecase h4 {
  font-family: var(--serif);
  font-size: 20px;
  font-weight: 600;
  letter-spacing: -0.005em;
  color: var(--omm-zinc-900);
  margin: 0 0 10px;
}
.usecase p {
  font-size: 14px;
  line-height: 1.6;
  color: var(--omm-zinc-600);
  margin: 0 0 16px;
}
.usecase .stat {
  display: flex; align-items: baseline; gap: 6px;
  padding-top: 14px;
  border-top: 1px solid var(--omm-zinc-200);
}
.usecase .stat .num {
  font-family: var(--serif);
  font-size: 28px;
  font-weight: 700;
  background: linear-gradient(135deg, var(--accent-from), var(--accent-to));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  letter-spacing: -0.02em;
}
.usecase .stat .label {
  font-size: 12px;
  color: var(--omm-zinc-500);
}

/* ============================================================
   OFFICE PLUGIN STRIP
   ============================================================ */

.plugins {
  background: linear-gradient(135deg, #f8fafc 0%, #ffffff 50%, var(--accent-soft) 100%);
  border: 1px solid var(--omm-zinc-200);
  border-radius: 28px;
  padding: clamp(40px, 5vw, 64px);
  margin-top: 40px;
}
.plugins-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(32px, 4vw, 56px);
  align-items: center;
}
@media (max-width: 900px) { .plugins-grid { grid-template-columns: 1fr; } }

.plugins-icons {
  display: flex; gap: 12px; margin-top: 18px; margin-bottom: 24px;
  flex-wrap: wrap;
}
.plugin-chip {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 14px;
  background: #fff;
  border: 1px solid var(--omm-zinc-200);
  border-radius: 9999px;
  font-size: 13px;
  font-weight: 500;
  color: var(--omm-zinc-800);
  box-shadow: var(--omm-shadow-card);
}
.plugin-chip .dot {
  width: 18px; height: 18px;
  border-radius: 4px;
  display: inline-flex; align-items: center; justify-content: center;
  color: #fff;
  font-size: 11px;
  font-weight: 700;
}
.plugin-chip.word .dot   { background: #2b579a; }
.plugin-chip.excel .dot  { background: #217346; }
.plugin-chip.ppt .dot    { background: #b7472a; }

/* ============================================================
   PRICING
   ============================================================ */

.pricing-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
@media (max-width: 1100px) { .pricing-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .pricing-grid { grid-template-columns: 1fr; } }

.price-card {
  background: #fff;
  border: 1px solid var(--omm-zinc-200);
  border-radius: 18px;
  padding: 24px;
  transition: all 250ms var(--omm-ease-standard);
  display: flex; flex-direction: column;
}
.price-card.featured {
  border-color: transparent;
  background:
    linear-gradient(#fff,#fff) padding-box,
    linear-gradient(135deg, var(--accent-from), var(--accent-to)) border-box;
  border: 2px solid transparent;
  box-shadow: 0 16px 40px -16px var(--accent-line);
}
.price-card .name {
  font-family: var(--serif);
  font-size: 19px;
  font-weight: 600;
  color: var(--omm-zinc-900);
  margin: 0 0 6px;
}
.price-card .desc {
  font-size: 13px;
  color: var(--omm-zinc-500);
  margin: 0 0 16px;
  min-height: 32px;
}
.price-card .price {
  font-family: var(--serif);
  font-size: 32px;
  font-weight: 700;
  color: var(--omm-zinc-900);
  letter-spacing: -0.02em;
  margin-bottom: 4px;
}
.price-card .price small {
  font-family: var(--omm-font-sans);
  font-size: 13px;
  font-weight: 500;
  color: var(--omm-zinc-500);
}
.price-card .unit {
  font-size: 13px;
  color: var(--omm-zinc-500);
  margin-bottom: 18px;
}

/* ============================================================
   STATS
   ============================================================ */

.stat-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 32px;
  text-align: center;
}
@media (max-width: 900px) { .stat-row { grid-template-columns: repeat(2, 1fr); } }
.stat-row .num {
  font-family: var(--serif);
  font-size: clamp(40px, 5vw, 64px);
  font-weight: 700;
  letter-spacing: -0.025em;
  background: linear-gradient(135deg, var(--accent-from), var(--accent-to));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  line-height: 1;
}
.stat-row .label {
  margin-top: 10px;
  font-size: 14px;
  color: var(--omm-zinc-600);
  line-height: 1.4;
}

/* ============================================================
   FAQ
   ============================================================ */

.faq-grid {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 48px;
}
@media (max-width: 900px) { .faq-grid { grid-template-columns: 1fr; } }

.faq-item {
  border-bottom: 1px solid var(--omm-zinc-200);
  padding: 18px 0;
  cursor: pointer;
}
.faq-item summary {
  list-style: none;
  display: flex; justify-content: space-between; align-items: center; gap: 16px;
  font-family: var(--serif);
  font-size: 18px;
  font-weight: 600;
  color: var(--omm-zinc-900);
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary .material-symbols-rounded {
  color: var(--omm-zinc-500);
  transition: transform 200ms var(--omm-ease-standard);
}
.faq-item[open] summary .material-symbols-rounded { transform: rotate(45deg); color: var(--accent-from); }
.faq-item p {
  margin: 14px 0 0;
  font-size: 15px;
  line-height: 1.6;
  color: var(--omm-zinc-600);
  max-width: 64ch;
}

/* ============================================================
   FINAL CTA
   ============================================================ */

.cta-card {
  position: relative;
  background:
    radial-gradient(800px 400px at 80% 0%, rgba(255,255,255,0.16), transparent 60%),
    linear-gradient(135deg, #0f172a 0%, #1e3a8a 60%, #0369a1 100%);
  border-radius: 32px;
  padding: clamp(48px, 6vw, 88px);
  color: #fff;
  overflow: hidden;
}
.cta-card::after {
  content: "";
  position: absolute;
  right: -100px; top: -100px;
  width: 400px; height: 400px;
  background: radial-gradient(circle, rgba(201,169,110,0.18), transparent 70%);
  pointer-events: none;
}
.cta-card .section-eyebrow { color: rgba(255,255,255,0.7); }
.cta-card h2 {
  font-family: var(--serif);
  font-size: clamp(32px, 4.2vw, 56px);
  font-weight: 600;
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: #fff;
  margin: 0 0 20px;
  max-width: 22ch;
}
.cta-card p {
  font-size: 17px;
  line-height: 1.55;
  color: rgba(255,255,255,0.78);
  max-width: 56ch;
  margin: 0 0 32px;
}
.cta-card .btn-primary {
  background: #fff;
  color: var(--omm-zinc-900);
}
.cta-card .btn-primary:hover {
  background: linear-gradient(135deg, #fff, var(--warm-cream));
  color: var(--omm-zinc-900);
  box-shadow: 0 14px 30px rgba(0,0,0,0.3);
}
.cta-card .btn-ghost {
  background: rgba(255,255,255,0.1);
  border-color: rgba(255,255,255,0.25);
  color: #fff;
}
.cta-card .btn-ghost:hover { background: rgba(255,255,255,0.18); }

/* ============================================================
   FOOTER
   ============================================================ */

.footer {
  background: var(--omm-zinc-900);
  color: var(--omm-zinc-400);
  padding: 64px 0 32px;
}
.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 40px;
  margin-bottom: 48px;
}
@media (max-width: 900px) { .footer-grid { grid-template-columns: 1fr 1fr; } }

.footer-brand .brand { color: #fff; }
.footer-brand .brand small { color: rgba(255,255,255,0.5); }
.footer-brand p {
  font-size: 14px;
  line-height: 1.6;
  margin: 16px 0 0;
  max-width: 32ch;
}
.footer h5 {
  color: #fff;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin: 0 0 16px;
}
.footer ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
.footer ul a { font-size: 14px; }
.footer ul a:hover { color: #fff; }

.footer-bottom {
  border-top: 1px solid rgba(255,255,255,0.08);
  padding-top: 24px;
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: 12px;
  font-size: 13px;
}

/* ============================================================
   ANIMATIONS
   ============================================================ */

@keyframes float {
  0%,100% { transform: translateY(0); }
  50% { transform: translateY(-6px); }
}
@keyframes pulse-soft {
  0%,100% { opacity: 0.6; }
  50% { opacity: 1; }
}
@keyframes typewriter-cursor {
  0%,50% { opacity: 1; }
  51%,100% { opacity: 0; }
}
@keyframes slide-up {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}

.float { animation: float 3.5s ease-in-out infinite; }
.pulse-soft { animation: pulse-soft 2s ease-in-out infinite; }

/* utility */
.muted { color: var(--omm-zinc-500); }

/* ============================================================
   PHASE A — additive components
   ============================================================ */

/* ---------- two-tone "human/trust" warm-gold accent ----------
   Used by founder block, testimonial markers, Made-in-DE chips.
   Royal-indigo stays the product/tech accent.                       */
:root {
  --warm-gold:      #c9a96e;
  --warm-gold-soft: #f4ead4;
  --warm-gold-line: rgba(201, 169, 110, 0.32);
  --warm-gold-tint: rgba(201, 169, 110, 0.10);
}

/* ---------- Mobile nav: hamburger + drawer ---------- */
.nav-burger {
  display: none;
  width: 40px; height: 40px;
  border-radius: 9999px;
  border: 1px solid var(--omm-zinc-200);
  background: rgba(255,255,255,0.7);
  cursor: pointer;
  align-items: center; justify-content: center;
  margin-left: auto;
  padding: 0;
  transition: all 200ms var(--omm-ease-standard);
}
.nav-burger:hover { background: #fff; border-color: var(--omm-zinc-300); }
.nav-burger .material-symbols-rounded { font-size: 22px; color: var(--omm-zinc-800); }
.nav-burger .icon-close { display: none; }
.nav-burger[aria-expanded="true"] .icon-open  { display: none; }
.nav-burger[aria-expanded="true"] .icon-close { display: inline-block; }

.nav-drawer {
  display: none;
  position: fixed;
  top: 64px; left: 0; right: 0; bottom: 0;
  background: rgba(255,255,255,0.98);
  backdrop-filter: saturate(140%) blur(16px);
  -webkit-backdrop-filter: saturate(140%) blur(16px);
  z-index: 49;
  padding: 32px clamp(20px, 5vw, 40px) 40px;
  flex-direction: column;
  gap: 4px;
  overflow-y: auto;
  opacity: 0;
  transform: translateY(-12px);
  transition: opacity 220ms var(--omm-ease-standard),
              transform 220ms var(--omm-ease-standard);
  pointer-events: none;
}
.nav-drawer.is-open {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.nav-drawer .nav-link {
  font-family: var(--serif);
  font-size: 22px;
  padding: 14px 16px;
  color: var(--omm-zinc-900);
  border-bottom: 1px solid var(--omm-zinc-100);
}
.nav-drawer .nav-link:hover { background: var(--omm-zinc-50); }
.nav-drawer-footer {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 24px;
  flex-wrap: wrap;
}
.nav-drawer-footer .nav-lang {
  background: var(--omm-zinc-100);
}
.nav-drawer-footer .nav-cta {
  flex: 1;
  justify-content: center;
}
html.is-drawer-open { overflow: hidden; }

@media (max-width: 760px) {
  .nav-inner > .nav-links,
  .nav-inner > .nav-lang,
  .nav-inner > .nav-cta { display: none; }
  .nav-burger { display: inline-flex; }
  .nav-drawer { display: flex; }
}

/* ---------- Hero pricing hint line ---------- */
.hero-pricing-hint {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin: -16px 0 28px;
  padding: 10px 16px;
  border-radius: 9999px;
  background: rgba(255,255,255,0.65);
  border: 1px solid var(--omm-zinc-200);
  font-size: 13px;
  color: var(--omm-zinc-700);
  font-family: var(--omm-font-mono);
  letter-spacing: 0.02em;
}
.hero-pricing-hint .dot {
  width: 4px; height: 4px;
  border-radius: 50%;
  background: var(--accent-from);
  display: inline-block;
}

/* ---------- Stats row source caption ---------- */
.stat-source {
  margin-top: 28px;
  text-align: center;
  font-family: var(--omm-font-mono);
  font-size: 11.5px;
  letter-spacing: 0.04em;
  color: var(--omm-zinc-400);
}

/* ============================================================
   COMPARISON TABLE (#compare)
   ============================================================ */

.compare-section {
  background: linear-gradient(180deg, #ffffff 0%, var(--accent-soft) 100%);
  border-top: 1px solid var(--omm-zinc-200);
  border-bottom: 1px solid var(--omm-zinc-200);
}

.compare-wrap {
  margin-top: clamp(32px, 4vw, 48px);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  background: #fff;
  border: 1px solid var(--omm-zinc-200);
  border-radius: 22px;
  box-shadow: var(--omm-shadow-card);
}

.compare-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 880px;
  font-size: 14px;
  color: var(--omm-zinc-800);
}

.compare-table thead th {
  padding: 18px 16px;
  text-align: center;
  vertical-align: bottom;
  font-weight: 600;
  font-size: 13px;
  letter-spacing: 0.02em;
  color: var(--omm-zinc-700);
  border-bottom: 1px solid var(--omm-zinc-200);
  background: var(--omm-zinc-50);
  white-space: nowrap;
}
.compare-table thead th:first-child {
  text-align: left;
  background: #fff;
  width: 28%;
}
.compare-table thead th.is-us {
  background: linear-gradient(180deg, var(--accent-soft), #fff);
  color: var(--accent-from);
  font-family: var(--serif);
  font-size: 16px;
  letter-spacing: -0.005em;
  border-bottom: 2px solid var(--accent-from);
  position: relative;
}
.compare-table thead th.is-us::after {
  content: "";
  position: absolute;
  inset: 0 auto auto 0;
  height: 3px; width: 100%;
  background: linear-gradient(90deg, var(--accent-from), var(--accent-to));
}
.compare-table tbody td {
  padding: 14px 16px;
  border-bottom: 1px solid var(--omm-zinc-100);
  text-align: center;
  vertical-align: middle;
}
.compare-table tbody td:first-child {
  text-align: left;
  font-weight: 500;
  color: var(--omm-zinc-900);
}
.compare-table tbody td.is-us {
  background: rgba(238, 240, 251, 0.45);
  border-left: 1px solid var(--accent-line);
  border-right: 1px solid var(--accent-line);
}
.compare-table tbody tr:last-child td.is-us {
  border-bottom: 1px solid var(--accent-line);
}
.compare-table tbody tr:hover td:not(:first-child) {
  background: var(--omm-zinc-50);
}
.compare-table tbody tr:hover td.is-us {
  background: rgba(238, 240, 251, 0.7);
}

.cmp-cell {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  white-space: nowrap;
}
.cmp-yes  { color: var(--omm-success); }
.cmp-warn { color: var(--omm-warning); }
.cmp-no   { color: var(--omm-zinc-400); }
.cmp-yes .material-symbols-rounded,
.cmp-warn .material-symbols-rounded,
.cmp-no .material-symbols-rounded { font-size: 18px; font-variation-settings: "FILL" 1; }
.cmp-note { color: var(--omm-zinc-500); font-size: 12px; }

.compare-foot {
  margin-top: 16px;
  font-size: 12px;
  color: var(--omm-zinc-500);
  text-align: center;
  font-family: var(--omm-font-mono);
  letter-spacing: 0.02em;
}

/* ============================================================
   ROI CALCULATOR (#roi)
   ============================================================ */

.roi-section {
  background: var(--warm-cream);
  border-top: 1px solid var(--omm-zinc-200);
  border-bottom: 1px solid var(--omm-zinc-200);
}

.roi-grid {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: clamp(32px, 5vw, 64px);
  align-items: stretch;
  margin-top: clamp(32px, 4vw, 56px);
}
@media (max-width: 900px) {
  .roi-grid { grid-template-columns: 1fr; }
}

.roi-inputs {
  background: #fff;
  border: 1px solid var(--omm-zinc-200);
  border-radius: 22px;
  padding: clamp(24px, 3vw, 36px);
  box-shadow: var(--omm-shadow-card);
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.roi-input {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.roi-input-head {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 12px;
}
.roi-input-label {
  font-size: 13px;
  font-weight: 600;
  color: var(--omm-zinc-800);
  letter-spacing: 0.01em;
}
.roi-input-value {
  font-family: var(--serif);
  font-size: 22px;
  font-weight: 600;
  color: var(--accent-from);
  letter-spacing: -0.015em;
  min-width: 4ch;
  text-align: right;
}
.roi-input-value .unit {
  font-family: var(--omm-font-mono);
  font-size: 12px;
  color: var(--omm-zinc-500);
  letter-spacing: 0.04em;
  margin-left: 2px;
}
.roi-input input[type="range"] {
  -webkit-appearance: none;
  appearance: none;
  width: 100%;
  height: 6px;
  border-radius: 9999px;
  background: linear-gradient(90deg, var(--accent-from), var(--accent-to));
  outline: none;
}
.roi-input input[type="range"]::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 22px; height: 22px;
  border-radius: 50%;
  background: #fff;
  border: 2px solid var(--accent-from);
  box-shadow: 0 4px 12px var(--accent-line);
  cursor: pointer;
  transition: transform 150ms var(--omm-ease-standard);
}
.roi-input input[type="range"]::-webkit-slider-thumb:hover {
  transform: scale(1.12);
}
.roi-input input[type="range"]::-moz-range-thumb {
  width: 22px; height: 22px;
  border-radius: 50%;
  background: #fff;
  border: 2px solid var(--accent-from);
  box-shadow: 0 4px 12px var(--accent-line);
  cursor: pointer;
}
.roi-input-bounds {
  display: flex; justify-content: space-between;
  font-family: var(--omm-font-mono);
  font-size: 11px;
  color: var(--omm-zinc-400);
  letter-spacing: 0.02em;
}

.roi-outputs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1.4fr 1fr;
  gap: 16px;
}
@media (max-width: 480px) {
  .roi-outputs { grid-template-columns: 1fr; grid-template-rows: auto; }
}
.roi-output {
  background:
    linear-gradient(#fff,#fff) padding-box,
    linear-gradient(135deg, var(--accent-from), var(--accent-to)) border-box;
  border: 2px solid transparent;
  border-radius: 22px;
  padding: 24px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 8px;
  box-shadow: 0 12px 32px -16px var(--accent-line);
}
.roi-output.is-hero {
  grid-column: 1 / -1;
  background:
    radial-gradient(800px 300px at 70% 0%, var(--accent-soft), #fff 70%) padding-box,
    linear-gradient(135deg, var(--accent-from), var(--accent-to)) border-box;
}
.roi-output-label {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent-from);
}
.roi-output-value {
  font-family: var(--serif);
  font-size: clamp(28px, 3.6vw, 44px);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.05;
  background: linear-gradient(135deg, var(--accent-from), var(--accent-to));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.roi-output-note {
  font-size: 12.5px;
  line-height: 1.5;
  color: var(--omm-zinc-600);
}

.roi-foot {
  margin-top: 28px;
  text-align: center;
  font-family: var(--omm-font-mono);
  font-size: 12px;
  color: var(--omm-zinc-500);
  letter-spacing: 0.02em;
}

/* ============================================================
   RISK-REVERSAL chip strip
   ============================================================ */
.risk-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: center;
  margin: clamp(36px, 5vw, 56px) 0 clamp(24px, 3vw, 40px);
}
.risk-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 18px;
  background: linear-gradient(135deg, #fff, var(--warm-gold-soft));
  border: 1px solid var(--warm-gold-line);
  border-radius: 9999px;
  font-size: 14px;
  font-weight: 500;
  color: var(--omm-zinc-900);
  box-shadow: 0 4px 16px -8px rgba(201, 169, 110, 0.4);
}
.risk-chip .material-symbols-rounded {
  font-size: 18px;
  color: var(--warm-gold);
  font-variation-settings: "FILL" 1;
}
.risk-chip strong {
  font-weight: 600;
  color: var(--omm-zinc-900);
}

/* ============================================================
   STICKY BOTTOM CTA BAR (mobile only)
   ============================================================ */
.sticky-cta {
  display: none;
  position: fixed;
  bottom: 0; left: 0; right: 0;
  z-index: 48;
  padding: 10px 14px calc(10px + env(safe-area-inset-bottom));
  background: rgba(24, 24, 27, 0.96);
  backdrop-filter: saturate(140%) blur(16px);
  -webkit-backdrop-filter: saturate(140%) blur(16px);
  color: #fff;
  align-items: center;
  gap: 10px;
  transform: translateY(120%);
  transition: transform 280ms var(--omm-ease-standard);
  box-shadow: 0 -8px 24px rgba(0,0,0,0.18);
  border-top: 1px solid rgba(255,255,255,0.08);
}
.sticky-cta.is-visible { transform: translateY(0); }
.sticky-cta-text {
  flex: 1;
  font-size: 13px;
  line-height: 1.3;
  color: rgba(255,255,255,0.92);
}
.sticky-cta-tel {
  width: 40px; height: 40px;
  border-radius: 9999px;
  border: 1px solid rgba(255,255,255,0.18);
  background: rgba(255,255,255,0.06);
  color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.sticky-cta-tel .material-symbols-rounded { font-size: 20px; }
.sticky-cta-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 10px 16px;
  background: #fff;
  color: var(--omm-zinc-900);
  border-radius: 9999px;
  font-size: 13px;
  font-weight: 600;
  text-decoration: none;
  flex-shrink: 0;
}
.sticky-cta-btn .material-symbols-rounded { font-size: 16px; }

@media (max-width: 759.98px) {
  .sticky-cta { display: flex; }
  /* leave room at bottom of page so footer isn't covered */
  .footer { padding-bottom: 100px; }
}

/* ============================================================
   HERO MOCK SCENE CAPTION
   ============================================================ */
.hm-caption {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 16px;
  background: var(--omm-zinc-50);
  border-bottom: 1px solid var(--omm-zinc-100);
  font-family: var(--omm-font-mono);
  font-size: 11.5px;
  letter-spacing: 0.04em;
  color: var(--omm-zinc-600);
}
.hm-caption-idx {
  padding: 2px 8px;
  background: #fff;
  border: 1px solid var(--omm-zinc-200);
  border-radius: 9999px;
  color: var(--accent-from);
  font-weight: 600;
  flex-shrink: 0;
  white-space: nowrap;
}
.hm-caption-text { line-height: 1.3; }

/* ============================================================
   Hero-mock cross-fade between scenes
   ============================================================ */
.hm-bubble {
  transition: opacity 240ms var(--omm-ease-standard);
}
.hm-bubble.is-fading { opacity: 0; }

/* ============================================================
   PHASE B placeholder layout — additive
   ============================================================ */

/* ---------- Customer logo wall ---------- */
.logo-wall {
  background: #fff;
  border-top: 1px solid var(--omm-zinc-200);
  border-bottom: 1px solid var(--omm-zinc-200);
  padding: clamp(40px, 5vw, 64px) 0;
}
.logo-wall-eyebrow {
  text-align: center;
  font-family: var(--omm-font-mono);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--omm-zinc-500);
  margin-bottom: 24px;
}
.logo-wall-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 24px;
  align-items: center;
}
@media (max-width: 980px) {
  .logo-wall-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 480px) {
  .logo-wall-grid { grid-template-columns: repeat(2, 1fr); gap: 16px; }
}
.logo-cell {
  height: 56px;
  background: var(--omm-zinc-50);
  border: 1px dashed var(--omm-zinc-200);
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--omm-font-mono);
  font-size: 11px;
  color: var(--omm-zinc-400);
  letter-spacing: 0.04em;
  transition: all 220ms var(--omm-ease-standard);
}
.logo-cell:hover {
  background: #fff;
  border-color: var(--omm-zinc-300);
  color: var(--omm-zinc-700);
}

/* ---------- Testimonials ---------- */
.testimonials-section {
  background: linear-gradient(180deg, #fff 0%, var(--warm-gold-soft) 100%);
  border-bottom: 1px solid var(--omm-zinc-200);
}
.testimonial-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-top: clamp(32px, 4vw, 48px);
}
@media (max-width: 980px) { .testimonial-grid { grid-template-columns: 1fr; } }

.testimonial {
  position: relative;
  background: #fff;
  border: 1px solid var(--omm-zinc-200);
  border-radius: 22px;
  padding: 32px 28px 28px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  box-shadow: var(--omm-shadow-card);
  transition: all 250ms var(--omm-ease-standard);
}
.testimonial:hover {
  transform: translateY(-2px);
  border-color: var(--warm-gold-line);
  box-shadow: 0 16px 40px -16px rgba(201, 169, 110, 0.4);
}
.testimonial::before {
  content: "\201C";
  position: absolute;
  top: -8px; left: 24px;
  font-family: var(--serif);
  font-size: 64px;
  color: var(--warm-gold);
  line-height: 1;
  font-weight: 600;
}
.testimonial-quote {
  font-family: var(--serif);
  font-size: 18px;
  line-height: 1.45;
  color: var(--omm-zinc-900);
  margin: 0;
  font-weight: 500;
  letter-spacing: -0.01em;
  text-wrap: balance;
}
.testimonial-metric {
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
  padding: 8px 14px;
  background: var(--warm-gold-soft);
  border: 1px solid var(--warm-gold-line);
  border-radius: 9999px;
  align-self: flex-start;
  font-size: 13px;
}
.testimonial-metric .num {
  font-family: var(--serif);
  font-size: 16px;
  font-weight: 700;
  color: var(--accent-from);
}
.testimonial-meta {
  display: flex;
  align-items: center;
  gap: 12px;
  padding-top: 16px;
  border-top: 1px solid var(--omm-zinc-100);
}
.testimonial-photo {
  width: 44px; height: 44px;
  border-radius: 9999px;
  background: linear-gradient(135deg, var(--accent-from), var(--accent-to));
  display: flex; align-items: center; justify-content: center;
  color: #fff;
  font-family: var(--serif);
  font-weight: 700;
  font-size: 16px;
  letter-spacing: 0.02em;
  flex-shrink: 0;
}
.testimonial-meta .who {
  display: flex; flex-direction: column; gap: 2px;
  font-size: 13px;
  line-height: 1.3;
}
.testimonial-meta .who .name { font-weight: 600; color: var(--omm-zinc-900); }
.testimonial-meta .who .role { color: var(--omm-zinc-500); font-size: 12px; }
.testimonial-placeholder-tag {
  position: absolute;
  top: 14px; right: 14px;
  font-family: var(--omm-font-mono);
  font-size: 9.5px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--omm-zinc-400);
  padding: 3px 8px;
  border: 1px dashed var(--omm-zinc-300);
  border-radius: 9999px;
}

/* ---------- Founder block ---------- */
.founders-section {
  background: linear-gradient(180deg, var(--warm-cream) 0%, #fdfaf2 100%);
  border-top: 1px solid var(--omm-zinc-200);
  border-bottom: 1px solid var(--omm-zinc-200);
}
.founder-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-top: clamp(32px, 4vw, 48px);
}
@media (max-width: 980px) { .founder-grid { grid-template-columns: 1fr; } }

.founder {
  background: #fff;
  border: 1px solid var(--omm-zinc-200);
  border-radius: 22px;
  padding: 28px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  transition: all 250ms var(--omm-ease-standard);
}
.founder:hover {
  border-color: var(--warm-gold-line);
  transform: translateY(-2px);
  box-shadow: 0 16px 40px -16px rgba(201, 169, 110, 0.4);
}
.founder-photo {
  width: 88px; height: 88px;
  border-radius: 9999px;
  background: linear-gradient(135deg, var(--accent-from), var(--accent-to));
  display: flex; align-items: center; justify-content: center;
  color: #fff;
  font-family: var(--serif);
  font-weight: 700;
  font-size: 28px;
  letter-spacing: 0.04em;
}
.founder-name {
  font-family: var(--serif);
  font-size: 22px;
  font-weight: 600;
  color: var(--omm-zinc-900);
  letter-spacing: -0.01em;
  margin: 0;
}
.founder-role {
  font-family: var(--omm-font-mono);
  font-size: 12px;
  color: var(--accent-from);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.founder-quote {
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--omm-zinc-700);
  font-style: italic;
  margin: 0;
}
.founder-links {
  margin-top: auto;
  display: flex; align-items: center; gap: 10px;
  padding-top: 12px;
  border-top: 1px solid var(--omm-zinc-100);
}
.founder-link {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 12px;
  font-weight: 500;
  color: var(--omm-zinc-700);
  padding: 6px 10px;
  border-radius: 9999px;
  background: var(--omm-zinc-50);
  border: 1px solid var(--omm-zinc-200);
  transition: all 200ms var(--omm-ease-standard);
}
.founder-link:hover {
  background: #fff;
  border-color: var(--omm-zinc-300);
  color: var(--omm-zinc-900);
}
.founder-placeholder-tag {
  position: absolute;
  top: 12px; right: 12px;
  font-family: var(--omm-font-mono);
  font-size: 9.5px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--omm-zinc-400);
  padding: 3px 8px;
  border: 1px dashed var(--omm-zinc-300);
  border-radius: 9999px;
}
.founder { position: relative; }

/* ---------- Network/affiliations strip ---------- */
.network-strip {
  margin-top: clamp(40px, 5vw, 64px);
  padding-top: 32px;
  border-top: 1px solid var(--omm-zinc-200);
  text-align: center;
}
.network-eyebrow {
  font-family: var(--omm-font-mono);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--omm-zinc-500);
  margin-bottom: 18px;
}
.network-row {
  display: flex; flex-wrap: wrap; gap: 12px; justify-content: center;
}
.network-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  background: #fff;
  border: 1px solid var(--omm-zinc-200);
  border-radius: 9999px;
  font-size: 13px;
  color: var(--omm-zinc-700);
  font-family: var(--omm-font-mono);
  letter-spacing: 0.02em;
}

/* ---------- Pricing tooltips ---------- */
.price-features {
  margin: 0 0 18px;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.price-features li {
  font-size: 12.5px;
  color: var(--omm-zinc-600);
  display: flex;
  align-items: flex-start;
  gap: 6px;
  line-height: 1.4;
}
.price-features li::before {
  content: "\2713";
  color: var(--omm-success);
  font-weight: 700;
  flex-shrink: 0;
}

/* ---------- Final-CTA founder card ---------- */
.cta-founder {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px 20px;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.16);
  border-radius: 16px;
  margin-bottom: 28px;
  max-width: 460px;
}
.cta-founder-photo {
  width: 56px; height: 56px;
  border-radius: 9999px;
  background: linear-gradient(135deg, #fff, var(--warm-cream));
  color: var(--omm-zinc-900);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--serif);
  font-weight: 700;
  font-size: 20px;
  flex-shrink: 0;
}
.cta-founder-text { display: flex; flex-direction: column; gap: 2px; line-height: 1.35; }
.cta-founder-text .name { font-weight: 600; color: #fff; font-size: 15px; }
.cta-founder-text .role { color: rgba(255,255,255,0.7); font-size: 12px; }
.cta-founder-text .tel  {
  margin-top: 4px;
  font-family: var(--omm-font-mono);
  font-size: 13px;
  color: rgba(255,255,255,0.85);
}
.cta-founder-text .tel a { color: #fff; }

/* ============================================================
   PHASE D — Design distinction
   ============================================================ */

/* ---------- Paper-grain noise overlay on warm-cream sections ----------
   Applied via a single SVG noise pattern. Very subtle (~3 % opacity) —
   adds tactility, doesn't distract.                                      */
.trust-band,
.roi-section,
.founders-section,
.testimonials-section,
#pricing {
  position: relative;
}
.trust-band::after,
.roi-section::after,
.founders-section::after,
.testimonials-section::after,
#pricing::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0.035;
  mix-blend-mode: multiply;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.92' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.6 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  background-size: 160px 160px;
}
.trust-band > .container,
.roi-section > .container,
.founders-section > .container,
.testimonials-section > .container,
#pricing > .container { position: relative; z-index: 1; }

/* ---------- Hand-drawn underline highlight on key emphasised phrases ----
   Used by hero <h1> em, section-title em. Inline SVG sits behind the
   gradient text and adds an organic stroke under the phrase.            */
.hero h1 em,
.section-title em,
.cta-card h2 em,
.td-h1 em {
  position: relative;
  display: inline;
  background-image: linear-gradient(110deg, var(--accent-from), var(--accent-to));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.hero h1 em::after,
.section-title em::after,
.cta-card h2 em::after,
.td-h1 em::after {
  content: "";
  position: absolute;
  left: -2px; right: -2px;
  bottom: -0.08em;
  height: 0.18em;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 12' preserveAspectRatio='none'><path d='M2 8 C 50 2 100 11 198 5' stroke='%23c9a96e' stroke-width='3' stroke-linecap='round' fill='none' opacity='0.55'/></svg>");
  background-repeat: no-repeat;
  background-size: 100% 100%;
  pointer-events: none;
  z-index: -1;
}

/* ---------- Bouncy CTA arrow ---------- */
.btn .material-symbols-rounded,
.focus-cta .material-symbols-rounded,
.focus-foot-cta .material-symbols-rounded {
  transition: transform 320ms cubic-bezier(0.34, 1.56, 0.64, 1);
}
.btn:hover .material-symbols-rounded,
.focus-cta:hover .material-symbols-rounded,
.focus-foot-cta:hover .material-symbols-rounded {
  transform: translateX(4px);
}

/* ---------- Subtle hover-tilt on feature cards ----------
   Pure CSS — small uniform 0.6° tilt on hover, plus deeper lift.
   Adds a hand-crafted feel without JS pointer-tracking complexity.       */
.usecase,
.testimonial,
.founder,
.trust-item,
.price-card {
  transform-origin: center bottom;
}
.usecase:hover         { transform: translateY(-3px) rotate(-0.4deg); }
.testimonial:hover     { transform: translateY(-3px) rotate(0.3deg); }
.founder:hover         { transform: translateY(-3px) rotate(-0.3deg); }
.trust-item:hover .icon { transform: translateY(-2px) rotate(-3deg); transition: transform 320ms cubic-bezier(0.34, 1.56, 0.64, 1); }
.price-card:hover      { transform: translateY(-3px); }
.price-card.featured:hover { transform: translateY(-4px) scale(1.02); }

/* ---------- Comparison-table scrollytelling reveal ---------- */
.compare-table tbody tr {
  opacity: 0;
  transform: translateX(-12px);
  transition: opacity 540ms var(--omm-ease-standard), transform 540ms var(--omm-ease-standard);
}
.compare-section.is-revealed .compare-table tbody tr {
  opacity: 1;
  transform: translateX(0);
}
.compare-section.is-revealed .compare-table tbody tr:nth-child(1)  { transition-delay:  60ms; }
.compare-section.is-revealed .compare-table tbody tr:nth-child(2)  { transition-delay: 120ms; }
.compare-section.is-revealed .compare-table tbody tr:nth-child(3)  { transition-delay: 180ms; }
.compare-section.is-revealed .compare-table tbody tr:nth-child(4)  { transition-delay: 240ms; }
.compare-section.is-revealed .compare-table tbody tr:nth-child(5)  { transition-delay: 300ms; }
.compare-section.is-revealed .compare-table tbody tr:nth-child(6)  { transition-delay: 360ms; }
.compare-section.is-revealed .compare-table tbody tr:nth-child(7)  { transition-delay: 420ms; }
.compare-section.is-revealed .compare-table tbody tr:nth-child(8)  { transition-delay: 480ms; }
.compare-section.is-revealed .compare-table tbody tr:nth-child(9)  { transition-delay: 540ms; }
.compare-section.is-revealed .compare-table tbody tr:nth-child(10) { transition-delay: 600ms; }

@media (prefers-reduced-motion: reduce) {
  .compare-table tbody tr { opacity: 1; transform: none; transition: none; }
  .usecase:hover, .testimonial:hover, .founder:hover, .price-card:hover, .price-card.featured:hover { transform: none; }
}

/* ============================================================
   PHASE E — Identity & World-Class Polish
   ============================================================ */

/* ---------- "Die ersten 100" launch banner ---------- */
.launch-banner {
  position: relative;
  background:
    radial-gradient(800px 200px at 80% 50%, rgba(201,169,110,0.20), transparent 70%),
    linear-gradient(135deg, #0f172a 0%, #1e3a8a 70%, #0369a1 100%);
  color: #fff;
  z-index: 60;
}
.launch-inner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  padding: 9px clamp(20px, 4vw, 40px);
  font-size: 13px;
  font-weight: 500;
  flex-wrap: wrap;
}
.launch-pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 3px 10px;
  background: linear-gradient(135deg, var(--warm-gold), #e2c98c);
  color: #0f172a;
  font-family: var(--omm-font-mono);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  border-radius: 9999px;
  flex-shrink: 0;
}
.launch-msg {
  font-family: var(--serif);
  font-size: 14.5px;
  font-weight: 500;
  letter-spacing: -0.005em;
}
.launch-msg em {
  font-style: italic;
  color: var(--warm-gold);
}
.launch-cta {
  font-size: 12.5px;
  font-weight: 600;
  color: #fff;
  border-bottom: 1px solid rgba(255,255,255,0.4);
  padding-bottom: 1px;
  transition: border-color 200ms var(--omm-ease-standard);
}
.launch-cta:hover { border-bottom-color: var(--warm-gold); color: var(--warm-gold); }
@media (max-width: 760px) {
  .launch-msg { font-size: 13px; }
  .launch-inner { gap: 8px; padding: 8px 16px; }
}

/* ---------- OMM AI Hub wordmark refinement ---------- */
.brand {
  letter-spacing: -0.015em;
}
.brand-mark {
  background: linear-gradient(140deg, var(--accent-from) 0%, var(--accent-to) 60%, var(--warm-gold) 200%);
  position: relative;
  overflow: hidden;
}
.brand-mark::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 30% 20%, rgba(255,255,255,0.4), transparent 60%);
  pointer-events: none;
}

/* ---------- Numbered section eyebrow (01 · 02 · 03) ---------- */
.section-num {
  font-family: var(--omm-font-mono);
  font-size: 12px;
  font-weight: 600;
  color: var(--accent-from);
  letter-spacing: 0.08em;
  margin-right: 12px;
  opacity: 0.75;
}

/* ---------- Hero: world-class typographic bump ---------- */
.hero h1 {
  font-size: clamp(48px, 6.4vw, 92px);
  letter-spacing: -0.03em;
  line-height: 0.98;
  font-weight: 600;
  max-width: 14ch;
}
.hero h1 em {
  font-weight: 500;
}

/* Asymmetric hero adjustment */
.hero-grid {
  grid-template-columns: 1.25fr 1fr;
  align-items: center;
}
@media (min-width: 1280px) {
  .hero-grid { grid-template-columns: 1.35fr 1fr; gap: 80px; }
}

/* ---------- Manifesto section ---------- */
.manifesto-section {
  background:
    radial-gradient(1000px 400px at 70% 30%, rgba(42, 59, 143, 0.06), transparent 65%),
    linear-gradient(180deg, #ffffff 0%, #fafafa 100%);
  border-top: 1px solid var(--omm-zinc-200);
  border-bottom: 1px solid var(--omm-zinc-200);
}
.manifesto-grid {
  display: grid;
  grid-template-columns: 1fr 1.3fr;
  gap: clamp(40px, 6vw, 96px);
  align-items: start;
  padding: clamp(40px, 6vw, 80px) 0;
}
@media (max-width: 900px) { .manifesto-grid { grid-template-columns: 1fr; gap: 32px; } }

.manifesto-eyebrow {
  font-family: var(--omm-font-mono);
  font-size: 12px;
  font-weight: 600;
  color: var(--omm-zinc-500);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  display: flex; align-items: center; gap: 16px;
}
.manifesto-eyebrow::before {
  content: "01 · Manifest";
  color: var(--accent-from);
}
.manifesto-eyebrow .since {
  flex: 1;
  height: 1px;
  background: var(--omm-zinc-200);
}

.manifesto-title {
  font-family: var(--serif);
  font-size: clamp(32px, 3.4vw, 48px);
  font-weight: 600;
  line-height: 1.06;
  letter-spacing: -0.02em;
  color: var(--omm-zinc-900);
  margin: 18px 0 0;
  text-wrap: balance;
}
.manifesto-title em {
  font-style: italic;
  font-weight: 500;
  color: var(--accent-from);
}
.manifesto-body {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.manifesto-body p {
  font-family: var(--serif);
  font-size: clamp(18px, 1.5vw, 22px);
  line-height: 1.55;
  color: var(--omm-zinc-800);
  margin: 0;
  font-weight: 400;
  letter-spacing: -0.005em;
}
.manifesto-body p.lead {
  font-size: clamp(20px, 1.7vw, 26px);
  font-weight: 500;
  color: var(--omm-zinc-900);
}
.manifesto-body em {
  font-style: italic;
  color: var(--accent-from);
  font-weight: 500;
}
.manifesto-tag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 8px;
  padding: 8px 14px;
  background: var(--warm-gold-soft);
  border: 1px solid var(--warm-gold-line);
  border-radius: 9999px;
  font-family: var(--omm-font-mono);
  font-size: 12px;
  letter-spacing: 0.04em;
  color: var(--omm-zinc-800);
}
.manifesto-tag::before {
  content: "";
  width: 6px; height: 6px;
  background: var(--warm-gold);
  border-radius: 50%;
}

/* ---------- Pricing — world-class big-numerals layout ---------- */
.pricing-headline {
  font-family: var(--serif);
  font-size: clamp(44px, 6.5vw, 88px);
  font-weight: 700;
  line-height: 1;
  letter-spacing: -0.035em;
  color: var(--omm-zinc-900);
  margin: 0;
  display: flex;
  align-items: baseline;
  gap: 10px;
}
.pricing-headline .currency {
  font-size: 0.42em;
  font-weight: 500;
  color: var(--omm-zinc-500);
  letter-spacing: 0;
}
.pricing-headline .from {
  font-size: 0.28em;
  font-family: var(--omm-font-mono);
  font-weight: 500;
  color: var(--omm-zinc-500);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin-right: 4px;
}

.price-card {
  position: relative;
  padding: 32px 28px 28px;
  border-radius: 24px;
}
.price-card .name {
  font-family: var(--serif);
  font-size: 22px;
  font-weight: 600;
  margin: 0 0 4px;
  letter-spacing: -0.012em;
}
.price-card .target {
  font-family: var(--omm-font-mono);
  font-size: 11.5px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--omm-zinc-500);
  margin: 0 0 24px;
}
.price-card .desc {
  font-size: 13.5px;
  line-height: 1.55;
  color: var(--omm-zinc-700);
  margin: 0 0 24px;
  min-height: 0;
}
.price-card .pricing-headline {
  margin-bottom: 6px;
}
.price-card .unit {
  font-family: var(--omm-font-mono);
  font-size: 11.5px;
  letter-spacing: 0.04em;
  color: var(--omm-zinc-500);
  margin-bottom: 22px;
}
.price-card .price-features li {
  font-size: 13px;
  line-height: 1.5;
}
.price-card.featured {
  background:
    linear-gradient(#fff,#fff) padding-box,
    linear-gradient(160deg, var(--accent-from), var(--accent-to) 50%, var(--warm-gold)) border-box;
  border: 2px solid transparent;
  box-shadow:
    0 24px 60px -24px var(--accent-line),
    0 4px 12px -4px rgba(0,0,0,0.08);
  transform: translateY(-4px);
}
.price-card.featured::before {
  content: "Empfohlen für Mittelstand";
  position: absolute;
  top: -12px; left: 50%;
  transform: translateX(-50%);
  background: linear-gradient(135deg, var(--accent-from), var(--accent-to));
  color: #fff;
  padding: 5px 14px;
  border-radius: 9999px;
  font-family: var(--omm-font-mono);
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  white-space: nowrap;
  box-shadow: 0 6px 16px var(--accent-line);
}
html[data-lang="en"] .price-card.featured::before { content: "Recommended for mid-market"; }

/* Pricing meta row (Fair-Use, no token markup, etc.) */
.pricing-meta {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px 20px;
  margin: 28px 0 8px;
  font-family: var(--omm-font-mono);
  font-size: 12px;
  letter-spacing: 0.02em;
  color: var(--omm-zinc-600);
}
.pricing-meta span {
  display: inline-flex; align-items: center; gap: 6px;
}
.pricing-meta .check {
  color: var(--omm-success);
  font-size: 14px;
}
.pricing-meta .x {
  color: var(--omm-danger);
  font-size: 14px;
}

/* Quickstart-Pilot box */
.pilot-box {
  margin-top: clamp(40px, 5vw, 64px);
  background:
    radial-gradient(700px 240px at 90% -50%, rgba(201,169,110,0.12), transparent 70%),
    linear-gradient(135deg, #0f172a 0%, #1e3a8a 60%, #0369a1 100%);
  border-radius: 28px;
  padding: clamp(36px, 5vw, 56px);
  color: #fff;
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: clamp(24px, 4vw, 56px);
  align-items: center;
  position: relative;
  overflow: hidden;
}
@media (max-width: 900px) { .pilot-box { grid-template-columns: 1fr; } }
.pilot-box::after {
  content: "";
  position: absolute;
  right: -120px; bottom: -120px;
  width: 380px; height: 380px;
  background: radial-gradient(circle, rgba(201,169,110,0.18), transparent 70%);
  pointer-events: none;
}
.pilot-eyebrow {
  font-family: var(--omm-font-mono);
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--warm-gold);
  margin-bottom: 14px;
}
.pilot-title {
  font-family: var(--serif);
  font-size: clamp(28px, 3.4vw, 44px);
  font-weight: 600;
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: #fff;
  margin: 0 0 12px;
  text-wrap: balance;
  position: relative;
}
.pilot-title em {
  font-style: italic;
  font-weight: 500;
  color: var(--warm-gold);
}
.pilot-desc {
  font-size: 15.5px;
  line-height: 1.55;
  color: rgba(255,255,255,0.82);
  margin: 0 0 18px;
  max-width: 52ch;
}
.pilot-features {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px 18px;
  font-size: 13px;
  color: rgba(255,255,255,0.92);
}
@media (max-width: 600px) { .pilot-features { grid-template-columns: 1fr; } }
.pilot-features li {
  display: flex; align-items: center; gap: 6px;
}
.pilot-features li::before {
  content: "✓";
  color: var(--warm-gold);
  font-weight: 700;
}
.pilot-price-block {
  position: relative;
  z-index: 1;
  text-align: right;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 6px;
}
@media (max-width: 900px) { .pilot-price-block { text-align: left; align-items: flex-start; } }
.pilot-price-figure {
  font-family: var(--serif);
  font-size: clamp(56px, 7vw, 96px);
  font-weight: 700;
  line-height: 0.9;
  letter-spacing: -0.04em;
  background: linear-gradient(135deg, #fff, var(--warm-gold));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.pilot-price-unit {
  font-family: var(--omm-font-mono);
  font-size: 12px;
  letter-spacing: 0.04em;
  color: rgba(255,255,255,0.7);
  text-transform: uppercase;
}
.pilot-price-note {
  font-size: 13.5px;
  color: rgba(255,255,255,0.78);
  font-style: italic;
  font-family: var(--serif);
  margin-top: 4px;
  max-width: 28ch;
}
.pilot-cta {
  margin-top: 14px;
  background: var(--warm-gold);
  color: #0f172a;
  font-weight: 600;
}
.pilot-cta:hover {
  background: linear-gradient(135deg, var(--warm-gold), #e2c98c);
  color: #0f172a;
  box-shadow: 0 14px 30px rgba(201,169,110,0.35);
}

/* Add-on modules tease row */
.addon-row {
  margin-top: clamp(40px, 5vw, 64px);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
@media (max-width: 760px) { .addon-row { grid-template-columns: 1fr; } }
.addon {
  background: #fff;
  border: 1px solid var(--omm-zinc-200);
  border-radius: 18px;
  padding: 22px 24px;
  display: grid;
  grid-template-columns: 44px 1fr auto;
  gap: 16px;
  align-items: center;
  transition: all 240ms var(--omm-ease-standard);
}
.addon:hover {
  border-color: var(--accent-line);
  transform: translateY(-2px);
  box-shadow: 0 16px 36px -16px var(--accent-line);
}
.addon-icon {
  width: 44px; height: 44px;
  border-radius: 12px;
  background: var(--accent-soft);
  color: var(--accent-from);
  display: flex; align-items: center; justify-content: center;
}
.addon-icon .material-symbols-rounded { font-size: 22px; font-variation-settings: "FILL" 1; }
.addon h4 {
  font-family: var(--serif);
  font-size: 18px;
  font-weight: 600;
  margin: 0 0 2px;
  color: var(--omm-zinc-900);
}
.addon p {
  font-size: 13px;
  color: var(--omm-zinc-600);
  margin: 0;
  line-height: 1.4;
}
.addon-price {
  font-family: var(--serif);
  font-size: 22px;
  font-weight: 700;
  color: var(--accent-from);
  letter-spacing: -0.02em;
  white-space: nowrap;
}
.addon-price small {
  font-family: var(--omm-font-mono);
  font-size: 11px;
  font-weight: 500;
  color: var(--omm-zinc-500);
  letter-spacing: 0.04em;
}
@media (max-width: 760px) {
  .addon { grid-template-columns: 44px 1fr; }
  .addon-price { grid-column: 1 / -1; text-align: right; }
}

/* ---------- Founder block — editorial portrait redesign ---------- */
.founders-section .section-head {
  max-width: 720px;
}
.founders-section .section-title {
  font-size: clamp(40px, 5vw, 68px);
  letter-spacing: -0.025em;
  line-height: 1.02;
  max-width: 18ch;
}
.founders-since {
  font-family: var(--omm-font-mono);
  font-size: 12.5px;
  letter-spacing: 0.04em;
  color: var(--omm-zinc-500);
  margin-top: 18px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.founders-since::before {
  content: "";
  width: 24px; height: 1px;
  background: var(--accent-from);
}

/* Larger, asymmetric founder portrait cards */
.founder {
  display: grid;
  grid-template-columns: 96px 1fr;
  gap: 20px;
  padding: 28px 24px;
  align-items: start;
}
.founder-photo {
  width: 96px;
  height: 124px;
  border-radius: 14px;
  font-size: 32px;
  background: linear-gradient(160deg, var(--accent-from) 0%, var(--accent-to) 60%, var(--warm-gold) 200%);
  position: relative;
  overflow: hidden;
}
.founder-photo::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,0.4), transparent 65%);
}
.founder-content {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.founder-content .founder-name {
  font-size: 21px;
  margin: 0;
}
.founder-content .founder-role {
  margin: 0;
  font-size: 11.5px;
}
.founder-content .founder-quote {
  margin: 10px 0 14px;
  font-size: 14px;
  line-height: 1.55;
}
.founder-content .founder-links {
  margin-top: auto;
  border-top: 0;
  padding-top: 0;
}

/* ---------- "Markttreiber 2026" urgency strip ---------- */
.urgency-strip {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin: clamp(40px, 5vw, 64px) 0;
}
@media (max-width: 760px) { .urgency-strip { grid-template-columns: 1fr; } }
.urgency-item {
  background: #fff;
  border: 1px solid var(--omm-zinc-200);
  border-left: 3px solid var(--warm-gold);
  border-radius: 0 14px 14px 0;
  padding: 18px 20px;
}
.urgency-item .when {
  font-family: var(--omm-font-mono);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--warm-gold);
  margin-bottom: 6px;
}
.urgency-item h5 {
  font-family: var(--serif);
  font-size: 17px;
  font-weight: 600;
  color: var(--omm-zinc-900);
  margin: 0 0 4px;
  letter-spacing: -0.005em;
}
.urgency-item p {
  font-size: 13px;
  line-height: 1.5;
  color: var(--omm-zinc-600);
  margin: 0;
}

/* ---------- Section-transition warm-gold rule ----------
   Thin gold rule between cream-on-cream sections to add deliberate
   pacing instead of one register flowing into the next.                  */
.testimonials-section + #usecases::before,
.trust-band + .founders-section::before {
  content: "";
  display: block;
  width: 80px;
  height: 1px;
  margin: 0 auto -1px;
  background: linear-gradient(90deg, transparent, var(--warm-gold), transparent);
}
