/*
 * 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: 560px; }

/* ===== 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). */
.cw-stage { flex: 1; min-width: 0; display: flex; flex-direction: column; overflow: hidden; }
.cw-stage > .cw-main { flex: 1; }

/* 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. */
.cw-grid { flex: 1 1 auto; min-height: 0; 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: visible;
    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;
}
.cw-cell.active { border-color: var(--fn-primary); box-shadow: inset 0 0 0 1px 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);
}
.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: 360px; display: flex; flex-direction: column; overflow: visible; }
.cw-cell .cw-chart-host { flex: 1 1 auto; min-height: 360px; height: 100%; margin: 4px 8px 10px; overflow: visible; }

.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;
}
/* 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; }
.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); }

.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;
}

table.cw-series {
    width: calc(100% - 32px);
    margin: 14px 16px 16px;
    border-collapse: collapse;
    font-size: 12px;
    table-layout: auto;
    flex: 0 0 auto;
    border: var(--fn-border-width) solid var(--fn-border);
    border-radius: var(--fn-radius);
    overflow: visible;
    background: var(--fn-bg-alt);
}
table.cw-series th {
    text-align: left;
    font-weight: var(--fn-font-weight-bold);
    color: var(--fn-text);
    font-size: 10.5px;
    letter-spacing: .09em;
    text-transform: uppercase;
    padding: 8px 10px;
    border-bottom: var(--fn-border-width) solid var(--fn-border-strong);
    background: var(--fn-bg-alt);
}
table.cw-series td {
    padding: 8px 10px;
    border-bottom: var(--fn-border-width) solid var(--fn-border);
    font-family: var(--fn-font-mono);
    font-size: 11.5px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    background: var(--fn-bg-muted);
}
table.cw-series td:first-child { color: var(--fn-text); font-family: var(--fn-font-mono); }
table.cw-series td.name { font-family: var(--fn-font); color: var(--fn-text); }
table.cw-series .pos { color: var(--fn-success); }
table.cw-series .neg { color: var(--fn-danger); }
table.cw-series th.num, table.cw-series td.num { text-align: right; }
table.cw-series tr.selected td {
    background: color-mix(in srgb, var(--fn-cat-blue) 16%, var(--fn-bg-muted));
    border-bottom-color: var(--fn-accent-line);
}
table.cw-series tr.selected td:first-child .sym-sel { color: var(--fn-success); font-weight: var(--fn-font-weight-bold); }
.cw-series-block {
    position: relative;
    z-index: 0;
    flex: 0 0 auto;
    flex-shrink: 0;
    clear: both;
    margin: 14px 16px 0;
}

/* ===== 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 0 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 A — 1:1 zur VORSCHAU-…-Kursspanne-Balken-Varianten.
   Grün/Rot sind STILIDENTISCH (gleiche Maße/Schichten/Symbole); EINZIGER Unterschied ist die
   Stimmungsfarbe --bar-accent. Geometrie: track h8/top10, prev h8/top10, day h14/top7 (kräftiger
   Block), now 2px-Strich/h22 + 10px-Punkt. Positionen kommen datengetrieben aus SessionStats. ===== */
.cw-sess-bar-wrap { margin: 9px 0 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 — garantiert identischen Stil für grün/rot/neutral.
   Default + Mood auf der WRAP-Ebene setzen (nicht auf .cw-sess-bar, sonst überschreibt der
   nähere Selektor die Mood-Farbe und der rote Balken bliebe grün). */
.cw-sess-bar-wrap, .cw-chart-session { --bar-accent: var(--fn-success); }
.cw-sess-bar-wrap.variant-a.up,   .cw-chart-session.variant-a.up   { --bar-accent: var(--fn-success); }
.cw-sess-bar-wrap.variant-a.down, .cw-chart-session.variant-a.down { --bar-accent: var(--fn-danger); }
.cw-sess-bar-wrap.variant-a.flat, .cw-chart-session.variant-a.flat { --bar-accent: var(--fn-cat-blue); }

.cw-sess-bar { position: relative; height: 28px; overflow: visible; }
.cw-sess-bar .track, .cw-sess-bar .prev, .cw-sess-bar .day, .cw-sess-bar .now { position: absolute; border-radius: var(--fn-radius-pill); }
.cw-sess-bar .track { z-index: 1; top: 10px; left: 0; right: 0; height: 8px; border: 1px solid color-mix(in srgb, var(--bar-accent) 46%, transparent); background: linear-gradient(90deg, color-mix(in srgb, var(--bar-accent) 12%, transparent), color-mix(in srgb, var(--bar-accent) 32%, transparent)); }
.cw-sess-bar .prev { z-index: 2; top: 10px; height: 8px; background: color-mix(in srgb, var(--fn-text-secondary) 22%, transparent); }
.cw-sess-bar .day { z-index: 3; top: 7px; height: 14px; border: 1px solid color-mix(in srgb, var(--bar-accent) 72%, transparent); background: color-mix(in srgb, var(--bar-accent) 26%, transparent); }
.cw-sess-bar .now { z-index: 4; top: 3px; width: 2px; height: 22px; border-radius: 0; background: var(--bar-accent); transform: translateX(-50%); }
.cw-sess-bar .now::before { content: ""; position: absolute; left: -4px; top: -5px; width: 10px; height: 10px; border-radius: 50%; background: var(--bar-accent); border: 2px solid var(--fn-bg-muted); }
.cw-sess-bar .now::after { content: none; display: none; }

/* In-Chart-Overlay (oben im Chart): gleiche 1:1-Optik, nur dunklerer Punktrand für Kontrast. */
.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 .now::before { 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: 9px; font-size: 11px; color: var(--fn-text-tertiary); }
.cw-sess-legend i { display: inline-block; width: 12px; height: 8px; border-radius: 3px; margin-right: 5px; vertical-align: middle; }
.cw-sess-legend .lg-prev i { background: color-mix(in srgb, var(--fn-text-secondary) 22%, transparent); }
.cw-sess-legend .lg-day i { background: color-mix(in srgb, var(--bar-accent) 26%, transparent); border: 1px solid color-mix(in srgb, var(--bar-accent) 72%, transparent); }
.cw-sess-legend .lg-now i { width: 2px; height: 12px; background: var(--bar-accent); border-radius: 0; }

/* 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;
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    flex-direction: column;
}
.cw-chart-wrap .cw-chart-host {
    flex: 1 1 auto;
    min-height: 0;
}
.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);
}

table.cw-series tr.selected td {
    background: var(--fn-accent-soft);
}
table.cw-series tr.selected td:first-child {
    color: var(--fn-primary);
}

/* ChartPanel-Abnahme 28.06.2026: flaches Vergleichsgrid + vier Detailkacheln. */
table.cw-series {
    margin-top: 12px;
    margin-bottom: 14px;
    border: var(--fn-border-width) solid var(--fn-border);
    border-radius: var(--fn-radius);
    overflow: hidden;
    background: var(--fn-bg-alt);
}
table.cw-series th {
    background: var(--fn-bg-alt);
    color: var(--fn-text);
    border-bottom-color: var(--fn-border-strong);
}
table.cw-series td {
    background: var(--fn-bg-muted);
}
table.cw-series tr.selected td {
    background: color-mix(in srgb, var(--fn-cat-blue) 16%, var(--fn-bg-muted));
    border-bottom-color: var(--fn-accent-line);
}
table.cw-series tr.selected td:first-child {
    color: var(--fn-success);
}

.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; }
}

