/* Fintro — Seiten-Styles für Landing, Dashboard, Über mich. Tokens kommen aus app.css. */

/* hintergrund: steigender Chart (Geld/Wachstum), oben verankert */
.bgchart{position:fixed;left:0;right:0;top:0;height:66vh;z-index:-1;pointer-events:none}
.bgchart svg{width:100%;height:100%;display:block}
.bgfx{position:fixed;inset:0;width:100%;height:100%;z-index:-1;pointer-events:none}

footer.site{margin-top:40px;border-top:1px solid var(--line);padding:22px 0 54px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:13px;color:var(--muted)}
footer.site a{color:var(--green-d);text-decoration:none;font-weight:500}

/* ===================== DASHBOARD ===================== */
.dhead{padding:30px 0 8px}
.dhead h1{font-family:var(--fd);font-weight:700;font-size:clamp(26px,5vw,34px);letter-spacing:-.025em;margin:0}
.ov{margin-top:14px;display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:13px 18px;box-shadow:var(--sh)}
.ov .lab{font-family:var(--fd);font-weight:700;font-size:13px;white-space:nowrap;font-variant-numeric:tabular-nums}
.ov .track{flex:1;height:8px;background:#eaf0ec;border-radius:99px;overflow:hidden}
.ov .track i{display:block;height:100%;background:linear-gradient(90deg,var(--green),#5ee0a8);border-radius:99px;transition:width 1s cubic-bezier(.22,1,.36,1)}
.ov .pct{font-family:var(--fd);font-weight:700;font-size:13px;color:var(--green-d);font-variant-numeric:tabular-nums}

.cont{margin-top:16px;display:flex;align-items:center;gap:18px;background:var(--ink);color:#eafaf2;border-radius:18px;padding:20px 22px;box-shadow:6px 6px 0 var(--green)}
.cont .meta{flex:1;min-width:0}
.cont .k{font-family:var(--fd);font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#7bf0bf}
.cont .ti{font-family:var(--fd);font-weight:600;font-size:20px;margin-top:3px}
.cont .bw{height:6px;background:rgba(255,255,255,.16);border-radius:99px;overflow:hidden;margin-top:11px;max-width:260px}
.cont .bw i{display:block;height:100%;background:linear-gradient(90deg,var(--green),#5ee0a8);border-radius:99px}
.cont .go{flex:none;font-family:var(--fd);font-weight:600;font-size:15px;color:var(--ink);background:#fff;border:0;border-radius:11px;padding:13px 20px;cursor:pointer;white-space:nowrap;text-decoration:none}

.pathhead{font-family:var(--fd);font-weight:700;font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin:34px 0 8px}
.path{position:relative;padding-left:46px}
.path::before{content:"";position:absolute;left:21px;top:14px;bottom:34px;width:3px;background:linear-gradient(var(--green) 0%,var(--blue) 30%,var(--violet) 54%,var(--amber) 76%,var(--rose) 100%);opacity:.55;border-radius:2px}
.node{position:relative;margin-bottom:14px}
.node .dot{position:absolute;left:-46px;top:8px;width:44px;display:grid;place-items:center}
.ring{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;background:#fff;border:3px solid var(--line2);font-family:var(--fd);font-weight:700;font-size:12px;color:var(--muted);box-shadow:0 0 0 5px var(--bg);font-variant-numeric:tabular-nums}
.ring.done{background:var(--green);border-color:var(--green);color:#fff}
.node.c1 .ring{border-color:var(--green)} .node.c1 .ring.done{background:var(--green)}
.node.c2 .ring{border-color:#9cc0ff;color:var(--blue)}
.node.c3 .ring{border-color:#cdb8f5;color:var(--violet)}
.node.c4 .ring{border-color:#e8cb8f;color:var(--amber)}
.node.c5 .ring{border-color:#f4b6d2;color:var(--rose)}
.u-card{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:16px 18px;box-shadow:var(--sh)}
.node.c1 .u-card{border-left:4px solid var(--green)}
.node.c2 .u-card{border-left:4px solid var(--blue)}
.node.c3 .u-card{border-left:4px solid var(--violet)}
.node.c4 .u-card{border-left:4px solid var(--amber)}
.node.c5 .u-card{border-left:4px solid var(--rose)}
.u-card.lock{opacity:.62}
.u-top{display:flex;align-items:center;gap:12px}
.u-top .un{font-family:var(--fd);font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase}
.node.c1 .un{color:var(--green-d)} .node.c2 .un{color:var(--blue)} .node.c3 .un{color:var(--violet)} .node.c4 .un{color:var(--amber)} .node.c5 .un{color:var(--rose)}
.u-top .tt{font-family:var(--fd);font-weight:600;font-size:17px}
.u-top .meta{margin-left:auto;font-size:13px;color:var(--muted);font-family:var(--fd);font-weight:600;font-variant-numeric:tabular-nums}
.chaps{margin-top:12px;border-top:1px solid var(--line);padding-top:6px}
.chap{display:flex;align-items:center;gap:11px;padding:9px 0;border-bottom:1px solid var(--line);text-decoration:none;color:inherit}
.chap:last-child{border-bottom:0}
.chap .ci{width:20px;height:20px;border-radius:6px;flex:none;display:grid;place-items:center;background:#eef3f1;color:var(--muted)}
.chap .ci.done{background:var(--green);color:#fff}
.chap.cur .ci{background:var(--tint);color:var(--green-d);box-shadow:0 0 0 2px var(--green)}
.chap .cn{font-size:14.5px;font-weight:500}
.chap.cur .cn{font-weight:600}
.chap .go2{margin-left:auto;font-family:var(--fd);font-weight:600;font-size:12.5px;color:var(--green-d)}
.chap.soon .cn{color:var(--muted)} .chap.soon .go2{color:var(--line2)}

.summit{position:relative;margin-top:6px}
.summit .dot{position:absolute;left:-46px;top:6px;width:44px;display:grid;place-items:center}
.summit .ring{border-style:dashed}
.cert{background:linear-gradient(180deg,#fffdf4,#fff);border:1px dashed var(--line2);border-radius:16px;padding:15px 18px}
.cert .tt{font-family:var(--fd);font-weight:600;font-size:16px}
.cert .meta{font-size:13px;color:var(--muted)}

.extras{margin-top:26px;display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:560px){.extras{grid-template-columns:1fr}}
.ex{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:18px;box-shadow:var(--sh);display:flex;gap:13px;align-items:center;text-decoration:none;color:inherit}
.ex .ei{width:40px;height:40px;border-radius:11px;flex:none;display:grid;place-items:center}
.ex.mp .ei{background:#ede4ff;color:var(--violet)}
.ex.rp .ei{background:var(--tint);color:var(--green-d)}
.ex .et{font-family:var(--fd);font-weight:600;font-size:15.5px}
.ex .ed{font-size:13px;color:var(--muted);margin-top:1px}

/* ===================== LANDING ===================== */
.hero{min-height:calc(100svh - 58px);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;position:relative;overflow:hidden;padding:30px 0 74px}
.hero::before{content:"";position:absolute;inset:-10% -20%;z-index:0;pointer-events:none;background:radial-gradient(48% 42% at 50% 22%,rgba(16,185,129,.22),transparent 66%),radial-gradient(40% 32% at 11% 80%,rgba(124,77,219,.13),transparent 70%),radial-gradient(42% 34% at 90% 74%,rgba(30,95,214,.12),transparent 70%)}
.hero>*{position:relative;z-index:1}
.hero-in{max-width:760px;margin:0 auto;padding:0 22px}
.kick{font-family:var(--fd);font-size:12.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--green-d);display:inline-flex;align-items:center;gap:10px}
.kick .dots{display:inline-flex;gap:5px}
.kick .dots i{width:8px;height:8px;border-radius:50%}
.kick .dots i:nth-child(1){background:var(--green)} .kick .dots i:nth-child(2){background:var(--blue)} .kick .dots i:nth-child(3){background:var(--violet)} .kick .dots i:nth-child(4){background:var(--amber)} .kick .dots i:nth-child(5){background:var(--rose)}
.hero h1{font-family:var(--fd);font-weight:700;font-size:clamp(46px,9.2vw,84px);line-height:.97;letter-spacing:-.045em;margin:18px auto 0;max-width:14ch;text-wrap:balance}
.hero h1 mark{background:none;font-style:italic;color:var(--green-d);text-decoration:underline;text-decoration-color:var(--green);text-decoration-thickness:3px;text-underline-offset:9px}
.hero .sub{font-size:19px;color:var(--soft);margin:20px auto 0;max-width:44ch}
.btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:32px}
.ghost{display:inline-flex;align-items:center;font-family:var(--fd);font-weight:600;font-size:16px;color:var(--ink);background:none;border:1.5px solid #cdd9d2;border-radius:13px;padding:15px 22px;text-decoration:none;transition:border-color .15s}
.ghost:hover{border-color:var(--ink)}
.micro{margin-top:16px;font-size:13.5px;color:var(--muted)}
.cue{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:6px;color:var(--muted);font-size:11.5px;font-family:var(--fd);letter-spacing:.12em;text-transform:uppercase}
.cue svg{animation:bob 1.8s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(5px)}}
.sec{padding:56px 0;border-top:1px solid var(--line)}
.sec .eyb{font-family:var(--fd);font-size:11.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--green-d)}
.sec h2{font-family:var(--fd);font-weight:700;font-size:clamp(26px,4.4vw,34px);letter-spacing:-.025em;margin:10px 0 0;text-wrap:balance}
.sec .p{font-size:18px;color:var(--soft);margin:12px 0 0;max-width:52ch}
.pills{margin-top:22px;display:flex;gap:10px;flex-wrap:wrap}
.pill{font-family:var(--fd);font-weight:600;font-size:14px;background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:9px 16px;box-shadow:var(--sh);display:flex;align-items:center;gap:8px}
.ulist{margin-top:22px;display:flex;flex-direction:column;gap:12px}
.ul{display:flex;gap:16px;align-items:baseline;background:var(--surface);border:1px solid var(--line);border-left-width:4px;border-radius:14px;padding:16px 20px;box-shadow:var(--sh)}
.ul .no{font-family:var(--fd);font-weight:700;font-size:13px;flex:none;width:18px;font-variant-numeric:tabular-nums}
.ul .tt{font-family:var(--fd);font-weight:600;font-size:17px}
.ul .dd{font-size:14.5px;color:var(--muted);margin-top:2px}
.ul.k1{border-left-color:var(--green)} .ul.k1 .no{color:var(--green-d)}
.ul.k2{border-left-color:var(--blue)} .ul.k2 .no{color:var(--blue)}
.ul.k3{border-left-color:var(--violet)} .ul.k3 .no{color:var(--violet)}
.ul.k4{border-left-color:var(--amber)} .ul.k4 .no{color:var(--amber)}
.ul.k5{border-left-color:var(--rose)} .ul.k5 .no{color:var(--rose)}
.pillars{margin-top:22px;display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
@media(max-width:640px){.pillars{grid-template-columns:1fr 1fr}}
.pl{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:18px 16px;box-shadow:var(--sh)}
.pl .pt{font-family:var(--fd);font-weight:600;font-size:15.5px}
.pl .pd{font-size:13px;color:var(--muted);margin-top:3px;line-height:1.45}
.howfoot{margin-top:16px;font-size:14.5px;color:var(--soft)}.howfoot b{color:var(--ink);font-weight:600}
.stance{display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.stance .ss{font-family:var(--fd);font-weight:700;font-size:clamp(20px,3.4vw,26px);letter-spacing:-.02em}
.stance .ss b{color:var(--green-d)}
.stance .more{margin-left:auto;font-family:var(--fd);font-weight:600;font-size:14.5px;color:var(--green-d);text-decoration:none;white-space:nowrap}
.band{margin:56px 0 0;background:var(--ink);color:#eafaf2;border-radius:20px;padding:38px 30px;text-align:center;box-shadow:7px 7px 0 var(--green)}
.band h3{font-family:var(--fd);font-weight:700;font-size:clamp(24px,4vw,32px);letter-spacing:-.02em;margin:0;text-wrap:balance}
.band p{color:#9fc7b6;margin:8px 0 0;font-size:15.5px}
.band .cta{background:#fff;color:var(--ink);box-shadow:none;margin-top:20px}
.band .cta:hover{box-shadow:none;transform:translateY(-1px)}

/* ===================== ÜBER MICH ===================== */
.ahero{padding:52px 0 30px;display:flex;gap:26px;align-items:center;flex-wrap:wrap}
.av{width:108px;height:108px;border-radius:24px;flex:none;object-fit:cover;box-shadow:5px 6px 0 var(--navy)}
.ahero .eyb{font-family:var(--fd);font-size:12px;font-weight:600;letter-spacing:.13em;text-transform:uppercase;color:var(--green-d)}
.ahero h1{font-family:var(--fd);font-weight:700;font-size:clamp(32px,6vw,46px);line-height:1.02;letter-spacing:-.03em;margin:8px 0 0}
.ahero .one{font-size:18px;color:var(--soft);margin:10px 0 0;max-width:30ch}
.chips{margin-top:14px;display:flex;gap:8px;flex-wrap:wrap}
.chip{font-family:var(--fd);font-weight:600;font-size:12px;padding:6px 12px;border-radius:999px;border:1px solid var(--line);background:var(--surface)}
.chip.b{color:var(--blue);border-color:#cdddff} .chip.v{color:var(--violet);border-color:#e0d4fb} .chip.a{color:var(--amber);border-color:#ecd9b0} .chip.g{color:var(--green-d);border-color:#bfe9d6}
.story{padding:8px 0 8px}
.story p{margin:0 0 16px;color:var(--soft)}.story p b{color:var(--ink);font-weight:600}
.quote{margin:26px 0;background:var(--ink);color:#eafaf2;border-radius:18px;padding:24px 26px;box-shadow:7px 7px 0 var(--green)}
.quote .q{font-family:var(--fd);font-weight:600;font-size:22px;line-height:1.3;letter-spacing:-.01em}
.quote .qs{font-size:13.5px;color:#9fc7b6;margin-top:8px}
.builds{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:14px}
@media(max-width:560px){.builds{grid-template-columns:1fr}}
.bld{background:var(--surface);border:1px solid var(--line);border-left-width:4px;border-radius:14px;padding:18px;box-shadow:var(--sh)}
.bld.g{border-left-color:var(--green)} .bld.b{border-left-color:var(--blue)}
.bld .bt{font-family:var(--fd);font-weight:700;font-size:17px}
.bld .bd{font-size:14px;color:var(--muted);margin-top:5px;line-height:1.5}
.bld .blk{margin-top:10px;font-family:var(--fd);font-weight:600;font-size:13px;text-decoration:none;display:inline-block}
.bld.g .blk{color:var(--green-d)} .bld.b .blk{color:var(--blue)}
.contact{margin-top:30px;background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:20px 22px;box-shadow:var(--sh);display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.contact .ct{font-family:var(--fd);font-weight:600;font-size:16px}
.contact .cd{font-size:14px;color:var(--muted)}
.contact .cb{margin-left:auto;font-family:var(--fd);font-weight:600;font-size:14.5px;background:var(--ink);color:#fff;border-radius:11px;padding:11px 18px;text-decoration:none}
