/* ===================================================
   StageXpress — front-page.css
   1. GeneratePress Override-Resets (nur Spacing & Fonts, NICHT Farben)
   2. Footer Bullet-Fix
   3. Homepage-spezifische Komponenten
   Pfad: assets/css/front-page.css
   =================================================== */

/* ─── 1. GeneratePress Override-Resets ──────────────────── 
   GP setzt eigene font-family, line-height, margins auf 
   Headings/Paragraphs. Wir resetten NUR Spacing + Fonts,
   NICHT color — damit Hero/Footer/CTA/Reels-Farben erhalten bleiben. ─── */

body.page-home {
  font-family: var(--font-body) !important;
  line-height: 1.6 !important;
}
body.page-home h1,
body.page-home h2,
body.page-home h3,
body.page-home h4 {
  font-family: var(--font-display) !important;
  margin: 0 !important;
  padding: 0 !important;
  line-height: 1.15 !important;
}
body.page-home p {
  margin: 0 0 0.75em !important;
  font-family: var(--font-body) !important;
  line-height: 1.6 !important;
}
body.page-home ul,
body.page-home ol,
body.page-home li {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* ─── 2. Footer: wp_nav_menu <li> Bullets + Spacing ───── */
.footer__links li {
  list-style: none !important;
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
}
.footer__links li a {
  display: block;
  color: rgba(255,255,255,0.6);
  font-size: 0.875rem;
  padding: 4px 0;
  transition: color 0.2s;
}
.footer__links li a:hover { color: white; }

/* Nav: GP Link-Overrides entfernen */
.nav__links li,
.nav__mobile-menu li {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  display: inline !important;
}

/* ─── 3. Homepage-spezifische Komponenten ───────────────── */

/* Client Logos Strip */
.testimonial-strip {
  background: var(--bg-white);
  padding: 40px 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.testimonial-strip__inner {
  max-width: var(--max-w); margin: 0 auto; padding: 0 40px;
  display: flex; gap: 48px; align-items: flex-start; flex-wrap: wrap;
}
.testimonial-label {
  font-size: 0.75rem; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--text-light); font-weight: 600; white-space: nowrap; padding-top: 4px;
}
.client-logos { display: flex; gap: 32px; align-items: center; flex-wrap: wrap; }
.client-logo {
  font-family: var(--font-display) !important;
  font-size: 0.9rem; font-weight: 700;
  color: var(--text-light); letter-spacing: 0.03em; text-transform: uppercase;
}

/* How it Works */
.how-it-works {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px; margin-top: 56px;
}
.step { position: relative; }
.step__num {
  font-family: var(--font-display) !important;
  font-size: 3.5rem !important; font-weight: 800 !important;
  color: var(--border) !important; letter-spacing: 0.02em;
  line-height: 1 !important; margin-bottom: 12px !important;
}
.step__title {
  font-family: var(--font-display) !important;
  font-size: 1.05rem !important; font-weight: 700 !important; margin-bottom: 8px !important;
}
.step__text { font-size: 0.875rem; color: var(--text-mid); line-height: 1.6 !important; }
.step:not(:last-child)::after {
  content: ''; position: absolute; top: 24px; right: -16px;
  width: 32px; height: 1px; background: var(--border-strong);
}

/* CTA Banner */
.cta-banner {
  background: var(--accent); border-radius: 20px; padding: 56px;
  display: flex; justify-content: space-between; align-items: center;
  gap: 32px; flex-wrap: wrap; overflow: hidden; position: relative;
}
.cta-banner::before {
  content: ''; position: absolute; top: -60px; right: -60px;
  width: 300px; height: 300px; background: rgba(255,255,255,0.08); border-radius: 50%;
}
.cta-banner::after {
  content: ''; position: absolute; bottom: -80px; right: 100px;
  width: 200px; height: 200px; background: rgba(255,255,255,0.05); border-radius: 50%;
}
.cta-banner__text { position: relative; z-index: 1; }
.cta-banner__text h2 {
  font-family: var(--font-display) !important;
  font-size: 2rem !important; font-weight: 800 !important;
  color: white !important; letter-spacing: 0.01em; margin-bottom: 8px !important;
}
.cta-banner__text p { color: rgba(255,255,255,0.8) !important; font-size: 1rem; margin: 0 !important; }
.cta-banner__actions { display: flex; gap: 12px; flex-wrap: wrap; position: relative; z-index: 1; }

/* Service Grid */
.service-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.service-card {
  background: var(--card-bg); border: 1px solid var(--border); border-radius: 16px;
  padding: 32px; transition: all 0.2s;
}
.service-card:hover { border-color: var(--accent); transform: translateY(-2px); }
.service-card__icon { font-size: 2rem; margin-bottom: 16px; }
.service-card__title {
  font-family: var(--font-display) !important;
  font-size: 1.15rem !important; font-weight: 700 !important; margin-bottom: 10px !important;
}
.service-card__text { font-size: 0.875rem; color: var(--text-mid); line-height: 1.65; }
.service-card__link {
  display: inline-flex; align-items: center; gap: 6px; margin-top: 16px;
  font-size: 0.875rem; font-weight: 600; color: var(--accent);
}

/* FAQ Grid */
.faq-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; max-width: 1000px; }

/* ─── 4. Abschnitts-Titel: GP-Spacing fix (NUR helle Sektionen) ─── */
body.page-home .section-title {
  font-size: 2.75rem !important;
  font-weight: 800 !important;
  letter-spacing: -0.01em !important;
  line-height: 1.1 !important;
}
body.page-home .section-subtitle {
  font-size: 1rem !important;
  color: var(--text-mid) !important;
  line-height: 1.6 !important;
  max-width: 520px;
  margin: 12px 0 0 !important;
}
body.page-home .section-label {
  margin-bottom: 8px !important;
}

/* ─── 5. Produkt-Karten: Features korrekt ─── */
body.page-home .product-card__feature {
  display: flex !important;
  align-items: flex-start !important;
  gap: 8px !important;
  font-size: 0.85rem !important;
  color: var(--text-mid) !important;
  line-height: 1.4 !important;
  padding: 0 !important;
  margin: 0 !important;
}
body.page-home .product-card__feature::before {
  content: '→' !important;
  color: var(--accent) !important;
  flex-shrink: 0 !important;
  font-size: 0.75rem !important;
  margin-top: 1px !important;
}
body.page-home .product-card__name {
  font-size: 1.5rem !important;
  font-weight: 800 !important;
  letter-spacing: 0.01em !important;
  text-transform: uppercase !important;
  margin-bottom: 10px !important;
  line-height: 1.15 !important;
}
body.page-home .product-card__size {
  font-size: 0.8125rem !important;
  color: var(--text-light) !important;
  margin-bottom: 4px !important;
  font-weight: 500 !important;
}

/* ─── Responsive ─── */
@media (max-width: 768px) {
  .how-it-works { grid-template-columns: 1fr 1fr; }
  .service-grid { grid-template-columns: 1fr; }
  .cta-banner { padding: 32px; }
  .step::after { display: none; }
  .faq-grid { grid-template-columns: 1fr; }
  .testimonial-strip__inner { gap: 20px; }
}
@media (max-width: 480px) {
  .how-it-works { grid-template-columns: 1fr; }
}
