/*
 * 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;
}
.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;
}
.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;
}
.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; }

.cw-toolbar {
    display: flex; align-items: center; gap: 10px; padding: 10px 16px;
    border-bottom: var(--fn-border-width) solid var(--fn-border); flex-wrap: wrap; flex: 0 0 auto;
}
.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;
}
.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);
}

table.cw-series {
    width: calc(100% - 32px); margin: 14px 16px 16px;
    border-collapse: collapse; font-size: 12px; table-layout: fixed; flex: 0 0 auto;
}
table.cw-series th {
    text-align: left; font-weight: var(--fn-font-weight-bold); color: var(--fn-text-tertiary);
    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-muted);
}
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;
}
table.cw-series td:first-child { color: var(--fn-cat-blue); }
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; }

/* ===== 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; }

.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; }
.cw-sess-bar { position: relative; height: 26px; }
.cw-sess-bar .track { position: absolute; top: 9px; left: 0; right: 0; height: 8px; border-radius: var(--fn-radius-pill); background: var(--fn-bg); border: 1px solid var(--fn-border); }
.cw-sess-bar .prev { position: absolute; top: 9px; height: 8px; border-radius: var(--fn-radius-pill); background: color-mix(in srgb, var(--fn-text-secondary) 40%, transparent); }
.cw-sess-bar .day { position: absolute; top: 7px; height: 12px; border-radius: var(--fn-radius-pill); background: var(--fn-accent-soft); border: 1px solid var(--fn-cat-blue); }
.cw-sess-bar .now { position: absolute; top: 2px; width: 2px; height: 22px; background: var(--fn-text); }
.cw-sess-bar .now::after { content: ""; position: absolute; top: -5px; left: -4px; width: 10px; height: 10px; border-radius: var(--fn-radius-round); background: var(--fn-text); border: 2px solid var(--fn-bg-muted); }
.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) 50%, transparent); }
.cw-sess-legend .lg-day i { background: var(--fn-accent-soft); border: 1px solid var(--fn-cat-blue); }
.cw-sess-legend .lg-now i { width: 2px; height: 12px; background: var(--fn-text); }
