/* FLORIN+ · rechner-top.css — Gemeinsamer Original-Top (Hero ap-mast + 30-Sek ap-tldr + How ap-how) für fp-migrierte Rechner. Exakte Größen/Layout wie alt, Geist-Font via .fp-doc. Lädt nach calc-v2.css. */
/* ===== Original-Top (Hero + 30-Sek + How) — exakte Größen/Layout wie vorher, Geist-Font ===== */
:root{--ap-ink:#11201d;--ap-mid:#3a4744;--ap-muted:#6b7975;--ap-line:rgba(17,32,29,.12);--ap-bg:#f6f8f7;--ap-white:#fff;--ap-teal:#00afa3;--ap-teal-dark:#016a62;--ap-rl:18px;--max-w:1160px;}
.container{max-width:var(--max-w);margin:0 auto;padding:0 24px;}
/* ── Hero ── */
.ap-mast{background: var(--ap-white);padding: 48px 0 32px;border-bottom: .5px solid var(--ap-line);}
.ap-mast-inner{max-width: 760px;}
.ap-breadcrumb{font-size: 12px;color: var(--ap-muted);margin-bottom: 14px;letter-spacing: .01em;}
.ap-breadcrumb a{color: var(--ap-muted);text-decoration: none;}
.ap-breadcrumb a:hover{color: var(--ap-ink);}
.ap-cat-label{display: inline-block;font-size: 11px;font-weight: 700;letter-spacing: .07em;text-transform: uppercase;color: var(--ap-teal);margin-bottom: 12px;}
.ap-mast h1{font-size: clamp(2rem, 5vw, 3rem);font-weight: 800;line-height: 1.08;letter-spacing: -.03em;color: var(--ap-ink);margin: 0 0 14px;}
.ap-mast-lead{font-size: 1.05rem;line-height: 1.55;color: var(--ap-mid);margin: 0 0 16px;max-width: 640px;}
.ap-mast-rating{display: flex;align-items: center;gap: 8px;font-size: 14px;color: var(--ap-muted);}
.ap-mast-stars{color: #f59e0b;letter-spacing: 1px;}
.ap-mast-score{font-weight: 700;color: var(--ap-ink);}
.ap-mast-count{color: var(--ap-muted);}
/* ── How Section ── */
.ap-how{background: var(--ap-bg);padding: 28px 0;}
.ap-how__overline{font-size: 11px;font-weight: 700;letter-spacing: .08em;text-transform: uppercase;color: var(--ap-teal);margin: 0 0 16px;}
.ap-how__grid{display: grid;grid-template-columns: repeat(3, 1fr);gap: 16px;margin: 0 0 18px;}
.ap-how__grid{grid-template-columns: 1fr;}
.ap-how__card{background: var(--ap-white);border: .5px solid var(--ap-line);border-radius: 12px;padding: 22px 24px;}
.ap-how__nr{font-size: 36px;font-weight: 800;color: rgba(0,175,163,.22);letter-spacing: -.04em;line-height: 1;margin-bottom: 18px;font-variant-numeric: tabular-nums;}
.ap-how__card h3{font-size: 15px;font-weight: 700;color: var(--ap-ink);margin: 0 0 8px;letter-spacing: -.005em;}
.ap-how__card p{font-size: 13px;line-height: 1.55;color: var(--ap-mid);margin: 0;}
.ap-how__result{background: rgba(0,175,163,.05);border-left: 2px solid var(--ap-teal);border-radius: 0 8px 8px 0;padding: 12px 16px;font-size: 13px;line-height: 1.6;color: var(--ap-ink);margin: 0;}
.ap-how__result-arrow{color: var(--ap-teal);font-weight: 700;margin-right: 6px;}
/* Hero H1 — confident but quieter */
.ap-mast h1{font-size: clamp(2rem, 4.5vw, 2.8rem) !important;font-weight: 700 !important;line-height: 1.08 !important;letter-spacing: -.028em !important;color: var(--ap-ink) !important;margin: 0 0 12px !important;}
.ap-mast-lead{font-size: 1rem !important;font-weight: 400 !important;line-height: 1.55 !important;color: var(--ap-mid) !important;margin: 0 0 16px !important;max-width: 580px !important;}
/* How-card titles (small) */
.ap-how__card h3{font-size: .94rem !important;font-weight: 600 !important;line-height: 1.3 !important;letter-spacing: -.005em !important;color: var(--ap-ink) !important;margin: 0 0 6px !important;}
/* === TLDR Badge (Pill with clock icon) === */
.ap-tldr-badge{display: inline-flex;align-items: center;gap: 6px;padding: 6px 12px;background: rgba(0,175,163,.12);color: var(--ap-teal, #00afa3);border-radius: 999px;font-size: .72rem;font-weight: 700;letter-spacing: .04em;text-transform: uppercase;line-height: 1;align-self: flex-start;}
.ap-tldr-badge svg{width: 12px;height: 12px;fill: none;stroke: currentColor;stroke-width: 2.5;stroke-linecap: round;}
/* === Apple Components imported from blog-v8.css (for rechner pages) === */
.ap-tldr{background: var(--ap-white);border: .5px solid var(--ap-line);border-radius: var(--ap-rl);padding: 40px 44px 36px;margin: 40px 0 48px;position: relative;}
.ap-tldr::before{content: '';position: absolute;left: 0;top: 32px;bottom: 32px;width: 4px;border-radius: 0 4px 4px 0;background: linear-gradient(180deg, var(--ap-teal), var(--ap-teal-dark));}
.ap-tldr-head{display: flex;align-items: center;gap: 16px;margin-bottom: 22px;padding-bottom: 18px;border-bottom: .5px solid var(--ap-line);}
.ap-tldr-badge{display: inline-flex;align-items: center;justify-content: center;padding: 7px 14px;border-radius: 999px;background: var(--ap-teal);color: #fff;font-size: .72rem;font-weight: 700;letter-spacing: .06em;text-transform: uppercase;white-space: nowrap;flex-shrink: 0;box-shadow: 0 1px 2px rgba(0,175,163,.25);}
.ap-tldr-title{font-size: 1.05rem !important;font-weight: 800 !important;color: var(--ap-ink) !important;letter-spacing: -.015em !important;margin: 0 !important;padding: 0 !important;border: none !important;line-height: 1.25 !important;}
.ap-tldr-sub{font-size: .78rem;color: var(--ap-muted);letter-spacing: .02em;margin-top: 2px;}
.ap-tldr-list{list-style: none;padding: 0;margin: 0;display: flex;flex-direction: column;gap: 14px;}
.ap-tldr-list li{display: block;position: relative;padding-left: 26px;font-size: 1rem;line-height: 1.6;color: var(--ap-mid);margin: 0;}
.ap-tldr-list li::before{content: '';position: absolute;left: 0;top: 9px;width: 8px;height: 8px;border-radius: 50%;background: var(--ap-teal);box-shadow: 0 0 0 3px rgba(0,175,163,.15);}
.ap-tldr-list li strong{color: var(--ap-ink);font-weight: 700;display: inline;letter-spacing: -.005em;}
.ap-tldr{padding: 28px 26px 24px;margin: 28px 0 36px;}
.ap-tldr-badge{padding: 6px 12px;font-size: .68rem;}
.ap-tldr-title{font-size: .98rem !important;}
.ap-tldr-badge{display: inline-flex;align-items: center;gap: 6px;padding: 6px 12px;background: rgba(0,175,163,.12);color: var(--ap-teal, #00afa3);border-radius: 999px;font-size: .72rem;font-weight: 700;letter-spacing: .04em;text-transform: uppercase;line-height: 1;align-self: flex-start;}
.ap-tldr-badge svg{width: 12px;height: 12px;fill: none;stroke: currentColor;stroke-width: 2.5;stroke-linecap: round;}
.ap-breadcrumb{font-size: 12px;color: var(--ap-muted);margin-bottom: 16px;}
.ap-breadcrumb a{color: var(--ap-muted);text-decoration: none;}
.ap-breadcrumb a:hover{color: var(--ap-ink);}
.ap-cat-label{display: inline-block;font-size: 11px;font-weight: 700;letter-spacing: .08em;text-transform: uppercase;color: var(--ap-teal);margin-bottom: 14px;}
.ap-tldr{padding: 28px 26px 24px;margin: 28px 0 36px;}
.ap-tldr-badge{padding: 6px 12px;font-size: .68rem;}
.ap-tldr-title{font-size: .98rem !important;}
/* === 2026-Werte-Badge im Hero === */
.ap-data-badge{display: inline-flex;align-items: center;gap: 6px;padding: 4px 10px;background: rgba(0,175,163,.08);color: var(--ap-teal-dark, #0d8276);border-radius: 980px;font-size: 11px;font-weight: 700;letter-spacing: .04em;text-transform: uppercase;}
.ap-data-badge-dot{width: 6px;height: 6px;background: var(--ap-teal, #00afa3);border-radius: 50%;}
/* === Pflicht-Sektion: "So funktioniert der Rechner" (3 Step-Karten + Ergebnis) === */
.ap-how-section{padding: 48px 0;background: var(--ap-bg, #f5f5f7);}
.ap-how-inner{max-width: 1140px;margin: 0 auto;padding: 0 24px;}
.ap-how-overline{font-size: 11px;font-weight: 700;letter-spacing: .12em;text-transform: uppercase;color: var(--ap-teal-dark, #0d8276);margin: 0 0 20px;}
.ap-how-grid{display: grid;grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));gap: 16px;}
.ap-how-step{background: #fff;border-radius: 14px;padding: 22px 22px 20px;box-shadow: 0 1px 3px rgba(0,0,0,.04), 0 0 0 .5px rgba(0,0,0,.06);}
.ap-how-num{font-size: 1.35rem;font-weight: 800;color: var(--ap-teal-dark, #0d8276);font-variant-numeric: tabular-nums;letter-spacing: -.02em;margin: 0 0 10px;line-height: 1;}
.ap-how-step-title{font-size: 1rem;font-weight: 700;color: var(--ap-ink, #1d1d1f);margin: 0 0 8px;letter-spacing: -.012em;line-height: 1.3;}
.ap-how-step-desc{font-size: .88rem;color: var(--ap-mid, #515154);margin: 0;line-height: 1.55;}
.ap-how-result{margin-top: 22px;padding: 14px 18px;background: rgba(0,175,163,.08);border-radius: 12px;display: flex;align-items: flex-start;gap: 10px;color: var(--ap-mid, #515154);font-size: .9rem;line-height: 1.55;}
.ap-how-result-icon{color: var(--ap-teal, #00afa3);flex-shrink: 0;margin-top: 2px;width: 16px;height: 16px;}
.ap-how-result strong{color: var(--ap-ink, #1d1d1f);font-weight: 700;}
.ap-how-section, .ap-when-section{padding: 36px 0;}
.ap-how-step{padding: 18px 18px 16px;}
.ap-product-hero, header.ap-product-hero, header.ap-mast{padding-left: 16px !important;padding-right: 16px !important;}
.ap-product-hero-grid, .ap-mast{padding: 0 !important;gap: 32px !important;grid-template-columns: 1fr !important;}
/* H1 nicht ueberlaufen */
  h1, .ap-product-h1, .ap-mast h1{font-size: 1.85rem !important;line-height: 1.12 !important;word-break: normal;hyphens: auto;-webkit-hyphens: auto;}
/* Hero-Lead lesbar */
  .ap-product-lead, .ap-mast-lead{font-size: 1rem !important;}
/* 1. H1: nie in der Mitte von Compounds brechen */
  h1, .ap-product-h1, .ap-mast h1, .bx-h1, .hp-hero h1{word-break: keep-all !important;overflow-wrap: break-word !important;-webkit-hyphens: none !important;hyphens: none !important;font-size: 1.85rem !important;line-height: 1.12 !important;letter-spacing: -.025em !important;}
/* Numbered Step-Lists (Apple instruction style) */
.ap-article ol.step-list,
.ap-article ol:not(.ap-toc-list):not(.ap-tldr-list){list-style: none;counter-reset: stepCounter;padding: 0;margin: 24px 0 32px;}
.ap-article ol.step-list > li,
.ap-article ol:not(.ap-toc-list):not(.ap-tldr-list) > li{counter-increment: stepCounter;position: relative;padding: 16px 0 16px 56px;font-size: 1rem;line-height: 1.55;color: var(--ap-mid, #515154);border-bottom: .5px solid var(--ap-line, #d2d2d7);}
.ap-article ol.step-list > li:last-child,
.ap-article ol:not(.ap-toc-list):not(.ap-tldr-list) > li:last-child{border-bottom: none;}
.ap-article ol.step-list > li::before,
.ap-article ol:not(.ap-toc-list):not(.ap-tldr-list) > li::before{content: counter(stepCounter);position: absolute;left: 0;top: 14px;width: 32px;height: 32px;background: var(--ap-ink, #1d1d1f);color: #fff;border-radius: 50%;display: flex;align-items: center;justify-content: center;font-size: .82rem;font-weight: 700;font-variant-numeric: tabular-nums;letter-spacing: -.01em;}
.ap-article ol.step-list > li,
  .ap-article ol:not(.ap-toc-list):not(.ap-tldr-list) > li{padding: 14px 0 14px 48px;}
.ap-article ol.step-list > li::before,
  .ap-article ol:not(.ap-toc-list):not(.ap-tldr-list) > li::before{width: 28px;height: 28px;font-size: .76rem;top: 12px;}
/* H1 universal — kein Hyphenation in Compounds, klar lesbar */
  h1, .ap-product-h1, .ap-mast h1, .bx-h1, .hp-hero h1,
  .sim-mast h1, .sim-hero h1, header h1,
  [class*="-hero"] h1, [class*="-mast"] h1{font-size: 1.85rem !important;line-height: 1.12 !important;letter-spacing: -.025em !important;word-break: keep-all !important;overflow-wrap: break-word !important;-webkit-hyphens: none !important;hyphens: none !important;max-width: 100% !important;}
/* Hero/Mast padding kompakter */
  .sim-mast, .ap-product-hero, header.ap-mast{padding: 32px 16px 20px !important;}
/* Pill-Elemente von obigem Wildcard ausnehmen */
  .ap-mast-pills{padding-left: 0 !important;padding-right: 0 !important;}
.ap-mast-pill{padding: 5px 13px !important;}
.ap-mast-pill-dot{padding: 0 !important;width: 6px !important;height: 6px !important;}
/* ════════════════════════════════════════════════════════════
 * ap-how-section + ap-when-section — Rechner-Erklärungsblöcke
 * Fehlendes CSS das auf 67+ Rechner-Seiten benötigt wird.
 * ════════════════════════════════════════════════════════════ */

/* ── HOW IT WORKS ── */
.ap-how-section{background: var(--ap-bg, #f5f5f7);padding: 48px 0 52px;}
.ap-how-inner{max-width: 1140px;margin: 0 auto;padding: 0 24px;}
.ap-how-overline{font-size: 11px;font-weight: 700;letter-spacing: .12em;text-transform: uppercase;color: var(--ap-teal-dark, #0d8276);margin: 0 0 20px;}
.ap-how-grid{display: grid;grid-template-columns: repeat(3, 1fr);gap: 20px;margin: 0 0 24px;}
.ap-how-grid{grid-template-columns: 1fr;gap: 12px;}
.ap-how-step{background: #fff;border-radius: 14px;padding: 20px 22px;box-shadow: 0 1px 3px rgba(0,0,0,.04), 0 0 0 .5px rgba(0,0,0,.07);}
.ap-how-num{display: block;font-size: 2rem;font-weight: 800;letter-spacing: -.04em;color: var(--ap-teal, #00afa3);line-height: 1;margin: 0 0 10px;}
.ap-how-step-title{font-size: 1rem;font-weight: 700;color: var(--ap-ink, #1d1d1f);margin: 0 0 6px;letter-spacing: -.012em;}
.ap-how-step-desc{font-size: .88rem;color: var(--ap-mid, #515154);margin: 0;line-height: 1.55;}
.ap-how-result{display: flex;align-items: center;gap: 12px;background: rgba(0, 175, 163, .07);border-radius: 10px;padding: 14px 18px;font-size: .9rem;color: var(--ap-ink, #1d1d1f);line-height: 1.5;}
.ap-how-result-icon{width: 22px;height: 22px;flex-shrink: 0;color: var(--ap-teal, #00afa3);}
/* === Apple-pure: eine linke Schiene, variable Breiten (site-weit, 2026-06) === */
.ap-when-inner, .ap-sources-inner, .ap-how-inner{max-width: 1160px !important;margin-left: auto !important;margin-right: auto !important;padding-left: 24px !important;padding-right: 24px !important;box-sizing: content-box !important;}
.ap-when-inner, .ap-sources-inner, .ap-how-inner{padding-left: 16px !important;padding-right: 16px !important;}
@media (max-width: 720px){.ap-how__grid{grid-template-columns: 1fr;}}
@media(max-width:640px){.ap-tldr{padding: 28px 26px 24px;margin: 28px 0 36px;}.ap-tldr-badge{padding: 6px 12px;font-size: .68rem;}.ap-tldr-title{font-size: .98rem !important;}}
@media (max-width: 640px){.ap-how-section, .ap-when-section{padding: 36px 0;}.ap-how-step{padding: 18px 18px 16px;}}
@media (max-width: 768px){.ap-product-hero, header.ap-product-hero, header.ap-mast{padding-left: 16px !important;padding-right: 16px !important;}.ap-product-hero-grid, .ap-mast{padding: 0 !important;gap: 32px !important;grid-template-columns: 1fr !important;}/* H1 nicht ueberlaufen */
  h1, .ap-product-h1, .ap-mast h1{font-size: 1.85rem !important;line-height: 1.12 !important;word-break: normal;hyphens: auto;-webkit-hyphens: auto;}/* Hero-Lead lesbar */
  .ap-product-lead, .ap-mast-lead{font-size: 1rem !important;}}
@media (max-width: 768px){/* 1. H1: nie in der Mitte von Compounds brechen */
  h1, .ap-product-h1, .ap-mast h1, .bx-h1, .hp-hero h1{word-break: keep-all !important;overflow-wrap: break-word !important;-webkit-hyphens: none !important;hyphens: none !important;font-size: 1.85rem !important;line-height: 1.12 !important;letter-spacing: -.025em !important;}}
@media(max-width: 640px){.ap-article ol.step-list > li,
  .ap-article ol:not(.ap-toc-list):not(.ap-tldr-list) > li{padding: 14px 0 14px 48px;}.ap-article ol.step-list > li::before,
  .ap-article ol:not(.ap-toc-list):not(.ap-tldr-list) > li::before{width: 28px;height: 28px;font-size: .76rem;top: 12px;}}
@media (max-width: 768px){/* H1 universal — kein Hyphenation in Compounds, klar lesbar */
  h1, .ap-product-h1, .ap-mast h1, .bx-h1, .hp-hero h1,
  .sim-mast h1, .sim-hero h1, header h1,
  [class*="-hero"] h1, [class*="-mast"] h1{font-size: 1.85rem !important;line-height: 1.12 !important;letter-spacing: -.025em !important;word-break: keep-all !important;overflow-wrap: break-word !important;-webkit-hyphens: none !important;hyphens: none !important;max-width: 100% !important;}/* Hero/Mast padding kompakter */
  .sim-mast, .ap-product-hero, header.ap-mast{padding: 32px 16px 20px !important;}/* Pill-Elemente von obigem Wildcard ausnehmen */
  .ap-mast-pills{padding-left: 0 !important;padding-right: 0 !important;}.ap-mast-pill{padding: 5px 13px !important;}.ap-mast-pill-dot{padding: 0 !important;width: 6px !important;height: 6px !important;}}
@media (max-width: 768px){.ap-how-grid{grid-template-columns: 1fr;gap: 12px;}}
@media (max-width: 768px){.ap-when-inner, .ap-sources-inner, .ap-how-inner{padding-left: 16px !important;padding-right: 16px !important;}}
/* ── seiten-spezifische Hero-Overrides (Original-Inline) ── */
.ap-mast{background:linear-gradient(180deg,#f8faf9 0%,#ffffff 100%);padding:56px 0 32px;}
.ap-mast-inner{max-width:820px;margin:0;}
.ap-mast-inner h1{font-size:clamp(2rem,4.5vw,2.6rem);font-weight:700;letter-spacing:-.028em;line-height:1.08;color:var(--ap-ink);margin:0 0 14px;}
.ap-mast-lead{font-size:1.05rem;line-height:1.55;color:var(--ap-mid);margin:0 0 22px;max-width:660px;}
.ap-mast-badges{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 8px;}
