/* ──────────────────────────────────────────────────────────────────
   Loksen · Fjordwerk-Designsprache (Hell)
   Rams trifft Rorbu. Funktionsstrenge + nordische Ruhe.
   ────────────────────────────────────────────────────────────────── */

/* ── IBM Plex (lokal vendored) ──────────────────────────────────── */
@font-face {
  font-family: 'IBM Plex Sans';
  font-weight: 400; font-style: normal; font-display: swap;
  src: url('/static/vendor/fonts/ibm-plex-sans-latin-400-normal.woff2') format('woff2');
}
@font-face {
  font-family: 'IBM Plex Sans';
  font-weight: 500; font-style: normal; font-display: swap;
  src: url('/static/vendor/fonts/ibm-plex-sans-latin-500-normal.woff2') format('woff2');
}
@font-face {
  font-family: 'IBM Plex Sans';
  font-weight: 600; font-style: normal; font-display: swap;
  src: url('/static/vendor/fonts/ibm-plex-sans-latin-600-normal.woff2') format('woff2');
}
@font-face {
  font-family: 'IBM Plex Sans';
  font-weight: 700; font-style: normal; font-display: swap;
  src: url('/static/vendor/fonts/ibm-plex-sans-latin-700-normal.woff2') format('woff2');
}
@font-face {
  font-family: 'IBM Plex Sans Condensed';
  font-weight: 500; font-style: normal; font-display: swap;
  src: url('/static/vendor/fonts/ibm-plex-sans-condensed-latin-500-normal.woff2') format('woff2');
}
@font-face {
  font-family: 'IBM Plex Sans Condensed';
  font-weight: 600; font-style: normal; font-display: swap;
  src: url('/static/vendor/fonts/ibm-plex-sans-condensed-latin-600-normal.woff2') format('woff2');
}
@font-face {
  font-family: 'IBM Plex Mono';
  font-weight: 400; font-style: normal; font-display: swap;
  src: url('/static/vendor/fonts/ibm-plex-mono-latin-400-normal.woff2') format('woff2');
}
@font-face {
  font-family: 'IBM Plex Mono';
  font-weight: 500; font-style: normal; font-display: swap;
  src: url('/static/vendor/fonts/ibm-plex-mono-latin-500-normal.woff2') format('woff2');
}

/* ── Reset ───────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

/* ── Tokens ─────────────────────────────────────────────────────── */
:root {
  /* Flächen */
  --fw-paper:    #F8F4E9;
  --fw-paper-2:  #F1ECDD;
  --fw-card:     #FDFAF1;

  /* Tinten */
  --fw-ink:      #1B1A17;
  --fw-ink-2:    #3C3934;
  --fw-slate:    #6E6A60;

  /* Linien */
  --fw-mist:     #C9C3B3;
  --fw-mist-2:   #E2DCCB;

  /* Akzente */
  --fw-signal:   #B05B22;   /* Loksen Sand */
  --fw-tiefe:    #1F4A36;   /* Loksen Tang, positiv */
  --fw-moos:     #586B3F;
  --fw-rot:      #A23528;
  --fw-gelb:     #C9A02A;

  /* Fonts */
  --fw-font:      'IBM Plex Sans', system-ui, sans-serif;
  --fw-font-cond: 'IBM Plex Sans Condensed', 'IBM Plex Sans', sans-serif;
  --fw-font-mono: 'IBM Plex Mono', ui-monospace, monospace;

  /* Aliase auf Altklassen (Damit altes CSS+JS weiter rendert) */
  --bg:           var(--fw-paper);
  --surface:      var(--fw-card);
  --surface-2:    var(--fw-paper-2);
  --border:       var(--fw-mist-2);
  --border-strong:var(--fw-mist);
  --text:         var(--fw-ink);
  --text-2:       var(--fw-ink-2);
  --text-3:       var(--fw-slate);
  --accent:       var(--fw-signal);
  --accent-hover: var(--fw-signal);
  --accent-light: #F1E4D7;
  --green:        var(--fw-tiefe);
  --green-light:  #DEE5DC;
  --red:          var(--fw-rot);
  --red-light:    #F1DAD5;
  --orange:       var(--fw-signal);
  --orange-light: #F1E4D7;
  --yellow:       var(--fw-gelb);
  --radius:       0px;
  --radius-sm:    0px;
  --shadow:       none;
  --shadow-md:    none;
  --transition:   0.12s ease;
}

/* ── Dunkles Fjordwerk-Schema ───────────────────────────────────── */
/* Klasse `fw-dark` am <html>-Element überschreibt alle Token. Komponenten
   referenzieren nur Variablen, brauchen keine separate Logik. */
html.fw-dark {
  --fw-paper:    #15130E;
  --fw-paper-2:  #1E1B14;
  --fw-card:     #26221B;

  --fw-ink:      #EFEAD9;
  --fw-ink-2:    #C5BEA8;
  --fw-slate:    #8F8876;

  /* Trennlinien im Dunklen HELLER als das Papier (umgekehrt zum Hellschema) */
  --fw-mist:     #4A4438;
  --fw-mist-2:   #34302A;

  /* Akzente: OKLCH-L ~0.65, leuchten wie LEDs auf dunklem Panel */
  --fw-signal:   #D17A3F;
  --fw-tiefe:    #4E9376;
  --fw-moos:     #94A86B;
  --fw-rot:      #C76250;
  --fw-gelb:     #D9B852;

  /* Alt-Aliase nach Dunkel mappen */
  --accent-light: #2A2218;       /* signal × 18% Bronze-Tönung */
  --green-light:  #243429;       /* tiefe × 18% */
  --red-light:    #3A211B;       /* rot × 18% */
  --orange-light: #2A2218;
}

html { font-size: 15px; }

body {
  font-family: var(--fw-font);
  background: var(--fw-paper);
  color: var(--fw-ink);
  line-height: 1.55;
  font-feature-settings: "kern" 1;
  -webkit-font-smoothing: antialiased;
}

/* ── Typografie-Hilfsklassen ─────────────────────────────────────── */
.eyebrow,
.nav-label,
.fk-label, .ind-card-label, .fi-label, .tk-label,
.cash-pos-currency, .news-sentiment, .tax-type-badge,
.summary-tile .label, .cash-balance-display .label,
thead th, .badge {
  font-family: var(--fw-font-mono);
  font-weight: 500;
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fw-slate);
}

.mono-data,
.summary-tile .value, .fifo-kv .fk-value, .ind-card-value,
.fund-item .fi-value, .tax-kv .tk-value, .cash-balance-display .value,
.cash-pos-amount,
td.mono {
  font-family: var(--fw-font-mono);
  font-weight: 500;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0;
}

.display, h1, h2, h3, h4, .card-title, .modal-title, .topbar-title, .fund-name {
  font-family: var(--fw-font-cond);
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--fw-ink);
}

h1 { font-size: 28px; line-height: 1.10; }
h2 { font-size: 22px; line-height: 1.15; }
h3 { font-size: 17px; line-height: 1.20; }

/* ── App Shell ──────────────────────────────────────────────────── */
.app-shell { display: flex; min-height: 100vh; background: var(--fw-paper); }

/* ── Sidebar ────────────────────────────────────────────────────── */
.sidebar {
  width: 220px;
  min-width: 220px;
  background: var(--fw-paper-2);
  border-right: 1px solid var(--fw-mist-2);
  display: flex;
  flex-direction: column;
  padding: 0;
  position: sticky;
  top: 0;
  height: 100vh;
  overflow: hidden;
}

.sidebar-logo, .brand-block {
  padding: 22px 20px 18px;
  border-bottom: 1px solid var(--fw-mist-2);
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.brand-block .brand-row { display: flex; align-items: center; gap: 12px; }
.brand-block .brand-mark { width: 24px; height: 28px; flex-shrink: 0; }
.brand-block .wordmark {
  font-family: var(--fw-font-cond);
  font-weight: 600;
  font-size: 22px;
  letter-spacing: -0.01em;
  color: var(--fw-ink);
  text-transform: lowercase;
}
.brand-block .tagline {
  font-family: var(--fw-font-mono);
  font-weight: 500;
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: lowercase;
  color: var(--fw-signal);
  line-height: 1.4;
}
.sidebar-logo h1 {
  font-family: var(--fw-font-cond);
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--fw-ink);
  text-transform: lowercase;
}
.sidebar-logo span {
  font-family: var(--fw-font-mono);
  font-weight: 500;
  font-size: 10px;
  letter-spacing: 0.14em;
  color: var(--fw-signal);
  display: block;
  margin-top: 4px;
  text-transform: uppercase;
}

.sidebar-nav {
  flex: 1;
  padding: 12px 0;
  overflow-y: auto;
}

.nav-label {
  padding: 14px 20px 6px;
  color: var(--fw-slate);
}

.nav-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 9px 17px 9px 20px;
  border-left: 3px solid transparent;
  cursor: pointer;
  font-family: var(--fw-font);
  font-size: 14px;
  font-weight: 400;
  color: var(--fw-ink-2);
  transition: background var(--transition), border-color var(--transition), color var(--transition);
  user-select: none;
}
.nav-item:hover { background: var(--fw-card); color: var(--fw-ink); }
.nav-item.active {
  background: var(--fw-paper);
  color: var(--fw-ink);
  border-left-color: var(--fw-signal);
  font-weight: 500;
}
.nav-item .icon {
  font-family: var(--fw-font-mono);
  font-size: 14px;
  width: 18px;
  text-align: center;
  color: var(--fw-slate);
  letter-spacing: 0;
  text-transform: none;
}
.nav-item.active .icon { color: var(--fw-ink); }

.sidebar-footer {
  padding: 12px 20px 14px;
  border-top: 1px solid var(--fw-mist-2);
  font-family: var(--fw-font-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--fw-slate);
}
#checker-status { font-family: var(--fw-font-mono); font-size: 10px; letter-spacing: 0.08em; color: var(--fw-slate); }

/* ── Main / Topbar ──────────────────────────────────────────────── */
.main {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-width: 0;
  overflow: hidden;
}

.topbar {
  height: 52px;
  background: var(--fw-paper);
  border-bottom: 1px solid var(--fw-mist-2);
  display: flex;
  align-items: center;
  padding: 0 24px;
  gap: 16px;
  position: sticky;
  top: 0;
  z-index: 10;
}

.topbar-title {
  font-family: var(--fw-font-cond);
  font-size: 18px;
  font-weight: 600;
  letter-spacing: -0.01em;
  flex: 1;
  color: var(--fw-ink);
}

.content {
  flex: 1;
  padding: 24px;
  overflow-y: auto;
  background: var(--fw-paper);
}

/* ── Cards / Panels ─────────────────────────────────────────────── */
.card, .panel {
  background: var(--fw-card);
  border: 1px solid var(--fw-mist-2);
  border-radius: 0;
  box-shadow: none;
  overflow: hidden;
}
.card-header {
  padding: 14px 18px 12px;
  border-bottom: 1px solid var(--fw-mist-2);
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--fw-paper-2);
}
.card-title {
  font-family: var(--fw-font-cond);
  font-size: 16px;
  font-weight: 600;
  letter-spacing: -0.005em;
  flex: 1;
  color: var(--fw-ink);
}
.card-body { padding: 18px; }

/* ── Summary tiles ──────────────────────────────────────────────── */
.summary-bar {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 12px;
  margin-bottom: 20px;
}
.summary-tile {
  background: var(--fw-card);
  border: 1px solid var(--fw-mist-2);
  border-radius: 0;
  padding: 14px 16px;
  box-shadow: none;
  animation: fadeUp 0.25s ease both;
}
.summary-tile .label {
  font-family: var(--fw-font-mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fw-slate);
  margin-bottom: 6px;
}
.summary-tile .value {
  font-family: var(--fw-font-mono);
  font-size: 18px;
  font-weight: 500;
  letter-spacing: 0;
  font-variant-numeric: tabular-nums;
  color: var(--fw-ink);
}
.summary-tile .value.positive { color: var(--fw-tiefe); }
.summary-tile .value.negative { color: var(--fw-rot); }
.summary-tile-spark { display: flex; flex-direction: column; justify-content: space-between; }
.summary-tile-spark canvas { display: block; margin-top: 6px; }

/* ── Tabs (Rocker-Stil) ─────────────────────────────────────────── */
.tab-bar {
  display: flex;
  gap: 0;
  margin-bottom: 16px;
  border: 1px solid var(--fw-mist);
  width: fit-content;
}
.tab-btn {
  padding: 7px 14px;
  border: none;
  border-right: 1px solid var(--fw-mist);
  background: var(--fw-card);
  color: var(--fw-ink-2);
  font-family: var(--fw-font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background var(--transition), color var(--transition);
  border-radius: 0;
}
.tab-btn:last-child { border-right: none; }
.tab-btn:hover { background: var(--fw-paper-2); color: var(--fw-ink); }
.tab-btn.active {
  background: var(--fw-ink);
  color: var(--fw-paper);
  border-color: var(--fw-ink);
}

/* ── Tables ─────────────────────────────────────────────────────── */
.table-wrap { overflow-x: auto; }
table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13.5px;
  font-family: var(--fw-font);
}
thead th {
  text-align: left;
  padding: 8px 12px;
  font-family: var(--fw-font-mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fw-slate);
  border-bottom: 1px solid var(--fw-mist);
  white-space: nowrap;
  background: var(--fw-paper-2);
}
thead th[data-sort] {
  cursor: pointer;
  user-select: none;
  padding-right: 22px;
  position: relative;
  transition: color var(--transition);
}
thead th[data-sort]:hover { color: var(--fw-ink); }
thead th[data-sort]::after {
  content: "↕";
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 11px;
  letter-spacing: 0;
  opacity: 0.30;
  color: var(--fw-slate);
}
thead th[data-sort]:hover::after { opacity: 0.65; }
thead th.sort-asc::after  { content: "↑"; opacity: 1; color: var(--fw-signal); }
thead th.sort-desc::after { content: "↓"; opacity: 1; color: var(--fw-signal); }
thead th.sort-asc, thead th.sort-desc { color: var(--fw-ink); }

/* Numerische Spalten rechtsbündig (Zahlen vertikal alignen) */
thead th.num, td.num { text-align: right; }
/* Bei sortierbarem rechtsbündigem Header bleibt Platz für Pfeil rechts;
   der Text rückt entsprechend nach links */
thead th.num[data-sort] { padding-right: 22px; }

/* ── Screener-Tabelle: Spalten-Tuning + Responsive ───────────────── */
#scr-results { width: 100%; table-layout: auto; }
#scr-results .col-ticker   { min-width: 80px; }
#scr-results .col-name     { min-width: 120px; max-width: 240px; overflow: hidden; text-overflow: ellipsis; }
#scr-results th.num,
#scr-results td.num        { min-width: 70px; white-space: nowrap; }
#scr-results th[data-sort="mcap"],
#scr-results td.num:nth-child(8) { min-width: 90px; }
#scr-results .col-sector   { min-width: 110px; max-width: 180px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
#scr-results th.col-action,
#scr-results td.col-action { white-space: normal; text-align: right; padding: 6px 12px; }
#scr-results td.col-action .btn { padding: 3px 7px; font-size: 10px; margin: 1px 0 1px 4px; }

/* table-wrap als Scroll-Container – horizontal scrollbar bei Engpass */
.table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }

/* ── Backtest Run-Historie: Aktionsspalte sticky rechts ──────────────
   Durch die Steuer-Spalten (Brutto/Steuer/Netto/Quote) ist die Tabelle
   breiter als der Container; die Aktions-Buttons (Ansehen/Löschen) bleiben
   so immer sichtbar statt rechts abgeschnitten. var(--fw-card) hält den
   Hintergrund theme-korrekt (hell + dunkel). */
#bt-runs-table th:last-child,
#bt-runs-table td:last-child {
  position: sticky;
  right: 0;
  background: var(--fw-card);
  box-shadow: -1px 0 0 var(--fw-mist);
  white-space: nowrap;
  z-index: 1;
}
#bt-runs-table thead th:last-child {
  background: var(--fw-paper-2);
  z-index: 2;
}
#bt-runs-table tbody tr:hover td:last-child { background: var(--fw-paper-2); }

/* ── Tablet / kleine Breiten: Aktion-Buttons stapeln, Beta verbergen ── */
@media (max-width: 1200px) {
  #scr-results td.col-action .btn { display: block; width: 100%; margin: 2px 0; text-align: center; }
}
@media (max-width: 1024px) {
  /* Tooltip-Erläuterung erklärt das KPI weiter – Beta darf weichen */
  #scr-results thead th[data-sort="beta"],
  #scr-results tbody td:nth-child(7) { display: none; }
}
@media (max-width: 820px) {
  /* Sehr schmal: zusätzlich Div % verbergen */
  #scr-results thead th[data-sort="div"],
  #scr-results tbody td:nth-child(6) { display: none; }
  #scr-results .col-name { max-width: 160px; }
  #scr-results .col-sector { max-width: 140px; }
}
tbody tr {
  border-bottom: 1px solid var(--fw-mist-2);
  transition: background var(--transition);
  cursor: pointer;
}
tbody tr:last-child { border-bottom: none; }
tbody tr:hover { background: var(--fw-paper-2); }
tbody tr.selected { background: var(--fw-paper-2); box-shadow: inset 3px 0 0 var(--fw-signal); }
td {
  padding: 9px 12px;
  white-space: nowrap;
  color: var(--fw-ink);
  font-family: var(--fw-font);
}
td.mono {
  font-family: var(--fw-font-mono);
  font-variant-numeric: tabular-nums;
  font-size: 13px;
  font-weight: 500;
}
td.ticker {
  font-family: var(--fw-font-mono);
  font-weight: 500;
  color: var(--fw-ink);
  letter-spacing: 0.02em;
}
td.positive { color: var(--fw-tiefe); font-weight: 500; }
td.negative { color: var(--fw-rot); font-weight: 500; }
td.neutral { color: var(--fw-slate); }
td.spark-cell {
  padding: 4px 12px;
  vertical-align: middle;
  width: 100px;
  max-width: 100px;
  overflow: hidden;
}

/* ── Sparklines ─────────────────────────────────────────────────── */
.sparkline-canvas {
  display: block;
  image-rendering: crisp-edges;
  max-width: 100%;
  height: auto;
}

/* ── Buttons ────────────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 13px;
  border-radius: 0;
  font-family: var(--fw-font);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  border: 1px solid var(--fw-ink);
  background: var(--fw-card);
  color: var(--fw-ink);
  transition: background var(--transition), color var(--transition), border-color var(--transition);
  white-space: nowrap;
  letter-spacing: 0;
}
.btn:hover { background: var(--fw-paper-2); }
.btn:active { transform: translateY(1px); }

.btn-signal, .btn-primary {
  background: var(--fw-signal);
  color: var(--fw-paper);
  border-color: var(--fw-signal);
  font-family: var(--fw-font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  padding: 8px 14px;
}
.btn-signal:hover, .btn-primary:hover {
  background: var(--fw-ink);
  border-color: var(--fw-ink);
  color: var(--fw-paper);
  transform: none;
  box-shadow: none;
}

.btn-tiefe {
  background: var(--fw-tiefe);
  color: var(--fw-paper);
  border-color: var(--fw-tiefe);
  font-family: var(--fw-font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  padding: 8px 14px;
}
.btn-tiefe:hover { background: var(--fw-ink); border-color: var(--fw-ink); }

.btn-solid {
  background: var(--fw-ink);
  color: var(--fw-paper);
  border-color: var(--fw-ink);
  font-family: var(--fw-font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  padding: 8px 14px;
}

.btn-outline, .btn-secondary {
  background: transparent;
  border: 1px solid var(--fw-ink);
  color: var(--fw-ink);
}
.btn-outline:hover, .btn-secondary:hover { background: var(--fw-paper-2); }

.btn-soft {
  background: var(--fw-paper-2);
  border: 1px solid var(--fw-mist);
  color: var(--fw-ink);
}
.btn-soft:hover { background: var(--fw-card); border-color: var(--fw-ink); }

.btn-ghost, .btn-icon {
  background: transparent;
  border: 1px solid transparent;
  color: var(--fw-slate);
  padding: 6px 8px;
}
.btn-ghost:hover, .btn-icon:hover { color: var(--fw-ink); background: var(--fw-paper-2); }

.btn-danger, .btn-rot {
  background: var(--fw-rot);
  color: var(--fw-paper);
  border-color: var(--fw-rot);
  font-family: var(--fw-font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  padding: 8px 14px;
}
.btn-danger:hover, .btn-rot:hover { background: var(--fw-ink); border-color: var(--fw-ink); }

.btn-sell {
  background: transparent;
  color: var(--fw-rot);
  border: 1px solid var(--fw-rot);
  font-family: var(--fw-font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  padding: 7px 13px;
}
.btn-sell:hover { background: var(--fw-rot); color: var(--fw-paper); }

.btn-sm { padding: 4px 9px; font-size: 11px; border-radius: 0; }

.btn-group { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }

/* ── Badges ─────────────────────────────────────────────────────── */
.badge {
  display: inline-flex;
  align-items: center;
  padding: 2px 7px;
  border: 1px solid var(--fw-mist);
  border-radius: 0;
  font-family: var(--fw-font-mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  background: var(--fw-paper-2);
  color: var(--fw-ink-2);
}
.badge-buy   { background: var(--fw-tiefe); color: var(--fw-paper); border-color: var(--fw-tiefe); }
.badge-sell  { background: var(--fw-rot);   color: var(--fw-paper); border-color: var(--fw-rot); }
.badge-neutral { background: var(--fw-paper-2); color: var(--fw-slate); border-color: var(--fw-mist); }
.badge-gain  { background: var(--fw-tiefe); color: var(--fw-paper); border-color: var(--fw-tiefe); }
.badge-loss  { background: var(--fw-rot);   color: var(--fw-paper); border-color: var(--fw-rot); }

/* ── Tag / Chip ─────────────────────────────────────────────────── */
.tag, .chip {
  display: inline-flex;
  align-items: center;
  padding: 3px 8px;
  border: 1px solid var(--fw-mist);
  border-radius: 0;
  font-family: var(--fw-font-mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  background: var(--fw-card);
  color: var(--fw-ink-2);
  cursor: pointer;
}
.tag:hover, .chip:hover { border-color: var(--fw-ink); color: var(--fw-ink); }
.tag.active, .chip.active {
  background: var(--fw-ink);
  color: var(--fw-paper);
  border-color: var(--fw-ink);
}

/* ── Lamp (LED) ─────────────────────────────────────────────────── */
.lamp {
  display: inline-block;
  width: 8px; height: 8px;
  border-radius: 50%;
  border: 1px solid var(--fw-mist);
  background: var(--fw-mist-2);
}
.lamp.on, .lamp.bereit { background: var(--fw-moos); border-color: var(--fw-moos); box-shadow: 0 0 4px rgba(88,107,63,0.55); }
.lamp.aktiv  { background: var(--fw-signal); border-color: var(--fw-signal); box-shadow: 0 0 4px rgba(176,91,34,0.55); }
.lamp.aus    { background: var(--fw-rot);    border-color: var(--fw-rot);    box-shadow: 0 0 4px rgba(162,53,40,0.55); }

/* ── Forms ──────────────────────────────────────────────────────── */
.form-group { margin-bottom: 14px; }
label {
  display: block;
  font-family: var(--fw-font-mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fw-slate);
  margin-bottom: 5px;
}
input[type=text], input[type=number], input[type=email],
input[type=password], input[type=date], select, textarea {
  width: 100%;
  padding: 8px 11px;
  border: 1px solid var(--fw-ink);
  border-radius: 0;
  font-size: 14px;
  font-family: var(--fw-font);
  color: var(--fw-ink);
  background: var(--fw-paper);
  transition: border-color var(--transition);
  outline: none;
}
/* select bekommt eigenen Pfeil per background-image, daher appearance:none.
   Text/Number/Date behalten das native Picker-Icon (z.B. Kalender, Stepper). */
select, input[type=text], input[type=number], input[type=email], input[type=password], textarea {
  appearance: none;
  -webkit-appearance: none;
}
input:focus, select:focus, textarea:focus {
  border-color: var(--fw-signal);
  box-shadow: none;
}
input[type=text], input[type=number], input[type=email],
input[type=password], input[type=date] {
  font-family: var(--fw-font-mono);
  font-variant-numeric: tabular-nums;
}
/* Kalender-Picker-Icon im Loksen-Farbschema */
input[type=date]::-webkit-calendar-picker-indicator {
  cursor: pointer;
  filter: invert(38%) sepia(35%) saturate(900%) hue-rotate(355deg) brightness(96%) contrast(91%);
  opacity: 0.75;
}
input[type=date]::-webkit-calendar-picker-indicator:hover { opacity: 1; }
select {
  font-family: var(--fw-font);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236E6A60' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 10px center;
  padding-right: 30px;
}
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.form-row-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; }
.form-hint { font-size: 12px; color: var(--fw-slate); margin-top: 4px; font-family: var(--fw-font); text-transform: none; letter-spacing: 0; }

/* ── Toggle (mechanischer Rocker) ───────────────────────────────── */
.toggle-row { display: flex; align-items: center; justify-content: space-between; }
.toggle { position: relative; width: 44px; height: 22px; flex-shrink: 0; }
.toggle input { opacity: 0; width: 0; height: 0; }
.toggle-slider {
  position: absolute; inset: 0;
  background: var(--fw-paper-2);
  border: 1px solid var(--fw-ink);
  border-radius: 0;
  transition: background var(--transition);
  cursor: pointer;
}
.toggle-slider::before {
  content: "";
  position: absolute;
  width: 18px; height: 18px;
  left: 1px; top: 1px;
  background: var(--fw-ink);
  border-radius: 0;
  transition: transform var(--transition), background var(--transition);
}
.toggle input:checked + .toggle-slider { background: var(--fw-ink); }
.toggle input:checked + .toggle-slider::before { transform: translateX(22px); background: var(--fw-paper); }

/* ── Autocomplete ───────────────────────────────────────────────── */
.autocomplete-wrap { position: relative; width: 100%; }
.autocomplete-dropdown {
  position: absolute;
  top: calc(100% + 2px);
  left: 0; right: 0;
  background: var(--fw-card);
  border: 1px solid var(--fw-ink);
  border-radius: 0;
  box-shadow: none;
  z-index: 200;
  max-height: 280px;
  overflow-y: auto;
  display: none;
}
.autocomplete-dropdown.open { display: block; }
.autocomplete-item {
  padding: 9px 12px;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 10px;
  border-bottom: 1px solid var(--fw-mist-2);
  background: var(--fw-card);
}
.autocomplete-item:last-child { border-bottom: none; }
.autocomplete-item:hover, .autocomplete-item.focused { background: var(--fw-paper-2); }
.ac-symbol {
  font-family: var(--fw-font-mono);
  font-weight: 500;
  font-size: 13px;
  color: var(--fw-ink);
  min-width: 80px;
  letter-spacing: 0.02em;
}
.ac-name {
  font-size: 13px;
  color: var(--fw-ink-2);
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.ac-meta {
  font-family: var(--fw-font-mono);
  font-size: 10px;
  color: var(--fw-slate);
  letter-spacing: 0.10em;
  text-transform: uppercase;
  white-space: nowrap;
}
.ac-loading {
  padding: 14px;
  text-align: center;
  color: var(--fw-slate);
  font-family: var(--fw-font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.chart-ac-wrap { position: relative; display: flex; align-items: center; }
.chart-ac-wrap .autocomplete-dropdown { min-width: 320px; }

/* ── Modal ──────────────────────────────────────────────────────── */
.modal-backdrop {
  position: fixed; inset: 0;
  background: rgba(27,26,23,0.45);
  backdrop-filter: none;
  z-index: 100;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.modal-backdrop.open { display: flex; animation: fadeIn 0.12s ease; }
.modal {
  background: var(--fw-card);
  border: 1px solid var(--fw-ink);
  border-radius: 0;
  box-shadow: none;
  width: 100%;
  max-width: 520px;
  max-height: 90vh;
  overflow-y: auto;
  animation: scaleIn 0.14s ease;
}
.modal-lg { max-width: 700px; }
.modal-header {
  padding: 18px 22px 14px;
  border-bottom: 1px solid var(--fw-mist);
  display: flex;
  align-items: center;
  background: var(--fw-paper-2);
}
.modal-title {
  font-family: var(--fw-font-cond);
  font-size: 18px;
  font-weight: 600;
  flex: 1;
  letter-spacing: -0.005em;
  color: var(--fw-ink);
}
.modal-body { padding: 18px 22px; }
.modal-footer {
  padding: 14px 22px 18px;
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  border-top: 1px solid var(--fw-mist-2);
  background: var(--fw-paper-2);
}

/* ── FIFO / Sell result ─────────────────────────────────────────── */
.fifo-result {
  background: var(--fw-paper-2);
  border: 1px solid var(--fw-mist);
  border-radius: 0;
  padding: 14px;
  margin-top: 14px;
}
.fifo-result-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-top: 10px;
}
.fifo-kv { display: flex; flex-direction: column; gap: 2px; }
.fifo-kv .fk-label {
  font-family: var(--fw-font-mono);
  font-size: 10px;
  color: var(--fw-slate);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.14em;
}
.fifo-kv .fk-value {
  font-family: var(--fw-font-mono);
  font-size: 16px;
  font-weight: 500;
  color: var(--fw-ink);
  font-variant-numeric: tabular-nums;
}
.fifo-kv .fk-value.positive { color: var(--fw-tiefe); }
.fifo-kv .fk-value.negative { color: var(--fw-rot); }

/* ── Charts ─────────────────────────────────────────────────────── */
.chart-page-layout {
  display: flex;
  gap: 16px;
  align-items: flex-start;
}
.chart-main {
  flex: 0 0 60%;
  min-width: 0;
}
.chart-info-panel {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
  max-height: calc(100vh - 110px);
  overflow-y: auto;
}

#chart-container {
  background: var(--fw-card);
  border: 1px solid var(--fw-mist);
  border-radius: 0;
  box-shadow: none;
  overflow: hidden;
  position: relative;
}
.chart-toolbar {
  padding: 10px 14px;
  border-bottom: 1px solid var(--fw-mist-2);
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  background: var(--fw-paper-2);
}
.chart-ticker-input {
  font-family: var(--fw-font-mono);
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0.04em;
  border: none;
  outline: none;
  background: transparent;
  width: 110px;
  color: var(--fw-ink);
  text-transform: uppercase;
}
.chart-ticker-input::placeholder { color: var(--fw-slate); }

.period-btn {
  padding: 4px 9px;
  border-radius: 0;
  font-family: var(--fw-font-mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  cursor: pointer;
  border: 1px solid var(--fw-mist);
  background: transparent;
  color: var(--fw-slate);
  transition: background var(--transition), color var(--transition), border-color var(--transition);
}
.period-btn:hover { color: var(--fw-ink); border-color: var(--fw-ink); }
.period-btn.active {
  background: var(--fw-ink);
  color: var(--fw-paper);
  border-color: var(--fw-ink);
}

.indicator-toggle, .ind-toggle {
  padding: 3px 8px;
  border-radius: 0;
  font-family: var(--fw-font-mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  cursor: pointer;
  border: 1px solid var(--fw-mist);
  background: var(--fw-card);
  color: var(--fw-slate);
  transition: all var(--transition);
}
.indicator-toggle:hover, .ind-toggle:hover { color: var(--fw-ink); border-color: var(--fw-ink); }
.indicator-toggle.on, .ind-toggle.on {
  background: rgba(176,91,34,0.10);
  color: var(--fw-signal);
  border-color: var(--fw-signal);
}

.chart-wrap { padding: 0; position: relative; }
#price-chart, #rsi-chart, #macd-chart { width: 100%; display: block; }

/* Universe-Chip · Screener + Backtesting · Fjordwerk-konform (theme-aware) */
.uni-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 11px;
  border: 1px solid var(--fw-mist);
  border-radius: 0;
  background: var(--fw-card);
  cursor: pointer;
  font-family: var(--fw-font);
  font-size: 12.5px;
  color: var(--fw-ink-2);
  transition: background var(--transition), color var(--transition), border-color var(--transition);
  user-select: none;
}
.uni-chip:hover { border-color: var(--fw-ink); color: var(--fw-ink); }
.uni-chip input[type=checkbox] {
  margin: 0;
  width: 12px;
  height: 12px;
  accent-color: var(--fw-signal);
}
.uni-chip .uni-label {
  font-family: var(--fw-font-mono);
  font-size: 11px;
  letter-spacing: 0.05em;
}
.uni-chip .uni-size {
  font-family: var(--fw-font-mono);
  font-size: 10px;
  color: var(--fw-slate);
  letter-spacing: 0;
}
.uni-chip.active {
  background: var(--fw-paper-2);
  border-color: var(--fw-signal);
  color: var(--fw-signal);
}
.uni-chip.active .uni-size { color: color-mix(in srgb, var(--fw-signal) 65%, var(--fw-slate)); }

/* Chart-Legende oben links im Chart, Overlay */
.chart-legend {
  position: absolute;
  top: 14px;
  left: 22px;
  z-index: 3;
  /* paper mit 92 % Deckkraft — funktioniert hell + dunkel über color-mix */
  background: color-mix(in srgb, var(--fw-paper) 92%, transparent);
  border: 1px solid var(--fw-mist);
  padding: 6px 10px;
  font-family: var(--fw-font-mono);
  font-size: 10px;
  letter-spacing: 0.04em;
  color: var(--fw-ink-2);
  display: flex;
  flex-direction: column;
  gap: 3px;
  pointer-events: none;
  max-width: 220px;
}
.chart-legend:empty { display: none; }
.chart-legend .leg-row { display: flex; align-items: center; gap: 8px; line-height: 1.3; }
.chart-legend .leg-sw {
  display: inline-block;
  width: 18px;
  height: 0;
  border-top-width: 2px;
  border-top-style: solid;
  flex-shrink: 0;
}
.chart-legend .leg-sw.dashed { border-top-style: dashed; }
.chart-legend .leg-label { text-transform: uppercase; letter-spacing: 0.10em; }
.chart-legend .leg-price { color: var(--fw-ink); font-weight: 500; }

/* Loksen-Watermark unten links im Chart */
.chart-watermark {
  position: absolute;
  bottom: 18px;
  left: 18px;
  width: 32px; height: 38px;
  opacity: 0.25;
  pointer-events: none;
  z-index: 1;
}

/* ── Indicator right panel ──────────────────────────────────────── */
.ind-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.ind-card {
  background: var(--fw-card);
  border-radius: 0;
  padding: 11px 13px;
  border: 1px solid var(--fw-mist-2);
}
.ind-card-label {
  font-family: var(--fw-font-mono);
  font-size: 10px;
  color: var(--fw-slate);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  margin-bottom: 5px;
}
.ind-card-value {
  font-family: var(--fw-font-mono);
  font-size: 18px;
  font-weight: 500;
  color: var(--fw-ink);
  letter-spacing: 0;
  font-variant-numeric: tabular-nums;
}
.ind-card-sub {
  font-family: var(--fw-font-mono);
  font-size: 10px;
  color: var(--fw-slate);
  margin-top: 2px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
}
.ind-card.rsi-ob .ind-card-value { color: var(--fw-rot); }
.ind-card.rsi-os .ind-card-value { color: var(--fw-tiefe); }
.ind-card.rsi-neutral .ind-card-value { color: var(--fw-ink); }
.ind-badge {
  display: inline-block;
  padding: 1px 6px;
  border-radius: 0;
  font-family: var(--fw-font-mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  margin-left: 6px;
  border: 1px solid var(--fw-mist);
}
.ind-badge-above { background: var(--fw-tiefe); color: var(--fw-paper); border-color: var(--fw-tiefe); }
.ind-badge-below { background: var(--fw-rot);   color: var(--fw-paper); border-color: var(--fw-rot); }

/* ── Loksen-Signal-Box ─────────────────────────────────────────── */
.loksen-signal-box {
  background: var(--fw-card);
  border: 1px solid var(--fw-ink);
  padding: 14px 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.loksen-signal-box .ls-eyebrow {
  font-family: var(--fw-font-mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fw-slate);
}
.loksen-signal-box .ls-rec {
  font-family: var(--fw-font-cond);
  font-size: 28px;
  font-weight: 600;
  letter-spacing: 0.04em;
  color: var(--fw-signal);
  text-transform: uppercase;
}
.loksen-signal-box .ls-conf {
  font-family: var(--fw-font-mono);
  font-size: 12px;
  font-variant-numeric: tabular-nums;
  color: var(--fw-ink-2);
}
.loksen-signal-box .ls-reason {
  font-family: var(--fw-font);
  font-size: 13px;
  color: var(--fw-ink-2);
  line-height: 1.5;
}
.loksen-signal-box .ls-rec.buy   { color: var(--fw-tiefe); }
.loksen-signal-box .ls-rec.sell  { color: var(--fw-rot); }
.loksen-signal-box .ls-rec.watch { color: var(--fw-signal); }
.loksen-signal-box .ls-rec.hold  { color: var(--fw-ink-2); }

/* ── Fundamentals panel ─────────────────────────────────────────── */
.fund-name {
  font-family: var(--fw-font-cond);
  font-size: 16px;
  font-weight: 600;
  letter-spacing: -0.005em;
  margin-bottom: 4px;
  color: var(--fw-ink);
}
.fund-sub {
  font-family: var(--fw-font);
  font-size: 12px;
  color: var(--fw-slate);
  margin-bottom: 12px;
  line-height: 1.4;
}
.fund-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}
.fund-item {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 8px 10px;
  background: var(--fw-paper-2);
  border-radius: 0;
  border: 1px solid var(--fw-mist-2);
}
.fund-item .fi-label {
  font-family: var(--fw-font-mono);
  font-size: 10px;
  color: var(--fw-slate);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.14em;
}
.fund-item .fi-value {
  font-family: var(--fw-font-mono);
  font-size: 14px;
  font-weight: 500;
  color: var(--fw-ink);
  font-variant-numeric: tabular-nums;
}

/* ── Portfolio / Watchlist list panels ──────────────────────────── */
.pf-layout, .wl-layout { display: flex; gap: 16px; }

.pf-list-panel, .wl-list-panel {
  width: 200px;
  min-width: 200px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.pf-list-panel .card-body, .wl-list-panel .card-body { padding: 8px; }

.pf-item, .wl-item {
  padding: 9px 11px;
  border-radius: 0;
  border-left: 3px solid transparent;
  cursor: pointer;
  font-family: var(--fw-font);
  font-size: 14px;
  font-weight: 400;
  color: var(--fw-ink-2);
  display: flex;
  align-items: center;
  justify-content: space-between;
  transition: all var(--transition);
}
.pf-item:hover, .wl-item:hover { background: var(--fw-paper-2); color: var(--fw-ink); }
.pf-item.active, .wl-item.active {
  background: var(--fw-paper-2);
  color: var(--fw-ink);
  border-left-color: var(--fw-signal);
  font-weight: 500;
}

.pf-content, .wl-content { flex: 1; min-width: 0; }

/* ── Tax report ─────────────────────────────────────────────────── */
.tax-controls {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.tax-controls label { margin: 0; white-space: nowrap; }
.tax-controls input[type=number], .tax-controls select {
  width: auto;
  min-width: 70px;
  padding: 5px 9px;
  font-size: 12px;
}
.tax-summary-bar {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 10px;
  padding: 14px 18px;
  background: var(--fw-paper-2);
  border-top: 1px solid var(--fw-mist);
}
.tax-kv { display: flex; flex-direction: column; gap: 2px; }
.tax-kv .tk-label {
  font-family: var(--fw-font-mono);
  font-size: 10px;
  color: var(--fw-slate);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.14em;
}
.tax-kv .tk-value {
  font-family: var(--fw-font-mono);
  font-size: 16px;
  font-weight: 500;
  color: var(--fw-ink);
  font-variant-numeric: tabular-nums;
}
.tax-kv .tk-value.negative { color: var(--fw-rot); }
.tax-kv .tk-value.positive { color: var(--fw-tiefe); }

/* ── Toasts ─────────────────────────────────────────────────────── */
.toast-container {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 200;
  display: flex;
  flex-direction: column;
  gap: 8px;
  pointer-events: none;
}
.toast {
  background: var(--fw-card);
  border: 1px solid var(--fw-ink);
  border-left: 3px solid var(--fw-ink);
  border-radius: 0;
  padding: 12px 16px;
  box-shadow: none;
  display: flex;
  align-items: flex-start;
  gap: 10px;
  max-width: 340px;
  animation: slideUp 0.20s ease;
  pointer-events: all;
  font-family: var(--fw-font);
  font-size: 13px;
}
.toast-icon {
  font-family: var(--fw-font-mono);
  font-size: 14px;
  line-height: 1;
  margin-top: 1px;
  color: var(--fw-slate);
}
.toast-title {
  font-family: var(--fw-font-mono);
  font-weight: 500;
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fw-slate);
  margin-bottom: 4px;
}
.toast-msg { color: var(--fw-ink-2); font-size: 13px; line-height: 1.45; }
.toast.buy,   .toast.success { border-left-color: var(--fw-tiefe); }
.toast.sell,  .toast.err     { border-left-color: var(--fw-rot); }
.toast.warn                  { border-left-color: var(--fw-gelb); }
.toast.info                  { border-left-color: var(--fw-ink); }

/* ── Empty states ───────────────────────────────────────────────── */
.empty-state {
  text-align: center;
  padding: 40px 20px;
  color: var(--fw-slate);
}
.empty-state .empty-icon {
  font-family: var(--fw-font-mono);
  font-size: 28px;
  margin-bottom: 10px;
  color: var(--fw-mist);
}
.empty-state p { font-family: var(--fw-font); font-size: 13px; }

/* ── Loading ────────────────────────────────────────────────────── */
.spinner {
  width: 16px; height: 16px;
  border: 1px solid var(--fw-mist-2);
  border-top-color: var(--fw-signal);
  border-radius: 50%;
  animation: spin 0.7s linear infinite;
  display: inline-block;
}

/* ── Animations ─────────────────────────────────────────────────── */
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes fadeUp { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: translateY(0); } }
@keyframes scaleIn { from { opacity: 0; transform: scale(0.98); } to { opacity: 1; transform: scale(1); } }
@keyframes slideUp { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } }
@keyframes spin { to { transform: rotate(360deg); } }
@keyframes fade-in { from { opacity: 0; } to { opacity: 1; } }

.page { animation: fadeUp 0.20s ease both; }

/* ── Divider ────────────────────────────────────────────────────── */
hr { border: none; border-top: 1px solid var(--fw-mist-2); margin: 18px 0; }

/* ── Scrollbar ──────────────────────────────────────────────────── */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--fw-mist); border-radius: 0; }
::-webkit-scrollbar-thumb:hover { background: var(--fw-slate); }

/* ── Responsive ─────────────────────────────────────────────────── */
@media (max-width: 900px) {
  .chart-page-layout { flex-direction: column; }
  .chart-main { flex: unset; width: 100%; }
  .chart-info-panel { max-height: none; }
}
@media (max-width: 768px) {
  .sidebar { display: none; }
  .content { padding: 14px; }
  .form-row { grid-template-columns: 1fr; }
  .form-row-3 { grid-template-columns: 1fr; }
  .pf-list-panel, .wl-list-panel { display: none; }
}

/* ── News panel ─────────────────────────────────────────────────── */
.news-list { display: flex; flex-direction: column; }
.news-item {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 11px 14px;
  border-bottom: 1px solid var(--fw-mist-2);
  transition: background var(--transition);
  cursor: pointer;
  text-decoration: none;
  color: inherit;
}
.news-item:last-child { border-bottom: none; }
.news-item:hover { background: var(--fw-paper-2); }
.news-item-title {
  font-family: var(--fw-font);
  font-size: 13px;
  font-weight: 500;
  color: var(--fw-ink);
  line-height: 1.45;
}
.news-item-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--fw-font-mono);
  font-size: 10px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--fw-slate);
}
.news-sentiment {
  display: inline-block;
  padding: 1px 6px;
  border-radius: 0;
  font-family: var(--fw-font-mono);
  font-size: 10px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.10em;
  border: 1px solid var(--fw-mist);
}
.news-sentiment.bullish { background: var(--fw-tiefe); color: var(--fw-paper); border-color: var(--fw-tiefe); }
.news-sentiment.bearish { background: var(--fw-rot);   color: var(--fw-paper); border-color: var(--fw-rot); }
.news-sentiment.neutral { background: var(--fw-paper-2); color: var(--fw-slate); border-color: var(--fw-mist); }

/* ── KPI Tooltip ────────────────────────────────────────────────── */
.kpi-tooltip {
  position: fixed;
  z-index: 500;
  background: var(--fw-card);
  border: 1px solid var(--fw-ink);
  border-radius: 0;
  box-shadow: none;
  padding: 12px 14px;
  max-width: 320px;
  pointer-events: none;
  animation: fadeUp 0.12s ease;
}
.kpi-tt-name {
  font-family: var(--fw-font-cond);
  font-size: 14px;
  font-weight: 600;
  color: var(--fw-ink);
  margin-bottom: 6px;
}
.kpi-tt-text {
  font-family: var(--fw-font);
  font-size: 12px;
  color: var(--fw-ink-2);
  line-height: 1.5;
  margin-bottom: 8px;
}
.kpi-tt-formula {
  font-family: var(--fw-font-mono);
  font-size: 11px;
  color: var(--fw-signal);
  background: var(--fw-paper-2);
  border: 1px solid var(--fw-mist-2);
  border-radius: 0;
  padding: 5px 8px;
  margin-bottom: 8px;
  white-space: pre-wrap;
  word-break: break-word;
}
.kpi-tt-hint {
  font-family: var(--fw-font);
  font-size: 11px;
  color: var(--fw-slate);
  line-height: 1.45;
}
.ind-card-label { cursor: default; }
.ind-card-label.has-tooltip { cursor: help; border-bottom: 1px dashed var(--fw-mist); width: fit-content; }
.ind-toggle.has-tt { position: relative; }
.ind-toggle.has-tt:hover { z-index: 2; }
.news-sentiment.has-tt { cursor: help; }

/* ── Cash / Liquidität ──────────────────────────────────────────── */
.summary-tile-cash { position: relative; }
.cash-edit-btn {
  font-family: var(--fw-font-mono);
  font-size: 12px;
  font-weight: 500;
  width: 20px;
  height: 20px;
  border-radius: 0;
  padding: 0;
  line-height: 1;
  margin-left: 6px;
  vertical-align: middle;
  background: transparent;
  border: 1px solid var(--fw-mist);
  cursor: pointer;
  color: var(--fw-slate);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.cash-edit-btn:hover { background: var(--fw-paper-2); color: var(--fw-ink); border-color: var(--fw-ink); }
.cash-warning {
  font-family: var(--fw-font);
  font-size: 12px;
  color: var(--fw-rot);
  font-weight: 500;
  margin-top: 4px;
  line-height: 1.4;
}
.cash-negative { color: var(--fw-rot) !important; }
.cash-balance-display {
  background: var(--fw-paper-2);
  border-radius: 0;
  padding: 14px 16px;
  margin-bottom: 4px;
  border: 1px solid var(--fw-mist-2);
}
.cash-balance-display .label {
  font-family: var(--fw-font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fw-slate);
  margin-bottom: 4px;
}
.cash-balance-display .value {
  font-family: var(--fw-font-mono);
  font-size: 22px;
  font-weight: 500;
  font-variant-numeric: tabular-nums;
  color: var(--fw-ink);
}

/* ── Quick Order ────────────────────────────────────────────────── */
.order-type-toggle {
  display: flex;
  gap: 0;
  margin-bottom: 16px;
  border: 1px solid var(--fw-mist);
}
.order-type-btn {
  flex: 1;
  justify-content: center;
  border-radius: 0 !important;
  padding: 9px 14px !important;
  font-size: 11px !important;
  border-right: 1px solid var(--fw-mist);
  border-left: none !important;
  border-top: none !important;
  border-bottom: none !important;
}
.order-type-btn:last-child { border-right: none; }

.order-cost-panel {
  background: var(--fw-paper-2);
  border: 1px solid var(--fw-mist-2);
  border-radius: 0;
  padding: 11px 14px;
  margin: 12px 0 4px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.ocp-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: var(--fw-font-mono);
  font-size: 12px;
  color: var(--fw-ink-2);
  font-variant-numeric: tabular-nums;
}
.ocp-row.ocp-total {
  border-top: 1px solid var(--fw-mist);
  padding-top: 8px;
  margin-top: 2px;
  font-weight: 500;
  color: var(--fw-ink);
  font-size: 13px;
}

/* ── Crypto / Asset badges ──────────────────────────────────────── */
.badge-crypto {
  display: inline-block;
  padding: 1px 6px;
  border-radius: 0;
  font-family: var(--fw-font-mono);
  font-size: 10px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.10em;
  background: var(--fw-card);
  color: var(--fw-gelb);
  border: 1px solid var(--fw-gelb);
}
.ac-crypto-badge {
  display: inline-block;
  padding: 1px 5px;
  border-radius: 0;
  font-family: var(--fw-font-mono);
  font-size: 9px;
  font-weight: 500;
  text-transform: uppercase;
  background: var(--fw-card);
  color: var(--fw-gelb);
  border: 1px solid var(--fw-gelb);
  margin-left: 4px;
  vertical-align: middle;
}
.ac-options-link {
  display: inline-block;
  margin-left: 8px;
  padding: 1px 7px;
  border-radius: 0;
  font-family: var(--fw-font-mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  background: var(--fw-card);
  color: var(--fw-signal);
  border: 1px solid var(--fw-signal);
  cursor: pointer;
  vertical-align: middle;
}
.ac-options-link:hover { background: var(--fw-signal); color: var(--fw-paper); }

/* ── Tax-Type badges ────────────────────────────────────────────── */
.tax-type-badge {
  display: inline-block;
  padding: 2px 6px;
  border-radius: 0;
  font-family: var(--fw-font-mono);
  font-size: 10px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.10em;
  white-space: nowrap;
  border: 1px solid var(--fw-mist);
}
.tax-type-badge.abgelt     { background: var(--fw-paper-2); color: var(--fw-ink-2); border-color: var(--fw-mist); }
.tax-type-badge.para23     { background: var(--fw-paper-2); color: var(--fw-signal); border-color: var(--fw-signal); }
.tax-type-badge.steuerfrei { background: var(--fw-paper-2); color: var(--fw-tiefe); border-color: var(--fw-tiefe); }

/* ── Multi-currency cash list ───────────────────────────────────── */
.cash-positions-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 12px;
}
.cash-pos-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 12px;
  background: var(--fw-paper-2);
  border: 1px solid var(--fw-mist-2);
  border-radius: 0;
  font-family: var(--fw-font);
  font-size: 13px;
}
.cash-pos-left { display: flex; align-items: center; gap: 10px; }
.cash-pos-currency {
  font-family: var(--fw-font-mono);
  font-weight: 500;
  color: var(--fw-ink);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  background: var(--fw-card);
  padding: 2px 7px;
  border: 1px solid var(--fw-ink);
  border-radius: 0;
}
.cash-pos-amount {
  font-family: var(--fw-font-mono);
  font-weight: 500;
  font-variant-numeric: tabular-nums;
}
.cash-pos-converted {
  font-family: var(--fw-font-mono);
  font-size: 10px;
  color: var(--fw-slate);
  letter-spacing: 0.05em;
}
.cash-total-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 12px;
  background: var(--fw-ink);
  color: var(--fw-paper);
  border: 1px solid var(--fw-ink);
  border-radius: 0;
  font-family: var(--fw-font-mono);
  font-weight: 500;
  font-size: 13px;
  font-variant-numeric: tabular-nums;
  margin-top: 2px;
}

/* ── Chart responsive layout ────────────────────────────────────── */
#page-chart {
  min-height: 520px;
  height: calc(100vh - 56px - 52px);
  overflow: auto;
  display: flex;
  flex-direction: column;
}
.chart-page-layout {
  flex: 1;
  min-height: 480px;
  min-width: 880px;
  align-items: stretch !important;
}
.chart-main {
  display: flex;
  flex-direction: column;
  height: 100%;
}
#chart-container {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
  overflow: hidden;
}
.chart-toolbar { flex-shrink: 0; }
.chart-wrap {
  flex: 1;
  min-height: 0;
  padding: 8px 14px 0;
  position: relative;
}
#price-chart-host {
  position: absolute !important;
  top: 0; left: 0; right: 0; bottom: 0;
  width: 100% !important;
  height: 100% !important;
}
#price-chart {
  position: absolute !important;
  top: 0; left: 0; right: 0; bottom: 0;
  width: 100% !important;
  height: 100% !important;
}
#draw-overlay {
  position: absolute !important;
  top: 0; left: 0; right: 0; bottom: 0;
  width: 100% !important;
  height: 100% !important;
}
#rsi-wrap, #macd-wrap { flex-shrink: 0; }

/* ── Resizable right info panel sections ────────────────────────── */
.chart-info-panel {
  height: 100%;
  display: flex !important;
  flex-direction: column !important;
  gap: 0 !important;
  overflow: hidden !important;
  max-height: none !important;
}
.cip-section {
  min-height: 80px;
  overflow: hidden;
  flex-shrink: 0;
}
#cip-news {
  flex: 1 !important;
  min-height: 80px;
  overflow: hidden;
}
.cip-card {
  height: 100%;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border-radius: 0;
}
.cip-body {
  flex: 1;
  overflow-y: auto;
  min-height: 0;
  padding-right: 2px;
}
.cip-handle {
  height: 8px;
  cursor: ns-resize;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 2px 0;
  position: relative;
}
.cip-handle::before {
  content: '';
  display: block;
  width: 30px;
  height: 2px;
  background: var(--fw-mist);
  border-radius: 0;
  transition: all var(--transition);
}
.cip-handle:hover::before, .cip-handle.dragging::before {
  width: 48px;
  height: 3px;
  background: var(--fw-signal);
}

/* ── Print styles ───────────────────────────────────────────────── */
@media print {
  .sidebar, .topbar, .tab-bar, .btn-group, .toast-container, .tax-controls { display: none !important; }
  .content { padding: 0; }
  .card { box-shadow: none; border: 1px solid #999; }
  body { font-size: 12px; }
}

/* ── Settings tabs ──────────────────────────────────────────────── */
.settings-tabs {
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--fw-mist);
  margin-bottom: 18px;
  flex-wrap: wrap;
}
.settings-tabs .stab {
  background: transparent;
  border: none;
  padding: 9px 14px;
  font-family: var(--fw-font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--fw-slate);
  cursor: pointer;
  border-radius: 0;
  position: relative;
  transition: color var(--transition), background var(--transition);
}
.settings-tabs .stab:hover { color: var(--fw-ink); background: var(--fw-paper-2); }
.settings-tabs .stab.active { color: var(--fw-ink); }
.settings-tabs .stab.active::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: -1px;
  height: 2px;
  background: var(--fw-signal);
  border-radius: 0;
}
.stab-pane { display: none; }
.stab-pane.active { display: block; animation: fade-in 0.15s ease; }

/* ── Datenverwaltung-Liste ──────────────────────────────────────── */
.dm-list {
  display: flex; flex-direction: column; gap: 6px;
}
.dm-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 14px;
  background: var(--fw-card);
  border: 1px solid var(--fw-mist-2);
  border-radius: 0;
}
.dm-row .dm-meta {
  font-family: var(--fw-font-mono);
  font-size: 11px;
  color: var(--fw-slate);
  letter-spacing: 0.05em;
}
.dm-row .dm-name {
  font-family: var(--fw-font);
  font-weight: 500;
  font-size: 14px;
  color: var(--fw-ink);
}
.dm-row .dm-actions { display: flex; gap: 8px; }
.dm-row.is-default { background: var(--fw-paper-2); opacity: 0.85; }
.dm-row.is-default .dm-name::after {
  content: "Standard";
  display: inline-block; margin-left: 8px;
  font-family: var(--fw-font-mono);
  font-size: 10px; font-weight: 500;
  letter-spacing: 0.10em; text-transform: uppercase;
  padding: 1px 6px; border-radius: 0;
  background: var(--fw-ink); color: var(--fw-paper);
  vertical-align: middle;
}

/* ── Drawing-Toolbar ────────────────────────────────────────────── */
.chart-draw-toolbar {
  display: flex; align-items: center; gap: 4px;
  padding: 6px 12px;
  border-top: 1px solid var(--fw-mist-2);
  background: var(--fw-paper-2);
}
.draw-btn {
  width: 28px; height: 26px;
  border: 1px solid transparent;
  background: transparent;
  border-radius: 0;
  cursor: pointer;
  font-family: var(--fw-font-mono);
  font-size: 13px; line-height: 1;
  color: var(--fw-slate);
  display: inline-flex; align-items: center; justify-content: center;
  transition: background var(--transition), border-color var(--transition), color var(--transition);
}
.draw-btn:hover { background: var(--fw-card); color: var(--fw-ink); border-color: var(--fw-mist); }
.draw-btn.on {
  background: var(--fw-ink); color: var(--fw-paper);
  border-color: var(--fw-ink);
}
#draw-overlay { z-index: 5; pointer-events: none; }
#draw-overlay.active { pointer-events: auto; cursor: crosshair; }
.scr-criteria { display: flex; flex-direction: column; gap: 4px; }

/* ── Drawing Context Menu ───────────────────────────────────────── */
.draw-ctx {
  position: fixed; z-index: 9999;
  background: var(--fw-card);
  border: 1px solid var(--fw-ink);
  border-radius: 0;
  box-shadow: none;
  padding: 8px; min-width: 220px;
  font-family: var(--fw-font);
  font-size: 13px;
}
.draw-ctx-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 6px 8px;
}
.draw-ctx-row label {
  font-family: var(--fw-font-mono);
  font-size: 10px;
  color: var(--fw-slate);
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.draw-ctx-colors, .draw-ctx-widths, .draw-ctx-dashes {
  display: flex; gap: 4px;
}
.dctx-swatch {
  width: 18px; height: 18px; border-radius: 0;
  border: 1px solid var(--fw-mist);
  cursor: pointer;
}
.dctx-swatch.on { border: 1px solid var(--fw-ink); box-shadow: inset 0 0 0 2px var(--fw-card); }
.dctx-width, .dctx-dash {
  width: 32px; height: 22px;
  border: 1px solid var(--fw-mist-2);
  border-radius: 0;
  cursor: pointer; display: inline-flex; align-items: center; justify-content: center;
  background: var(--fw-card);
}
.dctx-width.on, .dctx-dash.on { border-color: var(--fw-ink); background: var(--fw-paper-2); }
.dctx-width svg, .dctx-dash svg { display: block; }
.draw-ctx-sep { height: 1px; background: var(--fw-mist-2); margin: 6px 0; }
.draw-ctx-item {
  display: block; width: 100%;
  padding: 8px 10px;
  background: transparent; border: 0;
  text-align: left;
  font-family: var(--fw-font);
  font-size: 13px;
  color: var(--fw-ink);
  cursor: pointer;
  border-radius: 0;
}
.draw-ctx-item:hover { background: var(--fw-paper-2); }
.draw-handle {
  position: absolute; width: 10px; height: 10px;
  background: var(--fw-paper); border: 2px solid var(--fw-signal);
  border-radius: 0;
  transform: translate(-50%, -50%);
  pointer-events: none; z-index: 6;
}
