/* ============================================================
   Hauptstile: Hero, Sektionen der Startseite, Artikel, Prosa
   ============================================================ */

/* ---------- Hero mit Zaehlern ---------- */
.nk-hero {
  background: var(--nk-gradient);
  color: #fff;
  padding: 84px 0 72px;
  position: relative;
  overflow: hidden;
}
.nk-hero::after {
  content: ""; position: absolute; right: -120px; top: -120px;
  width: 420px; height: 420px; border-radius: 50%;
  background: radial-gradient(circle, rgba(242, 163, 60, .28), transparent 70%);
}
.nk-hero-kicker {
  display: inline-block; padding: 6px 14px; border-radius: 100px;
  background: rgba(255, 255, 255, .14); font-size: 13.5px; font-weight: 500;
  letter-spacing: .03em; margin-bottom: 18px;
}
.nk-hero h1 { color: #fff; max-width: 760px; margin-bottom: 18px; }
.nk-hero-sub { max-width: 640px; font-size: 17.5px; color: rgba(255, 255, 255, .9); }

.nk-hero-stats { display: flex; gap: 48px; margin: 36px 0 32px; flex-wrap: wrap; }
.nk-stat { display: flex; flex-direction: column; }
.nk-stat-num {
  font-family: var(--nk-font-head); font-size: 40px; font-weight: 700;
  color: var(--nk-accent); line-height: 1.1;
}
.nk-stat-label { font-size: 14px; color: rgba(255, 255, 255, .82); margin-top: 4px; }

.nk-hero-actions { display: flex; gap: 14px; flex-wrap: wrap; }

/* ---------- Buttons ---------- */
.nk-btn {
  display: inline-block; padding: 13px 26px; border-radius: var(--nk-radius-sm);
  font-weight: 600; font-size: 15px; cursor: pointer; border: 0;
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
}
.nk-btn:hover { transform: translateY(-1px); }
.nk-btn-accent { background: var(--nk-accent); color: var(--nk-primary-dark); }
.nk-btn-accent:hover { box-shadow: 0 8px 22px rgba(242, 163, 60, .42); color: var(--nk-primary-dark); }
.nk-btn-ghost { background: rgba(255, 255, 255, .14); color: #fff; }
.nk-btn-ghost:hover { background: rgba(255, 255, 255, .24); color: #fff; }
.nk-btn-outline { background: transparent; color: var(--nk-primary); border: 1.5px solid var(--nk-border); }
.nk-btn-outline:hover { border-color: var(--nk-secondary); color: var(--nk-secondary); }

/* ---------- Schritte (So testen wir) ---------- */
.nk-steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; margin-top: 30px; }
.nk-step {
  background: var(--nk-surface); border: 1px solid var(--nk-border);
  border-radius: var(--nk-radius); padding: 26px 22px; position: relative;
}
.nk-step-num {
  display: inline-flex; align-items: center; justify-content: center;
  width: 38px; height: 38px; border-radius: 50%;
  background: var(--nk-accent-soft); color: var(--nk-primary);
  font-family: var(--nk-font-head); font-weight: 700; font-size: 17px;
  margin-bottom: 12px;
}
.nk-step h3 { margin: 0 0 8px; font-size: 17.5px; }
.nk-step p { margin: 0; font-size: 14.5px; color: var(--nk-muted); }
.nk-steps-more { margin-top: 20px; font-weight: 600; }

/* ---------- FAQ Akkordeon ---------- */
.nk-faq-acc details {
  background: var(--nk-surface); border: 1px solid var(--nk-border);
  border-radius: var(--nk-radius); margin-bottom: 12px; overflow: hidden;
}
.nk-faq-acc summary {
  padding: 18px 22px; cursor: pointer; font-weight: 600; font-size: 16px;
  color: var(--nk-primary); list-style: none; position: relative; padding-right: 48px;
}
.nk-faq-acc summary::-webkit-details-marker { display: none; }
.nk-faq-acc summary::after {
  content: "+"; position: absolute; right: 20px; top: 50%; transform: translateY(-50%);
  font-size: 22px; color: var(--nk-secondary); transition: transform .2s ease;
}
.nk-faq-acc details[open] summary::after { transform: translateY(-50%) rotate(45deg); }
.nk-faq-acc details p { padding: 0 22px 18px; margin: 0; color: var(--nk-muted); }

/* ---------- Prosa (Artikel-Inhalt + Content-CSS-Vertrag) ---------- */
.nk-prose { font-size: 16.5px; }
.nk-prose h2 { margin-top: 1.7em; padding-bottom: .35em; border-bottom: 2px solid var(--nk-accent-soft); }
.nk-prose img { border-radius: var(--nk-radius); }
.nk-prose a { font-weight: 500; text-decoration: underline; text-decoration-color: rgba(46, 134, 171, .35); text-underline-offset: 3px; }

/* AEO «Kurze Antwort» */
.p2pde-qa {
  display: flex; gap: 12px; align-items: baseline; flex-wrap: wrap;
  background: var(--nk-accent-soft); border-left: 4px solid var(--nk-accent);
  border-radius: 0 var(--nk-radius) var(--nk-radius) 0;
  padding: 18px 22px; margin: 0 0 28px;
}
.p2pde-qa strong { color: var(--nk-primary); font-family: var(--nk-font-head); }
.p2pde-qa p { margin: 0; flex: 1 1 100%; }

/* Pros/Cons */
.p2pde-proscons { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin: 24px 0; }
.p2pde-pros, .p2pde-cons { border-radius: var(--nk-radius); padding: 20px 22px; }
.p2pde-pros { background: rgba(22, 138, 90, .07); border: 1px solid rgba(22, 138, 90, .25); }
.p2pde-cons { background: rgba(214, 69, 69, .06); border: 1px solid rgba(214, 69, 69, .22); }
.p2pde-pros h3 { color: var(--nk-success); margin-top: 0; }
.p2pde-cons h3 { color: var(--nk-danger); margin-top: 0; }
.p2pde-pros ul, .p2pde-cons ul { margin-bottom: 0; }

/* Tabellen */
.p2pde-tablewrap { overflow-x: auto; margin: 24px 0; border-radius: var(--nk-radius); box-shadow: var(--nk-shadow); }
.p2pde-table { width: 100%; border-collapse: collapse; background: var(--nk-surface); font-size: 15px; }
.p2pde-table caption { caption-side: top; text-align: left; padding: 12px 16px; font-weight: 600; color: var(--nk-muted); font-size: 13.5px; }
.p2pde-table th { background: var(--nk-primary); color: #fff; text-align: left; padding: 13px 16px; font-weight: 600; }
.p2pde-table td { padding: 12px 16px; border-bottom: 1px solid var(--nk-border); }
.p2pde-table tbody tr:nth-child(even) { background: var(--nk-bg); }
.p2pde-table tbody tr:hover { background: var(--nk-accent-soft); }

/* FAQ im Inhalt */
.p2pde-faq { margin: 28px 0; }
.p2pde-faq-item { background: var(--nk-surface); border: 1px solid var(--nk-border); border-radius: var(--nk-radius); padding: 18px 22px; margin-bottom: 12px; }
.p2pde-faq-item h3 { margin: 0 0 8px; font-size: 16.5px; }
.p2pde-faq-a p { margin: 0; color: var(--nk-muted); }

/* Hinweis, Zitat, Disclaimer */
.p2pde-note { background: rgba(46, 134, 171, .08); border-left: 4px solid var(--nk-secondary); padding: 16px 20px; border-radius: 0 var(--nk-radius) var(--nk-radius) 0; margin: 22px 0; }
.p2pde-quote { border-left: 4px solid var(--nk-accent); padding: 8px 22px; color: var(--nk-muted); font-style: italic; }
.p2pde-disc, .nk-disc-box {
  margin-top: 36px; padding: 16px 20px; border: 1px dashed var(--nk-border);
  border-radius: var(--nk-radius); color: var(--nk-muted); font-size: 13.5px;
}

/* Autoren */
.p2pde-authors { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; margin: 26px 0; }
.p2pde-author { background: var(--nk-surface); border: 1px solid var(--nk-border); border-radius: var(--nk-radius); padding: 24px; text-align: center; }
.p2pde-author img { width: 120px; height: 120px; border-radius: 50%; object-fit: cover; margin: 0 auto 14px; }
.p2pde-author h2 { margin: 0 0 4px; font-size: 19px; }
.p2pde-author-role { color: var(--nk-secondary); font-weight: 600; font-size: 14px; margin-bottom: 10px; }

/* Sterne im Inhalt */
.p2pde-stars { color: var(--nk-accent); letter-spacing: 2px; }
.p2pde-score { font-family: var(--nk-font-head); font-weight: 700; color: var(--nk-primary); }
