/*
 * Chart-Modul (ChartPanel) — 1:1 nach docs/finnavigator_chart-window_v1.html
 * (Bauplan, Niko-Abnahme 05.06.2026). Präfix cw-. Nur var(--fn-*)-Tokens.
 */

.cw-body { display: flex; height: 100%; min-height: 320px; overflow: hidden; }

/* ===== Steuerspalte links ===== */
.cw-controls {
    width: 228px; flex: 0 0 228px;
    border-right: var(--fn-border-width) solid var(--fn-border);
    background: var(--fn-bg-muted);
    padding: 14px 12px; display: flex; flex-direction: column; gap: 14px; overflow-y: auto;
}
/* Ein-/ausklappbar wie die Menü-Sidebar (gleiche ‹/›-Chevrons). */
.cw-controls-head { display: flex; align-items: center; justify-content: flex-end; }
.cw-collapse-btn {
    display: inline-flex; align-items: center; justify-content: center;
    width: 26px; height: 26px; flex: 0 0 26px; padding: 0;
    background: var(--fn-bg-alt); border: var(--fn-border-width) solid var(--fn-border);
    border-radius: 7px; color: var(--fn-text-secondary); cursor: pointer; transition: all .14s;
}
.cw-collapse-btn:hover { color: var(--fn-text); border-color: var(--fn-border-strong); }
.cw-collapse-btn svg { width: 15px; height: 15px; }
.cw-controls.collapsed { width: 44px; flex: 0 0 44px; padding: 12px 8px; overflow: hidden; }
.cw-controls.collapsed > *:not(.cw-controls-head) { display: none; }
.cw-controls.collapsed .cw-controls-head { justify-content: center; }
.cw-group h4 {
    font-size: 10.5px; font-weight: var(--fn-font-weight-bold); letter-spacing: .10em;
    text-transform: uppercase; color: var(--fn-text-tertiary); margin: 0 0 8px 0;
}
.cw-toggles { display: flex; flex-wrap: wrap; gap: 6px; }
.cw-toggle {
    font-family: var(--fn-font); font-size: 11.5px; font-weight: var(--fn-font-weight-medium);
    color: var(--fn-text-secondary); background: var(--fn-bg-alt);
    border: var(--fn-border-width) solid var(--fn-border); border-radius: var(--fn-radius-pill);
    padding: 4px 10px; cursor: pointer; transition: all .14s;
}
.cw-toggle:hover { color: var(--fn-text); border-color: var(--fn-border-strong); }
.cw-toggle.on { color: var(--fn-primary); border-color: var(--fn-accent-line); background: var(--fn-accent-soft); }
.cw-select {
    width: 100%; background: var(--fn-bg-alt);
    border: var(--fn-border-width) solid var(--fn-border); border-radius: 8px;
    color: var(--fn-text); font-family: var(--fn-font); font-size: 12px; padding: 6px 8px; margin-top: 6px;
}
/* Compact toolbar variant: content-width, inline (NOT the full-width sidebar select). */
.cw-toolbar .cw-select { width: auto; margin-top: 0; }
/* SMA-/MACD-Preset-Listen: Spalten stabil untereinander darstellen.
   Nur explizit markierte Preset-Selects, damit Muster-/Zeitraum-Selects unberührt bleiben. */
.cw-preset-select {
    font-family: var(--fn-font-mono);
    font-variant-numeric: tabular-nums;
    font-feature-settings: "tnum" 1;
    text-align: center;
    text-align-last: center;
}
.cw-preset-select option {
    font-family: var(--fn-font-mono);
    font-variant-numeric: tabular-nums;
    font-feature-settings: "tnum" 1;
    text-align: center;
    white-space: pre;
}
.cw-tf-label { font-size: 10px; text-transform: uppercase; letter-spacing: .5px; color: var(--fn-text-tertiary); margin-left: 4px; }
.cw-hint { font-size: 10.5px; color: var(--fn-text-tertiary); margin-top: 6px; line-height: 1.45; }
.cw-seg { display: flex; border: var(--fn-border-width) solid var(--fn-border); border-radius: 8px; overflow: hidden; }
.cw-seg button {
    flex: 1; font-family: var(--fn-font); font-size: 11.5px; font-weight: var(--fn-font-weight-medium);
    color: var(--fn-text-secondary); background: transparent; border: none; padding: 6px 0; cursor: pointer;
    white-space: nowrap;
}
.cw-seg button + button { border-left: var(--fn-border-width) solid var(--fn-border); }
.cw-seg button.on { color: var(--fn-on-primary); background: var(--fn-primary); }

/* ===== Chart-Bereich ===== */
.cw-main { flex: 1; min-width: 0; display: flex; flex-direction: column; overflow-y: auto; }

/* ChartPanel-Stage: rechts der Steuerspalte; trägt die Top-Leiste (Raster·Zeitraum·Intervall) und
   darunter entweder eine volle Zelle (Layout 1) oder das Raster (Layout 2/3/4). */
/* Stage scrollt intern (sichtbarer Balken); .cw-body wird per JS (fnChart.fitHeight) auf die
   Viewport-Resthoehe begrenzt, damit dieser Scroll ueberhaupt greift (statt Overlay-Dokumentscroll). */
.cw-stage { flex: 1; min-width: 0; display: flex; flex-direction: column; overflow-y: auto; overflow-x: hidden; }
.cw-stage > .cw-main { flex: 1; }

/* Sichtbarer, getönter Scrollbalken für die scrollenden Bereiche (Einzel-Chart = .cw-main, Raster = .cw-stage).
   Nur ::-webkit-scrollbar (KEIN scrollbar-width:thin — das würde in Chromium die Breite auf Overlay/0 ziehen)
   -> klassischer, immer sichtbarer Balken in Chrome/Edge. */
.cw-main::-webkit-scrollbar, .cw-stage::-webkit-scrollbar { width: 12px; }
.cw-main::-webkit-scrollbar-track, .cw-stage::-webkit-scrollbar-track { background: var(--fn-input-bg); }
.cw-main::-webkit-scrollbar-thumb, .cw-stage::-webkit-scrollbar-thumb { background: var(--fn-primary); border-radius: 6px; border: 3px solid var(--fn-input-bg); }
.cw-main::-webkit-scrollbar-thumb:hover, .cw-stage::-webkit-scrollbar-thumb:hover { background: var(--fn-primary-hover, var(--fn-primary)); }

/* Raster-Layouts 1:1 aus dem Chart-Studio (Konzept §7: Split = ChartPanel-Funktion).
   3 = einer groß oben, zwei kleine darunter; 2/4 = gleich große Zellen. */
/* Begrenzte Workspace-Höhe, damit das Raster in die Seite passt (kein 5000px-Stapel). Die Zellen teilen
   sich diese Höhe über die grid-template-rows; ECharts skaliert in die Zelle. Konzept §10: Höhe gehört in
   die Komponente, nicht als Host-Hack. */
.cw-grid { flex: 0 0 auto; height: 72vh; min-height: 460px; display: grid; gap: 12px; padding: 12px 16px; }
.cw-grid.layout-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); grid-template-rows: 1fr; }
.cw-grid.layout-3 { grid-template-columns: repeat(2, minmax(0, 1fr)); grid-template-rows: 1.1fr .9fr; }
.cw-grid.layout-3 .cw-cell:first-child { grid-column: 1 / -1; }
.cw-grid.layout-4 { grid-template-columns: repeat(2, minmax(0, 1fr)); grid-template-rows: repeat(2, minmax(0, 1fr)); }
.cw-cell {
    position: relative; min-height: 0; min-width: 0; overflow: hidden;
    display: grid; grid-template-rows: auto minmax(0, 1fr);
    border: var(--fn-border-width) solid var(--fn-border); border-radius: var(--fn-radius);
    background: var(--fn-bg-alt); cursor: pointer;
}
/* Aktive Zelle: sauberer Rahmen rundum. KEIN inset-Schatten (den überdeckte der Zellen-Kopf oben). */
.cw-cell.active { border-color: var(--fn-primary); }
.cw-cell-head {
    display: flex; align-items: center; justify-content: space-between; gap: 10px;
    padding: 7px 11px; border-bottom: var(--fn-border-width) solid var(--fn-border); background: var(--fn-bg-muted);
}
/* Pro-Zelle Zeitraum/Intervall (jede Zelle eigene Zeit) — wie im Chart-Studio. */
.cw-cell-tf { display: inline-flex; align-items: center; gap: 5px; flex: 0 0 auto; }
.cw-cell-tf-select {
    font-family: var(--fn-font-mono); font-size: 10.5px; line-height: 1; color: var(--fn-primary);
    border: var(--fn-border-width) solid var(--fn-primary); background: color-mix(in srgb, var(--fn-primary) 10%, transparent);
    border-radius: var(--fn-radius-pill); padding: 3px 6px; cursor: pointer;
}
.cw-cell-tf-select:hover { border-color: var(--fn-primary); }
.cw-cell-tf-select option { background: var(--fn-bg-alt); color: var(--fn-text); }
.cw-cell .cw-main { height: 100%; min-height: 0; display: flex; flex-direction: column; overflow: visible; }
.cw-cell .cw-legend { flex: 0 0 auto; padding: 7px 11px 0; }
.cw-cell .cw-chart-wrap { flex: 1 1 auto; min-height: 0; display: flex; flex-direction: column; overflow: hidden; }
.cw-cell .cw-chart-wrap .cw-chart-host { flex: 1 1 auto; min-height: 0; height: 100%; margin: 4px 8px 10px; overflow: hidden; }

.cw-toolbar {
    display: flex; align-items: center; gap: 10px; padding: 10px 16px;
    border-bottom: var(--fn-border-width) solid var(--fn-border); flex-wrap: nowrap; overflow-x: auto; flex: 0 0 auto;
    /* bleibt oben sichtbar, waehrend der Chart-/Detailbereich darunter scrollt */
    position: sticky; top: 0; z-index: 6; background: var(--fn-bg-muted);
}
/* Controls must keep their natural width — the toolbar scrolls instead of squeezing them (sonst wird der
   aktive Button zum Splitter und Labels wie "1 Std"/"Max" werden abgeschnitten). Only the status may yield. */
.cw-toolbar > *:not(.cw-status) { flex-shrink: 0; }
/* Raster · Zeitraum · Intervall mittig; Werkzeuge/Status rechts. Gleich breite Spacer links/rechts zentrieren die Gruppe. */
.cw-tf-spacer { flex: 1 1 0; }
.cw-tf-group { flex: 0 0 auto; display: flex; align-items: center; gap: 10px; flex-wrap: wrap; justify-content: center; }
.cw-toolbar-right { flex: 1 1 0; display: flex; align-items: center; justify-content: flex-end; gap: 10px; min-width: 0; }
.cw-seg-h { display: inline-flex; border: var(--fn-border-width) solid var(--fn-border); border-radius: 8px; overflow: hidden; }
.cw-seg-h button {
    font-family: var(--fn-font); font-size: 11.5px; font-weight: var(--fn-font-weight-medium);
    color: var(--fn-text-secondary); background: transparent; border: none; padding: 5px 11px; cursor: pointer;
    flex-shrink: 0; white-space: nowrap;
}
.cw-seg-h button + button { border-left: var(--fn-border-width) solid var(--fn-border); }
.cw-seg-h button.on { color: var(--fn-on-primary); background: var(--fn-primary); }

.cw-status { margin-left: auto; font-family: var(--fn-font-mono); font-size: 11px; color: var(--fn-text-tertiary); white-space: nowrap; }

.cw-tools { display: flex; gap: 6px; }
.cw-tool {
    width: 26px; height: 26px; display: inline-flex; align-items: center; justify-content: center;
    background: var(--fn-bg-alt); border: var(--fn-border-width) solid var(--fn-border);
    border-radius: 6px; color: var(--fn-text-secondary); cursor: pointer; font-size: 12px;
}
.cw-tool:hover { color: var(--fn-text); border-color: var(--fn-border-strong); }
.cw-tool.on { color: var(--fn-cat-purple); border-color: var(--fn-cat-purple); }

.cw-legend {
    display: flex; gap: 16px; padding: 8px 16px; font-size: 11.5px;
    color: var(--fn-text-secondary); flex-wrap: wrap; flex: 0 0 auto;
}
.cw-legend span { display: inline-flex; align-items: center; gap: 6px; }
.cw-legend .cw-dot { width: 10px; height: 10px; border-radius: var(--fn-radius-round); display: inline-block; }
.cw-legend .lg-line i { width: 14px; height: 2px; border-radius: 2px; display: inline-block; }

.cw-chart-host {
    flex: 1 1 auto;
    min-height: 360px;
    margin: 0 16px;
    background: var(--fn-bg-muted);
    border: var(--fn-border-width) solid var(--fn-border);
    border-radius: var(--fn-radius);
}

/* Leeres Chart-Host kollabiert, wenn für die Auflösung keine echten Kursdaten vorliegen. */
.cw-chart-host.is-empty {
    min-height: 96px;
}

/* Hinweis statt Chart, wenn keine echten Kursdaten vorliegen (kein Fake). */
.cw-empty {
    margin: 12px 16px 0;
    padding: 22px 16px;
    text-align: center;
    color: var(--fn-text-tertiary);
    font-size: 12.5px;
}

/* (Serien-Tabelle cw-series entfernt — ersetzt durch den Kachelstreifen .cw-series-tiles, Niko 30.06.2026) */

/* ===== Info-Bereich unter dem Chart (Bloomberg-artig, Legacy /analyse-Vertrag) ===== */
.cw-info {
    display: grid; grid-template-columns: 1fr 1fr; gap: 14px;
    margin: 0 16px 16px; flex: 0 0 auto;
}
@media (max-width: 1100px) { .cw-info { grid-template-columns: 1fr; } }

.cw-info-panel {
    background: var(--fn-bg-muted);
    border: var(--fn-border-width) solid var(--fn-border);
    border-radius: var(--fn-radius);
    padding: 12px 14px;
}
.cw-info-panel h5 {
    margin: 0 0 9px 0; font-size: 11px; font-weight: var(--fn-font-weight-bold);
    letter-spacing: .09em; text-transform: uppercase; color: var(--fn-text-tertiary);
}
.cw-info-panel h5.cw-info-sub { margin-top: 12px; }
.cw-info-panel p { margin: 0; font-size: 12.5px; line-height: 1.55; color: var(--fn-text); }
.cw-info-ai { border-left: 3px solid var(--fn-cat-purple); }

.cw-kv { display: grid; grid-template-columns: auto 1fr; gap: 5px 16px; margin: 0; }
.cw-kv dt { font-size: 11.5px; color: var(--fn-text-secondary); }
.cw-kv dd { margin: 0; font-family: var(--fn-font-mono); font-size: 11.5px; color: var(--fn-text); text-align: right; }
.cw-kv .pos { color: var(--fn-success); }
.cw-kv .neg { color: var(--fn-danger); }
.cw-dim { color: var(--fn-text-tertiary); font-family: var(--fn-font); }

.cw-rating {
    display: inline-block; font-family: var(--fn-font);
    font-size: 11px; font-weight: var(--fn-font-weight-bold);
    border-radius: var(--fn-radius-pill); padding: 1px 9px;
    border: var(--fn-border-width) solid;
}
.cw-rating-buy { color: var(--fn-success); border-color: var(--fn-success); background: var(--fn-success-soft); }
.cw-rating-hold { color: var(--fn-warning); border-color: var(--fn-warning); background: var(--fn-warning-soft); }
.cw-rating-sell { color: var(--fn-danger); border-color: var(--fn-danger); background: var(--fn-danger-soft); }

.cw-chips { display: flex; flex-wrap: wrap; gap: 6px; }
.cw-chip {
    font-family: var(--fn-font-mono); font-size: 11px; color: var(--fn-text-secondary);
    background: var(--fn-bg-alt); border: var(--fn-border-width) solid var(--fn-border);
    border-radius: var(--fn-radius-pill); padding: 3px 10px;
}
.cw-chip-link { cursor: pointer; color: var(--fn-cat-blue); transition: all .14s; }
.cw-chip-link:hover { border-color: var(--fn-accent-line); background: var(--fn-accent-soft); color: var(--fn-primary); }
.cw-chip-pattern { color: var(--fn-cat-gold); border-color: rgba(251, 191, 36, 0.35); }

/* ===== Tag/Vortag-Hoch/Tief-Streifen (Variante A, Niko-Abnahme 08.06.2026) ===== */
.cw-session { display: flex; margin: 10px 16px 0; border: 1px solid var(--fn-border); border-radius: var(--fn-radius); overflow: hidden; background: var(--fn-bg-muted); }
.cw-sess-cell { flex: 1; padding: 9px 14px; border-right: 1px solid var(--fn-border); }
.cw-sess-cell:last-child { border-right: none; }
.cw-sess-cell .k { font-size: 10px; font-weight: var(--fn-font-weight-bold); letter-spacing: .08em; text-transform: uppercase; color: var(--fn-text-tertiary); margin-bottom: 4px; }
.cw-sess-hl { display: flex; gap: 14px; font-family: var(--fn-font-mono); font-size: 13px; }
.cw-sess-hl .h { color: var(--fn-success); }
.cw-sess-hl .t { color: var(--fn-danger); }
.cw-sess-hl .lbl { color: var(--fn-text-tertiary); font-family: var(--fn-font); font-size: 11px; margin-right: 3px; }
.cw-sess-range { font-family: var(--fn-font-mono); font-size: 13px; }
.cw-sess-range .pct { color: var(--fn-text-secondary); font-size: 11.5px; }

/* ===== Kursspanne-Balken Variante B „Fokus-Punkt" (Niko-Abnahme 30.06.2026,
   VORSCHAU-Kursspanne-Balken-B-FokusPunkt). Vortag-Bügel OBEN · Tagesspanne als Verlauf Tief→Hoch MITTE ·
   aktueller Kurs als Punkt + Wert-Chip UNTEN. Grün/Rot stilidentisch über die EINZIGE Variable --bar-accent.
   NUR Tokens, kein Hex. Positionen datengetrieben aus SessionStats (DayLeft/Width, PrevLeft/Width, NowLeft). ===== */
.cw-sess-bar-wrap { margin: 9px 16px 0; padding: 10px 14px; border: 1px solid var(--fn-border); border-radius: var(--fn-radius); background: var(--fn-bg-muted); }
.cw-sess-bar-k { font-size: 10px; font-weight: var(--fn-font-weight-bold); letter-spacing: .08em; text-transform: uppercase; color: var(--fn-text-tertiary); margin-bottom: 9px; }

/* Stimmungsfarbe als EINZIGE Variable — identischer Stil für grün/rot, nur Farbe wechselt. */
.cw-sess-bar-wrap, .cw-chart-session { --bar-accent: var(--fn-chart-up); }
.cw-sess-bar-wrap.variant-b.up,   .cw-chart-session.variant-b.up   { --bar-accent: var(--fn-chart-up); }
.cw-sess-bar-wrap.variant-b.down, .cw-chart-session.variant-b.down { --bar-accent: var(--fn-chart-down); }
.cw-sess-bar-wrap.variant-b.flat, .cw-chart-session.variant-b.flat { --bar-accent: var(--fn-cat-blue); }

.cw-sess-bar { position: relative; height: 64px; overflow: visible; }
.cw-sess-bar .brk, .cw-sess-bar .rail, .cw-sess-bar .tagband, .cw-sess-bar .conn, .cw-sess-bar .nowdot, .cw-sess-bar .chip { position: absolute; }
/* Vortag-Bügel OBEN (graue Klammer, ohne Unterkante) */
.cw-sess-bar .brk { z-index: 2; top: 2px; height: 10px; min-width: 3px; border: 1.5px solid color-mix(in srgb, var(--fn-text-secondary) 78%, transparent); border-bottom: none; border-radius: 5px 5px 0 0; }
/* Grundlinie = gemeinsame Spanne (Koordinatensystem, zurückhaltend) */
.cw-sess-bar .rail { z-index: 1; left: 0; right: 0; top: 25px; height: 2px; border-radius: 2px; background: var(--fn-border); }
/* Tagesspanne MITTE: Verlauf Tief→Hoch in Stimmungsfarbe */
.cw-sess-bar .tagband { z-index: 3; top: 19px; height: 14px; min-width: 3px; border-radius: 8px;
    border: 1px solid color-mix(in srgb, var(--bar-accent) 55%, transparent);
    background: linear-gradient(90deg, color-mix(in srgb, var(--bar-accent) 9%, transparent), color-mix(in srgb, var(--bar-accent) 44%, transparent)); }
/* Verbinder Punkt → Chip */
.cw-sess-bar .conn { z-index: 4; top: 33px; height: 11px; width: 2px; background: color-mix(in srgb, var(--bar-accent) 55%, transparent); transform: translateX(-50%); }
/* Aktueller Kurs: leuchtender Punkt auf dem Balken */
.cw-sess-bar .nowdot { z-index: 5; top: 26px; width: 16px; height: 16px; border-radius: 50%; background: var(--bar-accent);
    border: 2px solid var(--fn-bg-muted); box-shadow: 0 0 0 4px color-mix(in srgb, var(--bar-accent) 18%, transparent); transform: translate(-50%, -50%); }
/* Wert-Chip UNTEN: aktueller Kurs + Position */
.cw-sess-bar .chip { z-index: 4; top: 44px; transform: translateX(-50%); white-space: nowrap;
    font-family: var(--fn-font-mono); font-size: 12px; font-weight: var(--fn-font-weight-bold); color: var(--fn-text);
    background: color-mix(in srgb, var(--bar-accent) 16%, transparent); border: 1px solid color-mix(in srgb, var(--bar-accent) 58%, transparent);
    border-radius: 7px; padding: 2px 8px; }

/* In-Chart-Overlay (oben im Chart): gleiches B, nur dunklerer Punktrand für Kontrast auf der Chartfläche. */
.cw-chart-session { border: 1px solid var(--fn-border); border-radius: 10px; background: color-mix(in srgb, var(--fn-bg) 82%, transparent); padding: 10px 12px; backdrop-filter: blur(6px); }
.cw-chart-session-title { color: var(--fn-text-tertiary); font-size: 10px; text-transform: uppercase; letter-spacing: .1em; font-weight: var(--fn-font-weight-bold); margin-bottom: 8px; }
.cw-chart-session .nowdot { border-color: var(--fn-bg); }
.cw-chart-session-overlay { position: absolute; left: 16px; right: 16px; top: 8px; z-index: 4; pointer-events: none; }
.cw-chart-session-overlay .cw-chart-session { pointer-events: auto; }

.cw-sess-legend { display: flex; gap: 16px; margin-top: 12px; font-size: 11px; color: var(--fn-text-tertiary); }
.cw-sess-legend i { display: inline-block; margin-right: 5px; vertical-align: middle; }
.cw-sess-legend .lg-tag i { width: 14px; height: 9px; border-radius: 3px; background: linear-gradient(90deg, color-mix(in srgb, var(--bar-accent) 9%, transparent), color-mix(in srgb, var(--bar-accent) 44%, transparent)); }
.cw-sess-legend .lg-prev i { width: 13px; height: 6px; border: 1.5px solid color-mix(in srgb, var(--fn-text-secondary) 78%, transparent); border-bottom: none; border-radius: 3px 3px 0 0; }
.cw-sess-legend .lg-now i { width: 11px; height: 11px; border-radius: 50%; background: var(--bar-accent); }

/* ===== Serien-Kachelstreifen (Wertpapiere im aktiven Chart) — ersetzt die Serien-Tabelle (Niko 30.06.2026).
   Klick = aktive Serie → speist die Detail-Kacheln. --tile-accent = Serienfarbe (datengetrieben). NUR Tokens. ===== */
/* Einklappbar (Default 1 Zeile Chips) — spart Platz + schließt die Lücke Chart↔Streifen↔Detail-Kacheln. */
.cw-series-wrap { padding: 8px 16px 2px; }
/* overflow-x:auto erzwingt per CSS-Quirk overflow-y:auto -> 3px Chip-Ueberlauf gab eine Scrollbar.
   overflow-y:hidden unterdrueckt sie (Chip ist vertikal zentriert, kein sichtbares Clipping). */
.cw-series-bar { display: flex; align-items: center; gap: 8px; overflow-x: auto; overflow-y: hidden; }
.cw-series-label { font-size: 10px; font-weight: var(--fn-font-weight-bold); letter-spacing: .08em; text-transform: uppercase; color: var(--fn-text-tertiary); }
.cw-series-toggle { margin-left: auto; flex: 0 0 auto; display: inline-flex; align-items: center; justify-content: center; width: 26px; height: 24px; border: var(--fn-border-width) solid var(--fn-border); border-radius: 7px; background: var(--fn-bg-alt); color: var(--fn-text-secondary); cursor: pointer; }
.cw-series-toggle:hover { color: var(--fn-primary); border-color: var(--fn-border-strong); }
.cw-series-toggle i { width: 15px; height: 15px; }
.cw-chip { flex: 0 0 auto; display: inline-flex; align-items: center; gap: 7px; cursor: pointer; border: var(--fn-border-width) solid var(--fn-border); border-radius: var(--fn-radius-pill); background: var(--fn-bg-alt); color: var(--fn-text); padding: 4px 11px; font-size: 12px; white-space: nowrap; }
.cw-chip:hover { border-color: var(--fn-border-strong); }
.cw-chip.active { border-color: var(--fn-primary); box-shadow: inset 0 0 0 1px var(--fn-primary); }
.cw-chip-dot { flex: 0 0 auto; width: 8px; height: 8px; border-radius: 50%; background: var(--tile-accent, var(--fn-border-strong)); }
.cw-chip .pos { color: var(--fn-success); font-family: var(--fn-font-mono); font-size: 11px; }
.cw-chip .neg { color: var(--fn-danger); font-family: var(--fn-font-mono); font-size: 11px; }
.cw-series-tiles { display: flex; gap: 12px; padding: 10px 0 2px; overflow-x: auto; }
.cw-tile { position: relative; flex: 0 0 auto; min-width: 210px; text-align: left; cursor: pointer;
    border: var(--fn-border-width) solid var(--fn-border); border-left: 3px solid var(--tile-accent, var(--fn-border-strong));
    border-radius: var(--fn-radius); background: var(--fn-bg-alt); padding: 12px 14px 13px; color: var(--fn-text); }
.cw-tile:hover { border-color: var(--fn-border-strong); }
.cw-tile.active { border-color: var(--fn-primary); box-shadow: inset 0 0 0 1px var(--fn-primary); }
.cw-tile-name { font-weight: var(--fn-font-weight-bold); font-size: 14px; line-height: 1.2; padding-right: 28px; }
.cw-tile-sym { font-family: var(--fn-font-mono); font-size: 10.5px; color: var(--fn-text-tertiary); margin: 3px 0 10px; }
.cw-tile-kv { display: grid; grid-template-columns: 1fr 1fr; gap: 6px 14px; margin: 0; }
.cw-tile-kv > div { display: flex; flex-direction: column; min-width: 0; }
.cw-tile-kv dt { font-size: 9.5px; letter-spacing: .06em; text-transform: uppercase; color: var(--fn-text-tertiary); }
.cw-tile-kv dd { margin: 0; font-family: var(--fn-font-mono); font-size: 12.5px; color: var(--fn-text); white-space: nowrap; }
.cw-tile-kv dd.pos { color: var(--fn-success); }
.cw-tile-kv dd.neg { color: var(--fn-danger); }
.cw-tile-actions { position: absolute; top: 9px; right: 10px; display: flex; gap: 8px; }
.cw-tile-ic { display: inline-flex; color: var(--fn-text-tertiary); cursor: pointer; }
.cw-tile-ic:hover { color: var(--fn-primary); }
.cw-tile-ic i { width: 15px; height: 15px; }

/* Kaufen/Verkaufen — bläulich, leicht transparent, oben rechts im Chart (nur bei gewählter Watchliste). */
.cw-chart-wrap {
    position: relative;
    z-index: 1;
    isolation: isolate;
    /* Wrap umschliesst den Host eng (Host hat definite 52vh). Ohne flex:0 0 auto wuerde der Wrap
       im gebundenen .cw-main wachsen und unter dem Chart eine Luecke zum Kachelstreifen lassen. */
    flex: 0 0 auto;
    min-height: 0;
    display: flex;
    flex-direction: column;
}
/* Einzel-Chart (nicht Raster-Zelle): DEFINITE Hoehe, sonst hat ECharts im content-getriebenen
   Flex-Layout keine feste Hoehe und faellt auf ~300px zurueck -> Host wirkt ~30% zu gross (leerer Raum).
   Raster-Zellen behalten height:100% ueber die spezifischere .cw-cell-Regel. */
.cw-chart-wrap .cw-chart-host {
    flex: none;
    height: 52vh;
    min-height: 360px;
}
.cw-trade { position: absolute; top: 10px; right: 14px; display: flex; flex-direction: column; align-items: center; gap: 6px; z-index: 5; }
.cw-trade-row { display: flex; gap: 8px; }
/* Stückzahl-Kreis über den Buttons — bläulich, leicht transparent, kreisförmig (wie der RSI-Marker). */
.cw-trade-qty {
    min-width: 30px; height: 30px; padding: 0 8px; display: inline-flex; align-items: center; justify-content: center;
    border-radius: 50%; font-size: 13px; font-weight: var(--fn-font-weight-bold); color: var(--fn-text); backdrop-filter: blur(6px);
    border: 1px solid color-mix(in srgb, var(--fn-cat-blue) 60%, transparent);
    background: color-mix(in srgb, var(--fn-cat-blue) 18%, transparent);
}
/* Rechtsklick-Kontextmenü zu Kaufen/Verkaufen: Menge + Löschen. */
.cw-trade-menu-backdrop { position: absolute; inset: 0; z-index: 9; }
.cw-trade-menu { position: absolute; top: 50px; right: 14px; z-index: 10; min-width: 182px; display: flex; flex-direction: column; gap: 5px; padding: 8px; border-radius: 10px; background: var(--fn-bg-alt); border: 1px solid var(--fn-border-strong); }
.cw-tm-row { display: flex; align-items: center; justify-content: space-between; gap: 8px; padding: 2px 4px; font-size: 12px; color: var(--fn-text-secondary); }
.cw-tm-input { width: 64px; padding: 4px 6px; border-radius: 6px; font-size: 12.5px; border: 1px solid var(--fn-border-strong); background: var(--fn-bg-muted); color: var(--fn-text); }
.cw-tm-btn { text-align: left; padding: 7px 10px; border-radius: 7px; cursor: pointer; font-size: 12.5px; font-weight: var(--fn-font-weight-bold); color: var(--fn-text); border: 1px solid color-mix(in srgb, var(--fn-cat-blue) 45%, transparent); background: color-mix(in srgb, var(--fn-cat-blue) 12%, transparent); }
.cw-tm-btn:hover { background: color-mix(in srgb, var(--fn-cat-blue) 22%, transparent); }
.cw-tm-btn.danger { border-color: color-mix(in srgb, var(--fn-danger) 50%, transparent); background: color-mix(in srgb, var(--fn-danger) 14%, transparent); }
.cw-tm-sep { height: 1px; margin: 3px 2px; background: var(--fn-border); }
.cw-trade-btn {
    font-size: 12.5px; font-weight: var(--fn-font-weight-bold); padding: 7px 14px; border-radius: 9px;
    cursor: pointer; color: var(--fn-text); backdrop-filter: blur(6px);
    border: 1px solid color-mix(in srgb, var(--fn-cat-blue) 55%, transparent);
    background: color-mix(in srgb, var(--fn-cat-blue) 16%, transparent);
}
.cw-trade-btn:hover { background: color-mix(in srgb, var(--fn-cat-blue) 30%, transparent); }
.cw-trade-btn.sell {
    border-color: color-mix(in srgb, var(--fn-primary) 50%, transparent);
    background: color-mix(in srgb, var(--fn-primary) 12%, transparent);
}
.cw-trade-dialog-backdrop {
    position: absolute; inset: 0; z-index: 8; display: flex; align-items: center; justify-content: center;
    background: color-mix(in srgb, var(--fn-bg) 62%, transparent);
}
.cw-trade-dialog { background: var(--fn-bg-alt); border: 1px solid var(--fn-border-strong); border-radius: 12px; padding: 16px 18px; max-width: 360px; }
.cw-trade-dialog h4 { margin: 0 0 6px; font-size: 14px; color: var(--fn-text); }
.cw-trade-dialog p { margin: 0 0 14px; font-size: 12.5px; color: var(--fn-text-secondary); }
.cw-trade-dialog .row { display: flex; gap: 9px; justify-content: flex-end; }
.cw-trade-dialog .btn {
    font-size: 12.5px; font-weight: var(--fn-font-weight-bold); padding: 7px 15px; border-radius: 8px; cursor: pointer;
    border: 1px solid var(--fn-border-strong); background: transparent; color: var(--fn-text-secondary);
}
.cw-trade-dialog .btn.danger {
    border-color: color-mix(in srgb, var(--fn-danger) 50%, transparent);
    background: color-mix(in srgb, var(--fn-danger) 16%, transparent); color: var(--fn-text);
}

.cw-detail-tiles {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    margin-top: 0;
}
.cw-detail-tile {
    min-height: 168px;
    padding: 0;
    overflow: hidden;
}
.cw-tile-head {
    padding: 11px 13px 10px;
    border-bottom: var(--fn-border-width) solid var(--fn-border);
    background: color-mix(in srgb, var(--fn-cat-blue) 7%, var(--fn-bg-muted));
}
.cw-tile-head h5 {
    margin: 0;
    color: var(--fn-text);
    font-size: 12px;
    font-weight: var(--fn-font-weight-bold);
    letter-spacing: 0;
    text-transform: none;
}
.cw-tile-head p {
    margin: 3px 0 0;
    color: var(--fn-text-tertiary);
    font-size: 11px;
    font-family: var(--fn-font-mono);
}
.cw-kv-flat {
    padding: 13px 13px 12px;
    gap: 7px 18px;
}
.cw-kv-flat dt {
    color: var(--fn-text-secondary);
}
.cw-kv-flat dd {
    color: var(--fn-text);
}
.cw-range-stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin: 12px 13px 0;
    border: var(--fn-border-width) solid var(--fn-border);
    border-radius: 8px;
    overflow: hidden;
    background: var(--fn-bg-muted);
}
.cw-range-stats > div {
    padding: 9px 11px;
    border-right: var(--fn-border-width) solid var(--fn-border);
}
.cw-range-stats > div:last-child {
    border-right: 0;
}
.cw-range-stats .k {
    display: block;
    margin-bottom: 5px;
    color: var(--fn-text-tertiary);
    font-size: 10px;
    font-weight: var(--fn-font-weight-bold);
    letter-spacing: .08em;
    text-transform: uppercase;
}
.cw-range-stats .v {
    display: flex;
    gap: 9px;
    font-family: var(--fn-font-mono);
    font-size: 12.5px;
    font-weight: var(--fn-font-weight-bold);
}
.cw-range-stats .pos-text {
    color: var(--fn-text);
}
.cw-detail-empty {
    margin: 13px;
    color: var(--fn-text-tertiary);
    font-size: 12.5px;
}
.cw-detail-patterns {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    padding: 0 13px 13px;
}

/* Kursspannen-Balken Variante A: schmale Linie, Segment, runder Marker, Farbzustand rot bis grün. */
@media (max-width: 1100px) {
    .cw-detail-tiles { grid-template-columns: 1fr; }
    .cw-range-stats { grid-template-columns: 1fr; }
    .cw-range-stats > div { border-right: 0; border-bottom: var(--fn-border-width) solid var(--fn-border); }
    .cw-range-stats > div:last-child { border-bottom: 0; }
}

