/* Fintro — Design-System „Momentum". Hell, Grün-Akzent, weiche Tiefe + 1 taktiler Schatten. Keine Em-Dashes im Content. */
:root{
  --fd:'Space Grotesk',ui-sans-serif,system-ui,sans-serif;
  --fb:'Inter',ui-sans-serif,system-ui,-apple-system,'Segoe UI',sans-serif;
  --bg:#f6f9f7;--ink:#0b1310;--soft:#37443d;--muted:#6a786f;
  --line:#e4ece8;--line2:#d3ded7;--surface:#fff;
  --green:#10b981;--green-d:#0a7f59;--tint:#e7f6ef;
  --blue:#1e5fd6;--violet:#7c4ddb;--amber:#b4791f;--rose:#db2777;--navy:#0b2545;
  --sh:0 16px 38px -26px rgba(11,19,16,.55);
  --maxw:680px;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;color:var(--ink);font-family:var(--fb);font-size:17px;line-height:1.62;-webkit-font-smoothing:antialiased;
  background-color:var(--bg);
  background-image:radial-gradient(34% 22% at 8% 2%,rgba(16,185,129,.11),transparent 70%),radial-gradient(28% 20% at 95% 5%,rgba(124,77,219,.06),transparent 72%),radial-gradient(32% 22% at 92% 52%,rgba(30,95,214,.05),transparent 72%);
  background-attachment:fixed;
}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}
a{color:inherit}

/* ---- App topbar ---- */
.top{position:sticky;top:0;z-index:30;background:rgba(246,249,247,.85);backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--line)}
.top .in{max-width:1040px;margin:0 auto;padding:12px 20px;display:flex;align-items:center;gap:14px}
.logo{display:flex;align-items:center;gap:8px;font-family:var(--fd);font-weight:700;font-size:18px;letter-spacing:-.02em;text-decoration:none;color:var(--ink)}
.logo .ic{width:25px;height:25px;border-radius:7px;background:linear-gradient(150deg,#34d399,#0a7d57);display:grid;place-items:center;color:#fff;font-family:'Futura','Avenir Next',var(--fd);font-weight:700;font-size:15px;box-shadow:inset 0 1px 0 rgba(255,255,255,.5)}
.crumb{font-family:var(--fd);font-weight:600;font-size:13.5px;color:var(--muted)}
.crumb a{text-decoration:none;color:var(--muted)}
.hud{margin-left:auto;display:flex;align-items:center;gap:12px}
.hud .s{display:flex;align-items:center;gap:6px;font-family:var(--fd);font-weight:700;font-size:13px;font-variant-numeric:tabular-nums}
.hud .s.streak{color:var(--green-d)}.hud .s.xp{color:var(--muted)}
@media(max-width:560px){.crumb{display:none}}

/* ---- Chapter head ---- */
.chead{padding:40px 0 22px}
.kicker{font-family:var(--fd);font-size:12px;font-weight:600;letter-spacing:.13em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:10px}
.kicker:before{content:"";width:24px;height:2px;background:var(--green)}
.chead h1{font-family:var(--fd);font-weight:700;font-size:clamp(34px,7vw,52px);line-height:1.0;letter-spacing:-.035em;margin:14px 0 0;text-wrap:balance}
.chead .sub{font-size:18px;color:var(--soft);margin:12px 0 0;max-width:36ch}
.why{margin-top:16px;background:var(--surface);border:1px solid var(--line);border-left:3px solid var(--green);border-radius:0 12px 12px 0;padding:13px 16px;font-size:15px;color:var(--soft)}
.why b{color:var(--ink);font-weight:600}

/* momentum strip */
.mom{margin-top:20px;display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:12px 16px;box-shadow:var(--sh)}
.mom .step{font-family:var(--fd);font-weight:700;font-size:13px;white-space:nowrap;font-variant-numeric:tabular-nums}
.mom .track{flex:1;height:8px;background:#eaf0ec;border-radius:99px;overflow:hidden}
.mom .track i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--green),#5ee0a8);border-radius:99px;transition:width 1s cubic-bezier(.22,1,.36,1)}

/* ---- Tabs ---- */
.tabs{position:sticky;top:55px;z-index:20;background:rgba(246,249,247,.9);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.tabs .in{max-width:var(--maxw);margin:0 auto;padding:0 20px;display:flex;gap:2px}
.tab{border:0;background:none;font-family:var(--fd);font-weight:600;font-size:15px;color:var(--muted);padding:13px 13px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}
.tab[aria-selected=true]{color:var(--ink);border-bottom-color:var(--green)}
.tab .c{font-size:12px;color:var(--line2);margin-left:4px;font-variant-numeric:tabular-nums}
.panel{display:none}
.panel.on{display:block}

main{padding:8px 0 80px}

/* ---- Steps ---- */
.step{padding:36px 0;border-bottom:1px solid var(--line);--acc:var(--green-d);--acc-bg:var(--tint)}
.step.s-vert{--acc:var(--blue);--acc-bg:#e6eeff}
.step.s-kon{--acc:var(--violet);--acc-bg:#efe7ff}
.step.s-erk{--acc:var(--amber);--acc-bg:#fbeccd}
.step:last-child{border-bottom:0}
.ph{display:flex;align-items:center;gap:11px}
.ph .glyph{flex:none;width:27px;height:27px;border-radius:8px;background:var(--acc-bg);color:var(--acc);display:grid;place-items:center;font-family:var(--fd);font-weight:700;font-size:13px}
.ph .lbl{font-family:var(--fd);font-size:12px;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--acc)}
.ph .no{margin-left:auto;font-family:var(--fd);font-weight:700;font-size:12px;color:var(--line2);font-variant-numeric:tabular-nums}
.step h2{font-family:var(--fd);font-weight:600;font-size:24px;letter-spacing:-.02em;margin:15px 0 0;text-wrap:balance}
.lead{font-size:18px;color:var(--soft);margin:12px 0 0}.lead b{color:var(--ink);font-weight:600}

/* term tooltip */
.term{border-bottom:1.5px dotted var(--green);cursor:help;position:relative;font-weight:500}
.term:focus{outline:2px solid var(--green);outline-offset:2px;border-radius:2px}
.term .pop{position:absolute;left:0;bottom:calc(100% + 9px);width:240px;background:var(--ink);color:#eaf2ee;font-family:var(--fb);font-weight:400;font-size:13.5px;line-height:1.5;padding:11px 13px;border-radius:10px;box-shadow:var(--sh);opacity:0;visibility:hidden;transition:.16s;z-index:5}
.term:hover .pop,.term:focus .pop{opacity:1;visibility:visible}.term .pop b{color:#fff}

/* def */
.def{margin-top:18px;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:18px 20px;box-shadow:var(--sh)}
.def .l{font-family:var(--fd);font-size:11.5px;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--green-d)}
.def p{margin:7px 0 0;font-size:16.5px;color:var(--soft)}.def p b{color:var(--ink)}

/* two compare */
.two{margin-top:18px;display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:540px){.two{grid-template-columns:1fr}}
.two .c{border:1px solid var(--line);border-radius:14px;padding:17px 18px;background:var(--surface);box-shadow:var(--sh)}
.two .c.b{border-color:#c2d4ff;background:linear-gradient(180deg,#eaf1ff,#f6f9ff)}.two .c.b .t{color:var(--blue)}
.two .c.g{border-color:#bfe9d6;background:linear-gradient(180deg,var(--tint),#f4fbf7)}.two .c.g .t{color:var(--green-d)}
.two .c .t{font-family:var(--fd);font-weight:600;font-size:16px}
.two .c p{margin:8px 0 0;font-size:14.5px;color:var(--muted);line-height:1.5}

/* take / merksatz (taktiler Akzent) */
.take{margin-top:18px;background:var(--ink);color:#eafaf2;border-radius:16px;padding:18px 20px;box-shadow:7px 7px 0 var(--green)}
.take .k{font-family:var(--fd);font-size:11px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:#7bf0bf}
.take p{margin:6px 0 0;font-size:16.5px;line-height:1.5}.take b{color:#7bf0bf}

/* insights */
.ins{margin-top:14px;display:flex;flex-direction:column;gap:12px}
.it{display:flex;gap:14px;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:15px 18px;box-shadow:var(--sh)}
.it .n{flex:none;font-family:var(--fd);font-weight:700;font-size:14px;width:28px;height:28px;border-radius:8px;display:grid;place-items:center;background:#f0f4f2;color:var(--soft)}
.it.key{border-color:#bfe9d6;background:linear-gradient(180deg,var(--tint),#f4fbf7)}.it.key .n{background:var(--green);color:#fff}
.it .t{font-family:var(--fd);font-weight:600;font-size:16px;line-height:1.35}
.it p{margin:4px 0 0;font-size:14.5px;color:var(--muted);line-height:1.5}

/* statCompare */
.stat{margin-top:18px;border:1px solid var(--line);border-radius:16px;overflow:hidden;background:var(--surface);box-shadow:var(--sh)}
.stat .l{font-family:var(--fd);font-size:11.5px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);padding:14px 18px 0}
.stat .r{display:grid;grid-template-columns:1fr 1fr}
@media(max-width:540px){.stat .r{grid-template-columns:1fr}}
.stat .cell{padding:15px 18px 17px}.stat .cell:first-child{border-right:1px solid var(--line)}
@media(max-width:540px){.stat .cell:first-child{border-right:0;border-bottom:1px solid var(--line)}}
.stat .v{font-family:var(--fd);font-weight:700;font-size:28px;letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.stat .cell.win .v{color:var(--green-d)}.stat .cell.late .v{color:var(--amber)}
.stat .s{font-size:13.5px;color:var(--muted);margin-top:2px}
.stat .note{padding:13px 18px;background:#fafbfa;border-top:1px solid var(--line);font-size:14px;color:var(--soft)}
.fn{display:block;margin-top:8px;font-size:11.5px;color:var(--muted)}

/* note / warn */
.note{margin-top:16px;border-left:3px solid var(--violet);background:#f7f3ff;border-radius:0 12px 12px 0;padding:14px 18px}
.note.warn{border-left-color:var(--rose);background:#fff0f6}
.note .k{font-family:var(--fd);font-size:11.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--violet)}
.note.warn .k{color:#be185d}
.note p{margin:5px 0 0;font-size:15px;color:var(--soft)}

/* done + cta */
.done{margin-top:32px;display:flex;align-items:center;justify-content:center;gap:13px}
.check{width:30px;height:30px;border-radius:50%;background:var(--green);display:grid;place-items:center;color:#fff;transform:scale(.6);opacity:0}
.check.go{animation:pop .5s cubic-bezier(.18,1.5,.4,1) forwards}
@keyframes pop{to{transform:scale(1);opacity:1}}
.done .t{font-family:var(--fd);font-weight:600;font-size:16px}
.cta{display:flex;align-items:center;justify-content:center;gap:8px;margin:18px auto 0;font-family:var(--fd);font-weight:600;font-size:16px;color:#fff;background:var(--ink);border:0;border-radius:13px;padding:15px 26px;cursor:pointer;box-shadow:5px 5px 0 var(--green);transition:transform .12s,box-shadow .12s;text-decoration:none}
.cta:hover{transform:translate(-2px,-2px);box-shadow:7px 7px 0 var(--green)}

/* vocab */
.vlist{padding:28px 0 60px;display:flex;flex-direction:column;gap:12px}
.vrow{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:16px 18px;box-shadow:var(--sh)}
.vrow .vt{font-family:var(--fd);font-weight:700;font-size:16px;color:var(--green-d)}
.vrow .vd{font-size:15px;color:var(--soft);margin-top:4px}

/* quiz */
.quiz{padding:28px 0 60px;display:flex;flex-direction:column;gap:20px}
.q{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:18px 20px;box-shadow:var(--sh)}
.q .qq{font-family:var(--fd);font-weight:600;font-size:17px}
.q .opts{margin-top:12px;display:flex;flex-direction:column;gap:9px}
.opt{text-align:left;font-family:var(--fb);font-size:15px;background:#fafbfa;border:1.5px solid var(--line);border-radius:11px;padding:12px 14px;cursor:pointer;transition:border-color .12s,background .12s}
.opt:hover{border-color:var(--line2)}
.opt.correct{border-color:var(--green);background:var(--tint);color:var(--green-d);font-weight:600}
.opt.wrong{border-color:var(--rose);background:#fff0f6;color:#be185d}
.opt:disabled{cursor:default}
.expl{margin-top:11px;font-size:14px;color:var(--soft);background:#fafbfa;border-radius:10px;padding:11px 13px;display:none}
.expl.on{display:block}.expl b{color:var(--ink)}

/* game placeholder */
.gamePh{padding:48px 22px;text-align:center;color:var(--muted)}
.gamePh .gt{font-family:var(--fd);font-weight:700;font-size:18px;color:var(--ink)}

/* reveal */
.rv{opacity:0;transform:translateY(14px);transition:opacity .6s ease,transform .6s cubic-bezier(.22,1,.36,1)}
.rv.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.rv{opacity:1;transform:none;transition:none}.mom .track i{transition:none}.check.go{animation:none;opacity:1;transform:none}}

/* ===== Fixes-Runde: App-Nav, Side-Rail, Vokabeln, Quiz-Score ===== */
.appnav{display:flex;gap:20px;margin-left:4px;font-family:var(--fd);font-weight:500;font-size:14.5px}
.appnav a{color:var(--muted);text-decoration:none}
.appnav a[aria-current="page"]{color:var(--ink)}
.appnav a:hover{color:var(--green-d)}
@media(max-width:560px){.appnav{gap:13px;font-size:13px}}

.rail{position:fixed;left:26px;top:50%;transform:translateY(-50%);z-index:15;display:flex;flex-direction:column;gap:16px}
.rail a{display:flex;align-items:center;gap:10px;font-family:var(--fd);font-weight:600;font-size:12px;color:var(--muted);text-decoration:none;cursor:pointer}
.rail a .d{width:10px;height:10px;border-radius:50%;background:var(--line2);transition:.2s}
.rail a.on{color:var(--ink)} .rail a.on .d{background:var(--green);box-shadow:0 0 0 4px var(--tint)}
.rail a:hover .d{background:var(--green-d)}
@media(max-width:1100px){.rail{display:none}}

.vlist{padding:28px 0 60px;display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:560px){.vlist{grid-template-columns:1fr}}
.vrow{text-align:left;display:flex;gap:13px;align-items:flex-start;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:16px 18px;box-shadow:var(--sh);cursor:pointer;font-family:var(--fb);transition:transform .12s,box-shadow .12s}
.vrow:hover{transform:translateY(-2px)}
.vrow .vbadge{flex:none;width:36px;height:36px;border-radius:10px;background:var(--tint);color:var(--green-d);display:grid;place-items:center;font-family:var(--fd);font-weight:700;font-size:17px}
.vrow:nth-child(4n+2) .vbadge{background:#e6eeff;color:var(--blue)}
.vrow:nth-child(4n+3) .vbadge{background:#efe7ff;color:var(--violet)}
.vrow:nth-child(4n+4) .vbadge{background:#fbeccd;color:var(--amber)}
.vrow .vmain{flex:1;min-width:0}
.vrow .vt{font-family:var(--fd);font-weight:700;font-size:16px;color:var(--ink);display:block}
.vrow .vd{font-size:14px;color:var(--soft);margin-top:6px;line-height:1.5;display:none}
.vrow.open .vd{display:block}
.vrow .vmore{flex:none;font-family:var(--fd);font-size:10.5px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;align-self:center}
.vrow.open .vmore{display:none}

.qhead{display:flex;justify-content:space-between;align-items:center;padding-top:26px}
.qhead .qt{font-family:var(--fd);font-weight:700;font-size:18px}
.qscore{font-family:var(--fd);font-weight:700;font-size:14px;color:var(--green-d);background:var(--tint);padding:6px 13px;border-radius:999px;font-variant-numeric:tabular-nums}
.q .qn{display:inline-grid;place-items:center;width:24px;height:24px;border-radius:7px;background:#f0f4f2;color:var(--soft);font-family:var(--fd);font-weight:700;font-size:13px;margin-right:9px;vertical-align:middle}
