/* Simulation module (concept §9, VORSCHAU-Simulation-v2): hero verdict + ACS, ranking, tiles → fullscreen.
   Tokens-only (FINLIST003). Global (not scoped) so injected SVG equity curves are styled (Blazor pitfall). */

/* page fills the content area (between the sidebars) as a flex column: content scrolls above,
   the tile row docks at the very bottom. padding-bottom = 32px keeps it ABOVE the fixed LogPanel. */
.sim-page { display: flex; flex-direction: column; flex: 1 1 auto; min-height: 0; padding-bottom: 32px; }
.sim-scroll { flex: 1 1 auto; min-height: 0; overflow-y: auto; padding: 18px 22px; }
.sim-det-bar { margin: 2px 0 10px; }
.sim-select { background: var(--fn-bg-muted); border: 1px solid var(--fn-border-strong); border-radius: 8px;
    padding: 7px 11px; font-size: 13px; color: var(--fn-text); min-width: 280px; }
.sim-add { align-self: flex-end; background: var(--fn-bg-muted); border: 1px solid var(--fn-border-strong);
    color: var(--fn-text); border-radius: 8px; padding: 8px 13px; font-size: 12.5px; cursor: pointer; }
.sim-add:hover:not(:disabled) { border-color: var(--fn-primary); color: var(--fn-primary); }
.sim-add:disabled { opacity: .5; cursor: default; }
.sim-chips { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 9px; }
.sim-chip { display: inline-flex; align-items: center; gap: 7px; font-size: 12px; color: var(--fn-text);
    background: var(--fn-accent-soft); border: 1px solid var(--fn-primary); border-radius: var(--fn-radius-pill); padding: 3px 6px 3px 11px; }
.sim-chip button { border: none; background: none; color: var(--fn-text-secondary); cursor: pointer; font-size: 12px; line-height: 1; padding: 0 2px; }
.sim-chip button:hover { color: var(--fn-danger); }
.sim-fail { background: var(--fn-warning-soft); border: 1px solid var(--fn-warning); border-radius: 11px;
    padding: 13px 16px; font-size: 13px; color: var(--fn-text); margin-top: 10px; }
.sim-box { background: var(--fn-bg-muted); border: 1px solid var(--fn-border-strong); border-radius: 8px;
    padding: 7px 11px; font-size: 13px; color: var(--fn-text); min-width: 240px; }

/* strategy chips (1:1 v2 Vorgabe bar) */
.sim-fld-strats { flex: 1 1 auto; }
.sim-chips-strat { display: flex; gap: 6px; flex-wrap: wrap; }
.sim-chip-strat { font-size: 11.5px; border: 1px solid var(--fn-border-strong); color: var(--fn-text-secondary);
    border-radius: var(--fn-radius-pill); padding: 5px 11px; cursor: pointer; user-select: none; }
.sim-chip-strat.on { border-color: var(--fn-primary); color: var(--fn-primary); background: var(--fn-accent-soft); }
.sim-chip-strat.off { opacity: .45; cursor: not-allowed; }

.sim-win-row td { background: var(--fn-success-soft); }
.sim-tile-open { font-size: 10.5px; color: var(--fn-primary); margin-top: 8px; }

/* real fullscreen takeover (like Quant) */
/* B1: detail = inline panel inside .sim-page, never a fixed overlay covering the sidebars (like v2 .full) */
.sim-fs { background: var(--fn-bg-alt); border: 1px solid var(--fn-primary); border-radius: 16px;
    overflow: hidden; margin-top: 14px; }
.sim-fs .sim-fs-answer { padding: 16px 20px; }
.sim-full-bar .x { margin-left: auto; color: var(--fn-text-tertiary); font-size: 12px; background: none; border: none; cursor: pointer; }
.sim-full-bar .x:hover { color: var(--fn-primary); }

/* walk-forward windows (12 dots) */
.sim-wf { display: flex; gap: 4px; margin: 4px 0; }
.sim-wf span { flex: 1; height: 16px; border-radius: 3px; }
.sim-wf .g { background: var(--fn-success); }
.sim-wf .r { background: var(--fn-danger); opacity: .7; }

/* filmstrip of the other runs (bottom of fullscreen) */
.sim-strip { display: flex; gap: 8px; overflow: auto; padding: 11px 15px; border-top: 1px solid var(--fn-border); background: var(--fn-bg-muted); }
.sim-strip .f { flex: 0 0 auto; background: var(--fn-bg); border: 1px solid var(--fn-border); border-radius: 8px;
    padding: 7px 11px; font-size: 11px; color: var(--fn-text-secondary); min-width: 150px; cursor: pointer; text-align: left; }
.sim-strip .f.cur { border-color: var(--fn-primary); }
.sim-strip .f b { display: block; color: var(--fn-text); font-size: 11.5px; margin-bottom: 1px; }
.sim-head h1 { font-size: 21px; display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.sim-eyebrow { font-size: 11px; font-weight: 700; border: 1px solid var(--fn-primary); color: var(--fn-primary);
    border-radius: var(--fn-radius-pill); padding: 2px 10px; }
.sim-info-btn { font-size: 12px; font-weight: 700; border: 1px solid var(--fn-primary); color: var(--fn-primary);
    background: var(--fn-accent-soft); border-radius: var(--fn-radius-pill); padding: 4px 12px; cursor: pointer; margin-left: 6px; }
.sim-info-btn:hover { background: var(--fn-primary); color: var(--fn-on-primary); }

/* ACS colour scale under the hero bar + empty state */
.sim-acs-scale { display: flex; justify-content: space-between; gap: 6px; margin-top: 6px; font-size: 10px; color: var(--fn-text-tertiary); }
.sim-acs-scale span { display: inline-flex; align-items: center; gap: 4px; }
.sw { display: inline-block; width: 10px; height: 10px; border-radius: 3px; }
.sw.r { background: var(--fn-danger); } .sw.o { background: var(--fn-warning); opacity: .8; }
.sw.y { background: var(--fn-warning); } .sw.g { background: var(--fn-success); }
.sim-acs-empty { display: flex; flex-direction: column; gap: 8px; align-items: flex-start; }
.sim-acs-empty-txt { font-size: 13px; color: var(--fn-text-secondary); }
.sim-info-link { font-size: 12px; font-weight: 700; border: 1px solid var(--fn-primary); color: var(--fn-primary);
    background: var(--fn-accent-soft); border-radius: 8px; padding: 5px 12px; cursor: pointer; }

/* Info overlay (rich help) */
.sim-info { position: fixed; inset: 24px; z-index: 1001; background: var(--fn-bg-alt); border: 1px solid var(--fn-primary);
    border-radius: 16px; display: flex; flex-direction: column; overflow: hidden; box-shadow: 0 20px 60px var(--fn-shadow-hover); }
.sim-info-body { flex: 1 1 auto; overflow: auto; padding: 20px 26px; max-width: 920px; }
.sim-info-body h3 { font-size: 15px; margin: 22px 0 8px; color: var(--fn-text); border-bottom: 1px solid var(--fn-border); padding-bottom: 6px; }
.sim-info-body p { font-size: 13.5px; color: var(--fn-text-secondary); line-height: 1.6; }
.sim-info-lead { font-size: 14px; color: var(--fn-text); background: var(--fn-bg-muted); border-left: 3px solid var(--fn-primary);
    border-radius: 10px; padding: 13px 16px; }
.sim-info-dl { display: grid; grid-template-columns: max-content 1fr; gap: 6px 16px; font-size: 13.5px; margin-top: 4px; }
.sim-info-dl dt { font-weight: 700; color: var(--fn-text); }
.sim-info-dl dd { color: var(--fn-text-secondary); margin: 0; }
.sim-info-legend { display: flex; flex-wrap: wrap; gap: 14px; margin: 10px 0; font-size: 12.5px; color: var(--fn-text-secondary); }
.sim-info-legend span { display: inline-flex; align-items: center; gap: 7px; }
.sim-info-note { background: var(--fn-warning-soft); border: 1px solid var(--fn-warning); border-radius: 10px; padding: 10px 14px; }
.sim-info-verdicts { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 12px; margin-top: 6px; }
.sim-info-verdicts .v { border: 1px solid var(--fn-border); border-radius: 11px; padding: 12px 14px; background: var(--fn-bg-muted); }
.sim-info-verdicts .v b { display: block; font-size: 14px; margin-bottom: 5px; }
.sim-info-verdicts .v span { display: block; font-size: 12.5px; color: var(--fn-text-secondary); }
.sim-info-verdicts .v em { display: block; font-style: normal; font-size: 12.5px; color: var(--fn-text); margin-top: 7px; font-weight: 600; }
.sim-info-verdicts .v.pass { border-left: 3px solid var(--fn-success); } .sim-info-verdicts .v.pass b { color: var(--fn-success); }
.sim-info-verdicts .v.none { border-left: 3px solid var(--fn-text-tertiary); }
.sim-info-verdicts .v.art { border-left: 3px solid var(--fn-warning); } .sim-info-verdicts .v.art b { color: var(--fn-warning); }
.sim-info-foot { margin-top: 18px; padding-top: 12px; border-top: 1px solid var(--fn-border); font-size: 12px; color: var(--fn-text-tertiary); }
.sim-lead { color: var(--fn-text-secondary); font-size: 13px; margin: 5px 0 14px; max-width: 920px; }
.sim-section-label { font-size: 10.5px; text-transform: uppercase; letter-spacing: .07em;
    color: var(--fn-text-tertiary); margin: 20px 0 7px; font-weight: 700; }

/* mode switcher (segmented control like the watchlist) + contextual (i) info */
.sim-mode-row { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.sim-acs-empty-hint { font-size: 11.5px; color: var(--fn-text-tertiary); }
.sim-mode { display: inline-flex; background: var(--fn-bg-muted); border: 1px solid var(--fn-border);
    border-radius: 10px; padding: 3px; gap: 2px; }
.sim-mode-btn { font-size: 12.5px; color: var(--fn-text-secondary); padding: 6px 13px; border-radius: 7px;
    cursor: pointer; background: none; border: none; }
.sim-mode-btn.sim-on { background: var(--fn-primary); color: var(--fn-on-primary); font-weight: 700; }

/* input bar */
.sim-bar { display: flex; gap: 14px; align-items: flex-end; flex-wrap: wrap; background: var(--fn-bg-alt);
    border: 1px solid var(--fn-border); border-radius: 12px; padding: 13px 15px; margin-top: 7px; }
.sim-fld label { display: block; font-size: 10px; text-transform: uppercase; letter-spacing: .05em;
    color: var(--fn-text-tertiary); margin-bottom: 4px; }
.sim-fld input { background: var(--fn-bg-muted); border: 1px solid var(--fn-border-strong);
    border-radius: 8px; padding: 7px 11px; font-size: 13px; color: var(--fn-text); }
.sim-run { margin-left: auto; background: var(--fn-primary); color: var(--fn-on-primary); font-weight: 700;
    font-size: 13px; border: none; border-radius: 9px; padding: 9px 18px; cursor: pointer; }
.sim-run:disabled { opacity: .55; cursor: default; }

/* hero verdict + ACS */
.sim-hero { display: grid; grid-template-columns: 1.35fr 1fr; border: 1px solid var(--fn-border);
    border-radius: 16px; overflow: hidden; margin-top: 7px; }
.sim-hero.sim-ok { border-left: 5px solid var(--fn-success); }
.sim-hero.sim-no { border-left: 5px solid var(--fn-danger); }
.sim-hero-l { padding: 20px 22px; background: var(--fn-bg-alt); }
.sim-hero-r { padding: 20px 22px; background: var(--fn-bg-muted); border-left: 1px solid var(--fn-border);
    display: flex; flex-direction: column; justify-content: center; }
.sim-tgt { font-size: 11px; text-transform: uppercase; letter-spacing: .06em; color: var(--fn-text-tertiary); }
.sim-verdict { font-size: 30px; font-weight: 800; margin: 4px 0 6px; }
.sim-hero.sim-ok .sim-verdict { color: var(--fn-success); }
.sim-hero.sim-no .sim-verdict { color: var(--fn-danger); }
.sim-why { font-size: 13.5px; color: var(--fn-text-secondary); max-width: 440px; }
.sim-kpis { display: flex; gap: 26px; margin-top: 16px; }
.sim-kpis .k { font-size: 10px; text-transform: uppercase; letter-spacing: .04em; color: var(--fn-text-tertiary); }
.sim-kpis .v { font-size: 17px; font-weight: 700; margin-top: 2px; }
.sim-pos { color: var(--fn-success); } .sim-neg { color: var(--fn-danger); }

.sim-acs-top { display: flex; align-items: baseline; gap: 10px; }
.sim-acs-num { font-family: var(--fn-font-mono); font-size: 40px; font-weight: 800; color: var(--fn-success); line-height: 1; }
.sim-acs-band { font-size: 11px; font-weight: 700; border: 1px solid var(--fn-success); color: var(--fn-success);
    background: var(--fn-success-soft); border-radius: var(--fn-radius-pill); padding: 2px 10px; }
.sim-acs-lbl { font-size: 10.5px; text-transform: uppercase; letter-spacing: .06em; color: var(--fn-text-tertiary); margin-top: 10px; }
.sim-acs-bar { position: relative; height: 9px; border-radius: 6px; margin-top: 6px;
    background: linear-gradient(90deg, var(--fn-danger) 0 30%, var(--fn-warning) 30% 70%, var(--fn-success) 70% 100%); }
.sim-acs-mark { position: absolute; top: -4px; width: 3px; height: 17px; background: var(--fn-text);
    border-radius: 2px; }
.sim-acs-foot { font-size: 11px; color: var(--fn-text-tertiary); margin-top: 10px; }

/* trust callout */
.sim-trust { display: flex; align-items: flex-start; gap: 11px; background: var(--fn-warning-soft);
    border: 1px solid var(--fn-warning); border-radius: 12px; padding: 12px 15px; margin-top: 18px; }
.sim-trust .ic { font-size: 18px; }
.sim-trust .t { font-size: 13px; color: var(--fn-text); }
.sim-trust .t b { color: var(--fn-warning); }

/* ranking badges */
.sim-acsm { font-family: var(--fn-font-mono); font-weight: 700; }
.sim-b1 { color: var(--fn-success); } .sim-b2 { color: var(--fn-warning); } .sim-b3 { color: var(--fn-danger); }
.sim-badge { font-size: 9.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em;
    border-radius: 6px; padding: 2px 7px; border: 1px solid; }
.sim-badge.pass { color: var(--fn-success); border-color: var(--fn-success); background: var(--fn-success-soft); }
.sim-badge.none { color: var(--fn-text-tertiary); border-color: var(--fn-border-strong); }
.sim-badge.art { color: var(--fn-warning); border-color: var(--fn-warning); background: var(--fn-warning-soft); }

/* tiles = one stable horizontal row docked at the very bottom of the content area (flex end),
   not sticky (sticky fails on short pages). Sits above the LogPanel via .sim-page padding-bottom. */
.sim-tiles-dock { flex: 0 0 auto; background: var(--fn-bg); border-top: 1px solid var(--fn-border-strong);
    padding: 11px 22px 8px; }
.sim-tiles-dock-lbl { font-size: 10.5px; text-transform: uppercase; letter-spacing: .06em; color: var(--fn-text-tertiary); font-weight: 700; margin-bottom: 7px; }
.sim-tiles { display: flex; gap: 11px; overflow-x: auto; padding-bottom: 14px; }
/* color explicit: a <button> tile does NOT inherit the app text color (the shared identity sets its own;
   this keeps the rest of the tile readable too). Identity itself = <FnSecurityIdentity> (.fn-name/.sec-ids). */
.sim-tile { flex: 0 0 230px; background: var(--fn-bg-alt); border: 1px solid var(--fn-border); border-top: 3px solid var(--fn-border-strong);
    border-radius: 11px; padding: 12px 13px; cursor: pointer; text-align: left; color: var(--fn-text); }
.sim-tile.win { border-top-color: var(--fn-success); }
.sim-tile.sim-on { box-shadow: 0 0 0 1px var(--fn-primary) inset; border-color: var(--fn-primary); }
.sim-tile .sym { font-size: 13.5px; display: flex; justify-content: space-between; align-items: flex-start; gap: 8px; }
.sim-tile .meta { font-size: 11px; color: var(--fn-text-secondary); margin-top: 5px; }

/* fullscreen detail */
.sim-full { border: 1px solid var(--fn-primary); border-radius: 14px; overflow: hidden; margin-top: 11px; background: var(--fn-bg-alt); }
.sim-full-bar { display: flex; align-items: center; gap: 10px; padding: 11px 15px; background: var(--fn-bg-muted);
    border-bottom: 1px solid var(--fn-border); }
.sim-full-bar .ttl { font-weight: 700; font-size: 13.5px; }
.sim-full-bar .x { margin-left: auto; color: var(--fn-text-tertiary); font-size: 12px; background: none; border: none; cursor: pointer; }
.sim-full-body { display: grid; grid-template-columns: 1.3fr 1fr; }
.sim-full-body > div { padding: 15px 17px; }
.sim-full-body .right { border-left: 1px solid var(--fn-border); background: var(--fn-bg-muted); }
.sim-sec-t { font-size: 10px; text-transform: uppercase; letter-spacing: .05em; color: var(--fn-text-tertiary);
    margin-bottom: 7px; font-weight: 700; }
.sim-chk { display: flex; flex-wrap: wrap; gap: 6px; font-size: 11px; }
.sim-chk span { border: 1px solid var(--fn-border-strong); border-radius: var(--fn-radius-pill); padding: 2px 9px; }
.sim-chk .ok { color: var(--fn-success); border-color: var(--fn-success); }
.sim-chk .opn { color: var(--fn-warning); border-color: var(--fn-warning); }
.sim-aud h4 { font-size: 10px; text-transform: uppercase; letter-spacing: .05em; color: var(--fn-text-tertiary); margin: 12px 0 3px; }
.sim-aud ul { margin: 0 0 0 16px; font-size: 11.5px; color: var(--fn-text-secondary); }
.sim-aud-rec { font-size: 12px; color: var(--fn-text); margin-top: 11px; border-top: 1px solid var(--fn-border); padding-top: 9px; }
.sim-equity svg { width: 100%; height: auto; display: block; }

.sim-empty { color: var(--fn-text-tertiary); font-size: 13px; padding: 26px; text-align: center; }
.sim-disclaimer { background: var(--fn-bg-alt); border: 1px solid var(--fn-border); border-left: 3px solid var(--fn-warning);
    border-radius: 11px; padding: 11px 14px; font-size: 12px; color: var(--fn-text-secondary); margin-top: 20px; }
.sim-busy { color: var(--fn-text-tertiary); font-size: 13px; margin-top: 12px; }

/* Königsdisziplin: signals + open positions */
.sim-king { border: 1px solid var(--fn-border); border-top: 3px solid var(--fn-warning); border-radius: 14px;
    padding: 17px 19px; margin-top: 7px; background: var(--fn-bg-alt); }
.sim-king-h { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-bottom: 4px; }
.sim-king-h .t { font-weight: 700; font-size: 15px; }
.sim-king-h .on { font-size: 10px; font-weight: 700; border: 1px solid var(--fn-success); color: var(--fn-success);
    background: var(--fn-success-soft); border-radius: var(--fn-radius-pill); padding: 1px 9px; }
.sim-king-h .off { font-size: 10px; font-weight: 700; border: 1px solid var(--fn-text-tertiary);
    color: var(--fn-text-tertiary); border-radius: var(--fn-radius-pill); padding: 1px 9px; }
.sim-king-h .ch { margin-left: auto; font-size: 11px; color: var(--fn-text-tertiary); }
.sim-king-sub { font-size: 12.5px; color: var(--fn-text-secondary); margin-bottom: 12px; }
.sim-sig { display: flex; gap: 9px; flex-wrap: wrap; margin-bottom: 14px; }
.sim-sig span { font-size: 12px; border-radius: 8px; padding: 5px 11px; font-family: var(--fn-font-mono); }
.sim-sig .buy { color: var(--fn-success); background: var(--fn-success-soft); border: 1px solid var(--fn-success); }
.sim-sig .sell { color: var(--fn-danger); background: var(--fn-danger-soft); border: 1px solid var(--fn-danger); }
.sim-take { font-size: 11.5px; border: 1px solid var(--fn-primary); color: var(--fn-primary);
    background: var(--fn-accent-soft); border-radius: 7px; padding: 4px 12px; cursor: pointer; }
.sim-handoff { display: flex; align-items: center; gap: 9px; font-size: 11.5px; color: var(--fn-text-secondary);
    margin-top: 12px; border-top: 1px dashed var(--fn-border); padding-top: 11px; }
.sim-handoff b { color: var(--fn-warning); }

/* grouping control — centered, like the watchlist */
.sim-grp-ctl { display: flex; flex-direction: column; align-items: center; gap: 5px; margin: 4px 0 6px; }
.sim-grp-lbl { font-size: 10px; text-transform: uppercase; letter-spacing: .06em; color: var(--fn-text-tertiary); font-weight: 700; }
.sim-grp-row { display: flex; align-items: center; gap: 8px; position: relative; }
.sim-grp { display: inline-flex; background: var(--fn-bg-muted); border: 1px solid var(--fn-border); border-radius: 9px; padding: 3px; gap: 2px; }
.sim-grp-btn { font-size: 11.5px; color: var(--fn-text-secondary); padding: 5px 12px; border-radius: 6px; cursor: pointer; background: none; border: none; }
.sim-grp-btn.sim-on { background: var(--fn-primary); color: var(--fn-on-primary); font-weight: 700; }
.sim-grp-ico { font-size: 13px; color: var(--fn-text-secondary); border: 1px solid var(--fn-border-strong);
    background: var(--fn-bg); border-radius: 7px; padding: 4px 9px; cursor: context-menu; }
.sim-grp-ico:hover { color: var(--fn-primary); border-color: var(--fn-primary); }
.sim-ctx { position: absolute; top: 38px; right: 0; z-index: 20; width: 280px; background: var(--fn-bg-muted);
    border: 1px solid var(--fn-border-strong); border-radius: 11px; padding: 12px 14px; box-shadow: 0 14px 34px var(--fn-shadow-hover); }
.sim-ctx-h { font-size: 12px; font-weight: 700; color: var(--fn-text); }
.sim-ctx-sub { font-size: 10.5px; color: var(--fn-text-tertiary); margin: 3px 0 10px; }
.sim-ctx-row { display: grid; grid-template-columns: 1fr auto; gap: 10px; align-items: center; font-size: 12px;
    padding: 5px 0; border-bottom: 1px solid var(--fn-border); }
.sim-ctx-row input { width: 70px; background: var(--fn-bg); border: 1px solid var(--fn-border-strong);
    border-radius: 6px; padding: 3px 7px; font-family: var(--fn-font-mono); font-size: 11px; color: var(--fn-text); text-align: right; }
.sim-ctx-foot { display: flex; justify-content: space-between; align-items: center; margin-top: 11px; }
.sim-ctx-foot .rst { font-size: 11px; color: var(--fn-text-secondary); cursor: pointer; background: none; border: none; }
.sim-ctx-foot .apply { background: var(--fn-primary); color: var(--fn-on-primary); font-weight: 700; font-size: 11.5px;
    border: none; border-radius: 7px; padding: 5px 13px; cursor: pointer; }
.sim-ghead td { background: var(--fn-bg-muted); text-align: center; font-size: 11px; text-transform: uppercase;
    letter-spacing: .05em; color: var(--fn-text-secondary); font-weight: 700; }
.sim-ghead .cnt { color: var(--fn-text-tertiary); font-weight: 600; text-transform: none; letter-spacing: 0; }
.sim-side-short { color: var(--fn-danger); }
