/* pfotenrat.de – Lokale SEO Landing Pages – Navy Design */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;600;700;800;900&family=Lora:ital@1&display=swap');

/* BASE */
.pfr-lp { font-family: 'Montserrat', sans-serif; color: rgba(255,255,255,.88); }
.pfr-lp a { text-decoration: none; }
.pfr-lp-inner { max-width: 860px; margin: 0 auto; padding: 0 24px; }

/* HERO */
.pfr-lp-hero { text-align: center; padding: 80px 24px 72px; position: relative; }
.pfr-lp-hero::before { content: ''; position: absolute; width: 600px; height: 400px; border-radius: 50%; background: radial-gradient(ellipse, rgba(242,169,0,.06) 0%, transparent 70%); top: -80px; left: 50%; transform: translateX(-50%); pointer-events: none; }
.pfr-lp-hero-inner { position: relative; max-width: 680px; margin: 0 auto; }
.pfr-lp-eyebrow { display: inline-block; background: rgba(242,169,0,.12); color: #F2A900; border: 1px solid rgba(242,169,0,.25); font-size: 11px; font-weight: 800; letter-spacing: .16em; text-transform: uppercase; padding: 6px 18px; border-radius: 20px; margin-bottom: 24px; }
.pfr-lp-hero h1 { font-size: clamp(28px,5vw,50px); font-weight: 900; color: #fff; letter-spacing: -.03em; line-height: 1.1; margin: 0 0 18px; }
.pfr-lp-hero h1 em { font-style: italic; color: #F2A900; font-family: 'Lora',serif; }
.pfr-lp-lead { font-size: 16px; color: rgba(255,255,255,.55); line-height: 1.7; margin: 0 auto 36px; max-width: 520px; }
.pfr-lp-stats { display: flex; align-items: center; justify-content: center; margin-bottom: 40px; flex-wrap: wrap; }
.pfr-lp-stat { display: flex; flex-direction: column; align-items: center; padding: 0 28px; }
.pfr-lp-stat strong { font-size: 30px; font-weight: 900; color: #F2A900; letter-spacing: -.02em; line-height: 1; display: block; margin-bottom: 5px; }
.pfr-lp-stat span { font-size: 10px; color: rgba(255,255,255,.45); font-weight: 700; letter-spacing: .1em; text-transform: uppercase; }
.pfr-lp-divider { width: 1px; height: 44px; background: rgba(255,255,255,.12); }
.pfr-lp-hero-btn { display: inline-block; background: #F2A900; color: #0f2e3f; font-family: 'Montserrat',sans-serif; font-size: 14px; font-weight: 800; letter-spacing: .06em; text-transform: uppercase; padding: 16px 40px; border-radius: 12px; transition: all .2s; }
.pfr-lp-hero-btn:hover { background: #f7c040; transform: translateY(-2px); }

/* SECTIONS */
.pfr-lp-section { padding: 56px 0; border-bottom: 1px solid rgba(255,255,255,.07); }
.pfr-lp-section-alt { background: rgba(255,255,255,.03); }
.pfr-lp-section-label { font-size: 10px; font-weight: 800; letter-spacing: .2em; text-transform: uppercase; color: #F2A900; margin: 0 0 10px; display: block; }
.pfr-lp-section h2 { font-size: clamp(20px,3.5vw,30px); font-weight: 900; color: #fff; letter-spacing: -.02em; margin: 0 0 14px; line-height: 1.2; }
.pfr-lp-section p { font-size: 15px; color: rgba(255,255,255,.6); line-height: 1.8; margin: 0 0 16px; }
.pfr-lp-section strong { color: rgba(255,255,255,.9); }
.pfr-lp-section a { color: #F2A900; font-weight: 700; }

/* PREISE – alle gleich, kein Highlight */
.pfr-lp-prices { display: grid; grid-template-columns: repeat(4,1fr); gap: 12px; margin: 28px 0; }
.pfr-lp-price-card { background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1); border-radius: 14px; padding: 20px 14px; text-align: center; }
.pfr-lp-price-card p { margin: 0 !important; }
.pfr-lp-price-label { font-size: 11px; font-weight: 700; color: rgba(255,255,255,.5); margin: 0 0 10px !important; line-height: 1.3; display: block; }
.pfr-lp-price-val { font-size: 22px; font-weight: 900; color: #fff; letter-spacing: -.02em; display: block; }
.pfr-lp-price-sub { font-size: 10px; color: rgba(255,255,255,.3); margin: 4px 0 0 !important; display: block; }

/* TIPP */
.pfr-lp-tipp { display: flex; gap: 14px; align-items: flex-start; background: rgba(242,169,0,.08); border: 1px solid rgba(242,169,0,.2); border-radius: 12px; padding: 18px 20px; margin-top: 8px; }
.pfr-lp-tipp-icon { font-size: 20px; flex-shrink: 0; }
.pfr-lp-tipp div { font-size: 14px; color: rgba(255,255,255,.7); line-height: 1.6; }
.pfr-lp-tipp strong { color: #F2A900; }

/* TOOLS */
.pfr-lp-tools-wrap { padding: 56px 0; border-bottom: 1px solid rgba(255,255,255,.07); background: rgba(255,255,255,.03); }
.pfr-lp-tools-wrap .pfr-lp-section-label { font-size: 10px; font-weight: 800; letter-spacing: .2em; text-transform: uppercase; color: #F2A900; margin: 0 0 10px; display: block; }
.pfr-lp-tools-wrap h2 { font-size: clamp(20px,3.5vw,30px); font-weight: 900; color: #fff; letter-spacing: -.02em; margin: 0 0 14px; }
.pfr-lp-tools-wrap > .pfr-lp-inner > p { font-size: 15px; color: rgba(255,255,255,.6); line-height: 1.8; margin: 0 0 28px; }
.pfr-lp-tools { display: grid; grid-template-columns: repeat(3,1fr); gap: 14px; }
/* Beide Klassen unterstützen – alte Seiten nutzen pfr-lp-tool, neue pfr-lp-tool-wrap */
.pfr-lp-tool, .pfr-lp-tool-wrap { display: flex; flex-direction: column; background: #1A475F; border: none; border-radius: 18px; padding: 32px 28px 28px; transition: transform .2s; }
.pfr-lp-tool:hover, .pfr-lp-tool-wrap:hover { transform: translateY(-5px); }
.pfr-lp-tool p, .pfr-lp-tool-wrap p { margin: 0 !important; }
.pfr-lp-tool-top { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; flex-wrap: wrap; }
.pfr-lp-tool-ico { font-size: 30px !important; display: block !important; flex-shrink: 0; margin-bottom: 0 !important; }
.pfr-lp-tool-tag { font-size: 10px !important; font-weight: 800 !important; letter-spacing: .1em; text-transform: uppercase; color: #F2A900 !important; background: rgba(242,169,0,.15) !important; padding: 5px 12px !important; border-radius: 10px; display: inline-flex !important; align-items: center; margin-bottom: 0 !important; }
.pfr-lp-tool-name { font-size: 16px !important; font-weight: 900 !important; color: #fff !important; line-height: 1.2; margin-bottom: 8px !important; display: block !important; }
.pfr-lp-tool-desc { font-size: 13px !important; color: rgba(255,255,255,.55) !important; line-height: 1.6; margin-bottom: 22px !important; display: block !important; flex-grow: 1; }
.pfr-lp-tool-btn, .pfr-lp-tool .pfr-lp-tool-btn, .pfr-lp-tool-wrap .pfr-lp-tool-btn { display: block !important; font-size: 12px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; color: #0f2e3f !important; background: #F2A900 !important; padding: 12px 22px; border-radius: 10px; text-align: center; text-decoration: none !important; transition: background .18s; }
.pfr-lp-tool:hover .pfr-lp-tool-btn, .pfr-lp-tool-wrap:hover .pfr-lp-tool-btn { background: #f7c040 !important; }

/* STADTTEILE */
.pfr-lp-stadtteile { display: grid; grid-template-columns: repeat(auto-fill,minmax(185px,1fr)); gap: 10px; margin-top: 24px; }
.pfr-lp-st-card { display: flex; align-items: center; gap: 10px; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1); border-radius: 10px; padding: 12px 16px; font-size: 14px; font-weight: 700; color: rgba(255,255,255,.8); transition: all .18s; }
.pfr-lp-st-card:hover { border-color: rgba(242,169,0,.4); background: rgba(242,169,0,.08); color: #F2A900; }
.pfr-lp-st-arr { color: #F2A900; font-weight: 900; margin-left: auto; }

/* CHECKS */
.pfr-lp-checks { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 24px; }
.pfr-lp-check { display: flex; gap: 14px; align-items: flex-start; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.08); border-radius: 12px; padding: 16px 18px; }
.pfr-lp-check > span { font-size: 22px; flex-shrink: 0; }
.pfr-lp-check strong { display: block; color: #fff; margin-bottom: 3px; }
.pfr-lp-check div { font-size: 14px; color: rgba(255,255,255,.65); line-height: 1.5; }

/* AFFILIATE – cream wie in den Artikeln */
.pfr-lp-aff { display: flex; gap: 20px; align-items: flex-start; background: #fffcf0; border: 2px solid #F2A900; border-radius: 14px; padding: 22px; margin-bottom: 16px; }
.pfr-lp-aff:last-of-type { margin-bottom: 0; }
.pfr-lp-aff-ico { font-size: 40px; flex-shrink: 0; }
.pfr-lp-aff-badge { display: inline-block; background: #F2A900; color: #0f2e3f; font-size: 10px; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; padding: 3px 10px; border-radius: 6px; margin-bottom: 8px; }
.pfr-lp-aff-name { font-size: 17px; font-weight: 800; color: #0f2e3f; margin-bottom: 8px; display: block; }
.pfr-lp-aff-body p { font-size: 13px !important; color: #5a6a72 !important; margin-bottom: 10px !important; line-height: 1.6; }
.pfr-lp-aff-body a { color: #F2A900 !important; font-weight: 700; font-size: 13px; }

/* FAQ – kein Balken zwischen Frage und Antwort, Padding an allen Seiten */
.pfr-lp-faq { margin-bottom: 32px; }
.pfr-lp-faq-item { border: 1px solid rgba(255,255,255,.1); border-radius: 12px; margin-bottom: 8px; overflow: hidden; }
.pfr-lp-faq-item p { margin: 0 !important; padding: 0 !important; }
.pfr-lp-faq-q { display: block !important; padding: 20px 28px !important; font-size: 15px !important; font-weight: 700 !important; color: #fff !important; background: rgba(255,255,255,.07) !important; line-height: 1.4 !important; border-bottom: none !important; }
.pfr-lp-faq-a { display: block !important; padding: 18px 28px !important; font-size: 14px !important; color: rgba(255,255,255,.65) !important; line-height: 1.75 !important; background: rgba(255,255,255,.02) !important; }
.pfr-lp-faq-a a { color: #F2A900 !important; font-weight: 700; }

/* FAZIT */
.pfr-lp-fazit { background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.1); border-radius: 14px; padding: 28px 32px; margin-top: 32px; }
.pfr-lp-fazit-title { font-size: 16px; font-weight: 800; color: #fff; margin: 0 0 16px; display: block; }
.pfr-lp-fazit ul { margin: 0; padding-left: 20px; }
.pfr-lp-fazit li { font-size: 14px; color: rgba(255,255,255,.7); margin-bottom: 8px; font-weight: 600; }
.pfr-lp-fazit a { color: #F2A900; }

/* FINAL CTA */
.pfr-lp-cta { padding: 72px 24px; text-align: center; border-top: 1px solid rgba(242,169,0,.2); }
.pfr-lp-cta-inner { max-width: 580px; margin: 0 auto; }
.pfr-lp-cta h2 { font-size: clamp(24px,4vw,36px) !important; font-weight: 900 !important; color: #F2A900 !important; letter-spacing: -.02em !important; margin: 0 0 14px !important; }
.pfr-lp-cta p { font-size: 16px; color: rgba(255,255,255,.55); margin: 0 0 32px; }
.pfr-lp-cta-btn { display: inline-block; background: #F2A900; color: #0f2e3f; font-family: 'Montserrat',sans-serif; font-size: 14px; font-weight: 800; letter-spacing: .06em; text-transform: uppercase; padding: 18px 48px; border-radius: 12px; transition: all .2s; }
.pfr-lp-cta-btn:hover { background: #f7c040; transform: translateY(-2px); }

/* RESPONSIVE */
@media (max-width: 720px) {
  .pfr-lp-hero { padding: 56px 20px 48px; }
  .pfr-lp-stat { padding: 0 16px; }
  .pfr-lp-stat strong { font-size: 22px; }
  .pfr-lp-prices { grid-template-columns: 1fr 1fr; }
  .pfr-lp-tools { grid-template-columns: 1fr; }
  .pfr-lp-checks { grid-template-columns: 1fr; }
  .pfr-lp-stadtteile { grid-template-columns: 1fr; }
  .pfr-lp-aff { flex-direction: column; gap: 12px; }
  .pfr-lp-inner { padding: 0 16px; }
}
@media (max-width: 440px) {
  .pfr-lp-prices { grid-template-columns: 1fr; }
  .pfr-lp-divider { display: none; }
  .pfr-lp-stat { padding: 8px 0; }
}
