/* ============================================
   MEINMAKLER24 - Clean Editorial Dark
   JVM Ad Creative Style
   Ärztegrün + Dark + Clean Typography
   v3 — Proportionen korrigiert
   ============================================ */

:root {
  --bg: #ffffff;
  --bg-card: #f5f5f7;
  --bg-elevated: #ebebed;
  --bg-hover: #e0e0e3;
  --border: rgba(0,0,0,0.10);
  --border-hover: rgba(0,0,0,0.18);
  --teal: #0d9488;
  --teal-dim: rgba(13,148,136,0.08);
  --teal-border: rgba(13,148,136,0.18);
  --white: #1d1d1f;
  --gray-100: #1d1d1f;
  --gray-200: #424245;
  --gray-300: #6e6e73;
  --gray-400: #86868b;
  --gray-500: #aeaeb2;
  --red: #dc2626;
  --red-dim: rgba(220,38,38,0.06);
  --green: #059669;
  --font: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --max-w: 1320px;
  --radius: 8px;
  --radius-lg: 14px;
}

/* ── Reset ── */
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box }
html { scroll-behavior:smooth; scroll-padding-top:100px; font-size:16px; -webkit-font-smoothing:antialiased; overflow-x:hidden }
.has-trust-bar { scroll-padding-top:100px }
body { font-family:var(--font); color:var(--gray-300); background:var(--bg); line-height:1.75; overflow-x:hidden; cursor:none; max-width:100vw }
*, *::before, *::after { box-sizing:border-box }
img  { max-width:100%; height:auto; display:block }
a    { text-decoration:none; color:inherit; transition:color .2s }
ul,ol { list-style:none }

.container        { width:100%; max-width:var(--max-w); margin:0 auto; padding:0 32px }
.container--narrow { max-width:820px }
.container--wide   { max-width:1440px; overflow:hidden }

/* ── Typography Scale ──
   H1  3.2rem  800  hero only
   H2  2.2rem  700  section heads
   H3  1.4rem  700  sub-sections
   H4  1.1rem  600  cards / items
   Body .95rem 400
   Small .88rem
   Tiny  .78rem
   ── */

h1, h2, h3, h4 { color:var(--white); letter-spacing:-0.015em }

h1 { font-size:clamp(2.4rem, 5vw, 3.4rem); font-weight:700; line-height:1.08 }
h2 { font-size:clamp(1.8rem, 3.5vw, 2.8rem); font-weight:700; line-height:1.1 }
h3 { font-size:clamp(1.2rem, 2.2vw, 1.5rem); font-weight:600; line-height:1.25 }
h4 { font-size:1.05rem; font-weight:600; line-height:1.3 }

p      { font-size:1rem; margin-bottom:1rem }
strong { color:var(--gray-100); font-weight:600 }

.teal       { color:var(--teal) }
.text-center { text-align:center }

.label {
  display:inline-block;
  font-size:1.05rem; font-weight:700;
  text-transform:uppercase; letter-spacing:1.5px;
  color:var(--teal);
  margin-bottom:14px;
}

.subtitle {
  font-size:1.05rem; color:var(--gray-300);
  max-width:620px; line-height:1.7;
}
.subtitle--lg    { font-size:1.15rem; max-width:660px }
.subtitle--center { margin:0 auto 48px; text-align:center }

/* ── Links & CTAs ── */
.link {
  color:var(--teal); font-weight:500; font-size:.95rem;
  display:inline-flex; align-items:center; gap:5px;
  transition:gap .2s, color .2s;
}
.link:hover { gap:12px }
.link::after { content:'→' }

.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:6px;
  padding:12px 26px;
  font-family:var(--font); font-size:.92rem; font-weight:500;
  border:none; border-radius:999px;
  cursor:pointer; transition:all .2s;
  letter-spacing:0;
}
.btn--primary { background:var(--teal); color:#ffffff }
.btn--primary:hover { filter:brightness(1.06); transform:scale(1.02) }
.btn--outline { background:transparent; color:var(--teal); border:1.5px solid var(--teal) }
.btn--outline:hover { background:var(--teal); color:#fff; transform:scale(1.02) }
.btn--lg  { padding:14px 32px; font-size:1rem }
.btn--sm  { padding:8px 18px; font-size:.82rem }
.btn--ghost { background:transparent; color:var(--teal); padding:14px 0 }
.btn--ghost:hover { color:var(--white) }
.btn--ghost::after { content:'→'; margin-left:6px; transition:margin .2s }
.btn--ghost:hover::after { margin-left:12px }

/* ── Nav ── */
.nav {
  position:fixed; top:0; left:0; right:0; z-index:100;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
}
.nav__inner {
  display:flex; align-items:center; justify-content:space-between;
  height:48px;
}
.nav__logo {
  display:flex; align-items:center; gap:8px;
  font-size:.95rem; font-weight:600; color:var(--white);
}
.nav__logo img { width:24px; height:24px; border-radius:50% }
.nav__links { display:flex; align-items:center; gap:24px }
.nav__link  { color:var(--gray-400); font-size:.88rem; font-weight:400; transition:color .2s }
.nav__link:hover, .nav__link.active { color:var(--white) }
.nav__cta {
  color:var(--teal); font-size:.82rem; font-weight:500;
  border:1px solid var(--teal);
  padding:6px 16px; border-radius:999px;
  transition:all .2s;
}
.nav__cta:hover { background:var(--teal); color:#fff }
.nav__toggle {
  display:none; background:none; border:none;
  color:var(--white); font-size:1.4rem; cursor:pointer; padding:8px;
}

/* ── Hero ── */
.hero {
  position:relative; min-height:100vh;
  display:flex; align-items:center;
  padding:120px 0 80px; overflow:hidden;
}
.hero__bg { position:absolute; inset:0; z-index:0 }
.hero {
  background:var(--bg);
}
.hero__bg { display:none }
.hero__inner {
  position:relative; z-index:1;
  display:grid; grid-template-columns:1fr 1fr; gap:56px;
  align-items:center;
}
.hero h1     { margin-bottom:24px }
.hero .subtitle { margin-bottom:40px }
.hero__ctas  { display:flex; gap:16px; flex-wrap:wrap; margin-bottom:48px }
.hero__proof {
  display:flex; gap:36px;
  padding-top:28px;
  border-top:1px solid var(--border);
}
.hero__proof-item  { display:flex; flex-direction:column }
.hero__proof-number { font-size:1.3rem; font-weight:700; color:var(--white) }
.hero__proof-label  { font-size:.78rem; color:var(--gray-400); margin-top:2px }

/* Hero card */
.hero__card {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:28px;
}
.hero__stats { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:16px }
.hero__stat {
  padding:14px; text-align:center;
  background:var(--bg); border-radius:var(--radius); border:1px solid var(--border);
}
.hero__stat-val { font-size:1.5rem; font-weight:700; color:var(--white); display:block }
.hero__stat-lbl { font-size:.72rem; color:var(--gray-400); margin-top:2px }
.hero__quote {
  padding:14px; background:var(--bg); border-radius:var(--radius);
  border:1px solid var(--border);
}
.hero__quote-stars  { color:var(--teal); font-size:.95rem; margin-bottom:6px }
.hero__quote-text   { font-size:.88rem; font-style:italic; color:var(--gray-300); margin-bottom:6px; line-height:1.6 }
.hero__quote-author { font-size:.72rem; color:var(--gray-500) }

/* ── Sections ── */
.section      { padding:72px 0 }
.section--alt { background:#f5f5f7 }
.section--dark { background:var(--bg) }
.section__head { margin-bottom:48px }
.section__head.center { text-align:center }
.section__head .label { margin-bottom:10px }
.section__head h2 { margin-bottom:24px }

/* ── Bekannt aus ── */
.logos-bar {
  padding:28px 0;
  border:none;
  background:#f5f5f7;
  margin:0;
}
.logos-bar__label {
  text-align:center; font-size:.65rem; color:var(--gray-400);
  text-transform:uppercase; letter-spacing:2.5px; font-weight:500;
  margin-bottom:14px;
}
.logos-bar__row {
  display:flex; align-items:center; justify-content:center;
  gap:32px; flex-wrap:wrap;
}
.logos-bar__item { font-size:.82rem; font-weight:600; color:var(--gray-400); opacity:.55; transition:color .2s, opacity .2s }
a.logos-bar__item:hover { color:var(--teal); opacity:1 }

/* ── Split (Problem grid) ── */
.split {
  display:grid; grid-template-columns:1fr 1fr; gap:56px;
  align-items:center;
}
.split--reverse .split__visual { order:-1 }

.problem-list { margin-top:32px; display:flex; flex-direction:column; gap:8px }
.problem-item {
  display:flex; gap:16px;
  padding:18px 20px;
  border-radius:12px;
  border:1px solid rgba(0,0,0,0.12);
  transition:border-color .2s, transform .2s;
  background:#f5f5f7;
}
.problem-item:hover { border-color:rgba(255,255,255,0.1); transform:translateX(4px) }
.problem-item__icon {
  font-size:.72rem; flex-shrink:0; font-weight:600;
  color:var(--teal); width:28px; height:28px;
  display:flex; align-items:center; justify-content:center;
  border:1.5px solid var(--teal); border-radius:50%;
  background:rgba(13,148,136,0.08); margin-top:2px;
  letter-spacing:0;
}
.problem-item h4   { font-size:1rem; margin-bottom:3px }
.problem-item p    { font-size:.9rem; margin:0; color:var(--gray-400) }

.stat-card {
  border:1px solid rgba(0,0,0,0.12);
  border-radius:16px; padding:48px; text-align:center; background:#f5f5f7;
  display:flex; flex-direction:column; justify-content:center;
  min-height:100%;
}
.stat-card__num  { font-size:3.6rem; font-weight:800; color:var(--teal); display:block; line-height:1 }
.stat-card__text { font-size:1rem; color:var(--gray-300); margin-top:16px; line-height:1.6 }
.stat-card__note { font-size:.85rem; color:var(--gray-500); margin-top:16px; font-style:italic }

/* ── SC3 Pillars ── */
.pillars { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-bottom:56px }
.pillar {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:28px;
  transition:border-color .2s, transform .2s;
}
.pillar:hover { border-color:var(--teal-border); transform:translateY(-3px) }
.pillar__step {
  display:inline-flex; align-items:center; justify-content:center;
  width:44px; height:44px; border-radius:50%;
  font-weight:800; font-size:1.1rem; margin-bottom:14px;
  background:var(--teal-dim); color:var(--teal);
  border:1px solid var(--teal-border);
}
.pillar h3  { margin-bottom:8px }
.pillar p   { font-size:.88rem; color:var(--gray-400); margin-bottom:14px }
.pillar__checks { display:flex; flex-direction:column; gap:7px }
.pillar__check {
  display:flex; align-items:flex-start; gap:8px;
  font-size:.85rem; color:var(--gray-300); line-height:1.4;
}
.pillar__check::before { content:'✓'; color:var(--teal); font-weight:700; flex-shrink:0 }

/* Banner */
.banner {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:36px;
  display:flex; align-items:center; justify-content:space-between; gap:28px;
}
.banner h3 { margin-bottom:4px; font-size:1.2rem }
.banner p  { color:var(--gray-400); margin:0; font-size:.92rem }

/* ── Process Steps ── */
.steps { display:grid; grid-template-columns:repeat(4,1fr); gap:20px }
.step  { text-align:center }
.step__num {
  width:52px; height:52px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-weight:700; font-size:1.1rem;
  border:2px solid var(--teal); color:var(--teal);
  margin:0 auto 14px; background:var(--bg);
  transition:all .2s;
}
.step:hover .step__num { background:var(--teal); color:var(--bg) }
.step h4 { margin-bottom:6px; font-size:.95rem }
.step p  { font-size:.82rem; color:var(--gray-400) }
.step__tag {
  display:inline-block; margin-top:10px;
  padding:3px 12px; border-radius:99px;
  font-size:.72rem; font-weight:600;
  background:var(--teal-dim); color:var(--teal);
  border:1px solid var(--teal-border);
}

/* ── Comparison Table ── */
.table-wrap { overflow-x:auto }
table { width:100%; border-collapse:collapse; border-radius:var(--radius-lg); overflow:hidden }
table thead th {
  background:var(--bg-elevated); color:var(--gray-200);
  padding:14px 18px; font-size:.85rem; font-weight:600; text-align:left;
}
table thead th:last-child { color:var(--teal) }
table tbody td {
  padding:12px 18px; font-size:.85rem; color:var(--gray-300);
  border-bottom:1px solid var(--border); background:var(--bg-card);
}
table tbody tr:hover td { background:var(--bg-elevated) }
table tbody td:first-child { color:var(--gray-100); font-weight:500 }
.check { color:var(--teal) }
.cross { color:var(--red) }

/* ── Reviews ── */
.reviews-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-bottom:36px }
.review {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:24px;
  transition:transform .2s;
}
.review:hover { transform:translateY(-2px) }
.review__source { font-size:.72rem; color:var(--gray-500); margin-bottom:8px }
.review__stars  { color:var(--teal); font-size:.92rem; margin-bottom:10px; letter-spacing:1px }
.review__text   { font-size:.88rem; color:var(--gray-300); line-height:1.65; margin-bottom:14px; font-style:italic }
.review__author { display:flex; align-items:center; gap:10px }
.review__avatar {
  width:34px; height:34px; border-radius:50%;
  background:var(--bg-elevated); border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  font-size:.78rem; font-weight:600; color:var(--gray-300);
}
.review__name { font-size:.85rem; font-weight:600; color:var(--gray-100) }
.review__date { font-size:.72rem; color:var(--gray-500) }

.reviews-summary {
  display:flex; align-items:center; justify-content:center; gap:48px;
  padding:24px; background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-lg);
}
.reviews-summary__item { text-align:center }
.reviews-summary__num  { font-size:1.8rem; font-weight:700; color:var(--white) }
.reviews-summary__stars { color:var(--teal); font-size:1rem }
.reviews-summary__lbl  { font-size:.72rem; color:var(--gray-500); margin-top:2px }

/* ── Grids & Cards ── */
.grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:20px }
.grid-2 { display:grid; grid-template-columns:repeat(2,1fr); gap:20px }

.card {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:28px;
  transition:border-color .2s, transform .2s;
}
.card:hover { border-color:var(--teal-border); transform:translateY(-2px) }
.card__icon { font-size:1.6rem; margin-bottom:12px }
.card h4    { margin-bottom:6px }
.card p     { font-size:.88rem; margin:0; color:var(--gray-400) }

/* ── Myths ── */
.myth {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:24px;
}
.myth__false { display:flex; gap:10px; margin-bottom:12px; color:var(--red); font-weight:600; font-size:.92rem }
.myth__true  { display:flex; gap:10px; color:var(--gray-300); font-size:.88rem; line-height:1.6 }
.myth__true::before { content:'✓'; color:var(--teal); font-weight:700; flex-shrink:0 }

/* ── CTA Block ── */
.cta-block {
  padding:96px 0; text-align:center; margin-bottom:0;
  background:var(--bg-card); border-top:1px solid var(--border); border-bottom:1px solid var(--border);
}

.footer { margin-top:48px }
.cta-block h2 { margin-bottom:12px }
.cta-block .subtitle { margin:0 auto 28px }
.cta-checks {
  display:flex; justify-content:center; gap:24px;
  margin-bottom:28px; flex-wrap:wrap;
}
.cta-checks span {
  display:flex; align-items:center; gap:6px;
  font-size:.88rem; color:var(--gray-300);
}
.cta-checks span::before { content:'✓'; color:var(--teal); font-weight:700 }
.cta-note { font-size:.78rem; color:var(--gray-500); margin-top:14px }

/* ── Stats Bar ── */
.stats-bar {
  padding:56px 0;
  border-top:1px solid var(--border); border-bottom:1px solid var(--border);
}
.stats-row { display:grid; grid-template-columns:repeat(4,1fr); gap:20px }
.stats-item { text-align:center; padding:20px }
.stats-item__val { font-size:2.2rem; font-weight:700; color:var(--white); display:block }
.stats-item__lbl { font-size:.82rem; color:var(--gray-400); margin-top:4px }

/* ── Funnel Form ── */
.form-wrap {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:36px;
  max-width:540px; margin:0 auto;
}
.form-progress { display:flex; justify-content:space-between; margin-bottom:28px; position:relative }
.form-progress::before {
  content:''; position:absolute; top:15px; left:12%; right:12%;
  height:1px; background:var(--border);
}
.form-progress__step { display:flex; flex-direction:column; align-items:center; gap:6px; z-index:1 }
.form-progress__dot {
  width:30px; height:30px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:.78rem; font-weight:600;
  background:var(--bg); border:2px solid var(--border-hover); color:var(--gray-500);
  transition:all .2s;
}
.form-progress__step.active .form-progress__dot { border-color:var(--teal); color:var(--teal); background:var(--teal-dim) }
.form-progress__step.done .form-progress__dot   { border-color:var(--teal); background:var(--teal); color:var(--bg) }
.form-progress__label { font-size:.68rem; color:var(--gray-500) }

.form-step { display:none }
.form-step.active { display:block; animation:fadeUp .3s ease }
@keyframes fadeUp { from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:translateY(0)} }

.form-group { margin-bottom:14px }
.form-label { display:block; font-size:.88rem; font-weight:500; color:var(--gray-200); margin-bottom:6px }
.form-input, .form-select {
  width:100%; padding:11px 14px;
  background:var(--bg); border:1px solid var(--border-hover);
  border-radius:var(--radius); color:var(--white); font-family:var(--font); font-size:.92rem;
  transition:border-color .2s;
}
.form-input:focus, .form-select:focus { outline:none; border-color:var(--teal) }
.form-input::placeholder { color:var(--gray-500) }

.form-radios { display:grid; grid-template-columns:1fr 1fr; gap:10px }
.form-radio {
  padding:12px; text-align:center;
  border:1px solid var(--border-hover); border-radius:var(--radius);
  cursor:pointer; font-size:.88rem; font-weight:500; color:var(--gray-300);
  background:var(--bg); transition:all .2s;
}
.form-radio:hover    { border-color:var(--teal); color:var(--white) }
.form-radio.selected { border-color:var(--teal); background:var(--teal-dim); color:var(--teal) }

.form-radio--check {
  display:flex; align-items:center; gap:10px; text-align:left; cursor:pointer;
}
.form-radio--check input[type="checkbox"] {
  accent-color:var(--teal); width:18px; height:18px; flex-shrink:0;
}
.form-radios--multi { grid-template-columns:1fr 1fr }

.form-actions { display:flex; gap:10px; margin-top:20px }
.form-actions .btn { flex:1 }

/* Error states */
.form-error {
  background:var(--red-dim); border:1px solid rgba(248,113,113,0.2);
  border-radius:var(--radius); padding:10px 14px;
  font-size:.85rem; color:var(--red); margin-bottom:12px;
}
.form-input.invalid, .form-select.invalid {
  border-color:var(--red);
}
.form-label { position:relative }


/* ── About ── */
.about-img     { border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--border) }
.about-img img { width:100%; height:100%; object-fit:cover; object-position:center 20% }
.about-features {
  display:grid; grid-template-columns:1fr 1fr; gap:8px; margin-top:20px;
}
.about-feat {
  display:flex; align-items:center; gap:8px;
  font-size:.88rem; color:var(--gray-300);
}
.about-feat::before { content:'✓'; color:var(--teal); font-weight:700 }

/* ── Knowledge Cards ── */
.knowledge-card {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:24px;
  transition:border-color .2s, transform .2s;
}
.knowledge-card:hover { border-color:var(--teal-border); transform:translateY(-2px) }
.knowledge-card__icon { font-size:1.5rem; margin-bottom:12px }
.knowledge-card h4    { margin-bottom:5px; font-size:1rem }
.knowledge-card p     { font-size:.85rem; color:var(--gray-400); margin-bottom:10px }

/* ── FAQ ── */
.faq { max-width:760px; margin:0 auto }
.faq-item { border-bottom:1px solid var(--border) }
.faq-q {
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 0; cursor:pointer;
  font-weight:600; font-size:.95rem; color:var(--gray-100);
  transition:color .2s;
}
.faq-q:hover { color:var(--teal) }
.faq-icon { font-size:.85rem; color:var(--gray-400); transition:transform .3s }
.faq-item.open .faq-icon { transform:rotate(180deg) }
.faq-a { max-height:0; overflow:hidden; transition:max-height .3s ease }
.faq-a__inner {
  padding:0 0 18px; font-size:.92rem;
  color:var(--gray-300); line-height:1.8;
}

/* ── Footer ── */
.footer {
  background:var(--bg-card); padding:56px 0 18px;
  border-top:1px solid var(--border);
}
.footer__grid {
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr;
  gap:36px; margin-bottom:36px;
}
.footer__logo {
  display:flex; align-items:center; gap:10px;
  font-size:1.05rem; font-weight:700; color:var(--white); margin-bottom:10px;
}
.footer__logo img { width:26px; height:26px; border-radius:50% }
.footer__desc { font-size:.85rem; color:var(--gray-400); line-height:1.6; margin-bottom:14px; max-width:280px }
.footer__social { display:flex; gap:8px }
.footer__social a {
  width:30px; height:30px; border-radius:50%;
  background:var(--bg); border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  font-size:.72rem; color:var(--gray-400); transition:all .2s;
}
.footer__social a:hover { border-color:var(--teal); color:var(--teal) }
.footer h4      { color:var(--gray-100); font-size:.85rem; font-weight:600; margin-bottom:12px; letter-spacing:0 }
.footer__link   { display:block; font-size:.85rem; color:var(--gray-500); padding:3px 0; transition:color .2s }
.footer__link:hover { color:var(--teal) }
.footer__bottom {
  border-top:1px solid var(--border); padding-top:14px;
  display:flex; justify-content:space-between; align-items:center;
  font-size:.75rem; color:var(--gray-500); flex-wrap:wrap; gap:12px;
}
.footer__bottom-links { display:flex; gap:18px }
.footer__bottom-links a { color:var(--gray-500); transition:color .2s }
.footer__bottom-links a:hover { color:var(--teal) }

/* ── Floating CTA ── */
.float-cta {
  position:fixed; bottom:32px; right:32px; z-index:99;
  display:flex; flex-direction:column; gap:12px; align-items:flex-end;
}
.float-btn {
  border-radius:50%; border:none;
  cursor:pointer; display:flex; align-items:center; justify-content:center;
  transition:transform .3s cubic-bezier(.4,0,.2,1), box-shadow .3s;
}
.float-btn--book {
  width:64px; height:64px;
  background:var(--teal); color:var(--bg);
  font-size:1.3rem; font-weight:700;
  box-shadow:0 4px 20px rgba(92,224,210,0.3);
  animation:floatPulse 3s ease-in-out infinite;
}
.float-btn--book:hover {
  transform:scale(1.15) rotate(5deg);
  box-shadow:0 8px 32px rgba(92,224,210,0.5);
  animation:none;
}
@keyframes floatPulse {
  0%,100% { box-shadow:0 4px 20px rgba(92,224,210,0.25) }
  50% { box-shadow:0 4px 28px rgba(92,224,210,0.45) }
}
.float-btn--top {
  width:40px; height:40px;
  background:var(--bg-card); border:1px solid var(--border);
  color:var(--gray-300); font-size:.85rem;
  opacity:0; pointer-events:none; transition:opacity .2s;
}
.float-btn--top.show { opacity:1; pointer-events:auto }
.float-btn--top:hover { transform:scale(1.08) }

/* ── Mobile bar ── */
.mobile-bar {
  position:fixed; bottom:0; left:0; right:0; z-index:98;
  background:var(--bg-card); border-top:1px solid var(--border);
  padding:10px 16px; padding-bottom:calc(10px + env(safe-area-inset-bottom)); display:none;
}
.mobile-bar__inner { display:flex; align-items:center; justify-content:space-between; gap:10px }
.mobile-bar__text  { color:var(--gray-100); font-size:.82rem; font-weight:600 }

/* ── Exit Popup ── */
.popup-overlay {
  position:fixed; inset:0; background:rgba(0,0,0,.8);
  backdrop-filter:blur(4px); z-index:1000;
  display:flex; align-items:center; justify-content:center;
  opacity:0; pointer-events:none; transition:opacity .2s;
}
.popup-overlay.active { opacity:1; pointer-events:auto }
.popup {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-lg); max-width:460px; width:90%;
  padding:36px; text-align:center;
  transform:scale(.95); transition:transform .2s;
}
.popup-overlay.active .popup { transform:scale(1) }
.popup__close {
  position:absolute; top:12px; right:12px; background:none; border:none;
  color:var(--gray-500); font-size:1.2rem; cursor:pointer; padding:4px;
}
.popup__close:hover { color:var(--white) }
.popup__icon { font-size:2rem; margin-bottom:10px }
.popup h3    { margin-bottom:8px }
.popup p     { margin-bottom:18px; font-size:.92rem }

/* ══════════════════════════════════════════
   HIGH-END: Scroll-Driven Animations (CSS-only)
   Reading Progress, Parallax, Section Entrances
   ══════════════════════════════════════════ */

/* ── Reading Progress Bar ── */
/* Progress Bar wird komplett per JS erstellt */

/* ── Vergleich Desktop/Mobile ── */
.compare-desktop { display:block }
.compare-mobile { display:none }
.compare-row {
  background:var(--bg-card); border:1px solid var(--border); border-radius:12px;
  padding:16px; display:flex; flex-direction:column; gap:6px;
}
.compare-label { font-weight:600; font-size:.88rem; color:var(--white); margin-bottom:2px }
.compare-a { font-size:.82rem; color:var(--gray-400) }
.compare-b { font-size:.82rem; color:var(--teal); font-weight:500 }
.compare-a .cross { color:#ef4444; margin-right:4px }
.compare-b .check { color:var(--teal); margin-right:4px }

/* ── Hero Parallax ── */
.hero__bg img {
  animation: heroParallax linear;
  animation-timeline: scroll(root block);
}
@keyframes heroParallax { from{transform:translateY(0)} to{transform:translateY(15%)} }

/* ── Scroll-Driven Section Entrances ── */
@keyframes scrollFadeUp {
  from { opacity:0; transform:translateY(28px) }
  to   { opacity:1; transform:translateY(0) }
}
@keyframes scrollFadeScale {
  from { opacity:0; transform:scale(0.96) translateY(20px) }
  to   { opacity:1; transform:scale(1) translateY(0) }
}
@keyframes scrollSlideLeft {
  from { opacity:0; transform:translateX(-24px) }
  to   { opacity:1; transform:translateX(0) }
}
@keyframes scrollSlideRight {
  from { opacity:0; transform:translateX(24px) }
  to   { opacity:1; transform:translateX(0) }
}

/* CSS scroll animations disabled — GSAP handles all animations */
/* .scroll-in, .scroll-in-scale etc. are animated via js/animations.js */

/* Stagger handled by GSAP */

/* All scroll animations handled by GSAP (js/animations.js) */

/* ── Micro-Interactions ── */
.card, .pillar, .review, .knowledge-card, .myth {
  will-change: transform;
}

/* Card hover — Apple subtle lift */
.card:hover, .pillar:hover, .knowledge-card:hover, .review:hover, .myth:hover {
  border-color:rgba(0,0,0,.14);
  box-shadow:0 2px 10px rgba(0,0,0,.05);
  transform:translateY(-1px);
}

/* Link hover micro-animation */
.link { position:relative }
.link::before {
  content:''; position:absolute; bottom:-2px; left:0;
  width:0; height:1px; background:var(--teal);
  transition:width .3s ease;
}
.link:hover::before { width:calc(100% - 20px) }

/* Button press effect */
.btn:active { transform:scale(0.98) }

/* Table row highlight slide */
table tbody tr { transition:background .15s ease }

/* ── WCAG Dark Mode Refinements ── */
body {
  letter-spacing:0.008em; /* +0.01em for dark readability */
}
p, li, .faq-a__inner, .review__text, .myth__true {
  font-weight:420; /* Slightly heavier for dark contrast */
}

/* ── Accessibility ── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration:0.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:0.01ms !important;
  }
}

/* ── Focus states for keyboard nav ── */
a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible {
  outline:2px solid var(--teal);
  outline-offset:2px;
}

/* ══════════════════════════════════════════
   NEUE KOMPONENTEN: Trust, Visuals, Charts
   ══════════════════════════════════════════ */

/* ── Trust Bar (unter Nav, persistent) ── */
.trust-bar {
  background:var(--bg-card); border-bottom:1px solid var(--border);
  padding:7px 0; position:fixed; top:48px; left:0; right:0; z-index:99;
}
.trust-bar__inner {
  display:flex; align-items:center; justify-content:center;
  gap:24px; flex-wrap:wrap;
}
.trust-bar__item {
  display:flex; align-items:center; gap:5px;
  font-size:.72rem; font-weight:500; color:var(--gray-400);
}
.trust-bar__item .teal { font-weight:700 }

/* Offset for trust bar */
.has-trust-bar .hero { padding-top:130px }
@media(max-width:768px) {
  .trust-bar__inner { gap:16px }
  .trust-bar__item { font-size:.72rem }
  .has-trust-bar .hero { padding-top:140px }
}

/* ── Full-Bleed Image Section ── */
.img-section {
  position:relative; overflow:hidden;
  min-height:520px; display:flex; align-items:center;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.img-section__bg {
  position:absolute; inset:0; z-index:0;
}
.img-section__bg img {
  width:100%; height:100%; object-fit:cover;
  object-position:center 15%;
  filter:brightness(.35);
}
.img-section__content {
  position:relative; z-index:1;
  max-width:600px;
}
.img-section__content h2, .img-section__content h3 { color:#ffffff }
.img-section__content p { color:rgba(255,255,255,.8); font-size:1.05rem; margin-bottom:24px }
.img-section__content .label { color:#5ce0d2 }
.img-section__content .link { color:#5ce0d2 }
.img-section__content .btn--primary { background:#5ce0d2; color:#0f1319 }

/* ── Photo + Text Split (mit echtem Foto) ── */
.photo-split {
  display:grid; grid-template-columns:1fr 1fr; gap:0;
  min-height:480px; overflow:hidden;
  border-radius:var(--radius-lg); border:1px solid var(--border);
}
.photo-split__img {
  overflow:hidden;
}
.photo-split__img img {
  width:100%; height:100%; object-fit:cover;
  object-position:center 20%;
  transition:transform .4s ease;
}
.photo-split:hover .photo-split__img img {
  transform:scale(1.03);
}
.photo-split__content {
  padding:48px 40px; display:flex; flex-direction:column; justify-content:center;
  background:var(--bg-card);
}
.photo-split__content h3 { margin-bottom:12px }
.photo-split__content p { font-size:.92rem; color:var(--gray-400) }
@media(max-width:768px) {
  .photo-split { grid-template-columns:1fr; min-height:auto }
  .photo-split__img { max-height:280px }
  .photo-split__content { padding:32px 24px }
}

/* ── Summary Box ("Das Wichtigste in Kürze") ── */
.summary-box {
  background:var(--teal-dim); border:1px solid var(--teal-border);
  border-radius:var(--radius-lg); padding:28px 32px;
  margin-bottom:40px;
}
.summary-box__title {
  font-size:.85rem; font-weight:700; color:var(--teal);
  text-transform:uppercase; letter-spacing:1px;
  margin-bottom:12px; display:flex; align-items:center; gap:8px;
}
.summary-box ul { margin:0; padding:0 }
.summary-box li {
  display:flex; align-items:flex-start; gap:8px;
  font-size:.92rem; color:var(--gray-200); line-height:1.6;
  padding:5px 0; list-style:none;
}
.summary-box li::before { content:'→'; color:var(--teal); font-weight:700; flex-shrink:0 }

/* ── CSS Bar Chart (Beitragsentwicklung) ── */
.bar-chart {
  display:flex; flex-direction:column; gap:20px;
  padding:40px; background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-lg);
}
.bar-chart__title {
  font-size:1.15rem; font-weight:700; color:var(--white);
  margin-bottom:4px;
}
.bar-chart__row {
  display:flex; align-items:center; gap:16px;
}
.bar-chart__label {
  width:120px; flex-shrink:0;
  font-size:.95rem; font-weight:500; color:var(--gray-300);
  text-align:right;
}
.bar-chart__track {
  flex:1; height:44px; background:var(--bg); border-radius:6px;
  overflow:hidden; position:relative;
}
.bar-chart__fill {
  height:100%; border-radius:6px;
  display:flex; align-items:center; padding:0 16px;
  font-size:.95rem; font-weight:700; color:var(--bg);
  min-width:90px; white-space:nowrap;
  transition:width .8s ease;
}
.bar-chart__fill--teal { background:var(--teal) }
.bar-chart__fill--muted { background:var(--gray-400) }
.bar-chart__note {
  font-size:.82rem; color:var(--gray-500); margin-top:4px; font-style:italic;
}

/* ── Author/Date Badge ── */
.author-badge {
  display:inline-flex; align-items:center; gap:10px;
  font-size:.78rem; color:var(--gray-400);
  padding:8px 0; margin-bottom:20px;
}
.author-badge img {
  width:32px; height:32px; border-radius:50%;
  border:2px solid #fff; box-shadow:0 0 0 1px var(--border);
  object-fit:cover;
}
.author-badge strong { color:var(--gray-200) }

/* ── Breadcrumbs ── */
.breadcrumbs {
  font-size:.78rem; color:var(--gray-500);
  padding:12px 0;
}
.breadcrumbs a { color:var(--gray-400); transition:color .2s }
.breadcrumbs a:hover { color:var(--teal) }
.breadcrumbs span { margin:0 6px; color:var(--gray-500) }

/* ── Number Highlight ── */
.num-highlight {
  display:flex; align-items:baseline; gap:12px;
  margin:24px 0;
}
.num-highlight__val {
  font-size:3rem; font-weight:800; color:var(--teal); line-height:1;
  letter-spacing:-0.03em;
}
.num-highlight__text {
  font-size:.95rem; color:var(--gray-300); max-width:400px;
}

/* ── Quote Block (Standalone) ── */
.quote-block {
  border-left:3px solid var(--teal);
  padding:24px 28px; margin:40px 0;
  background:rgba(92,224,210,0.03);
  border-radius:0 var(--radius-lg) var(--radius-lg) 0;
}
.quote-block p {
  font-size:1.1rem; font-style:italic; color:var(--gray-200);
  line-height:1.7; margin-bottom:8px;
}
.quote-block cite {
  font-size:.82rem; color:var(--gray-400); font-style:normal;
}

/* ── Responsive additions ── */
@media(max-width:1024px) {
  .photo-split { grid-template-columns:1fr }
  .img-section { min-height:320px }
}
@media(max-width:768px) {
  .trust-bar { display:none }
  .has-trust-bar .hero { padding-top:96px }
  .num-highlight__val { font-size:2.2rem }
  .summary-box { padding:20px 24px }
}

/* ── Responsive ── */
@media (max-width:1024px) {
  .hero__inner, .split { grid-template-columns:1fr; gap:36px }
  .hero__card { max-width:460px }
  .split--reverse .split__visual { order:0 }
  .pillars { grid-template-columns:1fr; max-width:460px; margin-left:auto; margin-right:auto }
  .steps   { grid-template-columns:1fr 1fr }
  .reviews-grid { grid-template-columns:1fr; max-width:460px; margin-left:auto; margin-right:auto }
  .grid-3  { grid-template-columns:1fr 1fr }
  .stats-row { grid-template-columns:1fr 1fr }
  .footer__grid { grid-template-columns:1fr 1fr }
  .banner { flex-direction:column; text-align:center }
}

/* ═══════════════════════════════════════
   MOBILE — Apple-level responsive
   ═══════════════════════════════════════ */
@media (max-width:768px) {
  /* ── Layout ── */
  .container { padding:0 20px }
  .section { padding:48px 0 }
  .section__head { margin-bottom:32px }
  .section__head h2 { font-size:1.5rem; line-height:1.25 }
  .split h2 { margin-bottom:20px }
  .section__head .label { font-size:.6rem }
  .subtitle { font-size:.9rem }

  /* ── Nav ── */
  .nav { top:0; padding-top:max(12px, env(safe-area-inset-top, 12px)) }
  .nav__links {
    position:fixed; top:calc(48px + max(12px, env(safe-area-inset-top, 12px))); left:0; right:0;
    background:var(--bg-card); flex-direction:column;
    padding:24px; gap:16px;
    transform:translateY(-120%); transition:transform .2s;
    border-bottom:1px solid var(--border);
    visibility:hidden;
  }
  .nav__links.open { transform:translateY(0); visibility:visible }
  .nav__toggle { display:block }

  /* ── Hero: Mobile Reihenfolge 1.Headline 2.Drei Prüfebenen 3.Foto 4.Unterüberschrift ── */
  .hero { min-height:auto; padding:calc(88px + max(12px, env(safe-area-inset-top, 12px))) 0 0 }
  .hero .container { text-align:center }
  .hero h1 { font-size:2.2rem !important; letter-spacing:-0.02em; margin-bottom:4px !important }
  .hero__img-desktop { display:none !important }
  .hero__img-mobile { display:block !important; margin:20px 0 16px }
  .hero__proof { flex-direction:column; gap:10px }

  /* ── Grids ── */
  .grid-3, .grid-2 { grid-template-columns:1fr }
  .steps { grid-template-columns:1fr; max-width:340px; margin:0 auto }
  .pillars { grid-template-columns:1fr; max-width:100% }
  .reviews-summary { flex-direction:column; gap:18px }
  .stats-row { grid-template-columns:1fr 1fr; gap:12px }
  .footer__grid { grid-template-columns:1fr }

  /* ── Tabellen: scrollbar auf Mobile ── */
  .table-wrap { overflow-x:auto; -webkit-overflow-scrolling:touch }
  table { font-size:.78rem; min-width:520px }
  .bap-table { display:block; overflow-x:auto; -webkit-overflow-scrolling:touch }
  .data-table { display:block; overflow-x:auto; -webkit-overflow-scrolling:touch }
  .compare-desktop { display:none }
  .compare-mobile { display:flex; flex-direction:column; gap:12px }
  table th, table td { padding:10px 12px }
  .data-table { font-size:.78rem; min-width:420px }
  .data-table th, .data-table td { padding:10px 12px }

  /* ── Cards & Pillars ── */
  .pillar { padding:24px }
  .pillar__checks { gap:6px }
  .pillar__check { font-size:.78rem }
  .card { padding:24px }

  /* ── Buttons ── */
  .btn--lg { padding:14px 28px; font-size:.92rem; width:100%; text-align:center }
  .cta-checks { flex-direction:column; gap:8px; align-items:center }

  /* ── Formular ── */
  .form-radios { grid-template-columns:1fr }
  .form-radios--multi { grid-template-columns:1fr }
  .form-wrap { padding:24px 20px }

  /* ── Stat-Grids auf Mobile stacken ── */
  .fact-box { padding:20px !important; margin-top:32px !important; border-radius:12px }
  .fact-grid { grid-template-columns:1fr 1fr !important; gap:10px !important }
  .fact-grid > div { padding:14px 10px !important }
  .fact-grid > div > div:first-child { font-size:1.3rem !important }
  .fact-grid > div > div:last-child { font-size:.7rem !important }

  /* ── Bild-Sektionen: kein Margin dazwischen ── */
  .img-section { min-height:200px !important; margin:0 !important }
  .img-section__content { padding:24px 20px }
  .img-section__content h3 { font-size:1.1rem }
  .img-section__content p { font-size:.82rem }

  /* ── Floating Elements ── */
  .mobile-bar { display:block }
  .float-cta { bottom:68px }
  .float-btn { width:44px; height:44px; font-size:1.1rem }

  /* ── Bekannt aus ── */
  .logos-bar { margin-top:24px !important; padding:16px 0 }
  .logos-bar__row { gap:12px; flex-wrap:wrap; justify-content:center }
  .logos-bar__item { font-size:.68rem }

  /* ── Bild-Sektionen ── */
  .img-section { min-height:240px !important }
  .img-section__content h3 { font-size:1.2rem }
  .img-section__content p { font-size:.85rem }
  .photo-split { grid-template-columns:1fr }

  /* ── Bar Charts ── */
  .bar-chart__label { width:80px; font-size:.78rem }
  .bar-chart__fill { font-size:.75rem; min-width:50px }
  .bar-chart__track { height:34px }

  /* ── Vergleichstabelle ── */
  .compare-table { font-size:.8rem }

  /* ── Case Studies ── */
  .case-study { margin:0 }

  /* ── Footer ── */
  .footer { padding:48px 0 32px }
  .footer__desc { font-size:.82rem }

  /* ── PKV-Ratgeber Spezial ── */
  .article h2 { font-size:1.35rem; margin:48px 0 12px }
  .article h3 { font-size:1.1rem }
  .article h4 { font-size:.95rem }
  .article p { font-size:.9rem }
  .article li { font-size:.88rem }
  .toc ol { columns:1 !important; column-gap:0 }
  .info, .warn { padding:18px; gap:12px; flex-direction:row; align-items:flex-start }
  .info::before, .warn::before { width:20px; height:20px; flex-shrink:0 }
  .cta-inline { padding:28px 20px; margin:28px 0 }
  .cta-inline h4 { font-size:1rem }
  .summary-box { padding:20px }
  .author-badge { flex-wrap:wrap }

  /* ── SC3-Seite Spezial ── */
  .feats { grid-template-columns:1fr }
  .vs { grid-template-columns:1fr }
  .srow { gap:24px }
  .bignum { font-size:clamp(5rem,12vw,8rem) }
  .ring { width:160px; height:160px }
  .timeline-vis { flex-direction:column; gap:12px; max-width:200px }
  .tl-step__line { display:none }
}

@media (max-width:480px) {
  .container { padding:0 16px }
  .hero h1 { font-size:1.9rem !important }
  .hero__stats { gap:6px }
  .hero__stat-val { font-size:1.2rem }
  .form-actions { flex-direction:column }
  .stats-item__val { font-size:1.8rem }
  .section__head h2 { font-size:1.3rem }
  .article h2 { font-size:1.2rem }
  .pillar__step { width:36px; height:36px; font-size:.85rem }
  table { min-width:360px; font-size:.72rem }
  table th, table td { padding:8px 10px }
  .data-table { min-width:340px; font-size:.72rem }
}

/* ── Utility ── */
/* ── Case Studies ── */
.case-study {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-lg); overflow:hidden;
  transition:border-color .2s, transform .2s;
}
.case-study:hover { border-color:var(--teal-border); transform:translateY(-3px) }
.case-study__video {
  position:relative; width:100%;
  background:var(--bg-elevated); overflow:hidden;
  border-radius:var(--radius-lg) var(--radius-lg) 0 0;
}
.case-study__video wistia-player {
  display:block; width:100%;
}
/* Wistia swatch styling for loading state */
.case-study__video wistia-player:not(:defined) {
  display:block;
  filter:blur(5px);
  padding-top:56.25%;
  background:center / contain no-repeat var(--bg-elevated);
}
.case-study__content { padding:24px }
.case-study__name { font-size:1.05rem; font-weight:700; color:var(--white); margin-bottom:2px }
.case-study__role { font-size:.82rem; color:var(--gray-400); margin-bottom:12px }
.case-study__quote {
  font-size:.92rem; color:var(--gray-300); line-height:1.65;
  font-style:italic; margin:0;
}
.case-study__quote::before { content:'"'; color:var(--teal); font-size:1.2rem; font-weight:700 }

/* ── Cookie Banner ── */
.cookie-banner {
  position:fixed; bottom:0; left:0; right:0; z-index:10001;
  background:#fff; border-top:1px solid rgba(0,0,0,.1);
  box-shadow:0 -4px 20px rgba(0,0,0,.08);
  padding:20px 0; display:none;
}
.cookie-banner.show { display:block }
.cookie-banner__inner {
  max-width:var(--max-w); margin:0 auto; padding:0 32px;
  display:flex; align-items:center; gap:20px; flex-wrap:wrap;
}
.cookie-banner__text {
  flex:1; min-width:280px;
  font-size:.85rem; color:var(--gray-300); line-height:1.6;
}
.cookie-banner__text a { color:var(--teal) }
.cookie-banner__actions { display:flex; gap:8px; flex-shrink:0 }
.cookie-banner__btn {
  padding:10px 22px; border-radius:999px; font-size:.85rem; font-weight:500;
  cursor:pointer; border:none; font-family:var(--font); transition:all .2s;
}
.cookie-banner__btn--accept { background:var(--teal); color:#fff }
.cookie-banner__btn--accept:hover { filter:brightness(1.08) }
.cookie-banner__btn--decline { background:transparent; color:var(--gray-300); border:1px solid rgba(0,0,0,.12) }
.cookie-banner__btn--decline:hover { border-color:rgba(0,0,0,.2) }

@media(max-width:768px) {
  .cookie-banner__inner { flex-direction:column; text-align:center }
  .cookie-banner__actions { width:100%; justify-content:center }
}

/* ── Time Banner (5 Min) ── */
.time-banner {
  position:fixed; bottom:0; left:0; right:0; z-index:10001;
  background:#000; color:#f5f5f7;
  padding:20px 0;
  transform:translateY(100%);
  transition:transform .4s ease;
}
.time-banner.show { transform:translateY(0) }
.time-banner__inner {
  max-width:var(--max-w); margin:0 auto; padding:0 32px;
  display:flex; align-items:center; gap:20px; flex-wrap:wrap;
}
.time-banner__text { flex:1; min-width:260px }
.time-banner__title { font-size:1rem; font-weight:600; color:#f5f5f7; margin-bottom:4px }
.time-banner__sub { font-size:.85rem; color:#86868b }
.time-banner__actions { display:flex; gap:8px; flex-shrink:0 }
.time-banner__close {
  background:none; border:none; color:#86868b; font-size:1.2rem;
  cursor:pointer; padding:4px; transition:color .2s;
}
.time-banner__close:hover { color:#f5f5f7 }
@media(max-width:768px) {
  .time-banner__inner { flex-direction:column; text-align:center }
  .time-banner__actions { width:100%; justify-content:center }
}

.mt-4 { margin-top:32px }  .mt-2 { margin-top:16px }
.mb-4 { margin-bottom:32px } .mb-2 { margin-bottom:16px }

/* ══════════════════════════════════════════
   APPLE GLASSMORPHISM
   ══════════════════════════════════════════ */

/* Glass cards — frosted background */
.glass {
  background:rgba(255,255,255,0.04);
  backdrop-filter:blur(24px) saturate(140%);
  -webkit-backdrop-filter:blur(24px) saturate(140%);
  border:1px solid rgba(255,255,255,0.08);
}

/* ── Dark "PRO" Sections (Apple-Style Inversion) ── */
.section--pro {
  background:#000;
  color:#86868b;
  /* Smooth transition edges */
  border-top:1px solid rgba(0,0,0,.05);
}
.section--pro h2, .section--pro h3, .section--pro h4 { color:#f5f5f7 }
.section--pro p { color:#86868b }
.section--pro .label { color:var(--teal) }
.section--pro .teal { color:var(--teal) }
.section--pro .card, .section--pro .pillar, .section--pro .review,
.section--pro .stat-card, .section--pro .bar-chart, .section--pro .banner {
  background:rgba(255,255,255,0.04); border-color:rgba(255,255,255,0.08);
}
.section--pro .card:hover, .section--pro .pillar:hover {
  background:rgba(255,255,255,0.07); border-color:rgba(92,224,210,0.2);
  box-shadow:none;
}
.section--pro .btn--primary { background:#5ce0d2; color:#0f1319 }
.section--pro .btn--outline { color:#cbd5e1; border-color:rgba(255,255,255,0.15) }
.section--pro .link { color:#5ce0d2 }
.section--pro .pillar__step { background:rgba(92,224,210,0.12); color:#5ce0d2; border-color:rgba(92,224,210,0.2) }
.section--pro .pillar__check::before { color:#5ce0d2 }
.section--pro .problem-item { border-color:rgba(255,255,255,0.06) }
.section--pro .problem-item__icon { background:rgba(92,224,210,0.12); color:#5ce0d2; border-color:rgba(92,224,210,0.2) }
.section--pro .stat-card__num { color:#5ce0d2 }
.section--pro .stats-item__val { color:#fff }
.section--pro .stats-item__lbl { color:#64748b }
.section--pro .cta-note { color:#64748b }
.section--pro .cta-checks span { color:#94a3b8 }
.section--pro .cta-checks span::before { color:#5ce0d2 }
.section--pro .subtitle { color:#94a3b8 }
.section--pro .reviews-summary { background:rgba(255,255,255,0.04); border-color:rgba(255,255,255,0.08) }
.section--pro .reviews-summary__num { color:#fff }
.section--pro .reviews-summary__stars { color:#5ce0d2 }
.section--pro .reviews-summary__lbl { color:#64748b }
.section--pro .review { background:rgba(255,255,255,0.04); border-color:rgba(255,255,255,0.08) }
.section--pro .review__stars { color:#5ce0d2 }
.section--pro .review__text { color:#94a3b8 }
.section--pro .review__name { color:#e2e8f0 }
.section--pro .review__avatar { background:rgba(255,255,255,0.08); border-color:rgba(255,255,255,0.1); color:#94a3b8 }

/* Light mode cards */
.pillar, .card, .review, .knowledge-card, .myth,
.hero__card, .hero__stat, .hero__quote,
.banner, .form-wrap, .bar-chart {
  background:#f5f5f7;
  border:1px solid rgba(0,0,0,0.08);
  border-radius:16px;
  box-shadow:none;
}
/* Cards on gray backgrounds need white */
.section--alt .pillar, .section--alt .card, .section--alt .review,
.section--alt .knowledge-card, .section--alt .myth,
.section--alt .bar-chart, .section--alt .banner {
  background:#fff;
}

/* Duplicate hover removed — handled above */

/* ══════════════════════════════════════════
   CUSTOM CURSOR — Teal glow circle
   ══════════════════════════════════════════ */

.cursor {
  position:fixed;
  width:28px; height:28px;
  border-radius:50%;
  border:2px solid var(--teal);
  pointer-events:none;
  z-index:9999;
  transform:translate(-50%,-50%);
  transition:width .15s, height .15s, border-color .15s, background .15s;
  mix-blend-mode:normal;
}

.cursor__dot {
  position:fixed;
  width:6px; height:6px;
  border-radius:50%;
  background:var(--teal);
  pointer-events:none;
  z-index:10000;
  transform:translate(-50%,-50%);
  transition:width .1s, height .1s, background .1s;
}

/* Cursor grows on hoverable elements */
.cursor--hover {
  width:48px; height:48px;
  background:rgba(13,148,136,0.08);
  border-color:rgba(13,148,136,0.4);
}

.cursor--hover + .cursor__dot {
  opacity:0;
}

/* Hide custom cursor on mobile / touch */
@media (hover:none), (max-width:768px) {
  body { cursor:auto }
  .cursor, .cursor__dot { display:none }
}

/* Keep native cursor on inputs */
input, select, textarea, button { cursor:auto !important }
@media (max-width:768px) {
  input, select, textarea { font-size:16px !important }
}
