/* Extrahiert aus der CSS-in-JS-Konstante der Original-Datei – Design lebt ausschließlich hier. */
@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400..800&family=Inter:wght@400;500;600;700&display=swap');

.ff-root{
  --ink:#131A33; --paper:#F1F3F8; --card:#FFFFFF;
  --blue:#2B45F0; --blue-ink:#1B2EB5; --blue-soft:#E8EBFE;
  --marker:#FFD73B; --muted:#5C6479; --line:#DFE3EE;
  min-height:100vh;
  background-color:var(--paper);
  background-image:
    linear-gradient(rgba(19,26,51,0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(19,26,51,0.05) 1px, transparent 1px);
  background-size:32px 32px;
  color:var(--ink);
  font-family:'Inter',system-ui,-apple-system,'Segoe UI',sans-serif;
  font-size:15.5px; line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
.ff-root *,.ff-root *::before,.ff-root *::after{box-sizing:border-box}
.ff-root button{font:inherit;color:inherit;background:none;border:0;padding:0;cursor:pointer;text-align:left}
.ff-root h1,.ff-root h2,.ff-root h3,.ff-root p,.ff-root ul{margin:0;padding:0}
.ff-root ul{list-style:none}
.ff-root :is(button,a):focus-visible{outline:3px solid var(--blue);outline-offset:2px;border-radius:10px}
.ff-display{font-family:'Bricolage Grotesque','Inter',sans-serif;letter-spacing:-0.015em}
.ff-wrap{max-width:1024px;margin:0 auto;padding:0 20px 60px}

/* Kopfzeile */
.ff-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:20px 0 16px}
.ff-logo{display:flex;align-items:center;gap:11px;font-size:19px;font-weight:700}
.ff-logo em{font-style:normal;color:var(--blue)}
.ff-wordmark{display:flex;flex-direction:column;line-height:1.05}
.ff-wordmark small{font-family:'Inter',sans-serif;font-size:10.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:3px}
.ff-logo-tile{width:34px;height:34px;border-radius:10px;background:var(--blue);color:#fff;display:grid;place-items:center;box-shadow:0 6px 14px -6px rgba(43,69,240,.55)}
.ff-stepinfo{font-size:11.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);white-space:nowrap}

/* Fortschritt */
.ff-prog{display:flex;gap:8px;margin-bottom:34px}
.ff-seg{flex:1}
.ff-seg i{display:block;height:6px;border-radius:99px;background:#DDE1EF;position:relative;overflow:hidden}
.ff-seg i::after{content:"";position:absolute;inset:0;border-radius:99px;background:var(--blue);transform:scaleX(0);transform-origin:left;transition:transform .55s cubic-bezier(.7,0,.3,1)}
.ff-seg.done i::after{transform:scaleX(1)}
.ff-seg.now i::after{transform:scaleX(.38);background:linear-gradient(90deg,var(--blue),#5A6FFF)}
.ff-seg span{display:block;margin-top:7px;font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:#A7ADC4;transition:color .3s}
.ff-seg.done span,.ff-seg.now span{color:var(--ink)}

/* Schritt-Kopf */
.ff-back{display:inline-flex;align-items:center;gap:6px;font-size:13.5px;font-weight:600;color:var(--muted);margin-bottom:14px;padding:6px 10px;border-radius:9px;transition:color .2s,background .2s}
.ff-back:hover{color:var(--ink);background:rgba(19,26,51,.06)}
.ff-eyebrow{font-size:11.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--blue);margin-bottom:10px}
.ff-step h1{font-size:clamp(26px,4.4vw,40px);font-weight:700;line-height:1.12;max-width:680px}
.ff-sub{color:var(--muted);margin-top:10px;max-width:580px}
.ff-meta{display:flex;flex-wrap:wrap;gap:14px;margin-top:14px}
.ff-meta li{display:flex;align-items:center;gap:6px;font-size:12.5px;font-weight:600;color:var(--blue-ink)}
.ff-note{display:flex;gap:8px;align-items:flex-start;margin-top:14px;font-size:13.5px;color:#6E5A0E;background:#FFF6D9;border:1px solid #F0DFA0;padding:10px 14px;border-radius:12px;max-width:640px}
.ff-note svg{flex:none;margin-top:2px}

/* Auswahlkarten */
.ff-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(235px,1fr));gap:14px;margin-top:26px}
.ff-opt{position:relative;display:flex;flex-direction:column;gap:10px;background:var(--card);border:1px solid var(--line);border-radius:16px;padding:20px 18px;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}
.ff-opt:hover{transform:translateY(-3px);border-color:#B9C2E8;box-shadow:0 14px 30px -16px rgba(19,26,51,.28)}
.ff-opt.sel{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-soft),0 14px 30px -16px rgba(43,69,240,.4)}
.ff-opt-t{font-size:17.5px;font-weight:700;line-height:1.25}
.ff-opt-d{font-size:13.5px;color:var(--muted)}
.ff-zg{margin-top:auto;font-size:12px;font-weight:600;color:var(--blue-ink);background:var(--blue-soft);padding:5px 10px;border-radius:99px;width:fit-content}
.ff-tick{position:absolute;top:12px;right:12px;width:24px;height:24px;border-radius:99px;background:var(--blue);color:#fff;display:grid;place-items:center;animation:ffPop .3s cubic-bezier(.5,1.6,.4,1) both}
.ff-tile{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;background:var(--blue-soft);color:var(--blue-ink);flex:none}
.ff-tile-solid{background:var(--blue);color:#fff}
.ff-tile-green{background:#DFF5E9;color:#0B7A4B}

/* Bundesland-Raster */
.ff-lgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(185px,1fr));gap:10px;margin-top:26px}
.ff-land{display:flex;align-items:center;gap:10px;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:9px 12px;font-size:13.5px;font-weight:600;transition:transform .16s,border-color .16s,box-shadow .16s,background .16s,color .16s}
.ff-land b{width:36px;height:27px;border-radius:8px;background:var(--ink);color:#fff;display:grid;place-items:center;font-size:11px;letter-spacing:.05em;flex:none;transition:background .16s,color .16s}
.ff-land:hover{transform:translateY(-2px);border-color:#B9C2E8;box-shadow:0 10px 22px -14px rgba(19,26,51,.3)}
.ff-land.sel{background:var(--blue);border-color:var(--blue);color:#fff}
.ff-land.sel b{background:var(--marker);color:var(--ink)}

/* Ergebnis */
.ff-sums{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}
.ff-sum{display:inline-flex;align-items:center;gap:7px;background:var(--card);border:1px solid var(--line);border-radius:99px;padding:7px 13px;font-size:13px;font-weight:600;transition:border-color .16s,color .16s,transform .16s}
.ff-sum span{font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#A2A8C0}
.ff-sum:hover{border-color:var(--blue);color:var(--blue-ink);transform:translateY(-1px)}
.ff-sum-re{background:transparent;border-style:dashed;color:var(--muted)}
.ff-sec{display:flex;align-items:center;gap:12px;margin:30px 0 4px;font-size:11.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.ff-sec i{flex:1;height:1px;background:#CBD1E4}
.ff-intro{color:var(--muted);margin-top:18px;max-width:660px;font-size:14px}
.ff-empty{color:var(--muted);font-size:14px;background:rgba(255,255,255,.7);border:1px dashed #C4CBE0;border-radius:14px;padding:14px 16px;margin-top:12px}

.ff-res{position:relative;display:flex;flex-direction:column;gap:12px;background:var(--card);border:1px solid var(--line);border-radius:18px;padding:22px;margin-top:12px;box-shadow:0 8px 20px -16px rgba(19,26,51,.2)}
.ff-feat{border:2px solid var(--blue);box-shadow:0 22px 44px -22px rgba(43,69,240,.45);margin-top:24px}
.ff-flag{position:absolute;top:-13px;left:18px;display:inline-flex;align-items:center;gap:6px;background:var(--blue);color:#fff;font-size:11.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:5px 11px;border-radius:99px;box-shadow:0 8px 16px -8px rgba(43,69,240,.7)}
.ff-res-head{display:flex;align-items:flex-start;gap:13px}
.ff-res-title{flex:1;min-width:0}
.ff-res-title h3{font-size:18px;font-weight:700;line-height:1.25}
.ff-res-title p{font-size:12.5px;color:var(--muted);margin-top:3px}
.ff-badge{flex:none;font-size:10.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;background:#EEF0F8;color:var(--muted);padding:5px 10px;border-radius:99px}
.ff-badge-land{background:var(--marker);color:var(--ink)}
.ff-badge-tipp{background:#DFF5E9;color:#0B7A4B}
.ff-badge-bu{background:var(--blue-soft);color:var(--blue-ink)}
.ff-hoehe{font-size:19px;font-weight:700}
.ff-kurz{font-size:14px;color:#3C4460;max-width:720px}
.ff-chips{display:flex;flex-wrap:wrap;gap:7px}
.ff-chips li{font-size:12px;font-weight:500;color:var(--muted);background:#F7F8FC;border:1px solid var(--line);border-radius:99px;padding:4px 10px}
.ff-link{display:inline-flex;align-items:center;gap:6px;font-size:13.5px;font-weight:600;color:var(--blue);text-decoration:none;width:fit-content}
.ff-link:hover{text-decoration:underline}

/* Textmarker-Signatur */
.ff-marker{background-image:linear-gradient(100deg,rgba(255,215,59,0) 0%,var(--marker) 4%,rgba(255,215,59,.92) 96%,rgba(255,215,59,0) 100%);background-repeat:no-repeat;background-size:0% 74%;background-position:0 62%;padding:0 .14em;margin:0 -.06em;border-radius:3px;box-decoration-break:clone;-webkit-box-decoration-break:clone;animation:ffMarker .8s .45s cubic-bezier(.7,0,.3,1) forwards}

/* Hinweis, CTA, Fu\xDFzeile */
.ff-notice{display:flex;gap:12px;background:#FFF6D9;border:1px solid #F0DFA0;border-radius:16px;padding:16px 18px;margin-top:22px}
.ff-notice-ic{flex:none;width:34px;height:34px;border-radius:10px;background:var(--marker);color:var(--ink);display:grid;place-items:center}
.ff-notice strong{display:block;font-size:14.5px;margin-bottom:4px}
.ff-notice p{font-size:13.5px;color:#5A4E1E}
.ff-cta{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:18px;background:var(--ink);color:#F2F4FD;border-radius:20px;padding:26px 28px;margin-top:34px}
.ff-cta h2{font-size:21px;font-weight:700}
.ff-cta p{font-size:13.5px;color:#B9BFD6;margin-top:5px;max-width:440px}
.ff-cta-btns{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.ff-cta-btn{background:var(--marker);color:var(--ink);font-size:14px;font-weight:700;padding:12px 20px;border-radius:12px;text-decoration:none;transition:transform .16s,box-shadow .16s}
.ff-cta-btn:hover{transform:translateY(-2px);box-shadow:0 12px 24px -10px rgba(255,215,59,.5)}
.ff-ghost{display:inline-flex;align-items:center;gap:7px;color:#B9BFD6;font-size:13.5px;font-weight:600;padding:11px 14px;border:1px solid rgba(255,255,255,.22);border-radius:12px;transition:color .16s,border-color .16s}
.ff-ghost:hover{color:#fff;border-color:rgba(255,255,255,.5)}
.ff-foot{margin-top:44px;padding-top:18px;border-top:1px solid #CBD1E4;font-size:12px;color:#8A91AB;text-align:center;line-height:1.7}
.ff-foot strong{color:var(--ink);font-weight:700}

/* Bewegung */
.ff-step{animation:ffStep .45s cubic-bezier(.3,.7,.3,1) both}
.ff-in{animation:ffUp .55s cubic-bezier(.3,.7,.3,1) both}
@keyframes ffStep{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
@keyframes ffUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
@keyframes ffPop{0%{transform:scale(.3);opacity:0}70%{transform:scale(1.15)}100%{transform:scale(1);opacity:1}}
@keyframes ffMarker{to{background-size:100% 74%}}

@media (max-width:560px){
  .ff-seg span{display:none}
  .ff-res{padding:18px 16px}
  .ff-cta{padding:22px 20px}
}
@media (prefers-reduced-motion:reduce){
  .ff-root *{animation:none!important;transition:none!important}
  .ff-marker{background-size:100% 74%}
}

/* ============================================================
   Zusatz nur für den Prototyp-Vergleich:
   Rücksprung-Pill zur Auswahlseite. Für den Livegang einfach
   diesen Block und das <a class="variante-wechsel"> entfernen.
   ============================================================ */
.variante-wechsel{
  position:fixed; left:16px; bottom:16px; z-index:60;
  display:inline-flex; align-items:center; gap:8px;
  padding:9px 14px; border-radius:999px;
  background:var(--card); color:var(--ink);
  border:1.5px solid var(--line);
  box-shadow:0 10px 24px -14px rgba(19,26,51,.35);
  font:600 13px/1 'Inter',system-ui,sans-serif;
  text-decoration:none; opacity:.88;
  transition:opacity .18s ease, transform .18s ease, border-color .18s ease;
}
.variante-wechsel:hover{opacity:1; transform:translateY(-1px); border-color:var(--blue)}
.variante-wechsel:focus-visible{outline:3px solid var(--blue); outline-offset:2px}
@media (prefers-reduced-motion:reduce){.variante-wechsel{transition:none}}
@media print{.variante-wechsel{display:none}}
