:root{
  --or:#3b82f6; --or2:#2563eb; --or3:#60a5fa;
  --bg:#07070c; --s1:#0d0d13; --s2:#13131a; --s3:#1a1a22; --s4:#25252f; --s5:#32323e; --s6:#42424f;
  --t0:#eeeef5; --t1:#b8b8d0; --t2:#7a7a96;
  --gr:#22c55e; --rd:#ef4444; --yw:#eab308;
  --fn:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
  --mono:'JetBrains Mono','Fira Code',Menlo,monospace;
  --serif:'Playfair Display',Georgia,serif;
  --fs-2xs:10.5px; --fs-xs:12px; --fs-sm:13.5px; --fs-base:15px; --fs-md:16.5px; --fs-lg:21px; --fs-xl:34px; --fs-2xl:46px;
  --lh-ui:1.6; --lh-text:1.9;
  --ls-tight:-.4px; --ls-normal:0; --ls-caps:1.5px;
  --fw-normal:400; --fw-medium:500; --fw-semibold:600; --fw-bold:700; --fw-black:800;
  --rad:16px; --rad-sm:10px; --rad-xs:7px; --rad-pill:100px;
  --border:1px solid var(--s4); --border-strong:1px solid var(--s5);
  --shadow:0 1px 4px rgba(0,0,0,.55),0 6px 20px rgba(0,0,0,.3),0 0 0 1px rgba(255,255,255,.03);
  --shadow-sm:0 1px 2px rgba(0,0,0,.4),0 3px 10px rgba(0,0,0,.22);
  --shadow-focus:0 0 0 3px rgba(59,130,246,.28);
  --tf:.12s ease; --tm:.20s ease; --ts:.30s cubic-bezier(.22,1,.36,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{font-family:var(--fn);font-size:var(--fs-base);color:var(--t0);background:var(--bg);line-height:var(--lh-text);min-height:100vh;overflow-x:hidden;color-scheme:dark;letter-spacing:.01em}
body::before{content:'';position:fixed;inset:0;pointer-events:none;z-index:0;background:radial-gradient(ellipse 70% 28% at 50% -4%,rgba(59,130,246,.06) 0%,transparent 72%)}
::selection{background:rgba(59,130,246,.2);color:#fff}
:focus-visible{outline:2px solid rgba(59,130,246,.65);outline-offset:3px;border-radius:var(--rad-xs)}
::-webkit-scrollbar{width:7px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--s5);border-radius:4px;border:1px solid var(--s3)}
::-webkit-scrollbar-thumb:hover{background:var(--s6)}
.wrap{max-width:1180px;margin:0 auto;padding:48px 64px 80px;position:relative;z-index:1}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.hdr{text-align:center;margin-bottom:40px;padding-bottom:32px;border-bottom:var(--border)}
.hdr-badge{display:inline-flex;align-items:center;gap:8px;border:var(--border);padding:6px 16px;border-radius:var(--rad-pill);font-size:var(--fs-2xs);font-weight:var(--fw-semibold);color:var(--t2);letter-spacing:1.8px;text-transform:uppercase;margin-bottom:22px;border-color:var(--s5)}
.hdr-badge .dot{width:6px;height:6px;border-radius:50%;background:var(--gr);flex-shrink:0;box-shadow:0 0 8px var(--gr),0 0 16px rgba(34,197,94,.3);animation:blink 2.8s ease-in-out infinite}
.hdr-logo{font-family:var(--serif);font-size:var(--fs-2xl);font-weight:var(--fw-black);letter-spacing:-2px;color:var(--t0);margin:0 0 12px;line-height:1.05}
.hdr-logo span{color:var(--or)}
.hdr-sub{font-size:var(--fs-sm);color:var(--t2);line-height:1.6;display:block;max-width:560px;margin:0 auto}
.card{background:var(--s1);border:var(--border);border-radius:var(--rad);padding:28px 36px;margin-bottom:14px;box-shadow:var(--shadow);transition:border-color var(--tm),box-shadow var(--tm);border-color:var(--s3)}
.card:hover{border-color:var(--s5);box-shadow:var(--shadow),0 6px 24px rgba(0,0,0,.22)}
.card-param{background:rgba(7,7,12,.7);border-color:var(--s3)}
.card-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;gap:12px;flex-wrap:wrap}
.card-label{font-size:10px;font-weight:var(--fw-semibold);color:var(--t2);letter-spacing:1.8px;text-transform:uppercase}
.card-label-line{display:flex;align-items:center;gap:10px;font-size:10px;font-weight:var(--fw-semibold);color:var(--t2);letter-spacing:1.8px;text-transform:uppercase;margin-bottom:18px}
.card-label-line::after{content:'';flex:1;height:1px;background:var(--s4)}
.sec-hd{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.sec-hd::after{content:'';flex:1;height:1px;background:var(--s4)}
.sec-hd-icon{width:28px;height:28px;border-radius:7px;background:var(--s3);border:var(--border);display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;border-color:var(--s4)}
.sec-hd-text{flex:1}
.sec-hd-title{font-size:10.5px;font-weight:var(--fw-semibold);color:var(--t2);letter-spacing:1.8px;text-transform:uppercase}
.sec-hd-sub{font-size:11px;color:var(--t2);margin-top:3px}
.inputs{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.ig{position:relative;min-width:0}
.ig.full{grid-column:1/-1}
.ig label{display:flex;align-items:center;gap:5px;font-size:10px;font-weight:var(--fw-semibold);color:var(--t2);letter-spacing:1.8px;text-transform:uppercase;margin-bottom:8px;transition:color var(--tf)}
.ig:focus-within label{color:var(--t1)}
.ig-icon{font-size:11px;opacity:.45;flex-shrink:0}
.ig input,.ig textarea{width:100%;background:var(--s2);border:var(--border);color:var(--t0);padding:13px 16px;font-family:var(--mono);font-size:var(--fs-base);font-weight:var(--fw-medium);outline:none;border-radius:var(--rad-xs);-webkit-appearance:none;transition:border-color var(--tf),background var(--tf);border-color:var(--s4);resize:vertical;line-height:1.6}
.ig textarea{min-height:80px;font-size:13px}
.ig input:hover:not(:focus),.ig textarea:hover:not(:focus){border-color:var(--s5)}
.ig input:focus,.ig textarea:focus{border-color:var(--or);background:var(--s3);box-shadow:var(--shadow-focus)}
.ig input::placeholder,.ig textarea::placeholder{color:var(--t2);font-family:var(--fn);font-size:var(--fs-sm);font-weight:var(--fw-normal)}
.input-hint{font-size:11px;color:var(--t2);margin-top:6px;line-height:1.5}
.btn-scan{width:100%;padding:15px 28px;margin-top:18px;min-height:52px;background:var(--or);color:#fff;border:none;border-radius:var(--rad-xs);font-family:var(--fn);font-size:12px;font-weight:var(--fw-bold);letter-spacing:1.8px;text-transform:uppercase;cursor:pointer;position:relative;overflow:hidden;transition:background var(--tf),opacity var(--tm),transform .14s ease,box-shadow var(--tf);box-shadow:0 2px 8px rgba(59,130,246,.25)}
.btn-scan:hover:not(:disabled){background:var(--or3);box-shadow:0 4px 16px rgba(59,130,246,.35)}
.btn-scan:active:not(:disabled){background:var(--or2);transform:scale(.978)}
.btn-scan:disabled{background:var(--s4);color:var(--t2);cursor:not-allowed;opacity:.48;transform:none!important}
.btn-prog-fill{position:absolute;inset:0;width:0%;background:linear-gradient(90deg,var(--or2) 0%,var(--or) 50%,var(--or3) 100%);transition:width .55s cubic-bezier(.4,0,.2,1);border-radius:var(--rad-xs);pointer-events:none;opacity:0}
.btn-scan.btn-scanning .btn-prog-fill{opacity:1}
.btn-t{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;width:100%}
.btn-reset{background:none;border:var(--border);color:var(--t2);font-family:var(--fn);font-size:10px;font-weight:var(--fw-semibold);letter-spacing:1.6px;text-transform:uppercase;padding:6px 12px;border-radius:var(--rad-xs);cursor:pointer;transition:border-color var(--tf),color var(--tf),background var(--tf);min-height:34px;border-color:var(--s4)}
.btn-reset:hover{border-color:rgba(239,68,68,.4);color:var(--rd);background:rgba(239,68,68,.04)}
.ls-badge{font-size:10.5px;color:var(--t2);border:var(--border);border-radius:var(--rad-pill);padding:3px 10px;font-weight:var(--fw-medium)}
.ls-badge.warn{color:var(--yw);border-color:rgba(234,179,8,.3)}
.ls-badge.err{color:var(--rd);border-color:rgba(239,68,68,.3)}
.ls-badge.ok{color:var(--gr);border-color:rgba(34,197,94,.3)}
.api-toggle{display:flex;align-items:center;justify-content:space-between;cursor:pointer;user-select:none;min-height:44px;padding:4px 0}
.api-toggle-icon{font-size:10px;color:var(--t2);transition:transform .2s ease}
.api-toggle.open .api-toggle-icon{transform:rotate(180deg)}
#slogWrap{overflow:hidden;transition:max-height .28s ease,opacity .22s ease;max-height:0;opacity:0}
#slogWrap.open{max-height:600px;opacity:1;overflow-y:auto}
/* Generische Collapsible-Mechanik (Konfiguration, Layer-2/3-Details, Fazit) */
.collapse-hd{display:flex;align-items:center;justify-content:space-between;cursor:pointer;user-select:none;min-height:40px;padding:6px 0}
.collapse-hd-label{display:flex;align-items:center;gap:7px;font-size:10px;font-weight:var(--fw-semibold);color:var(--t2);letter-spacing:1.6px;text-transform:uppercase}
.collapse-icon{font-size:10px;color:var(--t2);transition:transform .25s ease;flex-shrink:0}
.collapse-hd.open .collapse-icon{transform:rotate(180deg)}
.collapse-body{overflow:hidden;transition:max-height .3s ease,opacity .22s ease;max-height:0;opacity:0}
.collapse-body.open{max-height:20000px;opacity:1;overflow:visible}
.collapse-hint{font-size:10px;color:var(--t3);font-weight:400;letter-spacing:.3px;text-transform:none;margin-left:4px}
.slog{font-family:var(--mono);font-size:11.5px;line-height:1.8;color:var(--t2);padding:10px 0}
.sl{display:grid;grid-template-columns:18px 1fr;gap:5px;align-items:baseline;padding:1px 0}
.ok{color:var(--gr)}
.er{color:var(--rd)}
.ld{color:var(--yw)}
.sk{color:var(--t2)}
.api-chip{font-size:10.5px;color:var(--t2);margin-left:7px;font-family:var(--mono);border:var(--border);border-radius:var(--rad-pill);padding:2px 9px}
.spacer-16{height:14px}

/* Top-3 Aktien Tabelle */
.top3-wrap{display:flex;flex-direction:column;gap:10px}
.aktie-row{display:grid;grid-template-columns:36px 1fr auto auto;gap:14px;padding:18px 22px;background:var(--s2);border:var(--border);border-radius:var(--rad-sm);align-items:center;border-color:var(--s3);cursor:pointer;transition:border-color var(--tf),background var(--tf),transform var(--tf)}
.aktie-row:hover{border-color:var(--s5);background:var(--s3);transform:translateY(-1px)}
.aktie-row.top1{border-color:rgba(59,130,246,.35);background:linear-gradient(180deg,rgba(59,130,246,.05),var(--s2))}
.aktie-row.expanded{border-color:var(--or);background:var(--s3)}
.aktie-rank{font-family:var(--serif);font-size:24px;font-weight:var(--fw-black);color:var(--t2);text-align:center;width:36px;line-height:1}
.aktie-row.top1 .aktie-rank{color:var(--or)}
.aktie-info{display:flex;flex-direction:column;gap:3px;min-width:0}
.aktie-ticker{font-family:var(--mono);font-size:var(--fs-md);font-weight:var(--fw-bold);color:var(--t0);letter-spacing:-.3px}
.aktie-name{font-size:11.5px;color:var(--t2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:380px}
.aktie-score-wrap{display:flex;flex-direction:column;align-items:flex-end;gap:2px;min-width:80px}
.aktie-score{font-family:var(--mono);font-size:20px;font-weight:var(--fw-bold);color:var(--t0);letter-spacing:-.4px}
.aktie-score.s-bull{color:var(--gr)}
.aktie-score.s-neut{color:var(--yw)}
.aktie-score.s-bear{color:var(--rd)}
.aktie-rating{font-size:9px;font-weight:var(--fw-semibold);letter-spacing:1.4px;text-transform:uppercase;color:var(--t2)}
.aktie-sector{font-size:9.5px;font-weight:var(--fw-semibold);letter-spacing:1px;text-transform:uppercase;color:var(--t2);background:var(--s3);border:var(--border);border-radius:var(--rad-pill);padding:3px 9px;white-space:nowrap}
.aktie-expand-icon{font-size:10px;color:var(--t2);transition:transform .2s ease}
.aktie-row.expanded .aktie-expand-icon{transform:rotate(180deg);color:var(--or)}
.aktie-detail-wrap{max-height:0;overflow:hidden;opacity:0;transition:max-height .35s ease,opacity .22s ease;padding:0 22px}
.aktie-detail-wrap.open{max-height:20000px;opacity:1}
.aktie-detail{padding:14px 0 4px;border-top:1px solid var(--s3);margin-top:4px}

/* Kategorien-Grid */
.kat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:12px}
.kat-tile{background:var(--s2);border:var(--border);border-radius:var(--rad-xs);padding:11px 14px;border-color:var(--s3);transition:border-color var(--tf)}
.kat-tile:hover{border-color:var(--s5)}
.kat-tile-hd{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;gap:6px}
.kat-tile-label{font-size:9.5px;font-weight:var(--fw-semibold);color:var(--t2);letter-spacing:1.2px;text-transform:uppercase;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.kat-tile-w{font-size:9px;font-family:var(--mono);color:var(--t2);padding:1px 6px;border-radius:var(--rad-pill);border:var(--border);border-color:var(--s4)}
.kat-tile-w.w-high{color:var(--or);border-color:rgba(59,130,246,.3)}
.kat-tile-val{display:flex;align-items:baseline;gap:6px}
.kat-tile-num{font-family:var(--mono);font-size:15px;font-weight:var(--fw-bold);letter-spacing:-.4px}
.kat-tile-num.v-bull{color:var(--gr)}
.kat-tile-num.v-neut{color:var(--yw)}
.kat-tile-num.v-bear{color:var(--rd)}
.kat-tile-pts{font-size:10px;color:var(--t2);font-family:var(--mono)}

/* Kennzahlen-Liste */
.kpi-list{display:flex;flex-direction:column;margin-top:14px}
.kpi-cat{margin-bottom:14px}
.kpi-cat-hd{display:flex;align-items:center;gap:10px;font-size:9.5px;font-weight:var(--fw-semibold);color:var(--t2);letter-spacing:1.6px;text-transform:uppercase;margin-bottom:6px;padding:0 4px}
.kpi-cat-hd::after{content:'';flex:1;height:1px;background:var(--s4)}
.kpi-cat-score{font-family:var(--mono);font-size:11px;font-weight:var(--fw-bold);padding:2px 8px;border-radius:var(--rad-pill);border:var(--border);letter-spacing:.3px}
.kpi-cat-score.bull{color:var(--gr);border-color:rgba(34,197,94,.25)}
.kpi-cat-score.neut{color:var(--yw);border-color:rgba(234,179,8,.25)}
.kpi-cat-score.bear{color:var(--rd);border-color:rgba(239,68,68,.25)}
.kpi-row{display:grid;grid-template-columns:1fr auto auto auto;gap:10px;padding:7px 8px;font-size:12.5px;border-bottom:1px solid var(--s3);align-items:center}
.kpi-row:last-child{border-bottom:none}
.kpi-name{color:var(--t1);font-size:12.5px}
.kpi-val{font-family:var(--mono);color:var(--t0);font-size:12.5px;text-align:right;min-width:80px}
.kpi-bench{font-size:10px;color:var(--t2);text-align:right;min-width:100px;font-family:var(--mono)}
.kpi-pts{font-family:var(--mono);font-size:11.5px;font-weight:var(--fw-bold);text-align:right;min-width:48px;padding:2px 7px;border-radius:var(--rad-xs)}
.kpi-pts.bull{background:rgba(34,197,94,.1);color:var(--gr)}
.kpi-pts.neut{background:rgba(234,179,8,.08);color:var(--yw)}
.kpi-pts.bear{background:rgba(239,68,68,.08);color:var(--rd)}
.kpi-pts.na{color:var(--t2);background:var(--s3)}

/* Score-Bar */
.score-bar-wrap{margin-top:24px;padding-top:20px;border-top:var(--border)}
.score-cols{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}
.score-col{background:var(--s2);border:var(--border);border-radius:var(--rad-sm);padding:20px 24px;border-color:var(--s3)}
.score-col-label{font-size:10px;font-weight:var(--fw-semibold);color:var(--t2);letter-spacing:1.8px;text-transform:uppercase;margin-bottom:10px}
.score-val{font-size:36px;font-weight:var(--fw-black);font-family:var(--mono);line-height:1;letter-spacing:-2px}
.score-val.sv-bull{color:var(--gr)}
.score-val.sv-bear{color:var(--rd)}
.score-val.sv-neut{color:var(--yw)}
.score-val.sv-or{color:var(--or)}
.score-note{font-size:12px;color:var(--t2);margin-left:6px;font-family:var(--mono)}
.score-col-hint{font-size:11px;color:var(--t2);margin-top:6px;line-height:1.5}

.bar-wrap{margin-top:16px;position:relative;padding-bottom:30px}
.bar-track{width:100%;height:14px;border-radius:var(--rad-pill);background:linear-gradient(180deg,var(--s4),var(--s3));position:relative;overflow:visible;box-shadow:inset 0 2px 8px rgba(0,0,0,.65)}
.bar-fill{height:100%;border-radius:var(--rad-pill);background:linear-gradient(90deg,#b91c1c 0%,#ef4444 14%,#f97316 27.5%,#eab308 45%,#84cc16 56%,#22c55e 72%,#10b981 86%,#059669 100%);width:0%;transition:width .7s cubic-bezier(.22,1,.36,1)}
.bar-needle{position:absolute;top:50%;transform:translate(-50%,-50%);width:20px;height:20px;border-radius:50%;background:radial-gradient(circle at 38% 35%,#fff 0%,#e8e8e8 55%,#c8c8c8 100%);z-index:5;box-shadow:0 0 0 1.5px rgba(59,130,246,.6),0 0 0 4px rgba(59,130,246,.15),0 3px 16px rgba(0,0,0,.8),0 0 20px rgba(59,130,246,.25);transition:left .6s var(--ts);left:50%}
.bar-needle-dot{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:5px;height:5px;border-radius:50%;background:var(--or);box-shadow:0 0 0 1px rgba(59,130,246,.4),0 0 8px rgba(59,130,246,.8)}
.bar-labels{display:flex;justify-content:space-between;margin-top:14px;font-size:10.5px;color:var(--t2);font-family:var(--mono)}

/* Sparrate-Stufe */
.stufe-card{text-align:center;padding:32px 36px;background:var(--s1);border:var(--border);border-radius:var(--rad);margin-bottom:14px;box-shadow:var(--shadow);border-color:var(--s3)}
.stufe-card.s-s1{border-color:rgba(239,68,68,.22)}
.stufe-card.s-s2{border-color:rgba(249,115,22,.22)}
.stufe-card.s-s3{border-color:rgba(234,179,8,.22)}
.stufe-card.s-s4{border-color:rgba(132,204,22,.22)}
.stufe-card.s-s5{border-color:rgba(34,197,94,.25)}
.stufe-card.s-s6{border-color:rgba(59,130,246,.30)}
.stufe-eyebrow{font-size:10px;font-weight:var(--fw-semibold);color:var(--t2);letter-spacing:1.8px;text-transform:uppercase;margin-bottom:10px}
.stufe-icon{font-size:38px;margin-bottom:10px;line-height:1}
.stufe-ticker-row{margin-bottom:12px;font-family:var(--mono);font-size:14px;color:var(--t1);letter-spacing:-.2px}
.stufe-ticker-row strong{color:var(--t0);font-size:16px;font-weight:var(--fw-bold)}
.stufe-label{font-size:10.5px;font-weight:var(--fw-semibold);color:var(--t2);letter-spacing:1.6px;text-transform:uppercase;margin-bottom:10px}
.stufe-eur{font-family:var(--serif);font-size:var(--fs-xl);font-weight:var(--fw-black);line-height:1.05;letter-spacing:-1.5px;color:var(--t0)}
.stufe-card.s-s1 .stufe-eur{color:#ef4444}
.stufe-card.s-s2 .stufe-eur{color:#f97316}
.stufe-card.s-s3 .stufe-eur{color:#eab308}
.stufe-card.s-s4 .stufe-eur{color:#84cc16}
.stufe-card.s-s5 .stufe-eur{color:#22c55e}
.stufe-card.s-s6 .stufe-eur{color:var(--or3)}
.stufe-eur-unit{font-family:var(--fn);font-size:var(--fs-xs);font-weight:var(--fw-medium);color:var(--t1);margin-left:5px}
.stufen-dots{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:18px}
.s-dot{width:36px;height:36px;border-radius:50%;background:var(--s3);border:var(--border);display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:11px;font-weight:700;color:var(--t2)}
.s-dot.active{background:var(--or);border-color:var(--or);color:#fff;transform:scale(1.15);box-shadow:0 0 0 4px rgba(59,130,246,.22)}
.s-dot.past{background:var(--s4);border-color:var(--s4);color:var(--t2)}
.s-dot-line{height:2px;background:var(--s4);max-width:24px;flex:1;border-radius:1px}
.s-dot-line.past{background:rgba(59,130,246,.35)}

/* Gewichtungs-Preset Banner (oben in Detail) */
.preset-banner{background:var(--s2);border:var(--border);border-radius:var(--rad-sm);padding:16px 20px;margin-bottom:16px;border-color:var(--s3)}
.preset-banner-hd{font-size:var(--fs-sm);color:var(--t1);line-height:1.6;margin-bottom:10px}
.preset-banner-hd strong{color:var(--t0);font-weight:var(--fw-bold)}
.preset-banner-hd .preset-emoji{font-size:14px;margin-right:4px}
.preset-chips{display:flex;flex-wrap:wrap;gap:5px;margin-top:8px}
.preset-chip{font-family:var(--mono);font-size:10px;color:var(--t2);background:var(--s3);border:var(--border);border-radius:5px;padding:3px 9px;letter-spacing:.3px;border-color:var(--s4);transition:color var(--tf),border-color var(--tf)}
.preset-chip.w-high{color:var(--or);border-color:rgba(59,130,246,.30);background:rgba(59,130,246,.06)}
.preset-chip.w-low{color:var(--t2);opacity:.7}

/* KPI-Detail (Expand on click) */
.kpi-row{cursor:pointer;border-left:3px solid transparent;transition:background var(--tf),border-left-color var(--tf),padding-left var(--tf)}
.kpi-row:hover{background:var(--s2);border-left-color:var(--s5);padding-left:14px}
.kpi-row.kpi-expanded{background:var(--s2);border-left-color:var(--or);padding-left:14px}
.kpi-row.kpi-expanded:hover{background:var(--s3)}
.kpi-detail-wrap{grid-column:1/-1;max-height:0;overflow:hidden;opacity:0;transition:max-height .28s ease,opacity .22s ease}
.kpi-detail-wrap.open{max-height:2000px;opacity:1}
.kpi-detail{padding:16px 20px;margin:6px 0 8px;background:var(--s2);border:var(--border);border-left:3px solid var(--or);border-radius:0 var(--rad-sm) var(--rad-sm) 0;font-size:var(--fs-sm);color:var(--t1);line-height:1.72}
.kpi-detail-section{margin-bottom:14px}
.kpi-detail-section:last-child{margin-bottom:0}
.kpi-detail-label{font-size:10px;font-weight:var(--fw-semibold);letter-spacing:1.6px;text-transform:uppercase;color:var(--t2);margin-bottom:5px;display:flex;align-items:center;gap:6px}
.kpi-detail-label-dot{width:8px;height:8px;border-radius:50%;display:inline-block}
.kpi-detail-label-dot.dot-bull{background:var(--gr);box-shadow:0 0 5px rgba(34,197,94,.5)}
.kpi-detail-label-dot.dot-bear{background:var(--rd);box-shadow:0 0 5px rgba(239,68,68,.5)}
.kpi-detail-text{font-size:13px;color:var(--t1);line-height:1.7}
.kpi-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px 22px;margin-top:6px}
.kpi-zones{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.kpi-zone{font-size:11px;font-weight:var(--fw-semibold);padding:4px 10px;border-radius:var(--rad-pill);letter-spacing:.2px;border:1px solid}
.kpi-zone.z-bull{background:rgba(34,197,94,.07);color:var(--gr);border-color:rgba(34,197,94,.25)}
.kpi-zone.z-neut{background:rgba(234,179,8,.07);color:var(--yw);border-color:rgba(234,179,8,.25)}
.kpi-zone.z-bear{background:rgba(239,68,68,.07);color:var(--rd);border-color:rgba(239,68,68,.25)}
.kpi-zone.z-current{box-shadow:0 0 0 2px rgba(59,130,246,.35);font-weight:var(--fw-bold)}
.kpi-expand-icon{font-size:9px;color:var(--t2);transition:transform .2s ease,color var(--tf);margin-left:6px}
.kpi-row.kpi-expanded .kpi-expand-icon{transform:rotate(180deg);color:var(--or)}
.kpi-row .kpi-name{display:flex;align-items:center;gap:6px}
.kpi-est-badge{font-size:8.5px;font-weight:var(--fw-semibold);color:var(--yw);background:rgba(234,179,8,.12);border:1px solid rgba(234,179,8,.3);border-radius:4px;padding:1px 5px;letter-spacing:.3px;white-space:nowrap;cursor:help}
.kpi-est-note{grid-column:1/-1;font-size:10px;color:var(--yw);padding:2px 8px 6px;line-height:1.5}

/* Fazit */
.fazit-card{background:var(--s1);border:var(--border);border-radius:var(--rad);padding:28px 36px;margin-bottom:14px;box-shadow:var(--shadow);border-color:var(--s3)}
.fazit-card.fc-bull{border-color:rgba(34,197,94,.28)}
.fazit-card.fc-neut{border-color:rgba(234,179,8,.28)}
.fazit-card.fc-bear{border-color:rgba(239,68,68,.28)}
.fazit-action-banner{display:flex;align-items:flex-start;gap:12px;background:var(--s2);border:1px solid var(--s3);border-left:3px solid var(--or);border-radius:var(--rad-xs);padding:14px 18px;margin-bottom:20px}
.fazit-action-icon{font-size:17px;flex-shrink:0;margin-top:1px}
.fazit-action-text{font-size:var(--fs-sm);color:var(--t1);line-height:1.65}
.fazit-action-text strong{color:var(--t0);font-weight:var(--fw-bold)}
.fazit-section-lbl{margin-top:22px;margin-bottom:10px;display:flex;align-items:center;gap:8px;font-size:10px;font-weight:var(--fw-semibold);letter-spacing:1.8px;text-transform:uppercase;color:var(--t2)}
.fazit-section-lbl::after{content:'';flex:1;height:1px;background:var(--s4)}
.fazit-text{font-size:var(--fs-base);line-height:1.92;color:var(--t1)}
.fazit-text strong{color:var(--t0)}
.fazit-einordnung{font-size:var(--fs-sm);color:var(--t1);line-height:1.78;background:var(--s2);border:1px solid var(--s4);border-left:3px solid var(--s5);padding:14px 18px;border-radius:0 var(--rad-xs) var(--rad-xs) 0}
.fazit-checklist{display:flex;flex-direction:column;gap:6px}
.fazit-check-item{display:flex;align-items:flex-start;gap:10px;font-size:var(--fs-sm);color:var(--t1);line-height:1.65;padding:10px 15px;border-radius:var(--rad-xs);background:var(--s2);border:var(--border);border-color:var(--s3)}
.fazit-check-icon{font-size:13px;flex-shrink:0;margin-top:1px}
.fazit-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:20px;padding-top:16px;border-top:var(--border)}
.fazit-tag{font-size:10px;letter-spacing:1.4px;text-transform:uppercase;font-weight:var(--fw-semibold);padding:4px 10px;border-radius:var(--rad-pill);color:var(--t2);background:var(--s2);border:var(--border)}
.fazit-tag.positive{color:var(--gr);border-color:rgba(34,197,94,.18)}
.fazit-tag.negative{color:var(--rd);border-color:rgba(239,68,68,.18)}
.fazit-tag.neutral{color:var(--t1)}

/* Watchlist Manager */
.wl-grid{display:flex;flex-wrap:wrap;gap:6px;padding:8px 0;min-height:32px}
.wl-chip{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:11.5px;font-weight:var(--fw-semibold);color:var(--t1);background:var(--s2);border:var(--border);border-radius:var(--rad-pill);padding:5px 10px 5px 12px;border-color:var(--s4);transition:border-color var(--tf)}
.wl-chip:hover{border-color:var(--s5)}
.wl-chip-x{cursor:pointer;color:var(--t2);font-size:14px;line-height:1;padding:0 2px;transition:color var(--tf)}
.wl-chip-x:hover{color:var(--rd)}
.wl-empty{font-size:11.5px;color:var(--t2);font-style:italic;padding:4px 0}

/* Toast & Misc */
#toast{position:fixed;bottom:28px;left:50%;transform:translateX(-50%) translateY(18px);background:var(--s2);border:var(--border);color:var(--t0);font-size:var(--fs-sm);font-weight:var(--fw-semibold);padding:10px 20px;border-radius:var(--rad-pill);box-shadow:0 4px 20px rgba(0,0,0,.55);opacity:0;pointer-events:none;white-space:nowrap;z-index:9999;transition:opacity .22s ease,transform .22s var(--ts)}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
#toast.toast-ok{border-color:rgba(34,197,94,.25);color:var(--gr)}
#toast.toast-warn{border-color:rgba(234,179,8,.22);color:var(--yw)}
#toast.toast-err{border-color:rgba(239,68,68,.22);color:var(--rd)}
.result-intro{display:flex;align-items:center;gap:8px;padding:11px 14px;background:var(--s2);border:var(--border);border-radius:var(--rad-xs);margin-bottom:14px;font-size:12px;color:var(--t2);border-color:var(--s3)}
.result-intro-dot{width:6px;height:6px;border-radius:50%;background:var(--gr);animation:blink 2.6s ease-in-out infinite}
.skip-banner{background:var(--s1);border:var(--border);border-left:3px solid var(--yw);border-radius:var(--rad-sm);padding:14px 20px;margin-bottom:14px;font-size:var(--fs-sm);color:var(--t1);line-height:1.6;border-color:var(--s3);border-left-color:var(--yw)}
.skip-banner-hd{display:flex;align-items:center;gap:8px;font-size:10.5px;font-weight:var(--fw-semibold);color:var(--yw);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:8px}
.skip-banner-hd-icon{font-size:14px}
.skip-banner-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.skip-banner-chip{font-family:var(--mono);font-size:11px;font-weight:var(--fw-semibold);color:var(--t1);background:var(--s2);border:var(--border);border-radius:var(--rad-pill);padding:3px 10px;border-color:var(--s4)}
.skip-banner-chip.premium{color:var(--yw);border-color:rgba(234,179,8,.32)}
.skip-banner-chip.incomplete{color:#f97316;border-color:rgba(249,115,22,.32)}
.skip-banner-chip.error{color:var(--rd);border-color:rgba(239,68,68,.32)}
.skip-banner-hint{font-size:11.5px;color:var(--t2);margin-top:10px;line-height:1.65}
.foot{max-width:1180px;margin:0 auto;padding:16px 64px 28px;border-top:1px solid var(--s3);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;font-size:10px;color:var(--t2);letter-spacing:1.6px;text-transform:uppercase}
.foot-item{transition:color .18s}
.foot-item:hover{color:var(--t1)}
.foot-disclaimer{font-size:11px;color:var(--t2);letter-spacing:0;text-transform:none;line-height:1.6;flex-basis:100%;margin-top:8px}
.fade-in{animation:fadeUp .38s ease both}
.flex-gap-8{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.api-key-row{display:flex;gap:10px;align-items:flex-end}
.api-key-row .ig{flex:1}
.provider-tabs{display:flex;gap:8px;background:var(--s2);border:var(--border);border-color:var(--s3);padding:4px;border-radius:var(--rad-sm)}
.provider-tab{flex:1;display:flex;flex-direction:column;align-items:flex-start;gap:2px;background:transparent;border:none;color:var(--t2);padding:9px 14px;border-radius:var(--rad-xs);cursor:pointer;text-align:left;transition:background var(--tf),color var(--tf);font-family:var(--fn);min-height:54px}
.provider-tab:hover{background:var(--s3);color:var(--t1)}
.provider-tab.active{background:rgba(59,130,246,.12);color:var(--t0)}
.provider-tab.active .provider-tab-label{color:var(--or)}
.provider-tab-icon{font-size:14px;line-height:1;margin-bottom:1px}
.provider-tab-label{font-size:13px;font-weight:var(--fw-bold);letter-spacing:.2px}
.provider-tab-hint{font-size:10px;color:var(--t2);font-family:var(--mono);font-weight:var(--fw-medium)}
.btn-action{background:var(--s2);border:var(--border);color:var(--t1);font-family:var(--fn);font-size:10px;font-weight:var(--fw-semibold);letter-spacing:1.6px;text-transform:uppercase;padding:10px 18px;border-radius:var(--rad-xs);cursor:pointer;display:inline-flex;align-items:center;gap:7px;transition:border-color var(--tf),color var(--tf),background var(--tf);min-height:42px;border-color:var(--s4)}
.btn-action:hover{border-color:rgba(59,130,246,.4);color:var(--or);background:rgba(59,130,246,.05)}
.btn-action-bar{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap}

@keyframes blink{0%,100%{opacity:1}50%{opacity:.35}}
@keyframes fadeUp{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}

@media (max-width:900px){
  .wrap{padding:32px 24px 60px}
  .foot{padding:16px 24px 28px}
  .card,.fazit-card,.stufe-card{padding:22px 22px}
  .inputs{grid-template-columns:1fr}
  .kat-grid{grid-template-columns:repeat(2,1fr)}
  .score-cols{grid-template-columns:1fr}
  .aktie-row{grid-template-columns:30px 1fr auto;gap:10px;padding:14px 16px}
  .aktie-sector{display:none}
  .aktie-name{max-width:200px}
  .kpi-row{grid-template-columns:1fr auto auto;font-size:11.5px}
  .kpi-bench{display:none}
  .kpi-detail-grid{grid-template-columns:1fr}
  .hdr-logo{font-size:32px}
}
@media (max-width:520px){
  .wrap{padding:20px 14px 48px}
  .kat-grid{grid-template-columns:1fr}
  .api-key-row{flex-direction:column;align-items:stretch}
  .provider-tabs{flex-direction:column}
  .s-dot{width:30px;height:30px;font-size:10px}
}
@media print{
  .btn-scan,.btn-reset,.btn-action,.btn-action-bar,.api-toggle,#slogWrap,#toast,.collapse-icon{display:none!important}
  body{background:#fff!important;color:#000!important}
  body::before{display:none!important}
  .card,.fazit-card,.stufe-card{border:1px solid #ccc!important;break-inside:avoid}
  /* Eingeklappte Bereiche beim Drucken immer vollständig zeigen */
  .collapse-body{max-height:none!important;opacity:1!important;overflow:visible!important}
}
