/* ═══════════════════════════════════════════════════════════════════════
   FARO TELEMATIK — Design System
   Warm-Professionell · Erdtöne · Public Sans · Leicht abgerundet
   ═══════════════════════════════════════════════════════════════════════ */

:root {
  /* Brand Palette — Medical Blue + Cream-White */
  --color-bark:   #14315A;  /* deep navy — primary text, dark surfaces */
  --color-clay:   #3D6CA8;  /* medium blue — accent, borders */
  --color-amber:  #5B8FD9;  /* light azure — highlight, CTAs hover */
  --color-stone:  #5A6B82;  /* slate-blue — secondary text */
  --color-cream:  #F4F8FC;  /* cool cream-white — page background */
  --color-paper:  #FBFDFE;  /* paper-white — card backgrounds */
  --color-line:   #D8E2EE;  /* cool blue-grey divider */
  --color-ink:    #0F1F38;  /* near-black-blue text on cream */

  --color-success: #4A8B6D;
  --color-attention: #C75050;

  /* Type Scale */
  --font-display: 'Public Sans', 'IBM Plex Sans', system-ui, -apple-system, sans-serif;
  --font-body:    'Public Sans', system-ui, -apple-system, sans-serif;

  --fs-h1: clamp(2.25rem, 4.2vw, 3.625rem);
  --fs-h2: clamp(1.875rem, 3.5vw, 2.875rem);
  --fs-h3: clamp(1.25rem, 1.75vw, 1.5rem);
  --fs-h4: 1.125rem;
  --fs-body: 1.0625rem;
  --fs-small: 0.9375rem;
  --fs-eyebrow: 0.8125rem;

  /* Layout */
  --container: 1200px;
  --container-narrow: 880px;
  --gutter: clamp(1.25rem, 3vw, 2rem);

  /* Form */
  --radius-sm: 6px;
  --radius:    8px;
  --radius-lg: 12px;
  --radius-xl: 18px;

  /* Motion */
  --ease: cubic-bezier(0.22, 0.61, 0.36, 1);
  --speed-fast: 180ms;
  --speed: 320ms;
  --speed-slow: 520ms;

  /* Shadow (warm) */
  --shadow-sm: 0 1px 2px rgba(20, 49, 90, 0.06), 0 1px 3px rgba(20, 49, 90, 0.04);
  --shadow:    0 4px 12px rgba(20, 49, 90, 0.06), 0 2px 6px rgba(20, 49, 90, 0.04);
  --shadow-lg: 0 24px 48px -12px rgba(20, 49, 90, 0.18), 0 8px 16px -8px rgba(20, 49, 90, 0.08);
}

/* ── RESET ────────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; padding: 0; }

html {
  font-size: 16px;
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

/* Anchor scroll target offset — accounts for fixed nav (109px) + extra breath */
section[id] {
  scroll-margin-top: 140px;
}

body {
  font-family: var(--font-body);
  font-size: var(--fs-body);
  line-height: 1.6;
  color: var(--color-ink);
  background: var(--color-cream);
  font-feature-settings: "ss01", "cv11";
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

img, svg { display: block; max-width: 100%; }
button { font: inherit; cursor: pointer; border: 0; background: transparent; color: inherit; }
a { color: inherit; text-decoration: none; transition: color var(--speed-fast) var(--ease); }
a:hover { color: var(--color-clay); }

ul, ol { list-style: none; }

/* ── TYPOGRAPHY ───────────────────────────────────────────────────────── */
h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 600;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--color-bark);
}

h1 { font-size: var(--fs-h1); font-weight: 700; letter-spacing: -0.03em; line-height: 1.06; }
h2 { font-size: var(--fs-h2); font-weight: 600; }
h3 { font-size: var(--fs-h3); font-weight: 600; }
h4 { font-size: var(--fs-h4); font-weight: 600; }

h1 em, h2 em {
  font-style: italic;
  font-weight: 500;
  color: var(--color-clay);
}

p { color: var(--color-stone); line-height: 1.65; }
strong { font-weight: 600; color: var(--color-ink); }

.eyebrow {
  display: inline-block;
  font-size: var(--fs-eyebrow);
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-clay);
  margin-bottom: 1rem;
}

/* ── LAYOUT ───────────────────────────────────────────────────────────── */
.container {
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 var(--gutter);
}

.section-head {
  max-width: 720px;
  margin-bottom: clamp(2.5rem, 5vw, 4rem);
}
.section-head-center { margin-left: auto; margin-right: auto; text-align: center; }
.section-head h2 { margin-bottom: 0.5rem; }
.section-lead { font-size: 1.125rem; max-width: 60ch; }
.section-head-center .section-lead { margin: 1rem auto 0; }

/* ── BUTTONS ──────────────────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.85rem 1.4rem;
  font-family: var(--font-display);
  font-size: 0.9375rem;
  font-weight: 500;
  letter-spacing: -0.005em;
  border-radius: var(--radius);
  cursor: pointer;
  transition: all var(--speed) var(--ease);
  white-space: nowrap;
  text-decoration: none;
}

.btn-lg { padding: 1.05rem 1.85rem; font-size: 1rem; }

.btn-primary {
  background: var(--color-bark);
  color: var(--color-cream);
  box-shadow: var(--shadow-sm);
}
.btn-primary:hover {
  background: var(--color-ink);
  color: var(--color-cream);
  transform: translateY(-1px);
  box-shadow: var(--shadow);
}

.btn-ghost {
  color: var(--color-bark);
  background: transparent;
  border: 1px solid var(--color-line);
}
.btn-ghost:hover {
  background: var(--color-paper);
  border-color: var(--color-clay);
  color: var(--color-bark);
}

/* ── NAV — Editorial Masthead ────────────────────────────────────────── */
.nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 50;
  background: rgba(244, 248, 252, 0.88);
  backdrop-filter: saturate(180%) blur(14px);
  -webkit-backdrop-filter: saturate(180%) blur(14px);
  border-top: 1px solid var(--color-bark);
  border-bottom: 1px solid var(--color-line);
  transition: background-color 320ms var(--ease), transform 360ms var(--ease), border-bottom-color 320ms var(--ease);
  will-change: transform;
}
.nav.scrolled {
  background: rgba(244, 248, 252, 0.96);
  border-bottom-color: var(--color-bark);
}
.nav.nav-hidden { transform: translateY(-100%); }

body { padding-top: 132px; }
@media (max-width: 880px) {
  body { padding-top: 102px; }
  .nav-inner { height: 64px; }
  .nav-logo .brand-mark { height: 52px; }
  .nav-toptab-tagline { display: none; }
}
@media (max-width: 540px) {
  body { padding-top: 64px; }
  .nav-toptab { display: none; }
  .nav-logo .brand-mark { height: 44px; }
}

/* Top contact strip */
.nav-toptab {
  background: var(--color-paper);
  border-bottom: 1px solid var(--color-line);
}
.nav-toptab-inner {
  display: flex;
  align-items: center;
  gap: clamp(1rem, 2.5vw, 2rem);
  height: 36px;
  padding-top: 0;
  padding-bottom: 0;
  font-size: 0.8125rem;
  color: var(--color-stone);
}
.nav-toptab-item {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  color: var(--color-stone);
  font-weight: 500;
  letter-spacing: 0.005em;
  transition: color 220ms var(--ease);
}
.nav-toptab-tagline { font-weight: 400; letter-spacing: 0.01em; }
.nav-toptab-spacer { flex: 1; }
a.nav-toptab-item:hover { color: var(--color-bark); }
a.nav-toptab-item svg { color: var(--color-clay); }

.nav-inner {
  display: flex;
  align-items: stretch;
  gap: 0;
  height: 96px;
  padding: 0;
}

/* Brand block — left, separated by hairline */
.nav-logo {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0 clamp(1rem, 2vw, 1.5rem) 0 0;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1rem;
  color: var(--color-bark);
  letter-spacing: -0.015em;
  border-right: 1px solid var(--color-line);
}
.nav-logo .brand-mark {
  height: 72px;
  width: auto;
  display: block;
  object-fit: contain;
  transition: transform 600ms var(--ease);
}
.nav-logo:hover .brand-mark { transform: translateY(-1px) scale(1.05); }

/* Links — each one in its own column with a vertical hairline */
.nav-links {
  display: flex;
  align-items: stretch;
  margin: 0 auto;
}
.nav-links a {
  position: relative;
  display: flex;
  align-items: center;
  padding: 0 clamp(0.65rem, 1.2vw, 1.05rem);
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: 0.005em;
  white-space: nowrap;
  color: var(--color-stone);
  border-right: 1px solid var(--color-line);
  transition: color 220ms var(--ease), background-color 280ms var(--ease);
}
.nav-links a:first-child { border-left: 1px solid var(--color-line); }
.nav-links a::after {
  content: "";
  position: absolute;
  left: 0; right: 0;
  bottom: 0;
  height: 2px;
  background: var(--color-bark);
  transform: scaleX(0);
  transform-origin: center;
  transition: transform 320ms var(--ease);
}
.nav-links a:hover {
  color: var(--color-bark);
  background: rgba(61, 108, 168, 0.05);
}
.nav-links a:hover::after { transform: scaleX(1); }

/* CTA cell — flush right, dark, sharp edges, takes its own column */
.nav-cta {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0 clamp(1.1rem, 2vw, 1.6rem);
  height: 100%;
  font-size: 0.875rem;
  font-weight: 600;
  letter-spacing: -0.005em;
  color: var(--color-cream);
  background: var(--color-bark);
  border-radius: 0;
  border: 0;
  border-left: 1px solid var(--color-bark);
  box-shadow: none;
  transition: background-color 280ms var(--ease), letter-spacing 320ms var(--ease);
}
.nav-cta svg { transition: transform 280ms var(--ease); }
.nav-cta:hover {
  background: #0A1F3A;
  color: var(--color-cream);
  transform: none;
}
.nav-cta:hover svg { transform: translateX(3px); }

.nav-toggle {
  display: none;
  width: 32px;
  height: 32px;
  flex-direction: column;
  justify-content: center;
  gap: 4px;
  margin-left: auto;
}
.nav-toggle span {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--color-bark);
  border-radius: 2px;
  transition: transform var(--speed) var(--ease), opacity var(--speed) var(--ease);
}
.nav-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

.mobile-menu {
  display: none;
  flex-direction: column;
  gap: 0.5rem;
  padding: 1rem var(--gutter) 1.5rem;
  background: var(--color-cream);
  border-bottom: 1px solid var(--color-line);
}
.mobile-menu a {
  padding: 0.75rem 0;
  font-size: 1.0625rem;
  color: var(--color-bark);
  border-bottom: 1px solid var(--color-line);
}
.mobile-menu a.btn { border: 0; margin-top: 0.75rem; padding: 0.95rem 1.4rem; }

@media (max-width: 880px) {
  .nav-links, .nav-cta { display: none; }
  .nav-toggle { display: flex; }
  .mobile-menu[data-open="true"] { display: flex; }
}

/* ── HERO ─────────────────────────────────────────────────────────────── */
.hero {
  position: relative;
  padding: clamp(2rem, 4vw, 3.5rem) 0 clamp(3rem, 6vw, 5rem);
  overflow: hidden;
}

.hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

.blob {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  opacity: 0.5;
}
.blob-1 {
  width: 520px; height: 520px;
  top: -120px; right: -160px;
  background: radial-gradient(circle, var(--color-amber) 0%, transparent 70%);
  animation: float 22s ease-in-out infinite;
}
.blob-2 {
  width: 420px; height: 420px;
  bottom: -100px; left: -120px;
  background: radial-gradient(circle, #B8D4F0 0%, transparent 70%);
  animation: float 28s ease-in-out infinite reverse;
}

@keyframes float {
  0%, 100% { transform: translate(0, 0) scale(1); }
  50%      { transform: translate(40px, -30px) scale(1.05); }
}

.grain {
  position: absolute;
  inset: 0;
  opacity: 0.04;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/></filter><rect width='200' height='200' filter='url(%23n)'/></svg>");
  mix-blend-mode: multiply;
}

/* Hero flow-line — subtle decorative thread, sits BEHIND text and visuals.
   Fades in late so it doesn't pop in before the rest of the page settles. */
.hero-flowline {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  pointer-events: none;
  overflow: visible;
  /* start invisible, fade in after content reveal animations have run */
  opacity: 0;
  animation: flowlineEnter 1400ms cubic-bezier(0.33, 1, 0.68, 1) 1100ms forwards;
}
@keyframes flowlineEnter {
  from { opacity: 0; }
  to   { opacity: 1; }
}

/* Multiple flowing dashes — each line at a different speed */
.fl-d-1 { animation: flowDashMove 11s linear infinite; }
.fl-d-2 { animation: flowDashMove 9s linear infinite reverse; }
.fl-d-3 { animation: flowDashMove 13s linear infinite; }

@keyframes flowDashMove {
  from { stroke-dashoffset: 0; }
  to   { stroke-dashoffset: -1550; }  /* full cycle of dasharray (50–80 + 1500) */
}
.flowline-dot {
  filter: drop-shadow(0 0 3px rgba(10, 20, 66, 0.35));
}

@media (prefers-reduced-motion: reduce) {
  .hero-flowline { animation: none; opacity: 1; }
  .fl-d-1, .fl-d-2, .fl-d-3 { animation: none; }
  .flowline-dot animateMotion { display: none; }
}

.hero-inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: clamp(2rem, 4vw, 3.5rem);
  align-items: center;
}

.hero-copy h1 {
  margin: 0.85rem 0 1.5rem;
  max-width: 22ch;
}

/* Rotating words — words occupy the same grid cell, slide up + fade */
.rotating-words {
  display: inline-grid;
  grid-template-areas: "stack";
  vertical-align: bottom;
  position: relative;
  overflow: hidden;
  padding-bottom: 0.05em; /* prevent descender clipping */
}
.rotating-words em {
  grid-area: stack;
  font-style: italic;
  font-weight: 500;
  color: var(--color-clay);
  white-space: nowrap;
  opacity: 0;
  animation: rotateWord 16s infinite cubic-bezier(0.65, 0, 0.35, 1);
  animation-fill-mode: both;
}
.rotating-words em:nth-child(1) { animation-delay: 0s; }
.rotating-words em:nth-child(2) { animation-delay: 4s; }
.rotating-words em:nth-child(3) { animation-delay: 8s; }
.rotating-words em:nth-child(4) { animation-delay: 12s; }

@keyframes rotateWord {
  0%      { opacity: 0; transform: translateY(40%); }
  4%      { opacity: 1; transform: translateY(0); }
  22%     { opacity: 1; transform: translateY(0); }
  27%     { opacity: 0; transform: translateY(-40%); }
  99.9%   { opacity: 0; transform: translateY(-40%); }
  100%    { opacity: 0; transform: translateY(40%); }
}

@media (prefers-reduced-motion: reduce) {
  .rotating-words em { animation: none; opacity: 0; }
  .rotating-words em:first-child { opacity: 1; }
}
.hero-lead {
  font-size: 1.0625rem;
  max-width: 44ch;
  line-height: 1.55;
  color: var(--color-stone);
  margin-bottom: 1.5rem;
}

.hero-ctas {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
  margin-bottom: 1.75rem;
}

.hero-trust {
  display: flex;
  gap: clamp(1.5rem, 3vw, 2.5rem);
  flex-wrap: wrap;
  padding-top: 1.25rem;
  border-top: 1px solid var(--color-line);
}
.trust-item {
  display: flex;
  flex-direction: column;
  gap: 0.1rem;
}
.trust-item strong {
  font-family: var(--font-display);
  font-size: 1.375rem;
  font-weight: 600;
  color: var(--color-bark);
  letter-spacing: -0.02em;
  line-height: 1.1;
}
.trust-item span {
  font-size: 0.8125rem;
  color: var(--color-stone);
  line-height: 1.4;
}

/* Hero Visual */
.hero-visual {
  position: relative;
  display: flex;
  justify-content: flex-end;
  align-items: flex-start;   /* anchor the visual to the top of its column */
  align-self: start;          /* and the column itself starts at top of grid */
  min-height: 460px;
  padding-top: clamp(2.5rem, 3vw, 2.75rem);  /* badge aligns with first headline line */
  /* push the visual block past the column edge so the video sits further right */
  margin-right: clamp(-6rem, -6vw, -2.5rem);
}

.hero-card {
  background: var(--color-paper);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg);
  padding: 1.5rem;
  width: 100%;
  max-width: 360px;
}
.hero-card-1 {
  position: relative;
  z-index: 2;
  transform: rotate(-1.5deg);
}

/* Hero video — showcases the physical eHBA + SMC-B cards in motion */
.hero-video {
  position: relative;
  z-index: 2;
  width: 620px;
  max-width: 100%;
  aspect-ratio: 16 / 9;
  border-radius: 32px;
  overflow: hidden;
  isolation: isolate;                  /* fixes overflow + transform clipping */
  -webkit-mask-image: -webkit-radial-gradient(white, black); /* Safari clip fallback */
  background: var(--color-bark);
  box-shadow:
    0 1px 0 0 rgba(255, 255, 255, 0.6) inset,
    0 32px 64px -14px rgba(20, 49, 90, 0.34),
    0 12px 24px -10px rgba(20, 49, 90, 0.16);
  transform: rotate(-1.5deg);
  transition:
    transform 700ms cubic-bezier(0.33, 1, 0.68, 1),
    box-shadow 900ms cubic-bezier(0.4, 0, 0.2, 1);
  cursor: pointer;
}
.hero-video:hover {
  transform: rotate(0deg) scale(1.025) translateY(-4px);
  box-shadow:
    0 1px 0 0 rgba(255, 255, 255, 0.7) inset,
    0 44px 88px -16px rgba(20, 49, 90, 0.42),
    0 18px 36px -12px rgba(20, 49, 90, 0.22);
}
.hero-video video {
  transition: transform 1200ms cubic-bezier(0.33, 1, 0.68, 1);
}
.hero-video:hover video {
  transform: scale(1.05);
}
.hero-video video {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  border-radius: inherit;
}
/* subtle warm-tinted overlay so the cool blue video integrates with the
   warm-cream background of the hero — never washes out, just softens */
.hero-video-overlay {
  position: absolute;
  inset: 0;
  pointer-events: none;
  border-radius: inherit;
  background: linear-gradient(
    160deg,
    rgba(244, 248, 252, 0) 0%,
    rgba(244, 248, 252, 0) 55%,
    rgba(20, 49, 90, 0.18) 100%
  );
  mix-blend-mode: multiply;
}
/* Live badge on top-left of video — adds context */
.hero-video-badge {
  position: absolute;
  top: 14px;
  left: 14px;
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.35rem 0.75rem 0.35rem 0.65rem;
  background: rgba(20, 49, 90, 0.55);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid rgba(244, 248, 252, 0.18);
  border-radius: 999px;
  color: var(--color-cream);
  font-family: var(--font-display);
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.hvb-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--color-amber);
  box-shadow: 0 0 0 3px rgba(91, 143, 217, 0.25);
  animation: hvbPulse 2.4s ease-in-out infinite;
}
@keyframes hvbPulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%      { opacity: 0.55; transform: scale(0.85); }
}
.hero-card-2 {
  position: absolute;
  bottom: -1.5rem;
  right: -3.5rem;
  z-index: 3;
  max-width: 240px;
  padding: 1.25rem;
  transform: rotate(3deg);
  background: linear-gradient(135deg, var(--color-bark), #1E4475);
  color: var(--color-cream);
  border-color: transparent;
}

/* Card-3 — Partners + DE flag, sits top-right of the video */
.hero-card-3 {
  position: absolute;
  top: -1.25rem;
  right: -0.75rem;
  z-index: 3;
  width: max-content;
  max-width: 260px;
  padding: 0.85rem 1.1rem;
  transform: rotate(-1.5deg);
  background: var(--color-paper);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  box-shadow:
    0 1px 0 0 rgba(255, 255, 255, 0.7) inset,
    0 12px 28px -10px rgba(20, 49, 90, 0.20),
    0 4px 8px -4px rgba(20, 49, 90, 0.10);
}
.hc-flagrow {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  padding-bottom: 0.6rem;
  margin-bottom: 0.6rem;
  border-bottom: 1px solid var(--color-line);
}
.hc-flag {
  flex-shrink: 0;
  border-radius: 2px;
  box-shadow: 0 0 0 1px rgba(20, 49, 90, 0.15);
}
.hc-flaglabel {
  font-family: var(--font-display);
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-stone);
}
.hc-partnerlogos {
  display: flex;
  align-items: center;
  gap: 0.85rem;
}
.hc-partnerlogos img {
  height: 26px;
  width: auto;
  max-width: 84px;
  object-fit: contain;
  filter: grayscale(35%) opacity(0.92);
}
.hc-partnerdivider {
  display: inline-block;
  width: 1px;
  height: 18px;
  background: var(--color-line);
}

.hc-header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.8125rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-stone);
  padding-bottom: 1rem;
  margin-bottom: 1rem;
  border-bottom: 1px solid var(--color-line);
}
.hc-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--color-success);
  box-shadow: 0 0 0 4px rgba(107, 142, 90, 0.18);
}

.hc-row {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.5rem 0;
  font-size: 0.9375rem;
}
.hc-row-done { color: var(--color-success); }
.hc-row-done svg { color: var(--color-success); }
.hc-row-done span { color: var(--color-ink); }

.hc-row-active { color: var(--color-attention); }
.hc-row-active span { color: var(--color-ink); font-weight: 500; }

.hc-row-pending { color: var(--color-stone); }
.hc-row-pending span { color: var(--color-stone); }

.hc-spinner {
  width: 18px; height: 18px;
  border: 2px solid var(--color-line);
  border-top-color: var(--color-attention);
  border-radius: 50%;
  animation: spin 1.4s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

.hc-circle {
  width: 18px; height: 18px;
  border: 2px dashed var(--color-line);
  border-radius: 50%;
}

.hc-label {
  display: block;
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--color-amber);
  margin-bottom: 0.65rem;
}
.hc-amount {
  display: block;
  font-family: var(--font-display);
  font-size: 2.125rem;
  font-weight: 700;
  letter-spacing: -0.025em;
  color: var(--color-cream);
  line-height: 1;
  margin-bottom: 0.4rem;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.15);
}
.hc-note {
  display: block;
  font-size: 0.8125rem;
  font-weight: 500;
  color: rgba(244, 248, 252, 0.85);
  letter-spacing: 0.005em;
}

@media (max-width: 880px) {
  .hero-inner { grid-template-columns: 1fr; }
  .hero-visual { min-height: 320px; margin-top: 1rem; }
}

/* ── WAS IST TI — same standard treatment as other sections ────────────── */
.was-ist-ti {
  padding: clamp(3.5rem, 6vw, 5.5rem) 0;
  background: var(--color-paper);
  border-top: 1px solid var(--color-line);
  border-bottom: 1px solid var(--color-line);
}
.was-ist-ti .eyebrow-light {
  color: var(--color-clay);
}
.ti-banner-head {
  max-width: 720px;
  margin-bottom: clamp(2.5rem, 4vw, 3.5rem);
}
.ti-banner-head h2 {
  color: var(--color-bark);
  margin-top: 0.4rem;
  font-size: clamp(1.625rem, 2.5vw, 2.125rem);
}

/* Glossary — three terms in horizontal columns separated by hairlines */
.ti-glossary {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 1px solid rgba(61, 108, 168, 0.25);
}
.ti-term {
  padding: clamp(1.5rem, 2.5vw, 2rem) clamp(1.25rem, 2vw, 2rem);
  border-right: 1px solid rgba(61, 108, 168, 0.25);
}
.ti-term:last-child { border-right: none; }

.ti-term dt {
  display: flex;
  align-items: baseline;
  gap: 0.65rem;
  font-family: var(--font-display);
  font-size: 1.875rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--color-bark);
  margin-bottom: 0.4rem;
}
.ti-term-num {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.15em;
  color: var(--color-clay);
  font-family: var(--font-display);
}

.ti-term-def {
  display: block;
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--color-stone);
  margin-bottom: 1rem;
}

.ti-term-body {
  font-size: 0.9375rem;
  line-height: 1.6;
  color: var(--color-ink);
}
.ti-term-body strong {
  color: var(--color-bark);
  font-weight: 600;
}

/* Footer band beneath glossary */
.ti-banner-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1.5rem;
  margin-top: clamp(2rem, 3.5vw, 3rem);
  padding-top: clamp(1.5rem, 2.5vw, 2rem);
  border-top: 1px solid rgba(61, 108, 168, 0.25);
  font-size: 0.9375rem;
  color: var(--color-ink);
}
.ti-banner-foot strong { color: var(--color-bark); font-weight: 600; }

.ti-banner-link {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-weight: 500;
  color: var(--color-bark);
  text-decoration: underline;
  text-decoration-color: var(--color-clay);
  text-underline-offset: 4px;
  transition: color 220ms var(--ease), gap 280ms var(--ease);
}
.ti-banner-link:hover { color: var(--color-clay); gap: 0.65rem; }

@media (max-width: 880px) {
  .ti-glossary { grid-template-columns: 1fr; }
  .ti-term {
    border-right: none;
    border-bottom: 1px solid rgba(61, 108, 168, 0.25);
  }
  .ti-term:last-child { border-bottom: none; }
  .ti-banner-foot { justify-content: flex-start; }
}

/* ── ÜBER UNS ─────────────────────────────────────────────────────────── */
.ueber-uns {
  padding: clamp(4rem, 7vw, 6.5rem) 0;
}
.uu-grid {
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: clamp(2rem, 4vw, 4rem);
  align-items: start;
}
.uu-copy h2 { margin: 0.5rem 0 1.25rem; }
.uu-copy p {
  font-size: 1.0625rem;
  line-height: 1.65;
  margin-bottom: 1rem;
  max-width: 56ch;
}
.uu-quote {
  position: relative;
  padding: 1.5rem 1.5rem 1.5rem 2.5rem;
  margin: 2rem 0 0.5rem;
  font-family: var(--font-display);
  font-size: 1.125rem;
  font-style: italic;
  line-height: 1.55;
  color: var(--color-bark);
  background: var(--color-paper);
  border-left: 3px solid var(--color-clay);
  border-radius: 0 var(--radius) var(--radius) 0;
  max-width: 56ch;
}
.uu-quote-mark {
  font-family: var(--font-display);
  color: var(--color-amber);
  font-size: 1.5em;
  line-height: 1;
  font-style: normal;
}
.uu-quote-author {
  display: block;
  font-size: 0.875rem;
  color: var(--color-stone);
  font-weight: 500;
}

.uu-stats {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
  margin-top: 1rem;
}
.uu-stat {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  padding: 1.25rem 1.5rem;
  background: var(--color-paper);
  border: 1px solid var(--color-line);
  border-radius: var(--radius);
}
.uu-stat strong {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--color-bark);
  letter-spacing: -0.02em;
  line-height: 1.1;
}
.uu-stat span {
  font-size: 0.8125rem;
  color: var(--color-stone);
}

@media (max-width: 880px) {
  .uu-grid { grid-template-columns: 1fr; }
  .uu-stats { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 540px) {
  .uu-stats { grid-template-columns: 1fr; }
}

/* ── PROCESS ──────────────────────────────────────────────────────────── */
.process {
  padding: clamp(4rem, 7vw, 6.5rem) 0;
  background: var(--color-paper);
  border-top: 1px solid var(--color-line);
  border-bottom: 1px solid var(--color-line);
}

.steps {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.25rem;
  counter-reset: step;
}

.step {
  position: relative;
  padding: 1.75rem 1.5rem;
  background: var(--color-cream);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  transition: transform var(--speed) var(--ease), box-shadow var(--speed) var(--ease);
}
.step:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow);
  border-color: var(--color-clay);
}

.step-num {
  font-family: var(--font-display);
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-clay);
  letter-spacing: 0.05em;
  margin-bottom: 1.25rem;
}
.step h3 { margin-bottom: 0.5rem; }
.step p { font-size: var(--fs-small); }

@media (max-width: 880px) { .steps { grid-template-columns: 1fr 1fr; } }
@media (max-width: 540px) { .steps { grid-template-columns: 1fr; } }

/* ── SPLIT ────────────────────────────────────────────────────────────── */
.split {
  padding: clamp(4rem, 7vw, 6.5rem) 0;
}

.split-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(1.5rem, 4vw, 3rem);
}

.split-col {
  padding: clamp(1.75rem, 3vw, 2.5rem);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-line);
}
.split-pain {
  background: transparent;
}
.split-pain h2 { color: var(--color-stone); }
.split-gain {
  background: var(--color-paper);
  box-shadow: var(--shadow);
}

.split-col h2 { margin-bottom: 1.5rem; }

.checklist {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.checklist li {
  position: relative;
  padding-left: 1.85rem;
  font-size: var(--fs-small);
  color: var(--color-ink);
  line-height: 1.55;
}
.checklist-x li::before,
.checklist-check li::before {
  content: "";
  position: absolute;
  left: 0; top: 3px;
  width: 20px; height: 20px;
  border-radius: 50%;
  background-position: center;
  background-repeat: no-repeat;
  background-size: 12px 12px;
}
.checklist-x li {
  color: var(--color-stone);
  text-decoration: line-through;
  text-decoration-color: rgba(122, 107, 92, 0.3);
}
.checklist-x li::before {
  background-color: rgba(197, 123, 78, 0.12);
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12' fill='none'><path d='M3 3l6 6M9 3l-6 6' stroke='%23C57B4E' stroke-width='1.8' stroke-linecap='round'/></svg>");
}
.checklist-check li::before {
  background-color: rgba(107, 142, 90, 0.15);
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12' fill='none'><path d='M3 6.5L5 8.5l4-5' stroke='%236B8E5A' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/></svg>");
}

@media (max-width: 720px) { .split-inner { grid-template-columns: 1fr; } }

/* ── LEISTUNGEN / PRODUKTE ────────────────────────────────────────────── */
.leistungen {
  padding: clamp(4rem, 7vw, 6.5rem) 0;
  background: var(--color-paper);
  border-top: 1px solid var(--color-line);
  border-bottom: 1px solid var(--color-line);
}

.products {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  margin-bottom: 2.5rem;
}

.product {
  position: relative;
  display: flex;
  flex-direction: column;
  background: var(--color-cream);
  border-radius: var(--radius-lg);
  overflow: hidden;
  outline: 1px solid transparent;
  outline-offset: -1px;
  transition: outline-color 500ms cubic-bezier(0.4, 0, 0.2, 1);
}
.product:hover {
  outline-color: var(--color-clay);
}

.product-featured {
  /* badge handles the visual emphasis — no border needed */
}

.product-badge {
  position: absolute;
  top: 1rem;
  right: 1rem;
  z-index: 2;
  padding: 0.35rem 0.85rem;
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-cream);
  background: var(--color-bark);
  border-radius: 999px;
  box-shadow: 0 2px 8px rgba(20, 49, 90, 0.18);
}

.product-image {
  padding: clamp(0.75rem, 1.5vw, 1.25rem) clamp(1.25rem, 2.5vw, 2rem) 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.product-image img {
  width: 100%;
  height: auto;
  max-height: 440px;
  object-fit: contain;
  transition: transform 700ms cubic-bezier(0.4, 0, 0.2, 1);
}
.product:hover .product-image img {
  transform: scale(1.04);
}

.product-body {
  display: flex;
  flex-direction: column;
  flex: 1;
  padding: clamp(1rem, 2vw, 1.5rem) clamp(1.5rem, 2.5vw, 2rem) clamp(1.25rem, 2vw, 1.75rem);
}

.product-head { margin-bottom: 1.25rem; }
.product-head h3 { margin-bottom: 0.4rem; }
.product-head p { font-size: var(--fs-small); }

.product-microhead {
  font-family: var(--font-display);
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-clay);
  margin-bottom: 0.85rem;
}

/* Screen-reader only — keeps content for SEO/a11y, hides visually */
.sr-only {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.product-list {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin-bottom: 1rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--color-line);
}
.product-list li {
  position: relative;
  padding-left: 1.6rem;
  font-size: 0.9375rem;
  line-height: 1.55;
  color: var(--color-ink);
}
.product-list li::before {
  content: "";
  position: absolute;
  left: 0; top: 4px;
  width: 18px; height: 18px;
  border-radius: 50%;
  background-color: rgba(61, 108, 168, 0.15);
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 10 10' fill='none'><path d='M2 5l2 2 4-5' stroke='%238B6F47' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-position: center;
  background-repeat: no-repeat;
}

.product-cta {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 1rem;
  margin-top: auto;
  padding-top: 0.25rem;
}
.product-price {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.2rem;
}
.price-amount {
  font-family: var(--font-display);
  font-size: 2.25rem;
  font-weight: 700;
  letter-spacing: -0.025em;
  color: var(--color-bark);
  line-height: 1;
}
.price-note {
  font-size: 0.875rem;
  color: var(--color-stone);
}

.buy-button-target {
  display: flex;
  justify-content: center;
  width: 100%;
}

/* ── ENHANCED BUY BUTTON — centered, prominent, unmistakably-a-button ── */
.btn-buy {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.65rem;
  min-width: 240px;
  padding: 1.2rem 2.4rem;
  font-family: var(--font-display);
  font-size: 1.0625rem;
  font-weight: 600;
  letter-spacing: -0.005em;
  color: var(--color-cream);
  background: linear-gradient(135deg, var(--color-bark) 0%, #0A1F3A 100%);
  border: 0;
  border-radius: 999px;
  cursor: pointer;
  text-decoration: none;
  position: relative;
  overflow: hidden;
  box-shadow:
    0 1px 0 0 rgba(255, 255, 255, 0.12) inset,
    0 8px 20px rgba(20, 49, 90, 0.22),
    0 2px 6px rgba(20, 49, 90, 0.12);
  transition: transform var(--speed) var(--ease), box-shadow var(--speed) var(--ease);
}
.btn-buy::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, var(--color-clay) 0%, var(--color-bark) 100%);
  opacity: 0;
  transition: opacity var(--speed) var(--ease);
  z-index: 0;
}
.btn-buy > * { position: relative; z-index: 1; }
.btn-buy svg {
  transition: transform var(--speed) var(--ease);
}
.btn-buy:hover {
  color: var(--color-cream);
  transform: translateY(-3px);
  box-shadow:
    0 1px 0 0 rgba(255, 255, 255, 0.15) inset,
    0 16px 36px rgba(20, 49, 90, 0.32),
    0 6px 12px rgba(20, 49, 90, 0.18);
}
.btn-buy:hover::before { opacity: 1; }
.btn-buy:hover svg { transform: translateX(4px); }
.btn-buy:active { transform: translateY(0); }
.btn-buy:focus-visible {
  outline: 3px solid var(--color-amber);
  outline-offset: 3px;
}
/* Loading state — fired while we create the Storefront cart */
.btn-buy.is-loading {
  pointer-events: none;
  opacity: 0.85;
  cursor: progress;
}
.btn-buy.is-loading svg { opacity: 0.5; }

.leistungen-foot {
  text-align: center;
  font-size: var(--fs-small);
  color: var(--color-stone);
}
.leistungen-foot a {
  color: var(--color-bark);
  font-weight: 500;
  text-decoration: underline;
  text-decoration-color: var(--color-amber);
  text-underline-offset: 4px;
}

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

/* ── TRUST ────────────────────────────────────────────────────────────── */
.trust {
  padding: clamp(3.5rem, 6vw, 5.5rem) 0;
}

/* Editorial stat row — open layout, hairline dividers, no card wrapper */
.trust-numbers {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0;
  padding: clamp(2.5rem, 5vw, 4rem) 0;
  border-top: 1px solid var(--color-line);
  border-bottom: 1px solid var(--color-line);
  margin-bottom: clamp(2.5rem, 5vw, 4rem);
}

.num-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 0.6rem;
  padding: 0 clamp(0.75rem, 1.5vw, 1.25rem);
  position: relative;
}
.num-item:not(:last-child)::after {
  content: "";
  position: absolute;
  top: 12%;
  bottom: 12%;
  right: 0;
  width: 1px;
  background: var(--color-line);
}

.num-item strong {
  font-family: var(--font-display);
  font-size: clamp(2rem, 3.6vw, 3rem);
  font-weight: 700;
  letter-spacing: -0.03em;
  color: var(--color-bark);
  line-height: 0.95;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
.num-item span {
  font-size: 0.8125rem;
  color: var(--color-stone);
  line-height: 1.4;
  max-width: 18ch;
}

.partners {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.5rem;
  text-align: center;
}
.partners-label {
  font-size: var(--fs-eyebrow);
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-stone);
}
.partners-row {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: clamp(2.5rem, 6vw, 5rem);
}
.partner-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.5rem 0.75rem;
  border-radius: var(--radius);
  transition: background-color var(--speed) var(--ease), transform var(--speed) var(--ease);
}
.partner-link:hover {
  background-color: rgba(61, 108, 168, 0.08);
  transform: translateY(-2px);
}
.partner-link:focus-visible {
  outline: 2px solid var(--color-clay);
  outline-offset: 2px;
}
.partner-img {
  height: 88px;
  width: auto;
  max-width: 280px;
  object-fit: contain;
  filter: grayscale(60%) opacity(0.85);
  transition: filter var(--speed) var(--ease);
}
.partner-link:hover .partner-img {
  filter: grayscale(0%) opacity(1);
}
.partners-row:hover .partner-link:not(:hover) .partner-img {
  filter: grayscale(80%) opacity(0.5);
}
@media (max-width: 540px) {
  .partner-img { height: 64px; max-width: 220px; }
}

.partners-note {
  margin-top: 0.5rem;
  font-size: 0.875rem;
  color: var(--color-stone);
  max-width: 60ch;
  line-height: 1.55;
}
.partners-note strong { color: var(--color-bark); font-weight: 600; }

@media (max-width: 1024px) {
  .trust-numbers { grid-template-columns: repeat(3, 1fr); row-gap: 2.25rem; padding: 2.5rem 0; }
  .num-item:nth-child(3)::after { display: none; }
}
@media (max-width: 720px) {
  .trust-numbers { grid-template-columns: 1fr 1fr; row-gap: 2rem; padding: 2.5rem 0; }
  .num-item::after { display: none; }
  .num-item:nth-child(odd):not(:last-child) {
    border-right: 1px solid var(--color-line);
  }
  .partners-row { gap: 1.5rem; }
}
@media (max-width: 540px) {
  .trust-numbers { grid-template-columns: 1fr; row-gap: 1.5rem; }
  .num-item:nth-child(odd):not(:last-child) { border-right: none; }
  .num-item:not(:last-child) {
    padding-bottom: 1.5rem;
    border-bottom: 1px solid var(--color-line);
  }
}

/* ── TESTIMONIALS ─────────────────────────────────────────────────────── */
.stimmen {
  padding: clamp(4rem, 7vw, 6.5rem) 0;
  background: var(--color-paper);
  border-top: 1px solid var(--color-line);
  border-bottom: 1px solid var(--color-line);
}

.testimonials {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}

.testimonial {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  padding: 1.75rem;
  background: var(--color-cream);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  position: relative;
}
.testimonial::before {
  content: """;
  position: absolute;
  top: 0.5rem;
  left: 1.25rem;
  font-family: var(--font-display);
  font-size: 4rem;
  line-height: 1;
  color: var(--color-amber);
  opacity: 0.3;
}
.testimonial blockquote p {
  font-size: 1.0625rem;
  color: var(--color-ink);
  line-height: 1.55;
}
.testimonial figcaption {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  margin-top: auto;
  padding-top: 1.25rem;
  border-top: 1px solid var(--color-line);
}
.testimonial figcaption strong {
  font-size: 0.9375rem;
  color: var(--color-bark);
}
.testimonial figcaption span {
  font-size: 0.8125rem;
  color: var(--color-stone);
}

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

/* ── FAQ ──────────────────────────────────────────────────────────────── */
.faq { padding: clamp(4rem, 7vw, 6.5rem) 0; }

.faq-inner { max-width: var(--container-narrow); }

.faq-list {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.faq-item {
  border-bottom: 1px solid var(--color-line);
  padding: 0.5rem 0;
}
.faq-item summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 0;
  font-family: var(--font-display);
  font-size: 1.0625rem;
  font-weight: 500;
  color: var(--color-bark);
  cursor: pointer;
  list-style: none;
  transition: color var(--speed-fast) var(--ease);
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after {
  content: "";
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 20 20' fill='none'><path d='M5 8l5 5 5-5' stroke='%238B6F47' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  transition: transform var(--speed) var(--ease);
}
.faq-item[open] summary::after { transform: rotate(180deg); }
.faq-item summary:hover { color: var(--color-clay); }
.faq-item p {
  padding: 0.25rem 0 1.25rem;
  font-size: 1rem;
  max-width: 65ch;
}

/* ── WISSEN ───────────────────────────────────────────────────────────── */
.wissen {
  padding: clamp(4rem, 7vw, 6.5rem) 0;
  background: var(--color-paper);
  border-top: 1px solid var(--color-line);
  border-bottom: 1px solid var(--color-line);
}

.wissen-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}

.wissen-card {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  padding: 1.75rem;
  background: var(--color-cream);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  transition: transform var(--speed) var(--ease), box-shadow var(--speed) var(--ease);
  color: var(--color-ink);
}
.wissen-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow);
  border-color: var(--color-clay);
  color: var(--color-ink);
}
.wc-cat {
  display: inline-block;
  width: fit-content;
  padding: 0.25rem 0.6rem;
  font-size: 0.75rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-clay);
  background: rgba(61, 108, 168, 0.1);
  border-radius: var(--radius-sm);
  margin-bottom: 0.25rem;
}
.wissen-card h3 {
  font-size: 1.1875rem;
  margin-bottom: 0.25rem;
}
.wissen-card p { font-size: var(--fs-small); }
.wc-meta {
  margin-top: auto;
  padding-top: 1rem;
  font-size: 0.8125rem;
  color: var(--color-stone);
  border-top: 1px solid var(--color-line);
}

@media (max-width: 880px) { .wissen-cards { grid-template-columns: 1fr; } }

/* ── QUIZ FUNNEL ──────────────────────────────────────────────────────── */
.quiz-funnel {
  padding: clamp(4rem, 7vw, 6rem) 0;
  background: var(--color-paper);
  border-top: 1px solid var(--color-line);
  border-bottom: 1px solid var(--color-line);
}

/* INTRO */
.quiz-intro {
  max-width: var(--container-narrow);
  margin: 0 auto;
  text-align: center;
}
.quiz-intro h2 { margin: 0.5rem 0 1rem; }
.quiz-intro > p {
  font-size: 1.0625rem;
  line-height: 1.6;
  max-width: 60ch;
  margin: 0 auto 2rem;
}
.quiz-intro-actions {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.75rem;
}
.quiz-intro-meta { font-size: 0.875rem; color: var(--color-stone); }

/* PROGRESS BAR */
.quiz-stage {
  max-width: 720px;
  margin: 0 auto;
}
.quiz-progress {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 2.5rem;
}
.quiz-progress-bar {
  position: relative;
  flex: 1;
  height: 4px;
  background: var(--color-line);
  border-radius: 999px;
  overflow: hidden;
}
.quiz-progress-bar span {
  display: block;
  height: 100%;
  width: 0;
  background: var(--color-bark);
  border-radius: 999px;
  transition: width 500ms cubic-bezier(0.4, 0, 0.2, 1);
}
.quiz-progress-label {
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--color-stone);
  letter-spacing: 0.02em;
  white-space: nowrap;
}

/* QUESTION + OPTIONS */
.quiz-question {
  font-family: var(--font-display);
  font-size: clamp(1.375rem, 2.2vw, 1.75rem);
  font-weight: 600;
  line-height: 1.3;
  color: var(--color-bark);
  margin-bottom: 1.5rem;
  letter-spacing: -0.015em;
}
.quiz-options {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  margin-bottom: 2rem;
}
.quiz-option {
  display: flex;
  align-items: center;
  gap: 0.85rem;
  width: 100%;
  padding: 1.05rem 1.25rem;
  background: var(--color-cream);
  border: 1px solid var(--color-line);
  border-radius: var(--radius);
  font-family: var(--font-body);
  font-size: 1rem;
  font-weight: 500;
  text-align: left;
  color: var(--color-ink);
  cursor: pointer;
  transition:
    background-color 220ms var(--ease),
    border-color 220ms var(--ease),
    transform 220ms var(--ease);
}
.quiz-option-marker {
  flex-shrink: 0;
  width: 18px; height: 18px;
  border: 1.5px solid var(--color-line);
  border-radius: 50%;
  position: relative;
  transition: border-color 220ms var(--ease);
}
.quiz-option:hover {
  background: var(--color-paper);
  border-color: var(--color-clay);
}
.quiz-option:hover .quiz-option-marker { border-color: var(--color-clay); }
.quiz-option.selected,
.quiz-option:focus-visible {
  background: var(--color-paper);
  border-color: var(--color-bark);
  outline: none;
}
.quiz-option.selected .quiz-option-marker {
  border-color: var(--color-bark);
  background: var(--color-bark);
}
.quiz-option.selected .quiz-option-marker::after {
  content: "";
  position: absolute;
  inset: 4px;
  background: var(--color-cream);
  border-radius: 50%;
}

.quiz-controls {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.quiz-controls-spacer { flex: 1; }
.btn-text {
  background: none;
  border: 0;
  padding: 0.5rem 0.5rem;
  font-size: 0.875rem;
  color: var(--color-stone);
  text-decoration: underline;
  text-decoration-color: var(--color-line);
  text-underline-offset: 4px;
  cursor: pointer;
  transition: color 220ms var(--ease), text-decoration-color 220ms var(--ease);
}
.btn-text:hover { color: var(--color-bark); text-decoration-color: var(--color-clay); }

/* ANALYZING */
.quiz-analyzing {
  max-width: 480px;
  margin: 0 auto;
  text-align: center;
  padding: clamp(2rem, 4vw, 3.5rem) 0;
}
.quiz-analyzing-spinner {
  width: 48px; height: 48px;
  margin: 0 auto 1.25rem;
  border: 3px solid var(--color-line);
  border-top-color: var(--color-bark);
  border-radius: 50%;
  animation: quizSpin 1s linear infinite;
}
@keyframes quizSpin { to { transform: rotate(360deg); } }
.quiz-analyzing strong {
  display: block;
  font-family: var(--font-display);
  font-size: 1.125rem;
  color: var(--color-bark);
  margin-bottom: 1.25rem;
}
.quiz-analyzing-steps {
  list-style: none;
  padding: 0;
  text-align: left;
  max-width: 320px;
  margin: 0 auto;
}
.quiz-analyzing-steps li {
  position: relative;
  padding: 0.45rem 0 0.45rem 1.75rem;
  font-size: 0.9375rem;
  color: var(--color-stone);
  opacity: 0.4;
  transition: opacity 320ms var(--ease), color 320ms var(--ease);
}
.quiz-analyzing-steps li::before {
  content: "○";
  position: absolute;
  left: 0;
  color: var(--color-line);
  font-size: 0.875rem;
}
.quiz-analyzing-steps li.active {
  opacity: 1;
  color: var(--color-bark);
}
.quiz-analyzing-steps li.active::before {
  content: "✓";
  color: var(--color-success);
}

/* RESULT */
.quiz-result {
  max-width: 720px;
  margin: 0 auto;
  text-align: center;
}
.quiz-result h3 {
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  margin: 0.5rem 0 1rem;
}
.quiz-result-summary {
  font-size: 1.0625rem;
  line-height: 1.65;
  color: var(--color-stone);
  max-width: 56ch;
  margin: 0 auto 2.5rem;
}
.quiz-result-card {
  text-align: left;
  padding: 2rem;
  background: var(--color-cream);
  border: 1px solid var(--color-clay);
  border-radius: var(--radius-lg);
  margin-bottom: 1.5rem;
}

/* Calendar-only variant — qualified leads who don't need a package */
.quiz-result-card.quiz-result-card-cal {
  padding: clamp(2.5rem, 5vw, 4.5rem) clamp(1.5rem, 4vw, 3.5rem);
  background: linear-gradient(180deg, var(--color-paper) 0%, var(--color-cream) 100%);
  border: 1px solid var(--color-clay);
  text-align: center;
}
.qrc-cal-placeholder {
  max-width: 480px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.85rem;
}
.qrc-cal-icon {
  width: 80px;
  height: 80px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(61, 108, 168, 0.10);
  color: var(--color-bark);
  margin-bottom: 0.25rem;
}
.qrc-cal-placeholder strong {
  font-family: var(--font-display);
  font-size: clamp(1.375rem, 2.2vw, 1.75rem);
  font-weight: 600;
  color: var(--color-bark);
  letter-spacing: -0.015em;
  line-height: 1.2;
}
.qrc-cal-placeholder p {
  font-size: 0.9375rem;
  color: var(--color-stone);
  margin: 0 0 0.5rem;
}
.quiz-cal-cta {
  margin-top: 0.5rem;
  min-width: 280px;
}
.qrc-cal-alt {
  margin-top: 0.85rem;
  font-size: 0.8125rem;
  color: var(--color-stone);
}
.qrc-cal-alt a {
  color: var(--color-bark);
  text-decoration: underline;
  text-decoration-color: var(--color-clay);
  text-underline-offset: 3px;
}
.qrc-cal-alt a:hover { color: var(--color-clay); }
.qrc-badge {
  display: inline-block;
  padding: 0.3rem 0.75rem;
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-cream);
  background: var(--color-bark);
  border-radius: 999px;
  margin-bottom: 1rem;
}
.qrc-headline {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--color-bark);
  margin-bottom: 0.5rem;
}
.qrc-tagline {
  font-size: 1rem;
  color: var(--color-stone);
  margin-bottom: 1.25rem;
}
.qrc-bullets {
  list-style: none;
  padding: 0;
  margin: 0 0 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.qrc-bullets li {
  position: relative;
  padding-left: 1.5rem;
  font-size: 0.9375rem;
  line-height: 1.5;
  color: var(--color-ink);
}
.qrc-bullets li::before {
  content: "✓";
  position: absolute;
  left: 0;
  color: var(--color-clay);
  font-weight: 700;
}
.qrc-price {
  display: flex;
  align-items: baseline;
  gap: 0.6rem;
  padding-top: 1.25rem;
  border-top: 1px solid var(--color-line);
}
.qrc-price-amount {
  font-family: var(--font-display);
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--color-bark);
  line-height: 1;
}
.qrc-price-note {
  font-size: 0.875rem;
  color: var(--color-stone);
}

.quiz-result-actions {
  display: flex;
  gap: 0.75rem;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 1.5rem;
}

/* Newsletter (eliminated leads only) */
.quiz-newsletter {
  width: 100%;
  max-width: 520px;
  margin: 1.25rem auto 0;
  padding: 1.5rem;
  background: var(--color-paper);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  text-align: left;
}
.quiz-newsletter-lead {
  font-size: 0.9375rem;
  color: var(--color-stone);
  margin-bottom: 1rem;
}
.quiz-newsletter-form {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.quiz-newsletter-input {
  width: 100%;
  padding: 0.85rem 1rem;
  font-family: var(--font-body);
  font-size: 1rem;
  color: var(--color-ink);
  background: var(--color-cream);
  border: 1px solid var(--color-line);
  border-radius: var(--radius);
  transition: border-color 220ms var(--ease), background-color 220ms var(--ease);
}
.quiz-newsletter-input:focus {
  outline: none;
  border-color: var(--color-bark);
  background: #ffffff;
}
.quiz-newsletter-submit { width: 100%; }
.quiz-newsletter-msg {
  margin: 0.25rem 0 0;
  font-size: 0.8125rem;
  color: var(--color-stone);
  min-height: 1.2em;
}
.quiz-newsletter-msg.is-error { color: #B83A3A; }
.quiz-newsletter-msg.is-warning { color: var(--color-attention); }
.quiz-newsletter-success {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.4rem;
  padding: 0.75rem 0;
  text-align: center;
  color: var(--color-success);
}
.quiz-newsletter-success strong {
  font-family: var(--font-display);
  color: var(--color-bark);
  font-size: 1.0625rem;
}
.quiz-newsletter-success span { font-size: 0.875rem; color: var(--color-stone); }
.quiz-result-restart {
  display: block;
  margin: 0 auto;
}

@media (max-width: 540px) {
  .quiz-progress { flex-direction: column-reverse; align-items: flex-start; gap: 0.5rem; }
  .quiz-progress-label { white-space: normal; }
  .quiz-options { gap: 0.5rem; }
  .quiz-option { padding: 0.85rem 1rem; }
  .quiz-result-card { padding: 1.5rem; }
}

/* ── BERATUNG / FINAL CTA ─────────────────────────────────────────────── */
.beratung {
  padding: clamp(4rem, 8vw, 7rem) 0;
}
.beratung-inner {
  padding: clamp(2rem, 4vw, 3.5rem) clamp(1.75rem, 3vw, 3rem);
  background: linear-gradient(135deg, var(--color-paper) 0%, var(--color-cream) 100%);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow);
}

.beratung-grid {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: clamp(2rem, 4vw, 3.5rem);
  align-items: stretch;
}

.beratung-copy { display: flex; flex-direction: column; }
.beratung-copy h2 { margin: 0.5rem 0 1rem; }
.beratung-copy > p {
  max-width: 50ch;
  margin-bottom: 1.75rem;
}

.beratung-bullets {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-bottom: 2rem;
}
.beratung-bullets li {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  font-size: 0.9375rem;
  line-height: 1.5;
  color: var(--color-ink);
}
.beratung-bullets li svg { color: var(--color-clay); flex-shrink: 0; margin-top: 1px; }

.beratung-alt {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  margin-top: auto;
  padding-top: 1.5rem;
  border-top: 1px solid var(--color-line);
  font-size: 0.875rem;
  color: var(--color-stone);
}
.beratung-alt a {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  color: var(--color-bark);
  font-weight: 500;
  text-decoration: underline;
  text-decoration-color: var(--color-amber);
  text-underline-offset: 4px;
}
.beratung-alt a:hover { color: var(--color-clay); }
.beratung-alt .dot { color: var(--color-line); }

/* Calendly slot */
.beratung-booking { position: relative; }
.calendly-inline-widget {
  width: 100%;
  min-height: 640px;
  border-radius: var(--radius-lg);
  background: var(--color-paper);
  border: 1px solid var(--color-line);
  overflow: hidden;
}

.calendly-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  background:
    repeating-linear-gradient(
      135deg,
      rgba(61, 108, 168, 0.04) 0,
      rgba(61, 108, 168, 0.04) 12px,
      transparent 12px,
      transparent 24px
    ),
    var(--color-paper);
  border-style: dashed;
  border-color: var(--color-clay);
}
.cal-placeholder-inner {
  text-align: center;
  padding: 2.5rem 1.75rem;
  max-width: 360px;
}
.cal-placeholder-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 72px; height: 72px;
  margin-bottom: 1.25rem;
  background: rgba(61, 108, 168, 0.12);
  border-radius: 50%;
  color: var(--color-clay);
}
.cal-placeholder-inner strong {
  display: block;
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--color-bark);
  margin-bottom: 0.5rem;
}
.cal-placeholder-inner p {
  font-size: 0.9375rem;
  color: var(--color-stone);
  margin-bottom: 1.5rem;
  line-height: 1.5;
}
.cal-placeholder-inner .btn { width: 100%; }
.cal-placeholder-note {
  display: block;
  margin-top: 1rem;
  font-size: 0.8125rem;
  color: var(--color-stone);
  font-style: italic;
}

@media (max-width: 880px) {
  .beratung-grid { grid-template-columns: 1fr; }
  .calendly-inline-widget { min-height: 520px; }
}

/* Hero microcopy under CTAs */
.hero-microcopy {
  margin-top: -1.25rem;
  margin-bottom: 0.65rem;
  font-size: 0.875rem;
  color: var(--color-stone);
}

/* Quick-buy shortcut for users who already know what they need */
.hero-quickbuy {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem 0.75rem;
  margin-bottom: 1.75rem;
  font-size: 0.875rem;
  color: var(--color-stone);
}
.hero-quickbuy-link {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.4rem 0.75rem 0.4rem 0.85rem;
  background: rgba(61, 108, 168, 0.08);
  border: 1px solid transparent;
  border-radius: 999px;
  font-weight: 500;
  color: var(--color-bark);
  letter-spacing: -0.005em;
  transition:
    background-color 280ms var(--ease),
    border-color 280ms var(--ease),
    gap 280ms var(--ease);
}
.hero-quickbuy-link:hover {
  background: rgba(61, 108, 168, 0.14);
  border-color: var(--color-clay);
  color: var(--color-bark);
  gap: 0.75rem;
}
.hqb-prices {
  display: inline-block;
  padding: 0.1rem 0.5rem;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--color-cream);
  background: var(--color-bark);
  border-radius: 999px;
  letter-spacing: 0;
}
.hero-quickbuy-link svg {
  margin-left: 0.05rem;
  transition: transform 280ms var(--ease);
}
.hero-quickbuy-link:hover svg { transform: translate(2px, -2px); }

/* ── FOOTER ───────────────────────────────────────────────────────────── */
.footer {
  background: var(--color-bark);
  color: rgba(244, 248, 252, 0.8);
  padding: clamp(3rem, 5vw, 4.5rem) 0 1.5rem;
}

.footer-inner {
  display: grid;
  grid-template-columns: 1.4fr 2fr;
  gap: clamp(2rem, 4vw, 4rem);
  padding-bottom: 2.5rem;
  border-bottom: 1px solid rgba(244, 248, 252, 0.15);
  margin-bottom: 1.5rem;
}

.footer-logo {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  margin-bottom: 1rem;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.25rem;
  color: var(--color-cream);
}
.footer-logo svg { color: var(--color-amber); }
.footer-logo em { font-style: normal; font-weight: 400; opacity: 0.7; margin-left: 0.25rem; }

.footer-brand p {
  font-size: var(--fs-small);
  color: rgba(244, 248, 252, 0.65);
  max-width: 38ch;
}

.footer-cols {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
}
.footer-col {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.footer-col h4 {
  color: var(--color-cream);
  font-size: 0.9375rem;
  margin-bottom: 0.5rem;
}
.footer-col a {
  font-size: 0.9375rem;
  color: rgba(244, 248, 252, 0.65);
  transition: color var(--speed-fast) var(--ease);
}
.footer-col a:hover { color: var(--color-amber); }
.footer-address {
  display: block;
  margin-top: 0.5rem;
  font-size: 0.8125rem;
  line-height: 1.5;
  color: rgba(244, 248, 252, 0.55);
}

.footer-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.8125rem;
  color: rgba(244, 248, 252, 0.5);
  position: relative;
  z-index: 2;
  padding-bottom: 1.5rem;
}

/* Curved oversized brand wordmark anchored at the very bottom of the footer */
.footer-curved-word {
  margin-top: clamp(1.5rem, 3vw, 2.5rem);
  margin-bottom: -2rem;
  width: 100%;
  overflow: hidden;
  pointer-events: none;
}
.footer-curved-word svg {
  display: block;
  width: 100%;
  height: auto;
}
.footer-curved-text {
  font-family: var(--font-display);
  font-size: 200px;
  font-weight: 700;
  letter-spacing: 0.02em;
  fill: rgba(255, 255, 255, 0.96);
  text-transform: none;
}

@media (max-width: 880px) {
  .footer-curved-text { font-size: 140px; }
  .footer-curved-word { margin-bottom: -1.5rem; }
}
@media (max-width: 540px) {
  .footer-curved-text { font-size: 90px; }
  .footer-curved-word { margin-bottom: -1rem; }
}
.footer-legal { display: flex; gap: 1.5rem; }
.footer-legal a { color: rgba(244, 248, 252, 0.5); }
.footer-legal a:hover { color: var(--color-amber); }

@media (max-width: 880px) {
  .footer-inner { grid-template-columns: 1fr; }
  .footer-cols { grid-template-columns: 1fr 1fr; gap: 1.5rem; }
  .footer-bottom { flex-direction: column; gap: 1rem; align-items: flex-start; }
}

/* ── LEGAL PAGES (Impressum, Datenschutz, AGB) ───────────────────────── */
.legal-page {
  padding: clamp(2.5rem, 5vw, 4.5rem) 0 clamp(4rem, 7vw, 6rem);
}
.legal-head {
  max-width: var(--container-narrow);
  margin: 0 auto clamp(2.5rem, 4vw, 3.5rem);
  padding-bottom: 2rem;
  border-bottom: 1px solid var(--color-line);
}
.legal-head .eyebrow { margin-bottom: 0.75rem; }
.legal-head h1 {
  font-size: clamp(2rem, 3.6vw, 2.875rem);
  margin-bottom: 0.75rem;
}
.legal-head .legal-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 1.25rem;
  font-size: 0.875rem;
  color: var(--color-stone);
}
.legal-head .legal-meta strong { color: var(--color-bark); font-weight: 500; }

.legal-content {
  max-width: var(--container-narrow);
  margin: 0 auto;
  font-size: 1rem;
  line-height: 1.7;
  color: var(--color-ink);
}
.legal-content > section { margin-bottom: 3rem; }
.legal-content > section:last-child { margin-bottom: 0; }
.legal-content h2 {
  font-size: clamp(1.375rem, 2vw, 1.625rem);
  margin-bottom: 1rem;
  color: var(--color-bark);
  scroll-margin-top: 7rem;
}
.legal-content h3 {
  font-size: 1.0625rem;
  font-weight: 600;
  color: var(--color-bark);
  margin-top: 1.75rem;
  margin-bottom: 0.5rem;
  letter-spacing: -0.005em;
}
.legal-content p {
  margin-bottom: 1rem;
  color: var(--color-ink);
}
.legal-content ul, .legal-content ol {
  margin-bottom: 1rem;
  padding-left: 1.5rem;
}
.legal-content ul { list-style: disc; }
.legal-content ol { list-style: decimal; }
.legal-content li { margin-bottom: 0.4rem; line-height: 1.6; }
.legal-content a {
  color: var(--color-bark);
  text-decoration: underline;
  text-decoration-color: var(--color-amber);
  text-underline-offset: 3px;
}
.legal-content a:hover { color: var(--color-clay); }
.legal-content strong { color: var(--color-bark); font-weight: 600; }

.legal-content .info-block {
  display: grid;
  grid-template-columns: max-content 1fr;
  gap: 0.5rem 1.5rem;
  padding: 1.25rem 1.5rem;
  background: var(--color-paper);
  border: 1px solid var(--color-line);
  border-radius: var(--radius);
  font-size: 0.9375rem;
  margin: 1rem 0 1.5rem;
}
.legal-content .info-block dt { color: var(--color-stone); font-weight: 500; }
.legal-content .info-block dd { color: var(--color-ink); }

.legal-content .callout {
  padding: 1.25rem 1.5rem;
  background: var(--color-paper);
  border-left: 3px solid var(--color-clay);
  border-radius: 0 var(--radius) var(--radius) 0;
  margin: 1.5rem 0;
  font-size: 0.9375rem;
}
.legal-content .callout strong { display: block; margin-bottom: 0.35rem; }

.legal-toc {
  position: sticky;
  top: 130px;
  align-self: start;
  font-size: 0.875rem;
  padding: 1.25rem 0 1.25rem 1.25rem;
  border-left: 1px solid var(--color-line);
}
.legal-toc-title {
  display: block;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-clay);
  margin-bottom: 0.75rem;
  font-weight: 600;
}
.legal-toc ol { padding-left: 1.25rem; counter-reset: toc; }
.legal-toc li { margin-bottom: 0.45rem; }
.legal-toc a { color: var(--color-stone); transition: color 200ms var(--ease); text-decoration: none; }
.legal-toc a:hover { color: var(--color-bark); }

.legal-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 240px;
  gap: clamp(2rem, 4vw, 3.5rem);
  max-width: var(--container);
  margin: 0 auto;
}
.legal-grid .legal-content { margin: 0; max-width: none; }
@media (max-width: 880px) {
  .legal-grid { grid-template-columns: 1fr; }
  .legal-toc { display: none; }
}

/* ═══════════════════════════════════════════════════════════════════════
   SUBPAGE: WAS IST TI — Editorial Long-Form
   Unique DNA: serif accents (Fraunces), drop caps, side asides, pull quotes,
   roman numerals as section anchors, scroll-progress bar.
   ═══════════════════════════════════════════════════════════════════════ */

.page-wit { background: var(--color-cream); }

/* Scroll-progress bar pinned above nav */
.wit-scroll-bar {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: rgba(20, 49, 90, 0.05);
  z-index: 100;
}
.wit-scroll-bar > span {
  display: block;
  height: 100%;
  background: linear-gradient(90deg, var(--color-clay), var(--color-bark));
  transform-origin: left center;
  transform: scaleX(0);
  transition: transform 80ms linear;
}

.wit-main {
  --wit-text-max: 680px;
  --wit-art-max: 880px;
  font-family: var(--font-body);
  color: var(--color-ink);
}

.wit-article {
  max-width: var(--wit-art-max);
  margin: 0 auto;
}

/* HERO — type-only, generous whitespace */
.wit-hero {
  padding: clamp(3rem, 6vw, 5.5rem) 0 clamp(2.5rem, 5vw, 4.5rem);
  border-bottom: 1px solid var(--color-line);
}
.wit-hero-inner { max-width: var(--wit-art-max); }
.wit-hero-eyebrow {
  display: inline-block;
  font-family: var(--font-display);
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  color: var(--color-clay);
  margin-bottom: 1.5rem;
}
.wit-hero-title {
  font-family: 'Fraunces', Georgia, serif;
  font-size: clamp(2.25rem, 5.2vw, 4.5rem);
  font-weight: 500;
  line-height: 1.05;
  letter-spacing: -0.025em;
  color: var(--color-bark);
  margin: 0 0 1.5rem;
  max-width: 18ch;
}
.wit-hero-title em {
  font-weight: 700;
  font-style: italic;
  color: var(--color-clay);
}
.wit-hero-lead {
  font-size: 1.1875rem;
  line-height: 1.55;
  color: var(--color-stone);
  max-width: 56ch;
  margin: 0 0 2.5rem;
}

/* Inline TOC inside hero */
.wit-hero-toc {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 1.5rem;
  padding-top: 1.75rem;
  border-top: 1px solid var(--color-line);
}
.wit-toc-label {
  font-family: var(--font-display);
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-clay);
}
.wit-toc-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 1.25rem;
  counter-reset: toc;
}
.wit-toc-list li { font-size: 0.9375rem; }
.wit-toc-list a {
  color: var(--color-stone);
  text-decoration: none;
  transition: color 220ms var(--ease);
}
.wit-toc-list a:hover { color: var(--color-bark); }

/* Section structure */
.wit-section {
  padding: clamp(3rem, 6vw, 5rem) 0;
}
.wit-section + .wit-section { border-top: 1px solid var(--color-line); }
.wit-section-head {
  max-width: var(--wit-art-max);
  margin: 0 auto clamp(2rem, 4vw, 3rem);
  position: relative;
  padding-left: clamp(0, 4vw, 4.5rem);
}
.wit-numeral {
  position: absolute;
  left: 0; top: -0.25rem;
  font-family: 'Fraunces', Georgia, serif;
  font-size: clamp(2.5rem, 5vw, 4.5rem);
  font-weight: 500;
  line-height: 1;
  color: var(--color-clay);
  letter-spacing: -0.04em;
}
.wit-section-title {
  font-family: 'Fraunces', Georgia, serif;
  font-weight: 500;
  font-size: clamp(1.625rem, 3vw, 2.5rem);
  line-height: 1.12;
  letter-spacing: -0.02em;
  color: var(--color-bark);
  margin: 0 0 0.65rem;
  max-width: 24ch;
}
.wit-section-lead {
  font-size: 1.0625rem;
  line-height: 1.55;
  color: var(--color-stone);
  max-width: 56ch;
}

/* Prose — long-form reading column */
.wit-prose {
  max-width: var(--wit-text-max);
}
.wit-prose p {
  font-size: 1.0625rem;
  line-height: 1.75;
  margin: 0 0 1.5rem;
  color: var(--color-ink);
}
.wit-prose strong { color: var(--color-bark); font-weight: 600; }
.wit-prose em { font-style: italic; color: var(--color-clay); }
.wit-prose a {
  color: var(--color-bark);
  text-decoration: underline;
  text-decoration-color: var(--color-clay);
  text-underline-offset: 3px;
}

/* Drop cap — first paragraph */
.wit-dropcap .wit-drop {
  float: left;
  font-family: 'Fraunces', Georgia, serif;
  font-size: 4.75em;
  font-weight: 700;
  line-height: 0.85;
  margin: 0.1em 0.12em -0.05em -0.05em;
  color: var(--color-bark);
}

/* Side asides — visually distinct, indented panels */
.wit-aside {
  position: relative;
  margin: 2rem 0;
  padding: 1.25rem 1.5rem 1.25rem 1.75rem;
  background: var(--color-paper);
  border-left: 3px solid var(--color-clay);
  border-radius: 0 var(--radius) var(--radius) 0;
  font-size: 0.9375rem;
  line-height: 1.55;
  color: var(--color-ink);
}
.wit-aside-label {
  display: block;
  font-family: var(--font-display);
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-clay);
  margin-bottom: 0.4rem;
}
.wit-aside strong { color: var(--color-bark); font-weight: 600; }

/* Pull-quote — large editorial type */
.wit-pullquote {
  margin: 2.5rem 0;
  padding: 0.5rem 0 0.5rem 1.5rem;
  border-left: 4px solid var(--color-clay);
  font-family: 'Fraunces', Georgia, serif;
  font-size: clamp(1.375rem, 2.4vw, 1.875rem);
  font-style: italic;
  font-weight: 500;
  line-height: 1.3;
  color: var(--color-bark);
  letter-spacing: -0.01em;
}

/* Components grid (§ II) */
.wit-comp-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(1.25rem, 2.5vw, 2rem);
  max-width: var(--wit-art-max);
  margin: 0 auto;
}
.wit-comp {
  display: flex;
  flex-direction: column;
  padding: 2rem;
  background: var(--color-paper);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  transition: transform 600ms cubic-bezier(0.33, 1, 0.68, 1),
              border-color 400ms var(--ease);
}
.wit-comp:hover {
  transform: translateY(-4px);
  border-color: var(--color-clay);
}
.wit-comp-head {
  border-bottom: 1px solid var(--color-line);
  padding-bottom: 1rem;
  margin-bottom: 1rem;
}
.wit-comp-num {
  display: block;
  font-family: var(--font-display);
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.15em;
  color: var(--color-clay);
  margin-bottom: 0.4rem;
}
.wit-comp-head h3 {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 1.875rem;
  font-weight: 700;
  color: var(--color-bark);
  margin: 0 0 0.2rem;
  letter-spacing: -0.02em;
}
.wit-comp-full {
  display: block;
  font-size: 0.8125rem;
  color: var(--color-stone);
  font-weight: 500;
}
.wit-comp-tagline {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-size: 1.0625rem;
  color: var(--color-bark);
  margin: 0 0 1rem;
}
.wit-comp p {
  font-size: 0.9375rem;
  line-height: 1.55;
  color: var(--color-ink);
  margin: 0 0 1.25rem;
}
.wit-comp-meta {
  display: grid;
  grid-template-columns: max-content 1fr;
  column-gap: 0.85rem;
  row-gap: 0.4rem;
  margin: 0;
  padding-top: 1rem;
  border-top: 1px dashed var(--color-line);
  font-size: 0.8125rem;
}
.wit-comp-meta dt { color: var(--color-stone); font-weight: 500; }
.wit-comp-meta dd { color: var(--color-bark); margin: 0; }
.wit-comp-foot {
  max-width: var(--wit-art-max);
  margin: 2rem auto 0;
  font-size: 0.9375rem;
  color: var(--color-stone);
  text-align: center;
  line-height: 1.6;
}

/* Timeline (§ III) */
.wit-timeline {
  list-style: none;
  padding: 0;
  margin: 0 auto;
  max-width: var(--wit-art-max);
  position: relative;
}
.wit-timeline::before {
  content: "";
  position: absolute;
  left: 90px;
  top: 0;
  bottom: 0;
  width: 1px;
  background: var(--color-line);
}
.wit-tl-item {
  position: relative;
  padding: 1.25rem 0 1.25rem 130px;
  min-height: 80px;
}
.wit-tl-item::before {
  content: "";
  position: absolute;
  left: 84px;
  top: 1.85rem;
  width: 13px;
  height: 13px;
  border-radius: 50%;
  background: var(--color-cream);
  border: 2px solid var(--color-clay);
  z-index: 1;
}
.wit-tl-highlight::before {
  background: var(--color-bark);
  border-color: var(--color-bark);
  width: 16px;
  height: 16px;
  left: 82px;
  top: 1.7rem;
}
.wit-tl-year {
  position: absolute;
  left: 0;
  top: 1.4rem;
  width: 70px;
  text-align: right;
  font-family: 'Fraunces', Georgia, serif;
  font-size: 1.375rem;
  font-weight: 700;
  color: var(--color-bark);
  letter-spacing: -0.02em;
}
.wit-tl-item h3 {
  font-family: var(--font-display);
  font-size: 1.0625rem;
  font-weight: 600;
  color: var(--color-bark);
  margin: 0 0 0.35rem;
}
.wit-tl-item p {
  font-size: 0.9375rem;
  line-height: 1.6;
  color: var(--color-ink);
  margin: 0;
  max-width: 60ch;
}
.wit-tl-highlight h3 { color: var(--color-clay); }

/* Money card (§ IV) */
.wit-money-card {
  margin: 2rem 0;
  padding: 1.75rem;
  background: linear-gradient(135deg, var(--color-bark), #1E4475);
  border-radius: var(--radius-lg);
  color: var(--color-cream);
}
.wit-money-eyebrow {
  display: block;
  font-family: var(--font-display);
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-amber);
  margin-bottom: 1rem;
}
.wit-money-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9375rem;
}
.wit-money-table td {
  padding: 0.65rem 0;
  border-bottom: 1px solid rgba(244, 248, 252, 0.15);
}
.wit-money-table tr:last-child td { border-bottom: none; }
.wit-money-num {
  text-align: right;
  font-family: 'Fraunces', Georgia, serif;
  font-weight: 600;
  font-size: 1rem;
  letter-spacing: -0.01em;
  white-space: nowrap;
}
.wit-money-row-sum td {
  padding-top: 1rem;
  border-top: 2px solid var(--color-amber) !important;
}
.wit-money-row-sum strong {
  color: var(--color-amber);
  font-size: 1.25rem;
}
.wit-money-note {
  margin-top: 1.25rem;
  font-size: 0.75rem;
  color: rgba(244, 248, 252, 0.65);
  font-style: italic;
  line-height: 1.5;
}

/* Conclusion list */
.wit-conclusion-list {
  list-style: none;
  padding: 0;
  margin: 1.5rem 0 2.5rem;
  display: grid;
  gap: 1rem;
}
.wit-conclusion-list li {
  position: relative;
  padding: 1rem 1rem 1rem 3rem;
  background: var(--color-paper);
  border-radius: var(--radius);
  font-size: 1.0625rem;
  line-height: 1.55;
  color: var(--color-ink);
}
.wit-conclusion-list li::before {
  counter-increment: conclude;
  content: counter(conclude, decimal-leading-zero);
  position: absolute;
  left: 1rem;
  top: 1rem;
  font-family: 'Fraunces', Georgia, serif;
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-clay);
}
.wit-conclusion-list { counter-reset: conclude; }

/* Final CTA block */
.wit-cta-block {
  margin: 2.5rem 0;
  padding: clamp(1.75rem, 3.5vw, 2.5rem);
  background: var(--color-paper);
  border: 1px solid var(--color-clay);
  border-radius: var(--radius-lg);
  text-align: center;
}
.wit-cta-block h3 {
  font-family: 'Fraunces', Georgia, serif;
  font-size: clamp(1.375rem, 2.4vw, 1.75rem);
  font-weight: 600;
  color: var(--color-bark);
  margin: 0 0 0.65rem;
}
.wit-cta-block p {
  font-size: 1rem;
  color: var(--color-stone);
  max-width: 55ch;
  margin: 0 auto 1.5rem;
  line-height: 1.55;
}
.wit-cta-actions {
  display: flex;
  gap: 0.75rem;
  justify-content: center;
  flex-wrap: wrap;
}

/* End mark — typographic finale */
.wit-end-mark {
  text-align: center;
  font-family: 'Fraunces', Georgia, serif;
  font-size: 2rem;
  color: var(--color-clay);
  margin: 3rem 0 0;
  opacity: 0.6;
}

/* Active nav state */
.nav-links a.active {
  color: var(--color-bark);
  background: rgba(61, 108, 168, 0.1);
}
.nav-links a.active::after {
  transform: scaleX(1);
}

/* Mobile */
@media (max-width: 880px) {
  .wit-comp-grid { grid-template-columns: 1fr; }
  .wit-section-head { padding-left: 0; }
  .wit-numeral {
    position: static;
    display: block;
    margin-bottom: 0.5rem;
    font-size: 3rem;
  }
  .wit-timeline::before { left: 18px; }
  .wit-tl-item { padding-left: 60px; }
  .wit-tl-item::before { left: 12px; }
  .wit-tl-highlight::before { left: 10px; }
  .wit-tl-year {
    position: static;
    display: block;
    width: auto;
    text-align: left;
    margin-bottom: 0.4rem;
  }
  .wit-toc-list { gap: 0.4rem 1rem; }
  .wit-dropcap .wit-drop { font-size: 4em; }
  .wit-pullquote { padding-left: 1rem; }
}
@media (max-width: 540px) {
  .wit-aside { padding: 1rem 1.25rem; }
  .wit-money-card { padding: 1.25rem; }
  .wit-money-table { font-size: 0.875rem; }
}

/* ── REVEAL ANIMATIONS ────────────────────────────────────────────────── */
.reveal {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 700ms var(--ease), transform 700ms var(--ease);
}
.reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
  .reveal { opacity: 1; transform: none; }
  html { scroll-behavior: auto; }
}
