/* =============================================================
   LANDING PAGE — App-aligned (Pass 12)
   Tokens mirror app.blitzdoc.ch/globals.css so the landing and
   app feel like one product:
     • Sky Blue #1E6FD9 primary
     • Deep navy #0B2545 ink / hero surfaces
     • Cool white #F5F8FC page / #FFFFFF cards
     • Fraunces display + Inter body
   Scoped to body.landing-page so other legacy pages keep theirs.
   ============================================================= */

body.landing-page {
  overflow-x: hidden;
  /* Deep navy ink + hero surfaces — matches app --indigo-900 */
  --ln-navy: #0B2545;
  --ln-charcoal: #133A6B;
  /* Sky Blue primary — matches app --indigo-700 (var name kept as
     --ln-red for back-compat with existing rule set; value is blue) */
  --ln-red: #1E6FD9;
  --ln-red-dark: #133A6B;
  --ln-red-glow: rgba(30, 111, 217, 0.12);
  /* Cool white surfaces */
  --ln-white: #F5F8FC;
  --ln-cream: #FFFFFF;
  --ln-warm-gray: #4A5A7A;
  --ln-light-gray: #8C98B0;
  --ln-border: #D9E2EF;
  /* Typography — Fraunces display + Inter body, matches app */
  --ln-serif: 'Fraunces', 'Iowan Old Style', Georgia, 'Times New Roman', serif;
  --ln-sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Switzer', sans-serif;
  --ln-mono: 'JetBrains Mono', 'SF Mono', Menlo, Consolas, monospace;
  font-family: var(--ln-sans);
  color: var(--ln-navy);
  background: var(--ln-white);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Fraunces variable axes tuning — large-size refined display.
   Applied to all headlines on the landing. */
body.landing-page h1,
body.landing-page h2,
body.landing-page h3,
body.landing-page .ln-serif {
  font-family: var(--ln-serif);
  font-variation-settings: "opsz" 72, "SOFT" 30;
  font-weight: 500;
  letter-spacing: -0.02em;
}

/* Brand wordmark — italic "Blitz" + roman "Doc", matches app sidebar. */
body.landing-page .brand-wordmark {
  display: inline-flex;
  align-items: baseline;
  gap: 0;
  font-family: var(--ln-serif);
  font-variation-settings: "opsz" 48, "SOFT" 30;
  font-weight: 500;
  letter-spacing: -0.015em;
}
body.landing-page .brand-wordmark .logo-blitz {
  font-style: italic;
  font-weight: 500;
}
body.landing-page .brand-wordmark .logo-doc {
  font-style: normal;
  font-weight: 600;
}

/* --- Swiss Cross Pattern Background --- */
.ln-swiss-pattern {
  position: relative;
  overflow: hidden;
}
.ln-swiss-pattern::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(circle at 20% 30%, rgba(59,130,246,0.03) 0%, transparent 50%),
    radial-gradient(circle at 80% 70%, rgba(59,130,246,0.02) 0%, transparent 50%);
  pointer-events: none;
}

/* --- Landing Nav (transparent → solid) --- */
body.landing-page .nav {
  background: transparent;
  border-bottom: none;
  transition: background 0.3s ease, box-shadow 0.3s ease, border-bottom 0.3s ease;
}
body.landing-page .nav.nav-scrolled {
  background: rgba(255,255,255,0.97);
  border-bottom: 1px solid var(--ln-border);
  box-shadow: 0 1px 8px rgba(0,0,0,0.04);
  backdrop-filter: blur(12px);
}
body.landing-page .nav .nav-logo {
  font-family: var(--ln-sans);
  font-weight: 700;
  letter-spacing: -0.02em;
}
body.landing-page .nav .logo-blitz { color: #fff; }
body.landing-page .nav.nav-scrolled .logo-blitz { color: var(--ln-navy); }
body.landing-page .nav-links a {
  font-family: var(--ln-sans);
  font-weight: 500;
  font-size: 14px;
  letter-spacing: 0.01em;
}
body.landing-page .nav:not(.nav-scrolled) .nav-login {
  color: #fff !important;
  border-color: rgba(255,255,255,0.35) !important;
}
body.landing-page .nav:not(.nav-scrolled) .nav-login:hover {
  border-color: #fff !important;
  background: rgba(255,255,255,0.1) !important;
}

/* --- Hero Section --- */
.ln-hero {
  min-height: 100vh;
  display: flex;
  align-items: center;
  padding: 120px 0 80px;
  background: var(--ln-navy);
  position: relative;
  overflow: hidden;
}
.ln-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(135deg, rgba(59,130,246,0.04) 0%, transparent 40%),
    linear-gradient(315deg, rgba(59,130,246,0.02) 0%, transparent 50%);
  pointer-events: none;
}
/* Geometric grid pattern */
.ln-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.02) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
}
.ln-hero-inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 40px;
  align-items: center;
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 24px;
}
.ln-hero-text h1 {
  font-family: var(--ln-serif);
  font-size: clamp(2.4rem, 5vw, 3.8rem);
  font-weight: 700;
  line-height: 1.1;
  color: #fff;
  letter-spacing: -0.03em;
  margin-bottom: 24px;
}
.ln-hero-text h1 .ln-accent {
  color: var(--ln-red);
  display: block;
}
.ln-hero-subtitle {
  font-size: 18px;
  line-height: 1.7;
  color: rgba(255,255,255,0.6);
  max-width: 480px;
  margin-bottom: 36px;
  font-weight: 400;
}
.ln-hero-cta {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 16px 36px;
  background: var(--ln-red);
  color: #fff;
  font-family: var(--ln-sans);
  font-size: 16px;
  font-weight: 600;
  border-radius: 6px;
  text-decoration: none;
  letter-spacing: 0.01em;
  transition: all 0.2s ease;
  border: none;
  cursor: pointer;
}
.ln-hero-cta:hover {
  background: var(--ln-red-dark);
  transform: translateY(-1px);
  box-shadow: 0 8px 24px rgba(59,130,246,0.3);
}
.ln-hero-note {
  font-size: 13px;
  color: rgba(255,255,255,0.4);
  margin-top: 16px;
}

.ln-hero-kicker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  margin-bottom: 20px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.05);
  color: rgba(255,255,255,0.72);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.ln-hero-proof {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: 28px;
  max-width: 580px;
}

.ln-hero-proof-item {
  padding: 14px 14px 16px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.04);
}

.ln-hero-proof-item strong {
  display: block;
  margin-bottom: 6px;
  color: #fff;
  font-size: 18px;
  font-weight: 700;
  letter-spacing: -0.03em;
}

.ln-hero-proof-item span {
  display: block;
  color: rgba(255,255,255,0.58);
  font-size: 12px;
  line-height: 1.5;
}

/* Hero Video Teaser */
.ln-hero-video-wrap {
  overflow: hidden;
  border-radius: 16px;
  box-shadow: 0 20px 40px rgba(0,0,0,0.4);
}
.ln-hero-teaser {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Hero Demo Animation */
.ln-hero-demo {
  position: relative;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 12px;
  padding: 0;
  overflow: hidden;
  box-shadow: 0 20px 60px rgba(0,0,0,0.3);
}
.ln-demo-header {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 16px;
  background: rgba(255,255,255,0.06);
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.ln-demo-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: rgba(255,255,255,0.15);
}
.ln-demo-dot:first-child { background: #FF5F56; }
.ln-demo-dot:nth-child(2) { background: #FFBD2E; }
.ln-demo-dot:nth-child(3) { background: #27C93F; }
.ln-demo-title {
  font-size: 12px;
  color: rgba(255,255,255,0.4);
  margin-left: 8px;
  font-family: var(--ln-sans);
}
.ln-demo-body {
  padding: 24px;
  min-height: 320px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.ln-demo-input {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 8px;
  padding: 16px;
}
.ln-demo-input-label {
  font-size: 11px;
  font-weight: 600;
  color: rgba(255,255,255,0.3);
  text-transform: uppercase;
  letter-spacing: 1.5px;
  margin-bottom: 8px;
}
.ln-demo-keywords {
  font-size: 14px;
  color: rgba(255,255,255,0.7);
  line-height: 1.6;
  font-family: 'SF Mono', 'Fira Code', 'Cascadia Code', monospace;
  min-height: 40px;
}
.ln-demo-keywords .ln-cursor {
  display: inline-block;
  width: 2px;
  height: 16px;
  background: var(--ln-red);
  margin-left: 2px;
  vertical-align: text-bottom;
  animation: ln-blink 1s step-end infinite;
}
@keyframes ln-blink {
  0%, 100% { opacity: 1; }
  50% { opacity: 0; }
}
.ln-demo-output {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 8px;
  padding: 16px;
  opacity: 0;
  transform: translateY(8px);
  transition: all 0.5s ease;
}
.ln-demo-output.ln-visible {
  opacity: 1;
  transform: translateY(0);
}
.ln-demo-output-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--ln-red);
  text-transform: uppercase;
  letter-spacing: 1.5px;
  margin-bottom: 10px;
  display: flex;
  align-items: center;
  gap: 6px;
}
.ln-demo-output-label::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--ln-red);
  animation: ln-pulse 2s ease-in-out infinite;
}
@keyframes ln-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.5; transform: scale(1.3); }
}
.ln-demo-soap {
  font-size: 13px;
  color: rgba(255,255,255,0.6);
  line-height: 1.7;
}
.ln-demo-soap strong {
  color: rgba(255,255,255,0.85);
  font-weight: 600;
}
.ln-demo-soap .ln-soap-line {
  opacity: 0;
  transform: translateX(-4px);
  transition: all 0.3s ease;
}
.ln-demo-soap .ln-soap-line.ln-visible {
  opacity: 1;
  transform: translateX(0);
}
.ln-demo-icd {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 12px;
  opacity: 0;
  transition: opacity 0.4s ease;
}
.ln-demo-icd.ln-visible { opacity: 1; }
.ln-demo-icd-chip {
  font-size: 11px;
  padding: 4px 10px;
  background: rgba(59,130,246,0.1);
  color: rgba(255,255,255,0.7);
  border-radius: 4px;
  font-weight: 500;
  border: 1px solid rgba(59,130,246,0.15);
}

/* --- Trust Bar (below hero) --- */
.ln-trust-bar {
  display: flex;
  justify-content: center;
  gap: 40px;
  flex-wrap: wrap;
  padding: 20px 24px;
  background: var(--ln-white);
  border-bottom: 1px solid var(--ln-border);
}
.ln-trust-item {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13px;
  color: var(--ln-warm-gray);
  font-weight: 500;
  font-family: var(--ln-sans);
}
.ln-trust-item svg {
  flex-shrink: 0;
}

/* --- Explainer Video Section --- */
.ln-video-section {
  padding: 80px 0 100px;
  background: var(--ln-white);
  text-align: center;
}
.ln-video-inner {
  max-width: 900px;
  margin: 0 auto;
  padding: 0 24px;
}
.ln-video-inner .ln-section-tag {
  margin-bottom: 12px;
}
.ln-video-inner .ln-section-heading {
  margin-bottom: 40px;
  color: var(--ln-navy);
}
.ln-video-wrapper {
  position: relative;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.15),
              0 0 0 1px rgba(0, 0, 0, 0.05);
  background: #000;
  aspect-ratio: 16 / 9;
}
.ln-explainer-video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.ln-video-play-btn {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: none;
  border: none;
  cursor: pointer;
  transition: transform 0.2s ease, opacity 0.3s ease;
  z-index: 2;
  opacity: 1;
}
.ln-video-play-btn:hover {
  transform: translate(-50%, -50%) scale(1.1);
}
.ln-video-play-btn.ln-hidden {
  opacity: 0;
  pointer-events: none;
}
.ln-video-caption {
  margin-top: 20px;
  font-size: 14px;
  color: var(--ln-warm-gray);
  font-family: var(--ln-sans);
}
@media (max-width: 768px) {
  .ln-video-section {
    padding: 60px 0 80px;
  }
  .ln-video-wrapper {
    border-radius: 12px;
  }
}

/* --- Problem Section --- */
.ln-problem {
  padding: 120px 0;
  background: var(--ln-white);
}
.ln-problem-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 24px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
}
.ln-problem-text {
  max-width: 500px;
}
.ln-section-tag {
  font-size: 11px;
  font-weight: 700;
  color: var(--ln-red);
  text-transform: uppercase;
  letter-spacing: 2px;
  margin-bottom: 16px;
  font-family: var(--ln-sans);
}
.ln-section-heading {
  font-family: var(--ln-serif);
  font-size: clamp(1.8rem, 3.5vw, 2.6rem);
  font-weight: 700;
  line-height: 1.15;
  color: var(--ln-navy);
  letter-spacing: -0.02em;
  margin-bottom: 20px;
}
.ln-section-body {
  font-size: 16px;
  line-height: 1.8;
  color: var(--ln-warm-gray);
  font-weight: 400;
}

.ln-integrations {
  padding: 108px 0;
  background:
    radial-gradient(circle at top right, rgba(59,130,246,0.08), transparent 35%),
    linear-gradient(180deg, #f8fbff 0%, #ffffff 100%);
  border-top: 1px solid rgba(11,20,38,0.05);
  border-bottom: 1px solid rgba(11,20,38,0.05);
}

.ln-integrations-inner,
.ln-solutions-inner {
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 24px;
}

.ln-integrations-copy {
  max-width: 720px;
  margin-bottom: 28px;
}

.ln-logo-band {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 32px;
}

.ln-logo-band span {
  display: inline-flex;
  align-items: center;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(255,255,255,0.9);
  border: 1px solid rgba(11,20,38,0.08);
  color: var(--ln-charcoal);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: -0.01em;
  box-shadow: 0 8px 20px rgba(11,20,38,0.05);
}

.ln-integrations-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
}

.ln-integrations-metric {
  padding: 18px 0 0;
  border-top: 1px solid rgba(11,20,38,0.08);
}

.ln-integrations-metric strong {
  display: block;
  margin-bottom: 8px;
  color: var(--ln-navy);
  font-size: clamp(1.9rem, 3vw, 2.4rem);
  font-weight: 700;
  letter-spacing: -0.04em;
}

.ln-integrations-metric span {
  display: block;
  color: var(--ln-warm-gray);
  font-size: 14px;
  line-height: 1.65;
}

.ln-solutions {
  padding: 112px 0;
  background: #fff;
}

.ln-solutions-header {
  max-width: 720px;
  margin-bottom: 32px;
}

.ln-solutions-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.ln-solution-card {
  padding: 28px;
  border-radius: 22px;
  border: 1px solid rgba(11,20,38,0.08);
  background:
    linear-gradient(180deg, rgba(245,243,239,0.8), rgba(255,255,255,0.95)),
    #fff;
  box-shadow: 0 20px 40px rgba(11,20,38,0.05);
}

.ln-solution-eyebrow {
  margin-bottom: 16px;
  color: var(--ln-red);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.ln-solution-card h3 {
  margin: 0 0 12px;
  color: var(--ln-navy);
  font-family: var(--ln-serif);
  font-size: 1.75rem;
  line-height: 1.15;
  letter-spacing: -0.03em;
}

.ln-solution-card p {
  margin: 0 0 18px;
  color: var(--ln-warm-gray);
  font-size: 15px;
  line-height: 1.75;
}

.ln-solution-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 10px;
}

.ln-solution-list li {
  position: relative;
  padding-left: 18px;
  color: var(--ln-charcoal);
  font-size: 14px;
  line-height: 1.65;
}

.ln-solution-list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.7em;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--ln-red);
}
.ln-problem-visual {
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.ln-before-after {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}
.ln-ba-card {
  padding: 28px 24px;
  border-radius: 10px;
  border: 1px solid var(--ln-border);
}
.ln-ba-card.ln-before {
  background: #FEF2F2;
  border-color: #FECACA;
}
.ln-ba-card.ln-after {
  background: #F0FDF4;
  border-color: #BBF7D0;
}
.ln-ba-card h4 {
  font-family: var(--ln-sans);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  margin-bottom: 12px;
}
.ln-ba-card.ln-before h4 { color: #DC2626; }
.ln-ba-card.ln-after h4 { color: #16A34A; }
.ln-ba-card p {
  font-size: 14px;
  line-height: 1.6;
  color: var(--ln-navy);
}
.ln-stat-big {
  font-family: var(--ln-serif);
  font-size: clamp(3rem, 6vw, 5rem);
  font-weight: 700;
  color: var(--ln-navy);
  line-height: 1;
  letter-spacing: -0.04em;
}
.ln-stat-big .ln-stat-red {
  color: var(--ln-red);
}
.ln-stat-unit {
  font-family: var(--ln-sans);
  font-size: 16px;
  color: var(--ln-warm-gray);
  margin-top: 8px;
  font-weight: 400;
}

/* --- Timeline (How it Works) --- */
.ln-timeline {
  padding: 120px 0;
  background: var(--ln-cream);
}
.ln-timeline-header {
  text-align: center;
  max-width: 600px;
  margin: 0 auto 72px;
  padding: 0 24px;
}
.ln-timeline-track {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 24px;
  position: relative;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
}
/* Connecting line */
.ln-timeline-track::before {
  content: '';
  position: absolute;
  top: 28px;
  left: calc(12.5% + 12px);
  right: calc(12.5% + 12px);
  height: 2px;
  background: var(--ln-border);
  z-index: 0;
}
.ln-timeline-line-fill {
  position: absolute;
  top: 28px;
  left: calc(12.5% + 12px);
  height: 2px;
  background: var(--ln-red);
  z-index: 1;
  width: 0;
  transition: width 1.2s cubic-bezier(0.4, 0, 0.2, 1);
}
.ln-timeline-track.ln-animated .ln-timeline-line-fill {
  width: calc(100% - 25% - 24px);
}
.ln-timeline-step {
  text-align: center;
  position: relative;
  z-index: 2;
  padding: 0 12px;
  opacity: 0;
  transform: translateY(16px);
  transition: all 0.5s ease;
}
.ln-timeline-step.ln-visible {
  opacity: 1;
  transform: translateY(0);
}
.ln-step-dot {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--ln-white);
  border: 2px solid var(--ln-border);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 20px;
  font-size: 22px;
  transition: all 0.4s ease;
}
.ln-timeline-step.ln-active .ln-step-dot {
  border-color: var(--ln-red);
  background: var(--ln-red);
  box-shadow: 0 4px 16px rgba(59,130,246,0.25);
}
.ln-timeline-step.ln-active .ln-step-dot svg path,
.ln-timeline-step.ln-active .ln-step-dot svg polyline,
.ln-timeline-step.ln-active .ln-step-dot svg circle,
.ln-timeline-step.ln-active .ln-step-dot svg polygon {
  stroke: #fff;
  fill: none;
}
.ln-step-num {
  font-size: 11px;
  font-weight: 700;
  color: var(--ln-light-gray);
  text-transform: uppercase;
  letter-spacing: 1.5px;
  margin-bottom: 8px;
  font-family: var(--ln-sans);
}
.ln-timeline-step.ln-active .ln-step-num { color: var(--ln-red); }
.ln-step-title {
  font-family: var(--ln-sans);
  font-size: 16px;
  font-weight: 600;
  color: var(--ln-navy);
  margin-bottom: 8px;
}
.ln-step-desc {
  font-size: 13px;
  color: var(--ln-warm-gray);
  line-height: 1.6;
}

/* --- Demo Section --- */
.ln-demo {
  padding: 80px 0;
  background: var(--ln-white);
}
.ln-demo-inner {
  max-width: 1000px;
  margin: 0 auto;
  padding: 0 24px;
}
.ln-demo-frame {
  border: 1px solid var(--ln-border);
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(0,0,0,0.06);
}
.ln-demo-frame iframe {
  width: 100%;
  height: 580px;
  border: none;
  display: block;
}
.ln-demo-mobile {
  display: none;
  text-align: center;
  padding: 40px 24px;
  background: var(--ln-navy);
  border-radius: 12px;
}
.ln-demo-mobile h3 {
  font-family: var(--ln-serif);
  color: #fff;
  font-size: 1.3rem;
  margin-bottom: 12px;
}
.ln-demo-mobile p {
  color: rgba(255,255,255,0.6);
  font-size: 14px;
  margin-bottom: 20px;
}
.ln-demo-mobile a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 24px;
  background: var(--ln-red);
  color: #fff;
  border-radius: 6px;
  font-weight: 600;
  font-size: 14px;
  text-decoration: none;
}

/* --- Datenschutz Section --- */
.ln-privacy {
  padding: 120px 0;
  background: var(--ln-navy);
  position: relative;
  overflow: hidden;
}
.ln-privacy::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.015) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.015) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
}
.ln-privacy-inner {
  position: relative;
  z-index: 1;
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 24px;
}
.ln-privacy-header {
  text-align: center;
  margin-bottom: 64px;
}
.ln-privacy-header .ln-section-tag { color: rgba(255,255,255,0.5); }
.ln-privacy-header .ln-section-heading { color: #fff; }
.ln-privacy-header p { color: rgba(255,255,255,0.5); }

/* Data Flow Diagram */
.ln-dataflow {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  margin-bottom: 56px;
  flex-wrap: wrap;
}
.ln-flow-node {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  padding: 20px;
  min-width: 140px;
}
.ln-flow-icon {
  width: 64px;
  height: 64px;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  border: 1px solid rgba(255,255,255,0.1);
  background: rgba(255,255,255,0.04);
}
.ln-flow-label {
  font-size: 13px;
  font-weight: 600;
  color: rgba(255,255,255,0.8);
  text-align: center;
}
.ln-flow-sublabel {
  font-size: 11px;
  color: rgba(255,255,255,0.4);
  text-align: center;
}
.ln-flow-arrow {
  font-size: 20px;
  color: var(--ln-red);
  flex-shrink: 0;
  opacity: 0.7;
}
.ln-privacy-badges {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 16px;
}
.ln-privacy-badge {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 10px;
  padding: 24px;
  transition: border-color 0.2s ease;
}
.ln-privacy-badge:hover {
  border-color: rgba(59,130,246,0.2);
}
.ln-privacy-badge h4 {
  font-family: var(--ln-sans);
  font-size: 14px;
  font-weight: 600;
  color: #fff;
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.ln-privacy-badge p {
  font-size: 13px;
  color: rgba(255,255,255,0.5);
  line-height: 1.6;
}
.ln-privacy-legal {
  text-align: center;
  margin-top: 40px;
  font-size: 12px;
  color: rgba(255,255,255,0.35);
}
.ln-privacy-legal a {
  color: var(--ln-red);
  text-decoration: none;
  font-weight: 600;
}

/* --- Testimonials --- */
.ln-testimonials {
  padding: 120px 0;
  background: var(--ln-white);
}
.ln-testimonials-inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 24px;
}
.ln-testimonials-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 56px;
}
.ln-testimonial {
  padding: 32px;
  border: 1px solid var(--ln-border);
  border-radius: 10px;
  background: #fff;
  position: relative;
}
.ln-testimonial::before {
  content: '\201C';
  font-family: var(--ln-serif);
  font-size: 64px;
  color: var(--ln-red);
  opacity: 0.15;
  position: absolute;
  top: 12px;
  left: 20px;
  line-height: 1;
}
.ln-testimonial blockquote {
  font-size: 15px;
  line-height: 1.7;
  color: var(--ln-navy);
  font-style: italic;
  margin-bottom: 16px;
  position: relative;
  z-index: 1;
}
.ln-testimonial cite {
  font-size: 13px;
  color: var(--ln-warm-gray);
  font-style: normal;
  font-weight: 600;
}
.ln-testimonial .ln-time-saved {
  display: inline-block;
  margin-top: 8px;
  font-size: 12px;
  color: var(--ln-red);
  font-weight: 700;
  padding: 4px 10px;
  background: rgba(59,130,246,0.05);
  border-radius: 4px;
}

/* --- Arzt Section --- */
.ln-arzt {
  padding: 120px 0;
  background: var(--ln-cream);
}
.ln-arzt-inner {
  max-width: 900px;
  margin: 0 auto;
  padding: 0 24px;
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: 56px;
  align-items: start;
}
.ln-arzt-avatar {
  width: 160px;
  height: 160px;
  border-radius: 10px;
  background: linear-gradient(135deg, var(--ln-navy), #2A3654);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 48px;
  color: #fff;
  font-family: var(--ln-serif);
  font-weight: 700;
  letter-spacing: -0.02em;
  border: 3px solid var(--ln-border);
}
.ln-arzt-text h3 {
  font-family: var(--ln-serif);
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--ln-navy);
  margin-bottom: 4px;
}
.ln-arzt-text .ln-arzt-role {
  font-size: 13px;
  color: var(--ln-warm-gray);
  margin-bottom: 16px;
}
.ln-arzt-text p {
  font-size: 15px;
  line-height: 1.8;
  color: var(--ln-warm-gray);
}
.ln-arzt-contact {
  margin-top: 16px;
  font-size: 13px;
  color: var(--ln-light-gray);
}
.ln-arzt-contact a {
  color: var(--ln-red);
  text-decoration: none;
  font-weight: 600;
}

/* --- Final CTA --- */
.ln-final-cta {
  padding: 100px 0;
  background: var(--ln-navy);
  text-align: center;
  position: relative;
  overflow: hidden;
}
.ln-final-cta::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.015) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.015) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
}
.ln-final-cta-inner {
  position: relative;
  z-index: 1;
  max-width: 700px;
  margin: 0 auto;
  padding: 0 24px;
}
.ln-final-cta h2 {
  font-family: var(--ln-serif);
  font-size: clamp(1.8rem, 4vw, 2.8rem);
  font-weight: 700;
  color: #fff;
  letter-spacing: -0.02em;
  margin-bottom: 16px;
  line-height: 1.15;
}
.ln-final-cta p {
  font-size: 16px;
  color: rgba(255,255,255,0.5);
  margin-bottom: 32px;
  line-height: 1.7;
}
.ln-final-cta .ln-hero-cta {
  font-size: 17px;
  padding: 18px 44px;
}

/* --- Landing Footer Override --- */
body.landing-page .footer {
  font-family: var(--ln-sans);
}
body.landing-page .footer h4 {
  font-family: var(--ln-sans);
  font-weight: 600;
  letter-spacing: 0.02em;
}

/* --- Scroll Reveal --- */
.ln-reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: all 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}
.ln-reveal.ln-visible {
  opacity: 1;
  transform: translateY(0);
}
.ln-reveal-left {
  opacity: 0;
  transform: translateX(-24px);
  transition: all 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}
.ln-reveal-left.ln-visible {
  opacity: 1;
  transform: translateX(0);
}
.ln-reveal-right {
  opacity: 0;
  transform: translateX(24px);
  transition: all 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}
.ln-reveal-right.ln-visible {
  opacity: 1;
  transform: translateX(0);
}

/* --- Responsive: Landing --- */
@media (max-width: 900px) {
  .ln-hero-inner {
    grid-template-columns: 1fr;
    gap: 40px;
    padding-top: 40px;
  }
  .ln-hero { min-height: auto; padding: 120px 0 60px; }
  .ln-hero-text h1 { font-size: clamp(2rem, 7vw, 2.8rem); }
  .ln-hero-proof,
  .ln-integrations-metrics,
  .ln-solutions-grid {
    grid-template-columns: 1fr;
  }
  .ln-problem-inner {
    grid-template-columns: 1fr;
    gap: 48px;
  }
  .ln-timeline { overflow: hidden; }
  .ln-timeline-track {
    grid-template-columns: 1fr;
    gap: 32px;
    max-width: 100%;
  }
  .ln-timeline-track::before { display: none; }
  .ln-timeline-line-fill { display: none; }
  .ln-timeline-step { text-align: left; display: grid; grid-template-columns: 56px 1fr; gap: 16px; align-items: start; padding: 0; min-width: 0; }
  .ln-step-dot { margin: 0; }
  .ln-testimonials-grid { grid-template-columns: 1fr; }
  .ln-arzt-inner { grid-template-columns: 1fr; gap: 32px; }
  .ln-arzt-avatar { width: 100px; height: 100px; font-size: 32px; }
  .ln-dataflow { gap: 8px; overflow-x: hidden; }
  .ln-flow-node { min-width: 0; max-width: 100%; padding: 12px; }
  .ln-demo-frame { display: none; }
  .ln-demo-mobile { display: block; }
  .ln-before-after { grid-template-columns: 1fr; }
}

@media (max-width: 600px) {
  .ln-hero { padding: 100px 0 40px; }
  .ln-hero-text h1 { font-size: 1.8rem; }
  .ln-hero-subtitle { font-size: 15px; }
  .ln-hero-cta { padding: 14px 28px; font-size: 15px; width: 100%; justify-content: center; }
  .ln-hero-kicker { margin-bottom: 16px; }
  .ln-logo-band span { width: 100%; justify-content: center; }
  .ln-integrations,
  .ln-solutions { padding: 84px 0; }
  .ln-solution-card { padding: 22px; }
  .ln-trust-bar { gap: 20px; padding: 16px; }
  .ln-trust-item { font-size: 12px; }
  .ln-problem, .ln-timeline, .ln-testimonials, .ln-arzt { padding: 80px 0; }
  .ln-privacy { padding: 80px 0; }
  .ln-privacy-badges { grid-template-columns: 1fr; }
  .ln-final-cta { padding: 72px 0; }
  .ln-flow-arrow { display: none; }
  .ln-dataflow { flex-direction: column; gap: 16px; }
}

/* =============================================================
   SUBPAGES — Shared Swiss Design for public pages
   (login, funktionen, faq, extension, legal)
   ============================================================= */

/* --- Subpage Nav: always solid --- */
body.landing-page .nav.nav-solid {
  background: rgba(255,255,255,0.97);
  border-bottom: 1px solid var(--ln-border);
  box-shadow: 0 1px 8px rgba(0,0,0,0.04);
  backdrop-filter: blur(12px);
}

/* --- Page Header (subpages) --- */
body.landing-page .page-header {
  padding: 120px 0 48px;
  background: var(--ln-navy);
  text-align: center;
}
body.landing-page .page-header h1 {
  font-family: var(--ln-serif);
  font-size: clamp(1.8rem, 4vw, 2.6rem);
  font-weight: 700;
  color: #fff;
  letter-spacing: -0.02em;
  margin-bottom: 12px;
}
body.landing-page .page-header .page-subtitle {
  font-size: 16px;
  color: rgba(255,255,255,0.5);
  max-width: 560px;
  margin: 0 auto;
  font-family: var(--ln-sans);
  line-height: 1.7;
}
body.landing-page .page-header .back-link {
  color: rgba(255,255,255,0.4);
  font-size: 13px;
  font-family: var(--ln-sans);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 20px;
  transition: color 0.2s;
}
body.landing-page .page-header .back-link:hover {
  color: rgba(255,255,255,0.7);
}

/* --- FAQ Page --- */
body.landing-page .faq-list {
  max-width: 780px;
  margin: 0 auto;
  padding: 60px 24px 80px;
}
body.landing-page .faq-item {
  border: 1px solid var(--ln-border);
  border-radius: 8px;
  margin-bottom: 12px;
  overflow: hidden;
  transition: border-color 0.2s;
}
body.landing-page .faq-item:hover {
  border-color: rgba(59,130,246,0.2);
}
body.landing-page .faq-item summary {
  padding: 18px 24px;
  font-family: var(--ln-sans);
  font-size: 15px;
  font-weight: 600;
  color: var(--ln-navy);
  cursor: pointer;
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}
body.landing-page .faq-item summary::after {
  content: '+';
  font-size: 20px;
  color: var(--ln-light-gray);
  flex-shrink: 0;
  transition: transform 0.2s;
}
body.landing-page .faq-item[open] summary::after {
  content: '\2212';
  color: var(--ln-red);
}
body.landing-page .faq-item summary::-webkit-details-marker { display: none; }
body.landing-page .faq-item .faq-answer,
body.landing-page .faq-item > div,
body.landing-page .faq-item > p {
  padding: 0 24px 18px;
  font-size: 14px;
  line-height: 1.7;
  color: var(--ln-warm-gray);
  font-family: var(--ln-sans);
}

/* --- Features Page --- */
body.landing-page .features-grid {
  max-width: 1100px;
  margin: 0 auto;
  padding: 60px 24px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 20px;
}
body.landing-page .feature-card {
  border: 1px solid var(--ln-border);
  border-radius: 10px;
  padding: 28px 24px;
  background: #fff;
  transition: border-color 0.2s, box-shadow 0.2s;
}
body.landing-page .feature-card:hover {
  border-color: rgba(59,130,246,0.15);
  box-shadow: 0 4px 16px rgba(0,0,0,0.04);
}
body.landing-page .feature-card h3 {
  font-family: var(--ln-sans);
  font-size: 16px;
  font-weight: 600;
  color: var(--ln-navy);
  margin-bottom: 8px;
}
body.landing-page .feature-card p {
  font-size: 14px;
  line-height: 1.6;
  color: var(--ln-warm-gray);
}

/* --- Section CTA (subpages) --- */
body.landing-page .cta {
  text-align: center;
  padding: 56px 24px;
  background: var(--ln-cream);
}
body.landing-page .cta h2 {
  font-family: var(--ln-serif);
  font-size: clamp(1.4rem, 3vw, 2rem);
  color: var(--ln-navy);
  margin-bottom: 16px;
}
body.landing-page .cta p {
  font-size: 15px;
  color: var(--ln-warm-gray);
  margin-bottom: 24px;
}

/* --- Legal Pages --- */
body.landing-page .legal-page {
  max-width: 740px;
  margin: 0 auto;
  padding: 48px 24px 80px;
  font-family: var(--ln-sans);
}
body.landing-page .legal-page h1 {
  font-family: var(--ln-serif);
  font-size: clamp(1.6rem, 3.5vw, 2.2rem);
  color: var(--ln-navy);
  letter-spacing: -0.02em;
  margin-bottom: 8px;
}
body.landing-page .legal-page h2 {
  font-family: var(--ln-serif);
  font-size: 1.3rem;
  color: var(--ln-navy);
  margin-top: 32px;
  margin-bottom: 12px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--ln-border);
}
body.landing-page .legal-page h3 {
  font-family: var(--ln-sans);
  font-size: 1rem;
  font-weight: 600;
  color: var(--ln-navy);
  margin-top: 24px;
  margin-bottom: 8px;
}
body.landing-page .legal-page p,
body.landing-page .legal-page li {
  font-size: 14px;
  line-height: 1.8;
  color: var(--ln-warm-gray);
}
body.landing-page .legal-page a {
  color: var(--ln-red);
  text-decoration: none;
  font-weight: 500;
}
body.landing-page .legal-page a:hover {
  text-decoration: underline;
}
body.landing-page .legal-page table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
  margin: 16px 0;
}
body.landing-page .legal-page th,
body.landing-page .legal-page td {
  padding: 10px 14px;
  border: 1px solid var(--ln-border);
  text-align: left;
}
body.landing-page .legal-page th {
  background: var(--ln-cream);
  font-weight: 600;
  color: var(--ln-navy);
}
body.landing-page .legal-page .info-box,
body.landing-page .legal-page .summary-box,
body.landing-page .legal-page .eu-box {
  border-radius: 8px;
  padding: 16px 20px;
  margin: 16px 0;
  font-size: 13px;
  line-height: 1.7;
}
body.landing-page .legal-page .toc {
  background: var(--ln-cream);
  border-radius: 8px;
  padding: 20px 24px;
  margin: 16px 0;
}

/* --- Connector/Extension Page --- */
body.landing-page .connector-page {
  max-width: 720px;
  margin: 0 auto;
  padding: 48px 24px 80px;
  font-family: var(--ln-sans);
}
body.landing-page .connector-page h1 {
  font-family: var(--ln-serif);
  font-size: clamp(1.6rem, 3.5vw, 2.2rem);
  color: var(--ln-navy);
  letter-spacing: -0.02em;
}
body.landing-page .connector-page h2,
body.landing-page .connector-page h3 {
  font-family: var(--ln-sans);
  color: var(--ln-navy);
}
body.landing-page .connector-page p,
body.landing-page .connector-page li {
  font-size: 14px;
  line-height: 1.7;
  color: var(--ln-warm-gray);
}

/* --- Login Page Override --- */
body.landing-page.login-body {
  background: var(--ln-navy);
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
}
body.landing-page .login-card {
  font-family: var(--ln-sans);
  border-radius: 12px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.3);
}
body.landing-page .login-card h1 {
  font-family: var(--ln-serif);
  letter-spacing: -0.02em;
}
body.landing-page .login-btn,
body.landing-page .login-card .btn {
  background: var(--ln-red);
  border-color: var(--ln-red);
}
body.landing-page .login-btn:hover,
body.landing-page .login-card .btn:hover {
  background: var(--ln-red-dark);
  border-color: var(--ln-red-dark);
}

/* --- Subpage Buttons --- */
body.landing-page .btn-primary {
  background: var(--ln-red);
  border-color: var(--ln-red);
}
body.landing-page .btn-primary:hover {
  background: var(--ln-red-dark);
  border-color: var(--ln-red-dark);
  box-shadow: 0 4px 16px rgba(59,130,246,0.2);
}
body.landing-page .btn-outline {
  border-color: var(--ln-navy);
  color: var(--ln-navy);
}
body.landing-page .btn-outline:hover {
  background: var(--ln-navy);
  color: #fff;
}

/* --- Subpage gradient-text override --- */
body.landing-page .gradient-text {
  background: linear-gradient(135deg, var(--ln-red), #2563eb);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* =============================================================
   TOOL PAGE — Swiss Design Override
   Scoped to body.landing-page.dash-body
   ============================================================= */

/* --- Tool: Font + Base --- */
body.landing-page.dash-body {
  --sidebar-bg: #0B1426;
  --sidebar-text: #fff;
}

/* --- Tool: Topbar --- */
body.landing-page .tool-topbar {
  background: var(--ln-navy);
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
body.landing-page .tool-topbar-logo {
  color: #fff;
  font-family: var(--ln-sans);
}
body.landing-page .tool-topbar-burger span {
  background: #fff;
}
body.landing-page .dash-toggle-label {
  color: rgba(255,255,255,0.6);
  font-family: var(--ln-sans);
}
body.landing-page .dash-user-avatar {
  background: var(--ln-red);
  color: #fff;
  font-family: var(--ln-sans);
  font-weight: 700;
}

/* --- Tool: Sidebar --- */
body.landing-page .dash-sidebar {
  background: var(--ln-navy);
  font-family: var(--ln-sans);
}
body.landing-page .dash-sidebar-title {
  font-family: var(--ln-sans);
  letter-spacing: -0.02em;
}
body.landing-page .dash-nav-item {
  font-family: var(--ln-sans);
}
body.landing-page .dash-nav-item.active {
  background: rgba(59,130,246,0.1);
  color: #fff;
}
body.landing-page .dash-nav-item.active svg {
  color: var(--ln-red);
}
body.landing-page .dash-privacy-badge {
  color: rgba(255,255,255,0.4);
  font-family: var(--ln-sans);
  font-size: 11px;
}

/* --- Tool: Tabs --- */
body.landing-page .tool-tabs {
  font-family: var(--ln-sans);
  background: #fff;
  border-bottom: 1px solid var(--ln-border);
}
body.landing-page .tool-tab {
  font-family: var(--ln-sans);
  font-weight: 500;
}
body.landing-page .tool-tab.active {
  color: var(--ln-navy);
  border-bottom-color: var(--ln-red);
}

/* --- Tool: Primary Button → Swiss Red --- */
body.landing-page .dash-btn-primary {
  background: var(--ln-red);
  border-radius: 8px;
  font-family: var(--ln-sans);
}
body.landing-page .dash-btn-primary:hover {
  background: var(--ln-red-dark);
  box-shadow: 0 4px 16px rgba(59,130,246,0.2);
}

/* --- Tool: Copy Button --- */
body.landing-page .dash-copy-btn-prominent {
  background: var(--ln-red);
  font-family: var(--ln-sans);
}
body.landing-page .dash-copy-btn-prominent:hover {
  background: var(--ln-red-dark);
}

/* --- Tool: Input/Output Area --- */
body.landing-page .dash-textarea {
  font-family: var(--ln-sans);
  border-radius: 8px;
}
body.landing-page .dash-label {
  font-family: var(--ln-sans);
  font-weight: 600;
  color: var(--ln-navy);
}
body.landing-page .dash-input {
  font-family: var(--ln-sans);
}
body.landing-page .dash-result {
  font-family: var(--ln-sans);
}
body.landing-page .dash-placeholder p {
  font-family: var(--ln-sans);
  color: var(--ln-light-gray);
}

/* --- Tool: Ambient Recording --- */
body.landing-page .dash-soap-ambient-btn {
  font-family: var(--ln-sans);
  border-color: var(--ln-red);
  color: var(--ln-red);
}
body.landing-page .dash-soap-ambient-btn:hover {
  background: rgba(59,130,246,0.04);
}
body.landing-page .dash-soap-ambient-dot {
  background: var(--ln-red);
}

/* --- Tool: ICD Chips --- */
body.landing-page .dash-icd-chip {
  font-family: var(--ln-sans);
}

/* --- Tool: Profile & Settings --- */
body.landing-page .dash-profile-name {
  font-family: var(--ln-serif);
  letter-spacing: -0.02em;
}
body.landing-page .dash-profile-label,
body.landing-page .dash-profile-value {
  font-family: var(--ln-sans);
}
body.landing-page .dash-settings-tab.active {
  border-bottom-color: var(--ln-red);
  color: var(--ln-navy);
}

/* --- Tool: Anpassen/Refine --- */
body.landing-page .dash-anpassen-toggle {
  font-family: var(--ln-sans);
}

/* --- Tool: Footer --- */
body.landing-page .tool-footer {
  font-family: var(--ln-sans);
  color: var(--ln-light-gray);
  font-size: 11px;
}

/* --- Tool: User Dropdown --- */
body.landing-page .dash-user-dropdown {
  font-family: var(--ln-sans);
}
body.landing-page .dash-user-dropdown-item:hover {
  background: rgba(59,130,246,0.04);
}
