/* Landingspagina */

.page-landing main.container { padding-top: 0; }

/* Hero */
.hero { text-align: center; padding: var(--space-2xl) 0; }
.hero-eyebrow {
  display: inline-block; font-size: 0.8125rem; font-weight: 600; letter-spacing: 0.02em;
  color: var(--color-primary); background: #eff4ff; border: 1px solid #d6e2ff;
  padding: 0.25rem 0.875rem; border-radius: 999px; margin-bottom: var(--space-md);
}
.hero h1 { font-size: 2.75rem; line-height: 1.15; max-width: 680px; margin: 0 auto var(--space-md); letter-spacing: -0.02em; }
.hero-sub { font-size: 1.125rem; color: var(--color-muted); max-width: 560px; margin: 0 auto var(--space-xl); }
.hero-cta { display: flex; flex-direction: column; align-items: center; gap: var(--space-sm); margin-bottom: var(--space-lg); }
.hero-secondary { color: var(--color-muted); font-size: 0.9375rem; text-decoration: none; }
.hero-secondary:hover { color: var(--color-text); }
.hero-badges { list-style: none; display: flex; justify-content: center; gap: var(--space-lg); flex-wrap: wrap; padding: 0; color: var(--color-muted); font-size: 0.875rem; }
.hero-badges li::before { content: '✓ '; color: var(--color-success); font-weight: 700; }

/* Secties */
.section { padding: var(--space-2xl) 0; border-top: 1px solid var(--color-border); }
.section h2 { font-size: 1.875rem; text-align: center; margin-bottom: var(--space-xl); letter-spacing: -0.01em; }

/* Probleem */
.problem-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: var(--space-lg); }
.problem-card { background: #f9fafb; border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: var(--space-lg); }
.problem-card h3 { font-size: 1.0625rem; margin-bottom: var(--space-xs); }
.problem-card p { margin: 0; color: var(--color-muted); font-size: 0.9375rem; }
.problem-close { text-align: center; font-size: 1.125rem; font-weight: 600; margin-top: var(--space-xl); }

/* Stappen */
.steps { list-style: none; counter-reset: step; max-width: 620px; margin: 0 auto; padding: 0; }
.steps li { counter-increment: step; padding: var(--space-md) 0 var(--space-md) 3.25rem; position: relative; }
.steps li::before {
  content: counter(step); position: absolute; left: 0; top: var(--space-md);
  width: 2.25rem; height: 2.25rem; background: var(--color-primary); color: #fff;
  border-radius: 50%; text-align: center; line-height: 2.25rem; font-weight: 700;
}
.steps li strong { font-size: 1.125rem; }
.steps li p { margin: var(--space-xs) 0 0; color: var(--color-muted); }

/* Waarom */
.why-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: var(--space-lg); }
.why-item h3 { font-size: 1.0625rem; margin-bottom: var(--space-xs); }
.why-item h3::before { content: '✓ '; color: var(--color-success); }
.why-item p { margin: 0; color: var(--color-muted); font-size: 0.9375rem; }

/* Use-cases */
.usecase-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: var(--space-lg); }
.usecase-card { border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: var(--space-lg); text-align: center; }
.usecase-emoji { font-size: 2rem; display: block; margin-bottom: var(--space-sm); }
.usecase-card h3 { font-size: 1.0625rem; margin-bottom: var(--space-xs); }
.usecase-card p { margin: 0; color: var(--color-muted); font-size: 0.9375rem; }

/* Prijzen */
.packages-sub { text-align: center; color: var(--color-muted); margin-top: calc(-1 * var(--space-lg)); margin-bottom: var(--space-xl); }
.package-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: var(--space-lg); align-items: stretch; }
.package-card {
  position: relative; border: 1px solid var(--color-border); border-radius: var(--radius-md);
  padding: var(--space-xl) var(--space-lg); text-align: center; display: flex; flex-direction: column;
}
.package-featured { border-color: var(--color-primary); box-shadow: 0 4px 24px rgba(31, 111, 255, 0.12); }
.package-flag {
  position: absolute; top: -0.75rem; left: 50%; transform: translateX(-50%);
  background: var(--color-primary); color: #fff; font-size: 0.75rem; font-weight: 600;
  padding: 0.2rem 0.75rem; border-radius: 999px; white-space: nowrap;
}
.package-card h3 { font-size: 1.25rem; }
.package-tagline { color: var(--color-muted); font-size: 0.875rem; margin-bottom: var(--space-sm); }
.package-card .price { font-size: 2.5rem; font-weight: 700; color: var(--color-text); margin: var(--space-xs) 0 var(--space-md); }
.price-sub { font-size: 0.875rem; font-weight: 400; color: var(--color-muted); }
.package-features { list-style: none; padding: 0; text-align: left; margin: 0 0 var(--space-lg); flex: 1; }
.package-features li { padding: 0.375rem 0 0.375rem 1.5rem; position: relative; font-size: 0.9375rem; border-bottom: 1px solid #f2f4f7; }
.package-features li::before { content: '✓'; position: absolute; left: 0; color: var(--color-success); font-weight: 700; }
.packages-note { text-align: center; color: var(--color-muted); font-size: 0.875rem; margin-top: var(--space-lg); }

/* FAQ */
.faq { max-width: 680px; margin: 0 auto; }
.faq-item { border: 1px solid var(--color-border); border-radius: var(--radius-sm); margin-bottom: var(--space-sm); }
.faq-item summary { padding: var(--space-md); font-weight: 600; cursor: pointer; list-style: none; position: relative; padding-right: 2.5rem; }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after { content: '+'; position: absolute; right: var(--space-md); top: 50%; transform: translateY(-50%); font-size: 1.25rem; color: var(--color-muted); }
.faq-item[open] summary::after { content: '\2212'; }
.faq-item p { padding: 0 var(--space-md) var(--space-md); margin: 0; color: var(--color-muted); }

/* Slot-CTA */
.cta-final { text-align: center; }
.cta-final h2 { margin-bottom: var(--space-sm); }
.cta-final p { max-width: 480px; margin: 0 auto var(--space-lg); color: var(--color-muted); }
.cta-final .muted { margin-top: var(--space-md); }

/* Bestelformulier */
.order-total { font-size: 1.125rem; margin-bottom: var(--space-md); }

/* Mobiel */
@media (max-width: 640px) {
  .hero h1 { font-size: 2rem; }
  .section h2 { font-size: 1.5rem; }
  .hero-badges { gap: var(--space-sm); flex-direction: column; align-items: center; }
}
