/* ============================================================
   GeoWunder Marketing-Site — Design-System
   Quelle der Wahrheit: lib/design_system/tokens/color_tokens.dart
   Stil-Referenz: tool/make_store_screenshots.py (Store-Slides:
   Brand-Vollfarben, hartes Offset-Shadow ohne Blur, Bezel #0A0F1E,
   Nunito ExtraBold Headlines).
   ============================================================ */

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

:root {
  /* BrandColors */
  --blue: #1CB0F6;        --blue-shadow: #0E8BC4;  --blue-light: #5EC8FA;
  --navy: #0D1B40;        --navy-light: #1A2F6B;   --navy-shadow: #08112A;
  --gold: #FFC107;        --gold-shadow: #BF8F00;
  --green: #22B957;       --green-shadow: #178042;
  --orange: #F26419;      --orange-shadow: #C24A0A;
  --purple: #9333EA;      --purple-shadow: #7E22CE;
  --red: #FF4B4B;
  /* Tints (Flächen hinter Devices, analog Store-Slide-Hintergründen) */
  --blue-tint: #E4F5FE;   --green-tint: #E4F8EC;   --orange-tint: #FDEDE4;
  --purple-tint: #F4EAFD; --gold-tint: #FFF4D6;    --navy-tint: #E9EDF6;
  /* NeutralColors */
  --text: #2D2D2D; --text-soft: #4B4B4B; --muted: #616161; --faint: #9B9B9B;
  --surface: #F4F5F8; --card: #FFFFFF; --border: #E0E0E0;
  --on-warm: #2D2D2D; --on-brand: #FFFFFF;
  --bezel: #0A0F1E;
  /* Layout */
  --maxw: 1140px;
  --r-sm: 12px; --r-md: 16px; --r-lg: 24px; --r-xl: 32px; --r-pill: 999px;
  --shadow-card: 0 6px 0 rgba(13, 27, 64, 0.08);
}

html { scroll-behavior: smooth; }

body {
  font-family: 'Nunito', 'Segoe UI', system-ui, -apple-system, sans-serif;
  font-weight: 400;
  color: var(--text);
  background: var(--card);
  line-height: 1.6;
  overflow-x: hidden;
}

img { max-width: 100%; height: auto; }
a { color: var(--blue); }

.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 1.5rem; }

/* ── Typografie ── */
h1, h2, h3, h4 { font-weight: 800; line-height: 1.15; letter-spacing: -0.015em; }
.h1 { font-size: clamp(2.4rem, 5.5vw, 3.9rem); }
.h2 { font-size: clamp(1.85rem, 4vw, 2.7rem); }
.h3 { font-size: 1.3rem; }
.lead { font-size: clamp(1.05rem, 2vw, 1.25rem); color: var(--text-soft); }

.eyebrow {
  display: inline-block;
  font-size: 0.82rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 0.9rem;
}

/* ── Buttons (Duolingo-3D: harte Unterkante, Press = absinken) ── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.55rem;
  font-family: inherit;
  font-size: 1rem;
  font-weight: 800;
  line-height: 1.2;
  padding: 0.95rem 1.7rem;
  border: 0;
  border-radius: var(--r-md);
  cursor: pointer;
  text-decoration: none;
  text-align: center;
  color: #fff;
  background: var(--blue);
  box-shadow: 0 4px 0 var(--blue-shadow);
  transition: transform 0.1s ease, box-shadow 0.1s ease, filter 0.15s ease;
  -webkit-tap-highlight-color: transparent;
}
.btn:hover { filter: brightness(1.06); }
.btn:active { transform: translateY(4px); box-shadow: 0 0 0 transparent; }
.btn--gold   { background: var(--gold);   color: var(--on-warm); box-shadow: 0 4px 0 var(--gold-shadow); }
.btn--green  { background: var(--green);  box-shadow: 0 4px 0 var(--green-shadow); }
.btn--navy   { background: var(--navy);   box-shadow: 0 4px 0 var(--navy-shadow); }
.btn--purple { background: var(--purple); box-shadow: 0 4px 0 var(--purple-shadow); }
.btn--white  { background: #fff; color: var(--navy); box-shadow: 0 4px 0 rgba(13, 27, 64, 0.35); }
.btn--ghost {
  background: transparent;
  color: var(--blue);
  box-shadow: inset 0 0 0 2px var(--blue), 0 4px 0 rgba(28, 176, 246, 0.35);
}
.btn--ghost:hover { background: var(--blue-tint); }
.btn--big { font-size: 1.1rem; padding: 1.15rem 2.2rem; }
.btn--small { font-size: 0.9rem; padding: 0.65rem 1.2rem; border-radius: var(--r-sm); }

/* ── Topbar ── */
.topbar {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(255, 255, 255, 0.94);
  backdrop-filter: blur(10px);
  border-bottom: 2px solid var(--surface);
}
.topbar__inner {
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 0.8rem 1.5rem;
  display: flex;
  align-items: center;
  gap: 1.5rem;
}
.brand { display: flex; align-items: center; gap: 0.6rem; text-decoration: none; }
.brand img { width: 38px; height: 38px; border-radius: 10px; }
.brand span { font-size: 1.3rem; font-weight: 800; color: var(--navy); letter-spacing: -0.02em; }
.brand b { color: var(--blue); font-weight: 800; }

.topnav { display: flex; align-items: center; gap: 1.6rem; margin-left: auto; }
.topnav a {
  font-weight: 800;
  font-size: 0.95rem;
  color: var(--muted);
  text-decoration: none;
  transition: color 0.15s;
}
.topnav a:hover { color: var(--blue); }
.topnav .lang { color: var(--faint); font-weight: 600; }

.nav-burger {
  display: none;
  margin-left: auto;
  background: none;
  border: 0;
  cursor: pointer;
  padding: 0.4rem;
}
.nav-burger span {
  display: block;
  width: 26px;
  height: 3px;
  border-radius: 2px;
  background: var(--navy);
  margin: 5px 0;
}

/* ── Hero ── */
.hero { position: relative; overflow: hidden; padding: 4.5rem 0 5.5rem; }
.hero__inner {
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 0 1.5rem;
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 3rem;
  align-items: center;
}
.hero h1 { color: var(--navy); margin: 1rem 0 1.2rem; }
.hero h1 em { font-style: normal; color: var(--blue); }
.hero .lead { max-width: 34rem; }

.badge-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  background: var(--gold-tint);
  color: var(--gold-shadow);
  border: 2px solid var(--gold);
  border-radius: var(--r-pill);
  padding: 0.35rem 1rem;
  font-size: 0.85rem;
  font-weight: 800;
}

.hero__ctas { display: flex; flex-wrap: wrap; gap: 0.9rem; margin: 1.8rem 0 1rem; align-items: center; }
.hero__b2b { font-weight: 800; font-size: 1rem; }

/* Store-Badges */
.store-badges { display: flex; flex-wrap: wrap; gap: 0.8rem; }
.store-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.7rem;
  background: var(--navy);
  color: #fff;
  text-decoration: none;
  border-radius: var(--r-md);
  padding: 0.6rem 1.3rem;
  box-shadow: 0 4px 0 var(--navy-shadow);
  transition: transform 0.1s, box-shadow 0.1s, filter 0.15s;
}
.store-badge:hover { filter: brightness(1.18); }
.store-badge:active { transform: translateY(4px); box-shadow: 0 0 0 transparent; }
.store-badge svg { width: 26px; height: 26px; flex: 0 0 auto; }
.store-badge small { display: block; font-size: 0.68rem; font-weight: 600; opacity: 0.85; line-height: 1.1; }
.store-badge strong { display: block; font-size: 1.05rem; font-weight: 800; line-height: 1.2; }

/* Phone-Fan (Hero) */
.phone {
  background: var(--bezel);
  border-radius: 40px;
  padding: 10px;
  box-shadow: 14px 18px 0 rgba(13, 27, 64, 0.16);
}
.phone img { display: block; width: 100%; border-radius: 32px; }

.phone-fan { position: relative; height: 560px; }
.phone-fan .phone { position: absolute; width: 240px; }
.phone-fan .phone--l { left: 0; top: 60px; transform: rotate(-8deg); z-index: 1; }
.phone-fan .phone--c { left: 50%; top: 0; transform: translateX(-50%); z-index: 2; width: 260px; }
.phone-fan .phone--r { right: 0; top: 70px; transform: rotate(8deg); z-index: 1; }
.phone-fan .mascot {
  position: absolute;
  z-index: 3;
  width: 150px;
  left: -20px;
  bottom: -24px;
  filter: drop-shadow(8px 10px 0 rgba(13, 27, 64, 0.12));
}

/* Schwebende Deko */
.float-deco { position: absolute; pointer-events: none; user-select: none; }
@keyframes floaty {
  0%, 100% { transform: translateY(0) rotate(var(--rot, 0deg)); }
  50% { transform: translateY(-14px) rotate(var(--rot, 0deg)); }
}
.float-deco { animation: floaty 5s ease-in-out infinite; }
.float-deco--slow { animation-duration: 7s; }

/* ── Stats-Band ── */
.stats { background: var(--navy); color: #fff; padding: 2.6rem 0; }
.stats__grid {
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 0 1.5rem;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2rem;
  text-align: center;
}
.stats b { display: block; font-size: clamp(1.6rem, 3vw, 2.2rem); font-weight: 800; color: var(--gold); }
.stats span { font-size: 0.95rem; font-weight: 600; opacity: 0.9; }

/* ── Sections ── */
.section { padding: 5.5rem 0; }
.section--alt { background: var(--surface); }
.section__head { text-align: center; max-width: 46rem; margin: 0 auto 3.5rem; }
.section__head .lead { margin-top: 1rem; }

/* Video-Platzhalter */
.video-card {
  position: relative;
  aspect-ratio: 16 / 9;
  border-radius: var(--r-xl);
  overflow: hidden;
  background:
    radial-gradient(ellipse 70% 90% at 20% 10%, rgba(28, 176, 246, 0.35) 0%, transparent 60%),
    radial-gradient(ellipse 60% 80% at 85% 90%, rgba(147, 51, 234, 0.3) 0%, transparent 55%),
    var(--navy);
  box-shadow: 16px 20px 0 var(--blue-tint);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1.2rem;
}
.video-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(rgba(255, 255, 255, 0.14) 1.5px, transparent 1.5px);
  background-size: 30px 30px;
  mask-image: radial-gradient(ellipse 90% 90% at 50% 50%, black 20%, transparent 75%);
}
.video-card__play {
  position: relative;
  width: 88px;
  height: 88px;
  border-radius: 50%;
  border: 0;
  background: var(--gold);
  box-shadow: 0 6px 0 var(--gold-shadow);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.1s, box-shadow 0.1s;
}
.video-card__play:active { transform: translateY(6px); box-shadow: 0 0 0 transparent; }
.video-card__play svg { width: 34px; height: 34px; margin-left: 5px; fill: var(--on-warm); }
.video-card p { position: relative; color: #fff; font-weight: 800; font-size: 1.15rem; }
.video-card small { position: relative; color: rgba(255, 255, 255, 0.75); font-weight: 600; }

/* ── Schritte ── */
.steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.6rem; }
.step {
  background: var(--card);
  border: 2px solid var(--border);
  border-radius: var(--r-lg);
  padding: 2rem 1.7rem;
  box-shadow: var(--shadow-card);
}
.step__num {
  width: 46px;
  height: 46px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: 1.25rem;
  color: #fff;
  margin-bottom: 1.1rem;
}
.step:nth-child(1) .step__num { background: var(--blue); box-shadow: 0 3px 0 var(--blue-shadow); }
.step:nth-child(2) .step__num { background: var(--orange); box-shadow: 0 3px 0 var(--orange-shadow); }
.step:nth-child(3) .step__num { background: var(--green); box-shadow: 0 3px 0 var(--green-shadow); }
.step h3 { margin-bottom: 0.5rem; }
.step p { color: var(--text-soft); font-size: 0.98rem; }

/* ── Feature-Rows ── */
.feature {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 5vw, 4.5rem);
  align-items: center;
  padding: 3.5rem 0;
}
.feature h2 { color: var(--navy); margin-bottom: 1rem; }
.feature .lead { font-size: 1.08rem; margin-bottom: 1.4rem; }

.checklist { list-style: none; display: grid; gap: 0.8rem; }
.checklist li { display: flex; gap: 0.7rem; align-items: flex-start; font-weight: 600; color: var(--text-soft); }
.checklist svg { flex: 0 0 auto; width: 22px; height: 22px; margin-top: 2px; }

/* Device-Panel (Brand-Tint-Fläche, Device mit hartem Schatten — Store-Slide-Look) */
.shot-panel {
  border-radius: var(--r-xl);
  padding: clamp(1.8rem, 4vw, 3rem);
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 1.4rem;
  position: relative;
}
.shot-panel .phone { width: min(250px, 64%); flex: 0 1 auto; }
.shot-panel--blue   { background: var(--blue-tint); }
.shot-panel--green  { background: var(--green-tint); }
.shot-panel--orange { background: var(--orange-tint); }
.shot-panel--purple { background: var(--purple-tint); }
.shot-panel--gold   { background: var(--gold-tint); }
.shot-panel--navy   { background: var(--navy-tint); }
.shot-panel--blue .phone   { box-shadow: 12px 16px 0 rgba(14, 139, 196, 0.35); }
.shot-panel--green .phone  { box-shadow: 12px 16px 0 rgba(23, 128, 66, 0.3); }
.shot-panel--orange .phone { box-shadow: 12px 16px 0 rgba(194, 74, 10, 0.28); }
.shot-panel--purple .phone { box-shadow: 12px 16px 0 rgba(126, 34, 206, 0.26); }
.shot-panel--gold .phone   { box-shadow: 12px 16px 0 rgba(191, 143, 0, 0.3); }
.shot-panel--navy .phone   { box-shadow: 12px 16px 0 rgba(13, 27, 64, 0.3); }
.shot-panel--duo .phone:last-child { margin-left: -3rem; margin-top: 4rem; }
.shot-panel .panel-mascot {
  position: absolute;
  width: 110px;
  bottom: -18px;
  right: -14px;
  filter: drop-shadow(6px 8px 0 rgba(13, 27, 64, 0.12));
}

/* ── Zielgruppen-Karten (Vollfarbe wie Store-Slides) ── */
.audiences { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.6rem; }
.audience {
  border-radius: var(--r-xl);
  padding: 2.4rem 2rem;
  color: #fff;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  position: relative;
  overflow: hidden;
}
.audience::after {
  content: '';
  position: absolute;
  width: 220px;
  height: 220px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.08);
  right: -70px;
  bottom: -70px;
}
.audience--blue { background: var(--blue); box-shadow: 0 6px 0 var(--blue-shadow); }
.audience--navy { background: var(--navy); box-shadow: 0 6px 0 var(--navy-shadow); }
.audience--purple { background: var(--purple); box-shadow: 0 6px 0 var(--purple-shadow); }
.audience .eyebrow { color: rgba(255, 255, 255, 0.8); margin-bottom: 0; }
.audience h3 { font-size: 1.5rem; }
.audience p { color: rgba(255, 255, 255, 0.92); font-weight: 600; font-size: 0.98rem; }
.audience .checklist li { color: rgba(255, 255, 255, 0.92); font-size: 0.95rem; }
.audience .btn { margin-top: auto; position: relative; z-index: 1; }

/* ── Trust-Band ── */
.trust { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; }
.trust__item { display: flex; gap: 0.8rem; align-items: flex-start; }
.trust__item svg { flex: 0 0 auto; width: 26px; height: 26px; }
.trust__item b { display: block; color: var(--navy); }
.trust__item span { font-size: 0.92rem; color: var(--muted); font-weight: 600; }

/* ── FAQ ── */
.faq { max-width: 46rem; margin: 0 auto; display: grid; gap: 1rem; }
.faq details {
  background: var(--card);
  border: 2px solid var(--border);
  border-radius: var(--r-md);
  padding: 1.1rem 1.4rem;
  box-shadow: var(--shadow-card);
}
.faq details[open] { border-color: var(--blue); }
.faq summary {
  font-weight: 800;
  font-size: 1.05rem;
  color: var(--navy);
  cursor: pointer;
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after {
  content: '+';
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--blue);
  transition: transform 0.2s;
}
.faq details[open] summary::after { transform: rotate(45deg); }
.faq details p { margin-top: 0.8rem; color: var(--text-soft); font-weight: 600; font-size: 0.98rem; }

/* ── CTA-Band ── */
.cta-band {
  position: relative;
  background: var(--navy);
  color: #fff;
  text-align: center;
  padding: 5.5rem 1.5rem;
  overflow: hidden;
}
.cta-band::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(rgba(255, 255, 255, 0.1) 1.5px, transparent 1.5px);
  background-size: 34px 34px;
  mask-image: radial-gradient(ellipse 80% 100% at 50% 0%, black 10%, transparent 70%);
}
.cta-band .wrap { position: relative; }
.cta-band img.mascot { width: 130px; margin-bottom: 1.2rem; filter: drop-shadow(8px 10px 0 rgba(0, 0, 0, 0.25)); }
.cta-band h2 { margin-bottom: 0.8rem; }
.cta-band p { color: rgba(255, 255, 255, 0.85); font-weight: 600; margin-bottom: 2rem; }
.cta-band .store-badges { justify-content: center; }
.cta-band .store-badge { background: #fff; color: var(--navy); box-shadow: 0 4px 0 rgba(0, 0, 0, 0.35); }

/* ── Footer ── */
.footer { background: var(--navy-shadow); color: rgba(255, 255, 255, 0.85); padding: 4rem 0 2rem; }
.footer__grid {
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 0 1.5rem;
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 2.5rem;
}
.footer h4 { color: #fff; font-size: 0.95rem; text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 1rem; }
.footer ul { list-style: none; display: grid; gap: 0.55rem; }
.footer a { color: rgba(255, 255, 255, 0.75); text-decoration: none; font-weight: 600; font-size: 0.95rem; }
.footer a:hover { color: var(--gold); }
.footer__brand p { font-size: 0.92rem; font-weight: 600; color: rgba(255, 255, 255, 0.65); margin-top: 0.8rem; max-width: 22rem; }
.footer__bottom {
  max-width: var(--maxw);
  margin: 3rem auto 0;
  padding: 1.5rem 1.5rem 0;
  border-top: 1px solid rgba(255, 255, 255, 0.12);
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 1rem;
  font-size: 0.85rem;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.55);
}

/* ── Preisseite ── */
.pricing-head { text-align: center; padding: 4rem 0 1rem; }
.pricing-head h1 { color: var(--navy); }

.billing-toggle {
  display: inline-flex;
  background: var(--surface);
  border-radius: var(--r-pill);
  padding: 5px;
  gap: 4px;
  margin: 2rem auto 0;
}
.billing-toggle button {
  font-family: inherit;
  font-weight: 800;
  font-size: 0.95rem;
  border: 0;
  background: transparent;
  color: var(--muted);
  padding: 0.6rem 1.4rem;
  border-radius: var(--r-pill);
  cursor: pointer;
}
.billing-toggle button.on { background: var(--card); color: var(--navy); box-shadow: 0 2px 0 rgba(13, 27, 64, 0.12); }
.billing-toggle .save { color: var(--green); font-size: 0.8rem; margin-left: 0.3rem; }

.plans { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.6rem; align-items: stretch; margin-top: 3rem; }
.plan {
  position: relative;
  background: var(--card);
  border: 2px solid var(--border);
  border-radius: var(--r-lg);
  padding: 2.2rem 1.9rem;
  display: flex;
  flex-direction: column;
  gap: 1.1rem;
  box-shadow: 0 6px 0 rgba(13, 27, 64, 0.08);
}
.plan--featured { border-color: var(--gold); box-shadow: 0 6px 0 var(--gold-shadow); }
.plan__flag {
  position: absolute;
  top: -16px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--gold);
  color: var(--on-warm);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  border-radius: var(--r-pill);
  padding: 0.3rem 1rem;
  box-shadow: 0 3px 0 var(--gold-shadow);
  white-space: nowrap;
}
.plan__who { font-size: 0.85rem; font-weight: 800; letter-spacing: 0.08em; text-transform: uppercase; }
.plan h3 { font-size: 1.45rem; color: var(--navy); }
.plan__price { display: flex; align-items: baseline; gap: 0.5rem; min-height: 3.4rem; }
.plan__price b { font-size: 2.4rem; font-weight: 800; color: var(--navy); letter-spacing: -0.02em; }
.plan__price span { color: var(--muted); font-weight: 600; font-size: 0.95rem; }
.plan__note { font-size: 0.85rem; color: var(--muted); font-weight: 600; min-height: 2.2rem; }
.plan .checklist { font-size: 0.95rem; }
.plan .btn { margin-top: auto; }
.plan__sub { text-align: center; font-size: 0.85rem; font-weight: 600; color: var(--muted); }
.plan__sub a { font-weight: 800; }

/* Vergleichstabelle */
.cmp { overflow-x: auto; }
.cmp table { width: 100%; border-collapse: collapse; min-width: 640px; }
.cmp th, .cmp td { padding: 0.95rem 1rem; text-align: center; border-bottom: 2px solid var(--surface); font-weight: 600; }
.cmp th { font-weight: 800; color: var(--navy); font-size: 1rem; }
.cmp td:first-child, .cmp th:first-child { text-align: left; }
.cmp td { color: var(--text-soft); font-size: 0.95rem; }
.cmp .yes { color: var(--green); font-weight: 800; }
.cmp .no { color: var(--faint); }

/* Zahlarten */
.paymethods { display: flex; flex-wrap: wrap; gap: 0.6rem; justify-content: center; }
.paymethods span {
  background: var(--surface);
  border: 2px solid var(--border);
  border-radius: var(--r-sm);
  padding: 0.4rem 0.9rem;
  font-size: 0.85rem;
  font-weight: 800;
  color: var(--muted);
}

/* ── App-Link-Redirect-Overlay (Join-Links) ── */
#app-redirect {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 100;
  background: var(--navy);
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1.6rem;
  padding: 2rem;
  text-align: center;
  color: #fff;
}
#app-redirect img { width: 110px; filter: drop-shadow(8px 10px 0 rgba(0, 0, 0, 0.25)); }
#app-redirect h2 { font-size: 1.6rem; }
#app-redirect p { color: rgba(255, 255, 255, 0.8); max-width: 320px; font-weight: 600; }
#app-redirect .store-badge { background: #fff; color: var(--navy); box-shadow: 0 4px 0 rgba(0, 0, 0, 0.35); }

/* ── Scroll-Reveal ── */
.reveal { opacity: 0; transform: translateY(26px); transition: opacity 0.6s ease, transform 0.6s ease; }
.reveal.in { opacity: 1; transform: none; }

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .reveal { opacity: 1; transform: none; transition: none; }
  .float-deco { animation: none; }
}

/* ── Responsive ── */
@media (max-width: 980px) {
  .hero__inner { grid-template-columns: 1fr; text-align: center; }
  .hero .lead { margin: 0 auto; }
  .hero__ctas { justify-content: center; }
  .phone-fan { height: 480px; max-width: 560px; margin: 0 auto; width: 100%; }
  .phone-fan .phone { width: 200px; }
  .phone-fan .phone--c { width: 220px; }
  .feature, .feature--flip { grid-template-columns: 1fr; gap: 2.2rem; padding: 2.5rem 0; }
  .feature--flip .shot-panel { order: -1; }
  .steps, .audiences, .plans { grid-template-columns: 1fr; max-width: 480px; margin-left: auto; margin-right: auto; }
  .plans { margin-top: 3rem; }
  .stats__grid { grid-template-columns: repeat(2, 1fr); }
  .trust { grid-template-columns: repeat(2, 1fr); }
  .footer__grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 820px) {
  .topnav {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: #fff;
    border-bottom: 2px solid var(--surface);
    flex-direction: column;
    align-items: flex-start;
    padding: 1.2rem 1.5rem 1.6rem;
    gap: 1.1rem;
  }
  .topnav.open { display: flex; }
  .nav-burger { display: block; }
}

@media (max-width: 560px) {
  .section { padding: 3.5rem 0; }
  .phone-fan { height: 400px; }
  .phone-fan .phone { width: 160px; }
  .phone-fan .phone--c { width: 180px; }
  .phone-fan .mascot { width: 110px; left: -8px; }
  .shot-panel--duo .phone:last-child { margin-left: -2rem; margin-top: 2.5rem; }
  .trust { grid-template-columns: 1fr; }
  .stats__grid { gap: 1.2rem; }
  .footer__grid { grid-template-columns: 1fr; gap: 1.8rem; }
}

/* ============================================================
   Erweiterungen: Lottie-Maskottchen, Sticky-CTA, Social Proof,
   Demo-Band, Lead-Formular, Zielgruppen-Seiten, A11y
   ============================================================ */

:root { --gold-text: #8A6D00; }

/* ── A11y ── */
a:focus-visible, button:focus-visible, summary:focus-visible,
input:focus-visible, select:focus-visible, textarea:focus-visible {
  outline: 3px solid var(--blue);
  outline-offset: 2px;
}
.skip-link {
  position: absolute;
  left: -9999px;
  top: 0;
  z-index: 200;
  background: var(--navy);
  color: #fff;
  font-weight: 800;
  padding: 0.8rem 1.4rem;
  border-radius: 0 0 var(--r-sm) 0;
}
.skip-link:focus { left: 0; }

/* ── Lottie-Maskottchen ── */
[data-lottie] { position: relative; }
[data-lottie] svg { display: block; }
[data-lottie] > img { display: block; width: 100%; height: auto; }
[data-lottie].lottie-on > img { display: none; }
.mascot-slot { width: 96px; height: 96px; }
.audience .mascot-slot { margin-bottom: -0.4rem; }

/* ── Sticky-CTA (mobil) ── */
.sticky-cta {
  display: none;
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 60;
  padding: 0.65rem 1rem calc(0.65rem + env(safe-area-inset-bottom));
  background: rgba(255, 255, 255, 0.96);
  backdrop-filter: blur(10px);
  border-top: 2px solid var(--surface);
}
.sticky-cta .btn { width: 100%; }
@media (max-width: 820px) {
  .sticky-cta { display: block; }
  body { padding-bottom: 86px; }
}

/* ── Ratings-Strip (Hero) ── */
.ratings {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem 1.6rem;
  align-items: center;
  margin-top: 1.2rem;
}
.ratings .stars { color: var(--gold); letter-spacing: 2px; font-size: 1rem; }
.ratings span { font-weight: 800; font-size: 0.88rem; color: var(--muted); }
@media (max-width: 980px) { .ratings { justify-content: center; } }

/* ── Testimonials ── */
.quotes { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.6rem; }
.quote {
  background: var(--card);
  border: 2px solid var(--border);
  border-radius: var(--r-lg);
  padding: 1.9rem 1.7rem;
  box-shadow: var(--shadow-card);
  display: flex;
  flex-direction: column;
  gap: 1.2rem;
}
.quote .stars { color: var(--gold); letter-spacing: 2px; }
.quote blockquote { font-weight: 600; color: var(--text-soft); font-size: 1.02rem; line-height: 1.6; }
.quote figcaption { display: flex; align-items: center; gap: 0.8rem; margin-top: auto; }
.quote .avatar {
  width: 46px;
  height: 46px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  color: #fff;
  flex: 0 0 auto;
}
.quote figcaption b { display: block; color: var(--navy); font-size: 0.95rem; }
.quote figcaption span { font-size: 0.85rem; color: var(--muted); font-weight: 600; }
@media (max-width: 980px) { .quotes { grid-template-columns: 1fr; max-width: 480px; margin: 0 auto; } }

/* ── Demo-Band (Web-Player) ── */
.demo-band { background: var(--blue-tint); }
.demo-band .feature { padding: 0; }
.browser {
  background: var(--bezel);
  border-radius: var(--r-md);
  overflow: hidden;
  box-shadow: 14px 18px 0 rgba(14, 139, 196, 0.35);
}
.browser__bar {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 10px 14px;
}
.browser__bar i { width: 11px; height: 11px; border-radius: 50%; display: block; }
.browser__bar i:nth-child(1) { background: #FF5F57; }
.browser__bar i:nth-child(2) { background: #FEBC2E; }
.browser__bar i:nth-child(3) { background: #28C840; }
.browser__bar span {
  margin-left: 8px;
  font-size: 0.75rem;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.6);
  background: rgba(255, 255, 255, 0.1);
  border-radius: 6px;
  padding: 2px 12px;
}
.browser img { display: block; width: 100%; }

/* ── Lead-Formular ── */
.lead-form { display: grid; gap: 1.1rem; max-width: 560px; margin: 0 auto; }
.lead-form .row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 1.1rem; }
.field { display: grid; gap: 0.35rem; }
.field label { font-weight: 800; font-size: 0.9rem; color: var(--navy); }
.field input, .field select, .field textarea {
  font-family: inherit;
  font-size: 1rem;
  font-weight: 600;
  color: var(--text);
  background: var(--card);
  border: 2px solid var(--border);
  border-radius: var(--r-sm);
  padding: 0.75rem 0.9rem;
  width: 100%;
}
.field input:focus, .field select:focus, .field textarea:focus { border-color: var(--blue); outline: none; }
.field textarea { min-height: 120px; resize: vertical; }
.form-note { font-size: 0.82rem; color: var(--muted); font-weight: 600; text-align: center; }
.form-status { display: none; text-align: center; font-weight: 800; padding: 1rem; border-radius: var(--r-md); }
.form-status.ok { display: block; background: var(--green-tint); color: var(--green-shadow); }
.form-status.err { display: block; background: #FDE8E8; color: #C62828; }
.hp-field { position: absolute; left: -9999px; opacity: 0; height: 0; overflow: hidden; }
@media (max-width: 560px) { .lead-form .row2 { grid-template-columns: 1fr; } }

/* ── Zielgruppen-Seiten ── */
.page-hero { padding: 4rem 0 4.5rem; }
.page-hero .hero__inner { grid-template-columns: 1.1fr 0.9fr; }
.page-hero .phone { width: min(270px, 80%); margin: 0 auto; }
.benefits { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.6rem; }
.benefit {
  background: var(--card);
  border: 2px solid var(--border);
  border-radius: var(--r-lg);
  padding: 1.9rem 1.7rem;
  box-shadow: var(--shadow-card);
}
.benefit .benefit__icon {
  width: 52px;
  height: 52px;
  border-radius: var(--r-md);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1rem;
}
.benefit h3 { margin-bottom: 0.5rem; font-size: 1.15rem; }
.benefit p { color: var(--text-soft); font-size: 0.95rem; font-weight: 600; }
@media (max-width: 980px) {
  .page-hero .hero__inner { grid-template-columns: 1fr; }
  .benefits { grid-template-columns: 1fr; max-width: 480px; margin: 0 auto; }
}

/* ── Sitz-Wahl (Preiskarten) ── */
.seat-picker { display: flex; align-items: center; gap: 0.8rem; justify-content: center; margin-top: 0.4rem; }
.seat-picker button {
  width: 38px; height: 38px; border-radius: 50%; border: 0; cursor: pointer;
  font: 800 1.2rem 'Nunito'; color: #fff; background: var(--blue);
  box-shadow: 0 3px 0 var(--blue-shadow);
}
.seat-picker button:active { transform: translateY(3px); box-shadow: none; }
.seat-picker b { min-width: 2.2rem; text-align: center; font-size: 1.3rem; color: var(--navy); }
.seat-picker span { font-weight: 600; color: var(--muted); font-size: 0.9rem; }
.seat-total { display: block; text-align: center; font-size: 0.85rem; font-weight: 800; color: var(--green-shadow); margin-top: 0.5rem; min-height: 1.2em; }

/* ── Consent-Banner ── */
.consent {
  position: fixed;
  left: 50%;
  transform: translateX(-50%);
  bottom: 1rem;
  z-index: 90;
  width: min(560px, calc(100vw - 2rem));
  background: var(--card);
  border: 2px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: 0 8px 0 rgba(13, 27, 64, 0.12);
  padding: 1.2rem 1.4rem;
}
.consent p { font-size: 0.92rem; font-weight: 600; color: var(--text-soft); margin-bottom: 0.9rem; }
.consent__actions { display: flex; gap: 0.8rem; flex-wrap: wrap; }
.consent__actions .btn { flex: 1 1 12rem; font-size: 0.95rem; padding: 0.75rem 1rem; }
@media (max-width: 820px) { .consent { bottom: 92px; } }
