/**
 * Aktien Screener - Light Compact Design
 * Based on OptionFinder Design System
 * @version 4.22.0
 */

/* Scanner-Variablen scoped auf .ofma-dashboard (Member Area Container).
   Überschreibt die Theme-Typography (rem-basiert) mit kompakten px-Werten
   für die hohe Informationsdichte der Scanner-Tabellen.
   Theme-Typography (typography.css) bleibt auf :root für öffentliche Seiten. */
.ofma-dashboard {
    /* OptionFinder Light Theme */
    --of-bg-primary: #f8fafc;
    --of-bg-card: #ffffff;
    --of-bg-hover: #f1f5f9;
    --of-bg-subtle: #e2e8f0;
    --of-text-primary: #1e293b;
    --of-text-secondary: #475569;
    --of-text-muted: #94a3b8;
    --of-accent-teal: #14b8a6;
    --of-accent-cyan: #0891b2;
    --of-accent-violet: #8b5cf6;
    --of-accent-violet-dark: #6d28d9;
    --of-border: #e2e8f0;
    --of-border-dark: #cbd5e1;

    /* Badge Height (zentral für viz-badge und OF Score Boxes) */
    --badge-height: 24px;

    /* Score Colors */
    --score-excellent: #059669;
    --score-excellent-light: #10b981;
    --score-good: #4ade80;
    --score-good-light: #86efac;
    --score-medium: #d97706;
    --score-medium-light: #f59e0b;
    --score-weak: #dc2626;
    --score-weak-light: #ef4444;
    --score-warning: #eab308;
    --score-warning-light: #fde047;

    /* Trend Colors - Verwenden Score-Farben für Konsistenz */
    --trend-up: var(--score-excellent);
    --trend-down: var(--score-weak);
    --trend-neutral: #64748b;

    /* Shadows */
    --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.05);
    --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -2px rgba(0, 0, 0, 0.1);
    --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -4px rgba(0, 0, 0, 0.1);

    /* Typography - Kompakte Scanner-Schriftgrößen (px-basiert) */
    --of-font-size-3xs: 8px;
    --of-font-size-2xs: 9px;
    --of-font-size-xs: 10px;
    --of-font-size-sm: 11px;
    --of-font-size-base: 12px;
    --of-font-size-md: 13px;
    --of-font-size-lg: 14px;
    --of-font-size-xl: 15px;
    --of-font-size-2xl: 16px;
    --of-font-size-3xl: 18px;
    --of-font-size-4xl: 20px;
    --of-font-size-5xl: 24px;
    --of-font-size-6xl: 32px;
    --of-font-size-7xl: 48px;

    /* Aliase */
    --of-font-size-table: var(--of-font-size-md);
    --of-font-size-header: var(--of-font-size-sm);

    /* Font Weights */
    --of-font-weight-regular: 400;
    --of-font-weight-medium: 500;
    --of-font-weight-semibold: 600;
    --of-font-weight-bold: 700;
    --of-font-weight-black: 900;
}

/* Dark Mode Overrides */
.ofma-dashboard[data-theme="dark"] {
    --of-bg-primary: #0f172a;
    --of-bg-card: #1e293b;
    --of-bg-hover: #334155;
    --of-bg-subtle: #475569;
    --of-text-primary: #94a3b8;
    --of-text-secondary: #94a3b8;
    --of-text-muted: #64748b;
    --of-border: #334155;
    --of-border-dark: #475569;
}

[data-theme="dark"] .table-grid th {
    background: #1e293b;
}

[data-theme="dark"] .screener-footer {
    background: #1e293b;
    border-top-color: #334155;
}

[data-theme="dark"] .footer-info,
[data-theme="dark"] .footer-update {
    color: #94a3b8;
}

[data-theme="dark"] .ofma-pagination__per-page select {
    background-color: #1e293b !important;
    color: #e2e8f0 !important;
    border-color: #475569 !important;
}

/* Tabellen-Zeilen */
[data-theme="dark"] .table-grid td {
    background: #0f172a;
    color: #94a3b8;
    border-color: #334155;
}
[data-theme="dark"] .table-grid tr:hover td { background: #1e293b; }

/* Quick-Filter Cards */
[data-theme="dark"] .filter-card { background: #1e293b; border-color: #334155; box-shadow: none; }
[data-theme="dark"] .filter-card:hover { border-color: #475569; }
[data-theme="dark"] .filter-card.active { background: #1e293b; }
[data-theme="dark"] .filter-card__title { color: #e2e8f0; }
[data-theme="dark"] .filter-card__desc { color: #94a3b8; }

/* Screener-Header + Search */
[data-theme="dark"] .screener-search { background: #1e293b; border-color: #334155; }
[data-theme="dark"] .screener-search__input { color: #e2e8f0; }

/* Workflow / Spaltenauswahl Bereich */
[data-theme="dark"] .ofma-wf,
[data-theme="dark"] .ofma-wf__step { background: #1e293b; border-color: #334155; }
[data-theme="dark"] .ofma-wf__step-label { color: #94a3b8; }

/* Allgemein: hardcoded white Hintergruende */
[data-theme="dark"] .filter-popup,
[data-theme="dark"] .filter-popup__body,
[data-theme="dark"] .qb-modal,
[data-theme="dark"] .qb-modal__body { background: #1e293b; color: #e2e8f0; border-color: #334155; }

/* Pagination Buttons */
[data-theme="dark"] .ofma-pagination__btn { background: #1e293b; color: #94a3b8; border-color: #334155; }
[data-theme="dark"] .ofma-pagination__btn:hover:not(.disabled) { background: #334155; color: #f1f5f9; }
[data-theme="dark"] .ofma-pagination__current { color: #94a3b8; }

/* ========================================
   DASHBOARD INTEGRATION
   ======================================== */
.ofma-dashboard__main--screener {
    flex: 1 !important;
    width: 100% !important;
    max-width: none !important;
    padding: 1.5rem !important;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    background: var(--of-bg-primary);
}

/* ========================================
   SCREENER WRAPPER
   ======================================== */
.screener-wrapper {
    flex: 1;
    display: flex;
    flex-direction: column;
    font-family: var(--of-font-family);
    color: var(--of-text-primary);
    min-height: 0;
    gap: 1.5rem;
}

/* ========================================
   PAGE HEADER
   ======================================== */
.page-header {
    margin-bottom: 0.5rem;
}

.page-header__title {
    font-size: var(--of-font-size-5xl);
    font-weight: var(--of-font-weight-bold);
    color: var(--of-text-primary);
    margin: 0 0 1.25rem 0;
}

.page-header__subtitle {
    font-size: var(--of-font-size-md);
    font-weight: var(--of-font-weight-regular);
    color: var(--of-text-muted);
    margin: -1rem 0 1.25rem 0;
}

/* ========================================
   TOOLBAR
   ======================================== */
.toolbar {
    display: flex;
    align-items: center;
    gap: 1rem;
    background: var(--of-bg-card);
    padding: 0.75rem 1.25rem;
    border-radius: 12px;
    border: 1px solid var(--of-border);
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
}

.toolbar__group {
    display: flex;
    align-items: center;
    gap: 0.625rem;
}

.toolbar__label {
    font-size: var(--of-font-size-md);
    font-weight: var(--of-font-weight-semibold);
    color: var(--of-text-muted);
}

.toolbar__divider {
    width: 1px;
    height: 24px;
    background: var(--of-border);
}

.btn-ghost {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    background: transparent;
    border: 1px solid var(--of-border);
    padding: 0.375rem 0.875rem;
    border-radius: 6px;
    font-size: var(--of-font-size-lg);
    font-weight: var(--of-font-weight-medium);
    color: var(--of-text-primary);
    cursor: pointer;
    transition: all 0.2s;
}

.btn-ghost:hover {
    background: var(--of-bg-hover);
    border-color: var(--of-accent-teal);
}

/* ========================================
   TABLE WRAPPER (weißer Container)
   ======================================== */
.table-wrapper {
    background: var(--of-bg-card);
    border-radius: 16px;
    border: 1px solid var(--of-border);
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.05);
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
}

.table-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1.25rem 1.5rem;
    border-bottom: 1px solid var(--of-border);
}

.table-header__title {
    font-size: var(--of-font-size-3xl);
    font-weight: var(--of-font-weight-semibold);
    color: var(--of-text-primary);
    margin: 0;
}

.table-header__right {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.table-header__stats {
    display: flex;
    align-items: center;
    gap: 1.25rem;
    font-size: var(--of-font-size-md);
    color: var(--of-text-muted);
}

.table-header__stat {
    display: flex;
    align-items: center;
    gap: 0.375rem;
}

.table-header__stat-value {
    font-weight: var(--of-font-weight-semibold);
    color: var(--of-accent-teal);
}

.table-header__reset-btn {
    background: #ef4444;
    color: #fff;
    border: none;
    border-radius: 4px;
    padding: 2px 10px;
    font-size: var(--of-font-size-sm);
    font-weight: var(--of-font-weight-semibold);
    cursor: pointer;
    margin-left: 8px;
    transition: background 0.15s;
}
.table-header__reset-btn:hover {
    background: #dc2626;
}

/* Search Field */
.screener-search {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 0 14px;
    height: 32px;
    background: var(--of-bg-primary);
    border: 1px solid var(--of-border);
    border-radius: 8px;
    width: 180px;
    transition: border-color 0.15s ease;
}

.screener-search:focus-within {
    border-color: var(--of-accent-teal);
}

.screener-search__icon {
    color: var(--of-text-muted);
    flex-shrink: 0;
    width: 14px;
    height: 14px;
}

.screener-search__input {
    border: none !important;
    background: none !important;
    background-color: transparent !important;
    outline: none !important;
    box-shadow: none !important;
    font-size: var(--of-font-size-lg);
    color: var(--of-text-primary);
    width: 100%;
    padding: 0;
    margin: 0;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}

.screener-search__input::placeholder {
    color: var(--of-text-muted);
}

.screener-search__input:focus {
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
}

.screener-search__input::placeholder {
    color: #94a3b8;
    opacity: 1;
}

/* Header Stats */
.screener-header__stats {
    display: flex;
    align-items: center;
    gap: 1.25rem;
}

.screener-header__stat {
    font-size: var(--of-font-size-md);
    color: #94a3b8;
    white-space: nowrap;
}

.screener-header__stat span {
    color: var(--of-accent-teal);
    font-weight: var(--of-font-weight-semibold);
}

/* Section Title */
.screener-section-title {
    font-size: var(--of-font-size-3xl);
    font-weight: var(--of-font-weight-semibold);
    color: var(--of-text-primary);
    margin: 0;
    padding: 1rem 1.5rem 0.75rem;
}

/* Filter Row Number */
.filter-row__number {
    color: var(--of-text-primary);
    font-weight: var(--of-font-weight-semibold);
    margin-right: 0.25rem;
}

/* Sub Label for Schnellbuttons - same style as main labels */
.filter-row__label--sub {
    font-size: var(--of-font-size-md);
    font-weight: var(--of-font-weight-medium);
    color: var(--of-text-primary);
}

/* Label Group with Help Icon */
.filter-row__label-group {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    position: relative;
}

.filter-row__help {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    padding: 0;
    background: none;
    border: none;
    color: var(--of-accent-violet);
    cursor: pointer;
    opacity: 0.7;
    transition: opacity 0.15s ease;
}

.filter-row__help:hover {
    opacity: 1;
}

.filter-row__tooltip {
    position: absolute;
    top: calc(100% + 8px);
    left: 0;
    width: 320px;
    padding: 12px 14px;
    background: var(--of-accent-violet-dark);
    color: white;
    font-size: var(--of-font-size-base);
    line-height: 1.5;
    border-radius: 8px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
    z-index: 100;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-4px);
    transition: all 0.2s ease;
}

.filter-row__tooltip strong {
    color: white;
}

.filter-row__help:hover + .filter-row__tooltip,
.filter-row__tooltip:hover,
.filter-row__tooltip.visible {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

/* ========================================
   SCHNELLFILTER KOMPONENTE
   ======================================== */
.quick-filter-section {
    /* Direkt auf grauem Hintergrund */
}

/* Header / Label */
.quick-filter-header {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.75rem;
    padding-left: 0.25rem;
}

.quick-filter-label {
    font-size: var(--of-font-size-base);
    font-weight: var(--of-font-weight-semibold);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--of-text-muted);
}

/* Cards Container */
.quick-filter-cards {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 1rem;
}

/* Filter Card - Neues aufgelockerteres Design */
.filter-card {
    display: flex;
    flex-direction: column;
    padding: 1rem 1.25rem;
    border-radius: 12px;
    border: 1px solid var(--of-border);
    background: var(--of-bg-card);
    cursor: pointer;
    transition: all 0.2s;
    position: relative;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
}

.filter-card:hover {
    border-color: var(--of-border-dark);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}

.filter-card.active {
    border-left: 4px solid var(--of-accent-teal);
    background: var(--of-bg-card);
}

.card-title {
    font-weight: var(--of-font-weight-semibold);
    font-size: var(--of-font-size-lg);
    color: var(--of-text-primary);
    margin-bottom: 0.25rem;
}

.card-desc {
    font-size: var(--of-font-size-base);
    color: var(--of-text-muted);
    line-height: 1.4;
}

.card-count {
    display: inline-block;
    margin-top: 0.75rem;
    font-size: var(--of-font-size-sm);
    font-weight: var(--of-font-weight-bold);
    color: var(--of-accent-teal);
    background: rgba(13, 148, 136, 0.1);
    padding: 0.1875rem 0.625rem;
    border-radius: 10px;
    align-self: flex-start;
}

.card-count.empty {
    color: var(--of-text-muted);
    background: rgba(148, 163, 184, 0.15);
}

/* Add Card */
.filter-card-add {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 1rem 1.25rem;
    border-radius: 12px;
    border: 1px dashed var(--of-border-dark);
    background: transparent;
    cursor: pointer;
    transition: all 0.2s;
    color: var(--of-text-muted);
    min-height: 100px;
}

.filter-card-add:hover {
    border-color: var(--of-accent-teal);
    color: var(--of-accent-teal);
    background: rgba(13, 148, 136, 0.03);
}

.filter-card-add span {
    font-size: var(--of-font-size-lg);
    font-weight: var(--of-font-weight-medium);
}

/* ========================================
   FILTER ROWS
   ======================================== */
.filter-rows {
    background: var(--of-bg-primary);
    border-bottom: 1px solid var(--of-border);
    flex-shrink: 0;
}

.filter-row {
    display: flex;
    align-items: center;
    padding: 0.625rem 1.5rem;
    gap: 1rem;
}

.filter-row:not(:last-child) {
    border-bottom: 1px solid var(--of-border);
}

.filter-row__label {
    font-size: var(--of-font-size-md);
    font-weight: var(--of-font-weight-medium);
    color: var(--of-text-secondary);
    white-space: nowrap;
    min-width: 120px;
}

.filter-row__content {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex: 1;
    flex-wrap: wrap;
}

/* Gear Button */
.filter-config-gear {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    background: var(--of-bg-card);
    border: 1px solid var(--of-border);
    border-radius: 6px;
    cursor: pointer;
    transition: all 0.2s;
}

.filter-config-gear:hover {
    border-color: var(--of-accent-teal);
    background: var(--of-bg-hover);
}

.filter-config-gear__icon {
    font-size: var(--of-font-size-2xl);
    color: var(--of-text-muted);
    transition: transform 0.3s;
}

.filter-config-gear:hover .filter-config-gear__icon {
    transform: rotate(90deg);
    color: var(--of-accent-teal);
}

/* Universe Multi-Select Dropdown */
.universe-select {
    position: relative;
    min-width: 200px;
}

.universe-select__trigger {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: 0.625rem 1rem;
    background: var(--of-bg-card);
    border: 1px solid var(--of-border);
    border-radius: 8px;
    font-size: var(--of-font-size-md);
    font-weight: var(--of-font-weight-medium);
    color: var(--of-text-primary);
    cursor: pointer;
    transition: all 0.2s;
}

.universe-select__trigger:hover {
    border-color: var(--of-accent-teal);
}

.universe-select.open .universe-select__trigger {
    border-color: var(--of-accent-teal);
    box-shadow: 0 0 0 3px rgba(13, 148, 136, 0.1);
}

.universe-select__text {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.universe-select__arrow {
    font-size: var(--of-font-size-lg);
    color: var(--of-text-muted);
    transition: transform 0.2s;
    line-height: 1;
}

.universe-select.open .universe-select__arrow {
    transform: rotate(180deg);
}

.universe-select__dropdown {
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    right: 0;
    background: var(--of-bg-card);
    border: 1px solid var(--of-border);
    border-radius: 8px;
    box-shadow: var(--shadow-lg);
    z-index: 100;
    display: none;
    padding: 0.375rem;
}

.universe-select.open .universe-select__dropdown {
    display: block;
}

.universe-select__divider {
    height: 1px;
    background: var(--of-border, #e2e8f0);
    margin: 4px 8px;
}

.universe-option {
    display: flex;
    align-items: center;
    padding: 0.5rem 0.75rem;
    cursor: pointer;
    transition: background 0.15s;
    border-radius: 6px;
}

.universe-option:hover {
    background: var(--of-bg-hover);
}

.universe-option.disabled {
    opacity: 0.5;
    cursor: not-allowed;
    pointer-events: none;
}

.universe-option input {
    display: none;
}

.universe-option__check {
    display: none;
}

.universe-option:has(input:checked) {
    background: var(--of-bg-subtle);
}

.universe-option__label {
    font-size: var(--of-font-size-md);
    color: var(--of-text-primary);
}

.universe-option__divider {
    height: 1px;
    background: var(--of-border);
    margin: 0.375rem 0;
}

/* ETF Toggle */
.etf-toggle {
    display: flex;
    align-items: center;
    gap: 0.625rem;
    transition: opacity 0.2s;
}

.etf-toggle.disabled {
    opacity: 0.4;
    pointer-events: none;
}

.etf-toggle__label {
    font-size: var(--of-font-size-md);
    color: var(--of-text-secondary);
    white-space: nowrap;
}

/* Toggle Switch */
.toggle-switch {
    position: relative;
    display: inline-block;
    width: 44px;
    height: 24px;
}

.toggle-switch input {
    opacity: 0;
    width: 0;
    height: 0;
}

.toggle-switch__slider {
    position: absolute;
    cursor: pointer;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: var(--of-bg-subtle);
    border-radius: 24px;
    transition: all 0.2s;
}

.toggle-switch__slider::before {
    position: absolute;
    content: '';
    height: 18px;
    width: 18px;
    left: 3px;
    bottom: 3px;
    background: white;
    border-radius: 50%;
    transition: all 0.2s;
    box-shadow: 0 1px 3px rgba(0,0,0,0.2);
}

.toggle-switch input:checked + .toggle-switch__slider {
    background: var(--of-accent-teal);
}

.toggle-switch input:checked + .toggle-switch__slider::before {
    transform: translateX(20px);
}

/* ========================================
   FILTER CONFIG MODAL — Overrides für Aktien-Scanner
   (Base-Styles in column-configurator.css)
   ======================================== */

/* Aktien-Scanner: Ausgewählte Items ausblenden (statt dimmen) */
.filter-item.selected:not(.required) {
    display: none;
}

/* Required items bleiben sichtbar aber disabled */
.filter-item.required {
    opacity: 0.6;
    cursor: not-allowed;
}

.filter-item.required input[type="checkbox"] {
    cursor: not-allowed;
}

/* Visualization Colors for Table Cells - Einheitlich für alle Spalten */
.viz-green,
.viz-green.viz-soft {
    color: var(--score-excellent);
    font-weight: var(--of-font-weight-semibold);
}

.viz-yellow,
.viz-yellow.viz-soft {
    color: var(--score-medium);
    font-weight: var(--of-font-weight-semibold);
}

.viz-red,
.viz-red.viz-soft {
    color: var(--score-weak);
    font-weight: var(--of-font-weight-semibold);
}

.viz-orange,
.viz-orange.viz-soft {
    color: var(--score-medium);
    font-weight: var(--of-font-weight-semibold);
}

.viz-warning,
.viz-warning.viz-soft {
    color: var(--score-warning);
    font-weight: var(--of-font-weight-semibold);
}

/* Visualization Bar in Table */
.viz-bar-container {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.viz-bar-track {
    width: 50px;
    height: 6px;
    background: var(--of-border);
    border-radius: 3px;
    overflow: hidden;
    flex-shrink: 0;
}

.viz-bar {
    height: 100%;
    border-radius: 3px;
    transition: width 0.3s;
}

/* Einheitliche Balken-Farben für alle Spalten */
.viz-bar--green,
.viz-bar--green.viz-bar--soft {
    background: var(--score-excellent);
}

.viz-bar--yellow,
.viz-bar--yellow.viz-bar--soft {
    background: var(--score-medium);
}

.viz-bar--red,
.viz-bar--red.viz-bar--soft {
    background: var(--score-weak);
}

.viz-bar-value {
    font-size: var(--of-font-size-table);
    font-weight: var(--of-font-weight-semibold);
    color: var(--of-text-primary);
    white-space: nowrap;
}

/* Visualization Badge in Table - Einheitlich für alle Spalten */
.viz-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 38px;
    min-height: var(--badge-height);
    padding: 0.125rem 0.375rem;
    box-sizing: border-box;
    border-radius: 4px;
    font-size: var(--of-font-size-sm);
    font-weight: var(--of-font-weight-semibold);
    font-variant-numeric: tabular-nums;
    letter-spacing: 0.025em;
    white-space: nowrap;
    text-align: center;
    color: #ffffff;
    cursor: default;
}

/* Einheitliche Badge-Farben für alle Spalten (Gradient wie SP Score) */
.viz-badge--green,
.viz-badge--green.viz-badge--soft {
    background: linear-gradient(135deg, var(--score-excellent) 0%, var(--score-excellent-light) 100%);
    box-shadow: 0 1px 2px rgba(16, 185, 129, 0.3);
}

.viz-badge--yellow,
.viz-badge--yellow.viz-badge--soft {
    background: linear-gradient(135deg, var(--score-medium) 0%, var(--score-medium-light) 100%);
    box-shadow: 0 1px 2px rgba(245, 158, 11, 0.3);
}

.viz-badge--red,
.viz-badge--red.viz-badge--soft {
    background: linear-gradient(135deg, var(--score-weak) 0%, var(--score-weak-light) 100%);
    box-shadow: 0 1px 2px rgba(239, 68, 68, 0.3);
}

.viz-badge--orange,
.viz-badge--orange.viz-badge--soft {
    background: linear-gradient(135deg, var(--score-medium) 0%, var(--score-medium-light) 100%);
    box-shadow: 0 1px 2px rgba(245, 158, 11, 0.3);
}

.viz-badge--lightgreen,
.viz-badge--lightgreen.viz-badge--soft {
    background: linear-gradient(135deg, #22c55e 0%, #4ade80 100%);
    box-shadow: 0 1px 2px rgba(74, 222, 128, 0.3);
    color: #fff;
    text-shadow: 0 1px 1px rgba(0, 0, 0, 0.2);
}

.viz-badge--warning,
.viz-badge--warning.viz-badge--soft {
    background: linear-gradient(135deg, var(--score-warning) 0%, var(--score-warning-light) 100%);
    box-shadow: 0 1px 2px rgba(253, 224, 71, 0.3);
}

.viz-badge--neutral {
    background: var(--of-border);
    color: var(--of-text-muted);
    box-shadow: none;
}

/* RSI Trend Pfeile */
.rsi-trend {
    display: inline-block;
    font-size: 18px;
    font-weight: 900;
    margin-left: 3px;
    vertical-align: middle;
    min-width: 16px;
    text-align: center;
    text-shadow: 0 0 1px currentColor;
}
.rsi-trend--rising { color: #10b981; }
.rsi-trend--falling { color: #ef4444; }
.rsi-trend--sideways { color: #f59e0b; font-size: 20px; }

/* ADX Trend Pfeile */
.adx-trend {
    display: inline-block;
    font-size: 16px;
    font-weight: 700;
    margin-left: 3px;
    vertical-align: middle;
    min-width: 16px;
    text-align: center;
}
.adx-trend--rising { color: #10b981; }
.adx-trend--falling { color: #ef4444; }
.adx-trend--sideways { color: #f59e0b; font-size: 18px; }

/* Zell-Hintergrundfarben für Score/Theta-Einfärbung in der Optionskette */
.oc-bg-green  { background: rgba(16, 185, 129, 0.2); }
.oc-bg-yellow { background: rgba(217, 119, 6, 0.15); }
.oc-bg-orange { background: rgba(249, 115, 22, 0.15); }
.oc-bg-red    { background: rgba(239, 68, 68, 0.15); }

/* Delta-Farben in der Optionskette */
.oc-delta-call { color: var(--score-weak); }
.oc-delta-put  { color: var(--score-excellent); }

/* Viz icons in active columns */
.viz-icons--active {
    margin-left: auto;
    margin-right: 0.5rem;
}

.viz-icons--placeholder {
    /* Same width as 4 viz-icons (22px each) + 3 gaps (2px each) = 94px */
    width: 94px;
    margin-left: auto;
    margin-right: 0.5rem;
}

/* viz-legend: siehe column-configurator.css */

/* ========================================
   QUICKBUTTON CONFIGURATION MODAL
   ======================================== */
.qb-modal {
    position: fixed;
    inset: 0;
    z-index: 10000;
    display: none;
    align-items: center;
    justify-content: center;
}

.qb-modal.open {
    display: flex;
}

.qb-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
}

.qb-modal__container {
    position: relative;
    width: 100%;
    max-width: 600px;
    max-height: 90vh;
    background: var(--of-bg-card);
    border-radius: 12px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.2);
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.qb-modal__header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem 1.25rem;
    border-bottom: 1px solid var(--of-border);
}

.qb-modal__title {
    font-size: var(--of-font-size-2xl);
    font-weight: var(--of-font-weight-semibold);
    color: var(--of-text-primary);
    margin: 0;
}

.qb-modal__close {
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: none;
    border: 1px solid var(--of-border);
    border-radius: 6px;
    font-size: var(--of-font-size-2xl);
    color: var(--of-text-muted);
    cursor: pointer;
    transition: all 0.15s;
}

.qb-modal__close:hover {
    background: var(--of-bg-primary);
    color: var(--of-text-primary);
}

.qb-modal__body {
    padding: 1rem 1.25rem;
    overflow-y: auto;
    flex: 1;
}

.qb-modal__intro {
    font-size: var(--of-font-size-base);
    color: var(--of-text-secondary);
    margin: 0 0 1rem 0;
    line-height: 1.5;
}

/* Quickbutton List */
.qb-list {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

/* Single Quickbutton Item */
.qb-item {
    border: 1px solid var(--of-border);
    border-radius: 8px;
    overflow: hidden;
    transition: border-color 0.15s;
    background: var(--of-bg-primary);
}

.qb-item:hover {
    border-color: var(--of-accent-teal);
}

.qb-item__header {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.625rem 0.75rem;
    background: var(--of-bg-primary);
}

.qb-item__checkbox {
    width: 18px;
    height: 18px;
    accent-color: var(--of-accent-teal);
    cursor: pointer;
}

.qb-item__name {
    flex: 1;
    font-weight: var(--of-font-weight-medium);
    color: var(--of-text-primary);
}

.qb-item__criteria-preview {
    font-size: var(--of-font-size-base);
    color: var(--of-text-muted);
    max-width: 200px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.qb-item__toggle {
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: none;
    border: none;
    color: var(--of-text-muted);
    cursor: pointer;
    transition: transform 0.2s;
}

.qb-item.expanded .qb-item__toggle {
    transform: rotate(180deg);
}

.qb-item__delete {
    width: 20px;
    height: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: none;
    border: none;
    color: var(--of-text-muted);
    cursor: pointer;
    font-size: var(--of-font-size-lg);
    opacity: 0.5;
    transition: all 0.15s;
}

.qb-item__delete:hover {
    color: var(--score-weak);
    opacity: 1;
}

.qb-item__drag {
    color: var(--of-text-muted);
    cursor: grab;
    font-size: var(--of-font-size-lg);
    opacity: 0.5;
}

.qb-item__drag:hover {
    opacity: 1;
}

/* Name Input - Layout Only (Base styles via .of-input) */
.qb-item__name-input {
    flex: 1;
    border-color: transparent;
    background: transparent;
    font-weight: var(--of-font-weight-medium);
}

.qb-item__name-input:hover {
    background: var(--of-bg-card);
    border-color: var(--of-border);
}

.qb-item__criteria {
    display: flex;
    flex-direction: column;
    gap: 0.375rem;
    padding: 0 0.75rem;
}

.qb-item__add-criterion {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.375rem;
    margin: 0.5rem 0.75rem 0.75rem;
    padding: 0.375rem;
    background: none;
    border: 1px dashed var(--of-border);
    border-radius: 4px;
    font-size: var(--of-font-size-sm);
    color: var(--of-text-muted);
    cursor: pointer;
    transition: all 0.15s;
}

.qb-item__add-criterion:hover {
    border-color: var(--of-accent-teal);
    color: var(--of-accent-teal);
}

.qb-item__add-criterion span {
    font-size: var(--of-font-size-md);
    font-weight: var(--of-font-weight-semibold);
}

/* Criterion Row - Layout Only (Styles via .of-select, .of-input) */
.qb-criterion__column {
    flex: 1 1 105px;
    min-width: 85px;
}

.qb-criterion__operator {
    flex: 0 0 90px;
    width: 90px;
}

.qb-criterion__value {
    flex: 1 1 105px;
    min-width: 85px;
}

.qb-criterion__delete {
    width: 20px;
    height: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: none;
    border: none;
    color: var(--of-text-muted);
    cursor: pointer;
    font-size: var(--of-font-size-lg);
    opacity: 0.5;
    transition: all 0.15s;
    flex-shrink: 0;
}

.qb-criterion__delete:hover {
    color: var(--score-weak);
    opacity: 1;
}

/* Expanded Content */
.qb-item__body {
    display: none;
    padding: 1rem;
    border-top: 1px solid var(--of-border);
    background: var(--of-bg-card);
}

.qb-item.expanded .qb-item__body {
    display: block;
}

.qb-field {
    margin-bottom: 1rem;
}

.qb-field:last-child {
    margin-bottom: 0;
}

.qb-field__label {
    display: block;
    font-size: var(--of-font-size-base);
    font-weight: var(--of-font-weight-medium);
    color: var(--of-text-secondary);
    margin-bottom: 0.375rem;
}

.qb-field__input {
    width: 100%;
    padding: 0.5rem 0.75rem;
    border: 1px solid var(--of-border);
    border-radius: 6px;
    font-size: var(--of-font-size-md);
    color: var(--of-text-primary);
    background: var(--of-bg-card);
    transition: border-color 0.15s;
}

.qb-field__input:focus {
    outline: none;
    border-color: var(--of-accent-teal);
}

/* Criteria Section */
.qb-criteria {
    margin-top: 1rem;
}

.qb-criteria__title {
    font-size: var(--of-font-size-base);
    font-weight: var(--of-font-weight-semibold);
    color: var(--of-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 0.75rem;
}

.qb-criteria__list {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.qb-criterion {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    padding: 0.375rem;
    background: var(--of-bg-primary);
    border-radius: 4px;
    flex-wrap: wrap;
}

/* Legacy criterion styles - removed, using .of-select/.of-input instead */

.qb-criterion__remove {
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: none;
    border: none;
    color: var(--of-text-muted);
    cursor: pointer;
    margin-left: auto;
}

.qb-criterion__remove:hover {
    color: var(--score-weak);
}

.qb-criteria__add {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem;
    background: none;
    border: 1px dashed var(--of-border);
    border-radius: 6px;
    font-size: var(--of-font-size-base);
    color: var(--of-text-muted);
    cursor: pointer;
    transition: all 0.15s;
    width: 100%;
    justify-content: center;
    margin-top: 0.5rem;
}

.qb-criteria__add:hover {
    border-color: var(--of-accent-teal);
    color: var(--of-accent-teal);
}

/* Add Button */
.qb-add-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.375rem;
    width: 100%;
    padding: 0.625rem;
    margin-top: 0.75rem;
    background: none;
    border: 1px dashed var(--of-border);
    border-radius: 6px;
    font-size: var(--of-font-size-base);
    font-weight: var(--of-font-weight-medium);
    color: var(--of-text-secondary);
    cursor: pointer;
    transition: all 0.15s;
}

.qb-add-btn:hover {
    border-color: var(--of-accent-teal);
    color: var(--of-accent-teal);
}

.qb-add-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

/* Modal Footer */
.qb-modal__footer {
    display: flex;
    justify-content: flex-end;
    gap: 0.5rem;
    padding: 0.75rem 1.25rem;
    border-top: 1px solid var(--of-border);
    background: var(--of-bg-primary);
}

.qb-modal__btn {
    padding: 0.5rem 1rem;
    border-radius: 6px;
    font-size: var(--of-font-size-base);
    font-weight: var(--of-font-weight-medium);
    cursor: pointer;
    transition: all 0.15s;
}

.qb-modal__btn--secondary {
    background: var(--of-bg-card);
    border: 1px solid var(--of-accent-violet);
    color: var(--of-accent-violet);
}

.qb-modal__btn--secondary:hover {
    background: rgba(139, 92, 246, 0.1);
}

.qb-modal__btn--primary {
    background: var(--of-accent-teal);
    border: none;
    color: white;
}

.qb-modal__btn--primary:hover {
    background: #0b8277;
}

/* Max buttons warning */
.qb-max-warning {
    font-size: var(--of-font-size-base);
    color: var(--score-medium);
    text-align: center;
    margin-top: 0.5rem;
}

/* filter-modal Footer und Buttons: siehe column-configurator.css */

/* ========================================
   TABLE CONTAINER
   ======================================== */
.table-container {
    flex: 1;
    overflow: auto;
    min-height: 0;
    position: relative;
}

.table-grid {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    font-size: var(--of-font-size-table);
    font-family: var(--of-font-family);
    font-weight: var(--of-font-weight-semibold);
}

.table-grid thead tr {
    position: sticky;
    top: 0;
    z-index: 10;
}

.table-grid th {
    padding: 0.5rem !important;
    height: 40px;
    text-align: left;
    font-weight: var(--of-font-weight-semibold);
    font-size: var(--of-font-size-header) !important;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    color: var(--of-text-muted);
    background: #eef2f6;
    border-bottom: 1px solid var(--of-border);
    border-right: 1px solid var(--of-border-dark);
    white-space: nowrap;
    position: sticky;
    top: 0;
    z-index: 10;
}

.table-grid th:last-child {
    border-right: none;
}

.table-grid th.sortable {
    cursor: pointer;
    user-select: none;
}

.table-grid th.sortable:hover {
    color: var(--of-accent-teal);
    background: var(--of-bg-subtle);
}

/* Column Resize Handle */
.table-grid th {
    position: relative;
}

.col-resize-handle {
    position: absolute;
    top: 0;
    right: 0;
    width: 5px;
    height: 100%;
    cursor: col-resize;
    background: transparent;
    z-index: 11;
    transition: background 0.15s;
}

.col-resize-handle:hover,
.col-resize-handle.resizing {
    background: var(--of-accent-teal);
}

/* Während des Resizing */
.table-grid.resizing {
    cursor: col-resize;
    user-select: none;
}

.table-grid.resizing th,
.table-grid.resizing td {
    user-select: none;
}

/* ========================================
   COLUMN HEADER WITH FILTER ICON
   ======================================== */
.table-grid th .th-content {
    display: inline;
}

.table-grid th .th-icons {
    display: inline-flex;
    align-items: center;
    margin-left: 6px;
    gap: 4px;
    vertical-align: middle;
    position: relative;
    z-index: 12; /* Above resize handle */
}

.table-grid th .sort-icon {
    font-size: var(--of-font-size-xs);
    opacity: 0.6;
    margin-left: 0;
    min-width: 14px;
    text-align: center;
    color: var(--of-text-muted);
}

.table-grid th .sort-icon .sort-neutral {
    font-size: var(--of-font-size-3xs);
    letter-spacing: -1px;
    opacity: 0.5;
}

.table-grid th.sorted .sort-icon {
    opacity: 1;
    color: var(--of-accent-teal);
    font-weight: var(--of-font-weight-bold);
}

.table-grid th .th-filter {
    font-size: var(--of-font-size-sm);
    color: var(--of-text-secondary);
    cursor: pointer;
    padding: 2px 4px;
    border-radius: 3px;
    transition: all 0.15s;
    line-height: 1;
    border: 1px solid var(--of-border);
    background: var(--of-bg-subtle);
    position: relative;
    z-index: 15;
}

.table-grid th .th-filter:hover {
    color: var(--of-accent-teal);
    background: rgba(13, 148, 136, 0.15);
    border-color: var(--of-accent-teal);
}

.table-grid th .th-filter.has-filter {
    color: white;
    background: var(--of-accent-teal);
    border-color: var(--of-accent-teal);
}

/* ========================================
   FILTER POPUP
   ======================================== */
/* Filter-Popup: CSS-Variablen hier setzen, da Popups an document.body haengen
   und somit ausserhalb von .ofma-dashboard liegen */
.filter-popup {
    --of-text-primary: #1e293b;
    --of-text-secondary: #475569;
    --of-text-muted: #94a3b8;
    --of-border: #e2e8f0;
    --of-border-dark: #cbd5e1;
    --of-accent-teal: #14b8a6;
    --of-font-size-sm: 12px;
    --of-font-size-base: 13px;
    --of-font-weight-medium: 500;
    --of-font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;

    position: fixed;
    z-index: 1000;
    min-width: 200px;
    max-width: 280px;
    background: white;
    border: 1px solid var(--of-border-dark);
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    font-family: var(--of-font-family);
    color: var(--of-text-primary);
}

.filter-popup__header {
    padding: 0.5rem 0.75rem;
    font-size: var(--of-font-size-sm);
    font-weight: var(--of-font-weight-semibold);
    color: var(--of-text-secondary);
    border-bottom: 1px solid var(--of-border);
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.filter-popup__body {
    padding: 0.75rem;
}

.filter-popup__row {
    margin-bottom: 0.5rem;
}

.filter-popup__row:last-child {
    margin-bottom: 0;
}

.filter-popup__row--range {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.filter-popup__label {
    font-size: var(--of-font-size-sm);
    font-weight: var(--of-font-weight-medium);
    color: var(--of-text-secondary);
    min-width: 30px;
}

.filter-popup__input,
.filter-popup__value {
    width: 100%;
    padding: 0.4rem 0.5rem;
    font-size: var(--of-font-size-base);
    border: 1px solid var(--of-border);
    border-radius: 4px;
    background: white;
    color: var(--of-text-primary);
    outline: none;
    transition: border-color 0.15s;
    box-sizing: border-box;
}

.filter-popup__input:focus,
.filter-popup__value:focus {
    border-color: var(--of-accent-teal);
}

.filter-popup__input::placeholder,
.filter-popup__value::placeholder {
    color: var(--of-text-muted);
}

.filter-popup__value {
    -moz-appearance: textfield;
}

.filter-popup__value::-webkit-outer-spin-button,
.filter-popup__value::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.filter-popup__select,
.filter-popup__op {
    width: 100%;
    padding: 0.4rem 0.5rem;
    font-size: var(--of-font-size-base);
    border: 1px solid var(--of-border);
    border-radius: 4px;
    background: white;
    color: var(--of-text-primary);
    outline: none;
    cursor: pointer;
    box-sizing: border-box;
}

.filter-popup__select:focus,
.filter-popup__op:focus {
    border-color: var(--of-accent-teal);
}

.filter-popup__footer {
    display: flex;
    gap: 0.5rem;
    padding: 0.5rem 0.75rem;
    border-top: 1px solid var(--of-border);
    background: var(--of-bg-primary);
    border-radius: 0 0 8px 8px;
}

.filter-popup__btn {
    flex: 1;
    padding: 0.35rem 0.5rem;
    font-size: var(--of-font-size-sm);
    font-weight: var(--of-font-weight-medium);
    border: none;
    border-radius: 4px;
    cursor: pointer;
    transition: all 0.15s;
}

.filter-popup__btn--clear {
    background: var(--of-bg-subtle);
    color: var(--of-text-secondary);
}

.filter-popup__btn--clear:hover {
    background: var(--of-border-dark);
}

.filter-popup__btn--apply {
    background: var(--of-accent-teal);
    color: white;
}

.filter-popup__btn--apply:hover {
    background: #0b7b72;
}

/* Unit selector for large numbers (marketCap, etc.) */
.filter-popup__unit {
    flex-shrink: 0;
    width: auto;
    min-width: 55px;
    padding: 0.4rem 0.3rem;
    font-size: var(--of-font-size-sm);
    border: 1px solid var(--of-border);
    border-radius: 4px;
    background: var(--of-bg-subtle);
    color: var(--of-text-secondary);
    outline: none;
    cursor: pointer;
    box-sizing: border-box;
}

.filter-popup__unit:focus {
    border-color: var(--of-accent-teal);
}

.filter-popup__unit:hover {
    background: var(--of-bg-hover);
}

/* Adjust input width when unit selector is present */
.filter-popup__row--range .filter-popup__value {
    flex: 1;
    min-width: 0;
    width: auto;
}

/* Unit link icon between min/max rows */
.filter-popup__unit-link {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    margin: 0.25rem auto;
    padding: 4px;
    border-radius: 4px;
    cursor: pointer;
    color: var(--of-text-muted);
    background: var(--of-bg-subtle);
    border: 1px solid var(--of-border);
    transition: all 0.15s;
}

.filter-popup__unit-link svg {
    width: 14px;
    height: 14px;
}

.filter-popup__unit-link:hover {
    background: var(--of-bg-hover);
    color: var(--of-text-secondary);
}

.filter-popup__unit-link--active {
    background: var(--of-accent-teal);
    border-color: var(--of-accent-teal);
    color: white;
}

.filter-popup__unit-link--active:hover {
    background: #0b7b72;
    border-color: #0b7b72;
    color: white;
}

/* Options-Scanner: Popup-spezifische Erweiterungen */
.filter-popup__body--scroll {
    max-height: 260px;
    overflow-y: auto;
    padding: 4px 0;
}

.filter-popup__checkbox {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 4px 8px;
    font-size: 12px;
    color: var(--of-text-primary);
    cursor: pointer;
    border-radius: 4px;
    transition: background 0.15s;
}

.filter-popup__checkbox:hover {
    background: var(--of-bg-hover, #f1f5f9);
}

.filter-popup__checkbox input[type="checkbox"] {
    margin: 0;
    accent-color: var(--of-accent-teal, #14b8a6);
}

.filter-popup__radios {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    margin-bottom: 8px;
}

.filter-popup__radio {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 3px 8px;
    font-size: 11px;
    color: var(--of-text-secondary);
    cursor: pointer;
    border-radius: 4px;
    transition: background 0.15s;
}

.filter-popup__radio:hover {
    background: var(--of-bg-hover, #f1f5f9);
}

.filter-popup__radio input[type="radio"] {
    margin: 0;
    accent-color: var(--of-accent-teal, #14b8a6);
}

.filter-popup__date-range {
    display: flex;
    align-items: center;
    gap: 8px;
}

.filter-popup__date-range input[type="date"] {
    flex: 1;
}

.filter-popup__separator {
    color: #64748b;
    font-size: 12px;
}

.filter-popup__btn--selectall {
    background: transparent;
    border: 1px solid var(--of-accent-teal, #14b8a6);
    color: var(--of-accent-teal, #14b8a6);
    padding: 4px 10px;
    border-radius: 4px;
    font-size: 11px;
    cursor: pointer;
    transition: all 0.15s;
}

.filter-popup__btn--selectall:hover {
    background: var(--of-accent-teal, #14b8a6);
    color: white;
}

.filter-popup__divider {
    border-top: 1px solid var(--of-border, #e2e8f0);
    margin: 8px 0 4px;
}

.filter-popup__checkbox--toggle {
    font-size: 11px;
    color: var(--of-text-secondary);
    font-style: italic;
}

/* Help Icon in Table Header */
.th-help {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 14px;
    height: 14px;
    background: transparent;
    border: 1px solid var(--of-accent-violet);
    border-radius: 50%;
    font-size: var(--of-font-size-2xs);
    font-weight: var(--of-font-weight-semibold);
    color: var(--of-accent-violet);
    cursor: help;
    margin-left: 0.375rem;
    transition: all 0.15s;
    flex-shrink: 0;
    vertical-align: middle;
}

.th-help:hover {
    background: var(--of-accent-violet);
    color: white;
}

/* Tooltip Popup for Table Headers */
.th-tooltip {
    position: fixed;
    width: 240px;
    padding: 0.625rem 0.875rem;
    background: var(--of-accent-violet-dark);
    color: white;
    font-size: var(--of-font-size-base);
    font-weight: var(--of-font-weight-regular);
    text-transform: none;
    letter-spacing: normal;
    line-height: 1.4;
    border-radius: 6px;
    z-index: 9999;
    box-shadow: var(--shadow-lg);
    pointer-events: none;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.15s, visibility 0.15s;
}

.th-tooltip.visible {
    opacity: 1;
    visibility: visible;
}

.table-grid td {
    padding: 0.5rem !important;
    height: 40px;
    border-bottom: 1px solid var(--of-border);
    vertical-align: middle;
    font-size: var(--of-font-size-table) !important;
}

/* Schrift-Vererbung für Tabellenzellen */
.table-grid td * {
    font-family: inherit;
}

.table-grid tbody tr {
    background: var(--of-bg-card);
    transition: background 0.15s;
}

.table-grid tbody tr:nth-child(even) {
    background: var(--of-bg-primary);
}

.table-grid tbody tr:hover {
    background: rgba(13, 148, 136, 0.06);
}

/* ========================================
   CELL COMPONENTS
   ======================================== */

/* Name Column Default Width (kann per Resize geändert werden) */
.table-grid th.col-name,
.table-grid td.col-name {
    width: 240px;
    min-width: 120px;
}

/* Name Cell with Ticker + Company Name */
.name-cell {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    min-width: 0;
    max-width: 100%;
}

.name-cell__info {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-width: 0;
}

.name-cell__ticker {
    font-weight: var(--of-font-weight-semibold);
    color: var(--of-accent-teal);
    font-size: var(--of-font-size-md);
}

.name-cell__company {
    font-size: var(--of-font-size-sm);
    font-weight: var(--of-font-weight-regular);
    color: var(--of-text-secondary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Legacy support */
.name-cell__text {
    flex: 1;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.name-cell__actions {
    display: flex;
    align-items: center;
    gap: 0.25rem;
}

.action-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    padding: 0;
    background: transparent;
    border: none;
    border-radius: 4px;
    color: var(--of-text-muted);
    cursor: pointer;
    transition: all 0.15s;
}

.action-icon:hover {
    background: var(--of-bg-subtle);
    color: var(--of-accent-violet);
}

.action-icon.active {
    color: var(--of-accent-violet);
}

.action-icon.active svg {
    fill: var(--of-accent-violet);
}

.action-icon--watchlist.active {
    color: var(--of-accent-teal);
}

.action-icon--watchlist.active svg {
    fill: var(--of-accent-teal);
}

/* Watchlist Count in Sidebar */
.watchlist-count {
    font-size: var(--of-font-size-base);
    color: var(--of-text-muted);
    font-weight: var(--of-font-weight-regular);
}

/* Price Cell */
.price-cell {
    font-weight: var(--of-font-weight-semibold);
    font-variant-numeric: tabular-nums;
    color: var(--of-text-primary);
}

/* Sector - Plain Text */
.sector-text {
    display: inline-block;
    font-size: var(--of-font-size-md);
    font-weight: var(--of-font-weight-regular);
    color: var(--of-text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Market Cap Cell */
.mcap-cell {
    font-weight: var(--of-font-weight-medium);
    font-variant-numeric: tabular-nums;
    color: var(--of-text-primary);
}

.pe-loss {
    font-size: var(--of-font-size-base);
    font-style: italic;
    color: var(--of-text-muted);
    cursor: help;
    display: inline-flex;
    align-items: center;
    gap: 3px;
}

.pe-loss-icon {
    font-style: normal;
    opacity: 0.6;
    font-size: 0.85em;
}

/* IV Rank Gauge */
.iv-indicator {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.iv-gauge {
    width: 50px;
    height: 6px;
    background: linear-gradient(90deg,
        var(--score-excellent) 0%,
        var(--score-medium) 50%,
        var(--score-weak) 100%
    );
    border-radius: 3px;
    position: relative;
}

.iv-marker {
    position: absolute;
    top: -3px;
    width: 4px;
    height: 12px;
    background: var(--of-text-primary);
    border-radius: 2px;
    box-shadow: 0 0 4px rgba(0,0,0,0.2);
    transform: translateX(-50%);
}

.iv-value {
    font-weight: var(--of-font-weight-semibold);
    min-width: 28px;
    font-variant-numeric: tabular-nums;
}

/* Standard: Keine Farben für IV Rank */
.iv-value--high { color: var(--of-text-primary); }
.iv-value--mid { color: var(--of-text-primary); }
.iv-value--low { color: var(--of-text-primary); }
.iv-value--none { color: var(--of-text-muted); }

/* Earnings Cell */
.earnings-cell {
    display: flex;
    align-items: center;
    gap: 0.375rem;
}

.earnings-value {
    font-weight: var(--of-font-weight-semibold);
    min-width: 20px;
    font-variant-numeric: tabular-nums;
    color: var(--of-text-primary);
}

/* Standard: Keine Farben für Earnings */
.earnings-value--danger { color: var(--of-text-primary); }
.earnings-value--warning { color: var(--of-text-primary); }
.earnings-value--safe { color: var(--of-text-primary); }
.earnings-value--none { color: var(--of-text-muted); }

.earnings-label {
    font-size: var(--of-font-size-sm);
    color: var(--of-text-muted);
}

/* Dividend Cell */
.dividend-value {
    font-weight: var(--of-font-weight-semibold);
    font-variant-numeric: tabular-nums;
}

/* Standard: Keine Farben für Dividende */
.dividend-value--high { color: var(--of-text-primary); }
.dividend-value--mid { color: var(--of-text-primary); }
.dividend-value--low { color: var(--of-text-primary); }
.dividend-value--none { color: var(--of-text-muted); }

/* Utility color classes - Standard: Keine Farben */
.text-green { color: var(--of-text-primary); }
.text-red { color: var(--of-text-primary); }

/* Signal Badge */
.signal-badge {
    display: inline-block;
    padding: 0.125rem 0.5rem;
    border-radius: 4px;
    font-size: var(--of-font-size-table);
    font-weight: var(--of-font-weight-semibold);
    text-transform: capitalize;
}

.signal--bullish {
    background: var(--score-excellent);
    color: #ffffff;
}

.signal--bearish {
    background: var(--score-weak);
    color: #ffffff;
}

.signal--neutral {
    background: var(--of-bg-subtle);
    color: var(--of-text-secondary);
}

.signal--warning {
    background: var(--score-medium);
    color: #ffffff;
}

/* OF Signal Badge */
.of-signal {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    padding: 0.125rem 0.5rem;
    border-radius: 4px;
    font-size: var(--of-font-size-sm);
    font-weight: var(--of-font-weight-semibold);
    letter-spacing: 0.025em;
}

.of-signal--long {
    background: linear-gradient(135deg, var(--score-excellent) 0%, var(--score-excellent-light) 100%);
    color: #ffffff;
    box-shadow: 0 1px 2px rgba(16, 185, 129, 0.3);
}

/* LONG 4/5 - Hellere Version (RSL Close-Warnung) */
.of-signal--long-4 {
    background: linear-gradient(135deg, #34d399 0%, #6ee7b7 100%);
    color: #064e3b;
    box-shadow: 0 1px 2px rgba(52, 211, 153, 0.3);
}

.of-signal--short {
    background: linear-gradient(135deg, var(--score-weak) 0%, var(--score-weak-light) 100%);
    color: #ffffff;
    box-shadow: 0 1px 2px rgba(239, 68, 68, 0.3);
}

/* SHORT 4/5 - Hellere Version (RSL Close-Warnung) */
.of-signal--short-4 {
    background: linear-gradient(135deg, #f87171 0%, #fca5a5 100%);
    color: #7f1d1d;
    box-shadow: 0 1px 2px rgba(248, 113, 113, 0.3);
}

/* Score-Anzeige im Signal-Badge */
.of-signal small {
    font-size: 0.75em;
    opacity: 0.85;
    margin-left: 2px;
}

.of-signal--neutral {
    background: var(--of-bg-subtle);
    color: var(--of-text-secondary);
}

.of-signal--na {
    color: var(--of-text-muted);
}



/* OF Signal in Chart Modal */
.scm-info__meta-item--of-signal .scm-info__meta-value {
    display: flex;
    align-items: center;
}

/* OF Signal Overlay on Chart */
.chart-signal-overlay {
    font-family: var(--of-font-family);
}

.chart-signal-overlay__badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 10px;
    border-radius: 4px;
    font-size: var(--of-font-size-base);
    font-weight: var(--of-font-weight-semibold);
    letter-spacing: 0.025em;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.15);
}

.chart-signal-overlay__icon {
    font-size: var(--of-font-size-xs);
}

.chart-signal-overlay__details {
    display: flex;
    flex-direction: column;
    gap: 1px;
    font-size: var(--of-font-size-xs);
    color: #6b7280;
    background: rgba(255, 255, 255, 0.9);
    padding: 3px 6px;
    border-radius: 3px;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
}

.chart-signal-overlay__score {
    font-weight: var(--of-font-weight-semibold);
}

.chart-signal-overlay__days {
    color: #9ca3af;
}

/* Signal Warning Tooltip */
.signal-warning-tooltip {
    display: none;
    position: absolute;
    z-index: 100;
    width: 260px;
    padding: 10px 12px;
    background: rgba(30, 30, 50, 0.95);
    border: 1px solid rgba(245, 158, 11, 0.4);
    border-radius: 6px;
    font-family: var(--of-font-family);
    font-size: var(--of-font-size-base);
    color: #e5e7eb;
    pointer-events: none;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
}

.signal-warning-tooltip__title {
    font-weight: var(--of-font-weight-semibold);
    color: #f59e0b;
    margin-bottom: 6px;
    font-size: var(--of-font-size-md);
}

.signal-warning-tooltip__subtitle {
    color: #9ca3af;
    margin-bottom: 4px;
    font-size: var(--of-font-size-sm);
}

.signal-warning-tooltip__list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.signal-warning-tooltip__list li {
    padding: 2px 0 2px 14px;
    position: relative;
    color: #fbbf24;
    font-size: var(--of-font-size-sm);
}

.signal-warning-tooltip__list li::before {
    content: '✕';
    position: absolute;
    left: 0;
    color: #ef4444;
    font-size: var(--of-font-size-xs);
    font-weight: var(--of-font-weight-bold);
}

/* Trend Cell */
.trend-cell {
    display: flex;
    align-items: center;
    gap: 0.375rem;
}

.trend-icon {
    font-size: var(--of-font-size-2xl);
}

.trend-icon--up { color: var(--trend-up); }
.trend-icon--down { color: var(--trend-down); }
.trend-icon--neutral { color: var(--trend-neutral); }

.trend-label {
    font-size: var(--of-font-size-table);
    font-weight: var(--of-font-weight-semibold);
}

.trend-label--up { color: var(--trend-up); }
.trend-label--down { color: var(--trend-down); }
.trend-label--neutral { color: var(--trend-neutral); }

/* Score Cell */
.score-cell {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.score-bar-container {
    width: 60px;
    height: 8px;
    background: var(--of-border);
    border-radius: 4px;
    overflow: hidden;
}

.score-bar-fill {
    height: 100%;
    border-radius: 4px;
    transition: width 0.3s;
}

.score-bar-fill--excellent { background: var(--score-excellent); }
.score-bar-fill--good { background: var(--score-good); }
.score-bar-fill--medium { background: var(--score-medium); }
.score-bar-fill--weak { background: var(--score-weak); }
.score-bar-fill--warning { background: var(--score-warning); }

.score-value {
    font-weight: var(--of-font-weight-semibold);
    font-size: var(--of-font-size-table);
    min-width: 32px;
    font-variant-numeric: tabular-nums;
}

/* Standard: Keine Farben für Score-Werte */
.score-value--excellent { color: var(--of-text-primary); }
.score-value--good { color: var(--of-text-primary); }
.score-value--medium { color: var(--of-text-primary); }
.score-value--weak { color: var(--of-text-primary); }
.score-value--warning { color: var(--of-text-primary); }

/* OF Combined Score */
.of-combined-score {
    display: flex;
    gap: 4px;
    align-items: center;
    justify-content: flex-start;
}

/* OF Score Boxes: quadratisch, gleiche Höhe wie viz-badge */
.of-score-box {
    display: flex;
    flex: 0 0 auto;
    min-width: var(--badge-height);
    width: var(--badge-height);
    height: var(--badge-height);
    padding: 0;
}

/* Large variant for Chart Modal */
.of-combined-score--large {
    gap: 6px;
}

.of-combined-score--large .of-score-box {
    min-width: 30px;
    width: 30px;
    height: 30px;
    font-size: var(--of-font-size-base);
    border-radius: 5px;
}

/* OF Score Multi-Select Filter — Breiteres Popup */
.filter-popup--wide {
    min-width: 520px;
    max-width: 620px;
}

.filter-popup__body--multi {
    display: flex;
    flex-direction: column;
    gap: 6px;
    max-height: 520px;
    overflow-y: auto;
    padding: 8px;
}

/* Score-Gruppen-Container */
.of-score-group {
    border-radius: 6px;
    overflow: hidden;
}

.of-score-group--excellent { background: rgba(5, 150, 105, 0.12); }
.of-score-group--good { background: rgba(74, 222, 128, 0.12); }
.of-score-group--medium { background: rgba(245, 158, 11, 0.12); }
.of-score-group--weak { background: rgba(239, 68, 68, 0.12); }

/* Container-Header (klickbar) */
.of-score-group__header {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 6px 10px;
    cursor: pointer;
    font-weight: var(--of-font-weight-semibold);
    font-size: var(--of-font-size-base);
    color: var(--of-text-primary);
    user-select: none;
}

.of-score-group__header:hover {
    opacity: 0.85;
}

.of-score-group__toggle {
    width: 16px;
    text-align: center;
    font-size: var(--of-font-size-lg);
    font-weight: var(--of-font-weight-bold);
    line-height: 1;
    color: var(--of-text-secondary);
}

.of-score-group__count {
    color: var(--of-text-muted);
    font-weight: var(--of-font-weight-medium);
    margin-left: auto;
}

/* Container-Body (Flex-Wrap Grid) */
.of-score-group__body {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    padding: 4px 8px 8px;
}

.of-score-group--collapsed .of-score-group__body {
    display: none;
}

.of-score-group__empty {
    font-size: var(--of-font-size-sm);
    color: var(--of-text-muted);
    font-style: italic;
    padding: 2px 4px;
}

/* Kombo-Items (kompakter im gruppierten Layout) */
.of-score-group .filter-multi-option {
    flex: 0 0 auto;
    padding: 4px 8px;
    gap: 6px;
    border-radius: 4px;
    background: rgba(255, 255, 255, 0.6);
    border: 1px solid rgba(0, 0, 0, 0.08);
    cursor: pointer;
    display: flex;
    align-items: center;
    transition: all 0.15s ease;
}

.of-score-group .filter-multi-option:hover {
    border-color: var(--of-accent-teal);
}

.of-score-group .filter-multi-option--selected {
    background: rgba(20, 184, 166, 0.18);
    border-color: var(--of-accent-teal);
    box-shadow: 0 0 0 1px var(--of-accent-teal);
}

.filter-multi-option__count {
    font-size: var(--of-font-size-sm);
    color: var(--of-text-muted);
    font-weight: var(--of-font-weight-medium);
}

.filter-multi-option--selected .filter-multi-option__count {
    color: var(--of-accent-teal);
}

/* Mini-Badges (F/T/O Farbquadrate) */
.of-filter-badges {
    display: inline-flex;
    gap: 2px;
}

.of-filter-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 20px;
    border-radius: 3px;
    font-size: 10px;
    font-weight: 700;
    color: #fff;
    text-align: center;
    text-shadow: 0 1px 1px rgba(0, 0, 0, 0.25);
}

.of-filter-badge--green {
    background: #059669;
}

.of-filter-badge--lightgreen {
    background: #22c55e;
}

.of-filter-badge--yellow {
    background: #d97706;
}

.of-filter-badge--red {
    background: #dc2626;
}

.of-filter-badge--neutral {
    background: #94a3b8;
}

/* Dark Mode: Gruppierte Score-Container */
[data-theme="dark"] .of-score-group--excellent { background: rgba(5, 150, 105, 0.18); }
[data-theme="dark"] .of-score-group--good { background: rgba(74, 222, 128, 0.15); }
[data-theme="dark"] .of-score-group--medium { background: rgba(245, 158, 11, 0.15); }
[data-theme="dark"] .of-score-group--weak { background: rgba(239, 68, 68, 0.15); }

[data-theme="dark"] .of-score-group .filter-multi-option {
    background: rgba(255, 255, 255, 0.08);
    border-color: rgba(255, 255, 255, 0.1);
}

[data-theme="dark"] .of-score-group .filter-multi-option--selected {
    background: rgba(20, 184, 166, 0.25);
}

/* Action Button */
.action-btn {
    padding: 0.375rem 0.75rem;
    border-radius: 6px;
    font-size: var(--of-font-size-base);
    font-weight: var(--of-font-weight-semibold);
    border: 1px solid var(--of-border);
    background: var(--of-bg-card);
    color: var(--of-text-secondary);
    cursor: pointer;
    transition: all 0.2s;
}

.action-btn:hover {
    border-color: var(--of-accent-teal);
    color: var(--of-accent-teal);
    background: rgba(13, 148, 136, 0.05);
}

/* ========================================
   FOOTER / PAGINATION
   ======================================== */
.screener-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.875rem 1.5rem;
    background: var(--of-bg-hover);
    border-top: 1px solid var(--of-border);
    flex-shrink: 0;
    gap: 1rem;
}

.footer-left {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.footer-info {
    font-size: var(--of-font-size-md);
    color: var(--of-text-muted);
}

.footer-info strong {
    color: var(--of-accent-teal);
}

.footer-separator {
    margin: 0 0.5rem;
    color: var(--of-border-dark);
}

.footer-update {
    font-size: var(--of-font-size-sm);
    color: var(--of-text-muted);
}

.footer-center {
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 1;
}

.footer-right {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.export-btn {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    padding: 0.5rem 0.875rem;
    background: var(--of-bg-card);
    border: 1px solid var(--of-border);
    border-radius: 6px;
    font-size: var(--of-font-size-base);
    font-weight: var(--of-font-weight-medium);
    color: var(--of-text-secondary);
    cursor: pointer;
    transition: all 0.15s;
}

.export-btn:hover {
    border-color: var(--of-accent-violet);
    color: var(--of-accent-violet);
}

.export-btn__icon {
    font-size: var(--of-font-size-lg);
}

/* Pagination - Options Scanner Style */
.ofma-pagination {
    display: flex;
    align-items: center;
    gap: 1.5rem;
}

.ofma-pagination__per-page {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    font-size: var(--of-font-size-base);
    color: var(--of-text-muted);
}

.ofma-pagination__per-page select {
    padding: 3px 20px 3px 6px !important;
    border: 1px solid var(--of-border) !important;
    border-radius: 4px !important;
    background-color: white !important;
    color: #1e293b !important;
    font-size: 0.75rem !important;
    font-family: inherit !important;
    line-height: 1.3 !important;
    height: 24px !important;
    cursor: pointer;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='8' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 5px center !important;
}

.ofma-pagination__per-page select option {
    font-size: 0.75rem !important;
    padding: 2px 6px !important;
}

.ofma-pagination__nav {
    display: flex;
    align-items: center;
    gap: 0.25rem;
}

.ofma-pagination__btn {
    padding: 0.25rem 0.5rem;
    border: 1px solid var(--of-border);
    border-radius: 4px;
    background: white;
    color: var(--of-text-secondary);
    font-size: var(--of-font-size-base);
    cursor: pointer;
    transition: all 0.15s;
}

.ofma-pagination__btn:hover:not(.disabled) {
    border-color: var(--of-accent-teal);
    color: var(--of-accent-teal);
}

.ofma-pagination__btn.disabled {
    opacity: 0.4;
    cursor: not-allowed;
}

.ofma-pagination__current {
    font-size: var(--of-font-size-base);
    color: var(--of-text-muted);
    padding: 0 0.5rem;
}

.ofma-pagination__current strong {
    color: var(--of-text-primary);
}

.ofma-pagination__select {
    padding: 0.125rem 0.375rem;
    border: 1px solid var(--of-border);
    border-radius: 3px;
    font-size: var(--of-font-size-base);
    font-weight: var(--of-font-weight-semibold);
    background: white;
    color: var(--of-text-primary);
    cursor: pointer;
    line-height: 1.2;
    margin: 0 0.25rem;
}

.ofma-pagination__select:hover {
    border-color: var(--of-accent-teal);
}

.ofma-pagination__select:focus {
    outline: none;
    border-color: var(--of-accent-teal);
    box-shadow: 0 0 0 2px rgba(20, 184, 166, 0.2);
}

.pagination {
    display: flex;
    gap: 0.25rem;
    align-items: center;
}

.page-btn {
    padding: 0.5rem 0.75rem;
    border: 1px solid var(--of-border);
    background: var(--of-bg-card);
    color: var(--of-text-secondary);
    border-radius: 6px;
    font-size: var(--of-font-size-md);
    cursor: pointer;
    transition: all 0.2s;
}

.page-btn:hover {
    border-color: var(--of-accent-teal);
    color: var(--of-accent-teal);
}

.page-btn.active {
    background: var(--of-accent-teal);
    border-color: var(--of-accent-teal);
    color: white;
}

.page-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

/* ========================================
   LOADING STATE
   ======================================== */
.table-loading {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 3rem;
    color: var(--of-text-muted);
    font-size: var(--of-font-size-lg);
}

.table-loading .spinner {
    width: 20px;
    height: 20px;
    border: 2px solid var(--of-border);
    border-top-color: var(--of-accent-teal);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
    margin-right: 0.75rem;
}

@keyframes spin {
    to { transform: rotate(360deg); }
}

/* ========================================
   EMPTY STATE
   ======================================== */
.table-empty {
    text-align: center;
    padding: 3rem;
    color: var(--of-text-muted);
}

.table-empty-text {
    font-size: var(--of-font-size-lg);
}

/* ========================================
   RESPONSIVE
   ======================================== */
@media (max-width: 1200px) {
    .screener-header {
        flex-wrap: wrap;
    }

    .filter-row__content {
        flex-wrap: wrap;
    }
}

@media (max-width: 768px) {
    .ofma-dashboard__main--screener {
        padding: 0.75rem !important;
    }

    .screener-wrapper {
        border-radius: 12px;
    }

    .screener-header {
        padding: 0.875rem 1rem;
        flex-direction: column;
        align-items: stretch;
        gap: 1rem;
    }

    .screener-header__right {
        flex-direction: column;
        align-items: stretch;
        gap: 0.75rem;
    }

    .screener-search {
        width: 100%;
    }

    .screener-header__stats {
        justify-content: space-between;
    }

    .filter-row {
        padding: 0.5rem 1rem;
        flex-direction: column;
        align-items: flex-start;
        gap: 0.5rem;
    }

    .filter-row__label {
        min-width: auto;
    }

    .filter-row__content {
        width: 100%;
    }

    .universe-select {
        min-width: 100%;
    }

    .active-filter-chips {
        width: 100%;
    }

    .table-grid th,
    .table-grid td {
        padding: 0.375rem 0.5rem;
    }

    .symbol-name {
        display: none;
    }

    .screener-footer {
        flex-direction: column;
        gap: 0.75rem;
    }

    .footer-center {
        flex: none;
    }

    .footer-right {
        flex-wrap: wrap;
        justify-content: center;
    }
}

/* ========================================
   STOCK CHART MODAL - NEW DESIGN
   ======================================== */
.stock-chart-modal {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 10000;
}

.stock-chart-modal.is-open {
    display: flex;
    align-items: center;
    justify-content: center;
}

.stock-chart-modal__overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(15, 23, 42, 0.5);
    backdrop-filter: blur(4px);
}

.stock-chart-modal__container {
    position: relative;
    width: 95%;
    max-width: 1400px;
    height: min(85vh, 900px);
    background: #fff;
    border-radius: 16px;
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
    display: flex;
    flex-direction: column;
    overflow: hidden;  /* Only tab-content scrolls, header/tabs stay fixed */
}

/* ========== HEADER ========== */
.scm-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px 24px;
    border-bottom: 1px solid #e5e7eb;
    flex-shrink: 0;
}

.scm-header__left {
    display: flex;
    align-items: center;
    gap: 10px;
}

.scm-header__symbol-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 6px 12px;
    font-size: var(--of-font-size-md);
    font-weight: var(--of-font-weight-bold);
    color: #fff;
    background: var(--of-accent-teal, #14b8a6);
    border-radius: 6px;
}

.scm-header__type-badge {
    display: inline-flex;
    align-items: center;
    padding: 4px 8px;
    font-size: var(--of-font-size-xs);
    font-weight: var(--of-font-weight-semibold);
    color: #6b7280;
    background: #f3f4f6;
    border-radius: 4px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.scm-header__name {
    font-size: var(--of-font-size-3xl);
    font-weight: var(--of-font-weight-semibold);
    color: #1f2937;
}

.scm-header__right {
    display: flex;
    align-items: center;
    gap: 8px;
}

.scm-header__nav-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 8px 16px;
    font-size: var(--of-font-size-md);
    font-weight: var(--of-font-weight-medium);
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    background: #fff;
    color: #374151;
    cursor: pointer;
    transition: all 0.15s ease;
}

.scm-header__nav-btn:hover {
    background: #f3f4f6;
    color: #1f2937;
}

/* ========== INFO SECTION ========== */
.scm-info {
    display: flex;
    justify-content: space-between;
    padding: 16px 24px;
    background: #fafafa;
    border-bottom: 1px solid #e5e7eb;
    flex-shrink: 0;
}

.scm-info__left {
    display: flex;
    gap: 32px;
    align-items: flex-start;
}

.scm-info__right {
    display: flex;
    gap: 24px;
    align-items: flex-start;
}

.scm-info__meta-item {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
}

/* Right side items are right-aligned */
.scm-info__right .scm-info__meta-item {
    align-items: flex-end;
}

.scm-info__meta-item--scores {
    position: relative;
}

.scm-info__meta-label-row {
    display: flex;
    align-items: center;
    gap: 6px;
}

/* IV Rank inline neben OF SCORE */
.scm-info__iv-rank-inline {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    margin-left: 16px;
    padding-left: 16px;
    border-left: 1px solid #e5e7eb;
}

.scm-info__iv-rank-label {
    font-size: var(--of-font-size-xs);
    font-weight: var(--of-font-weight-medium);
    color: #9ca3af;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.scm-info__iv-rank-value {
    font-size: var(--of-font-size-md);
    font-weight: var(--of-font-weight-semibold);
    min-width: 28px;
}

.scm-info__iv-rank-value .iv-value {
    font-weight: var(--of-font-weight-semibold);
}

.scm-info__meta-label {
    font-size: var(--of-font-size-xs);
    font-weight: var(--of-font-weight-medium);
    color: #9ca3af;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.scm-info__meta-value {
    font-size: var(--of-font-size-md);
    font-weight: var(--of-font-weight-semibold);
    color: #1f2937;
    line-height: 28px; /* Align with score boxes height */
}

/* Change value colors */
.scm-info__meta-value--change {
    color: #10b981;
}

.scm-info__meta-value--change.negative {
    color: #ef4444;
}

.scm-info__meta-unit {
    font-size: var(--of-font-size-md);
    font-weight: var(--of-font-weight-semibold);
    margin-left: 1px;
    color: inherit;
}

/* Help Icon (violet circle with ?) */
.scm-info__help {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 14px;
    height: 14px;
    background: transparent;
    border: 1px solid var(--of-accent-violet);
    border-radius: 50%;
    font-size: var(--of-font-size-2xs);
    font-weight: var(--of-font-weight-semibold);
    color: var(--of-accent-violet);
    cursor: pointer;
    transition: all 0.15s;
    flex-shrink: 0;
}

.scm-info__help:hover {
    background: var(--of-accent-violet);
    color: white;
}

/* Tooltip popup */
.scm-info__tooltip {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    margin-top: 8px;
    width: 260px;
    padding: 12px 14px;
    background: var(--of-accent-violet-dark);
    color: white;
    font-size: var(--of-font-size-base);
    line-height: 1.5;
    border-radius: 6px;
    z-index: 9999;
    box-shadow: var(--shadow-lg);
}

.scm-info__tooltip.visible {
    display: block;
}

.scm-info__tooltip strong {
    color: white;
}

/* ========== TABS ========== */
.scm-tabs {
    display: flex;
    gap: 0;
    padding: 0 24px;
    border-bottom: 1px solid #e5e7eb;
    background: #fff;
    flex-shrink: 0;
}

.scm-tabs__btn {
    padding: 14px 20px;
    font-size: var(--of-font-size-lg);
    font-weight: var(--of-font-weight-medium);
    color: #6b7280;
    background: transparent;
    border: none;
    border-bottom: 2px solid transparent;
    cursor: pointer;
    transition: all 0.15s ease;
}

.scm-tabs__btn:hover {
    color: #1f2937;
}

.scm-tabs__btn--active {
    color: var(--of-accent-violet);
    border-bottom-color: var(--of-accent-violet);
}

/* ========== TAB CONTENT ========== */
.scm-tab-content {
    flex: 1;
    display: flex;
    flex-direction: column;
    overflow-y: auto;
    min-height: 0; /* Important for flex overflow */
}

/* ========== TECHNICAL INDICATORS BAR ========== */
.scm-indicators {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: 12px 24px;
    background: #f9fafb;
    border-bottom: 1px solid #e5e7eb;
}

.scm-indicators__left {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.scm-indicators__right {
    display: flex;
    align-items: center;
    gap: 12px;
}

.scm-indicators__label {
    font-size: var(--of-font-size-xs);
    font-weight: var(--of-font-weight-medium);
    color: #9ca3af;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.scm-indicators__toggles {
    display: flex;
    align-items: center;
    gap: 20px;
    flex-wrap: wrap;
}

/* Chart Type Buttons */
.scm-chart-type-btns {
    display: flex;
    background: #e5e7eb;
    border-radius: 6px;
    padding: 2px;
}

.scm-chart-type-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 28px;
    background: transparent;
    border: none;
    border-radius: 4px;
    color: #6b7280;
    cursor: pointer;
    transition: all 0.15s;
}

.scm-chart-type-btn:hover {
    color: #1f2937;
}

.scm-chart-type-btn--active {
    background: #1f2937;
    color: #fff;
}

/* Support/Resistance Button */
.scm-sr-btn {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    background: #e5e7eb;
    border: none;
    border-radius: 6px;
    font-size: var(--of-font-size-sm);
    font-weight: var(--of-font-weight-semibold);
    color: #6b7280;
    cursor: pointer;
    transition: all 0.15s;
}

.scm-sr-btn:hover {
    background: #d1d5db;
    color: #1f2937;
}

.scm-sr-btn--active {
    background: #1f2937;
    color: #fff;
}

.scm-sr-wrapper {
    display: flex;
    align-items: center;
    gap: 8px;
}

.scm-sr-options {
    display: flex;
    align-items: center;
    gap: 10px;
}

.scm-sr-options__label {
    display: flex;
    align-items: center;
    gap: 3px;
    font-size: var(--of-font-size-sm);
    color: #6b7280;
    cursor: pointer;
    white-space: nowrap;
    user-select: none;
}

.scm-sr-options__label input[type="checkbox"] {
    width: 13px;
    height: 13px;
    margin: 0;
    cursor: pointer;
    accent-color: #22c55e;
}

.scm-sr-options__label:last-child input[type="checkbox"] {
    accent-color: #ef4444;
}

[data-theme="dark"] .scm-sr-options__label {
    color: #94a3b8;
}

/* Fibonacci Button */
.scm-fib-btn {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    background: #e5e7eb;
    border: none;
    border-radius: 6px;
    font-size: var(--of-font-size-sm);
    font-weight: var(--of-font-weight-medium);
    color: #6b7280;
    cursor: pointer;
    transition: all 0.15s;
}

.scm-fib-btn:hover {
    background: #d1d5db;
    color: #1f2937;
}

.scm-fib-btn--active {
    background: #8b5cf6;
    color: #fff;
}

/* Toggle Switch */
.scm-toggle {
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
}

.scm-toggle input {
    display: none;
}

.scm-toggle__slider {
    position: relative;
    width: 36px;
    height: 20px;
    background: #d1d5db;
    border-radius: 20px;
    transition: all 0.2s ease;
}

.scm-toggle__slider::after {
    content: '';
    position: absolute;
    top: 2px;
    left: 2px;
    width: 16px;
    height: 16px;
    background: #fff;
    border-radius: 50%;
    box-shadow: 0 1px 3px rgba(0,0,0,0.2);
    transition: all 0.2s ease;
}

.scm-toggle input:checked + .scm-toggle__slider {
    background: var(--of-accent-teal, #14b8a6);
}

.scm-toggle input:checked + .scm-toggle__slider::after {
    left: 18px;
}

.scm-toggle__label {
    font-size: var(--of-font-size-md);
    font-weight: var(--of-font-weight-medium);
    color: #374151;
}

/* Small Toggle Variant */
.scm-toggle--small {
    gap: 6px;
}

.scm-toggle--small .scm-toggle__slider {
    width: 28px;
    height: 16px;
}

.scm-toggle--small .scm-toggle__slider::after {
    top: 2px;
    left: 2px;
    width: 12px;
    height: 12px;
}

.scm-toggle--small input:checked + .scm-toggle__slider::after {
    left: 14px;
}

/* Toggle color variants for SMA */
.scm-toggle--blue input:checked + .scm-toggle__slider {
    background: #3b82f6;
}

.scm-toggle--black input:checked + .scm-toggle__slider {
    background: #1f2937;
}

.scm-toggle--violet input:checked + .scm-toggle__slider {
    background: #8b5cf6;
}

.scm-toggle--orange input:checked + .scm-toggle__slider {
    background: #f97316;
}

.scm-toggle--teal input:checked + .scm-toggle__slider {
    background: #14b8a6;
}

/* Toggle with Tooltip Container */
.scm-toggle-with-tooltip {
    display: inline-flex;
    align-items: center;
    gap: 2px;
}

/* Tooltip Icon Styles */
.scm-tooltip-icon {
    position: relative;
    display: inline-flex;
    align-items: center;
    margin-left: 2px;
    cursor: help;
}

.scm-tooltip-icon__circle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 16px;
    height: 16px;
    border-radius: 50%;
    border: 1px solid #8b5cf6;
    background: transparent;
    color: #8b5cf6;
    font-size: var(--of-font-size-xs);
    font-weight: var(--of-font-weight-semibold);
    transition: all 0.2s ease;
}

.scm-tooltip-icon:hover .scm-tooltip-icon__circle {
    background: #8b5cf6;
    color: #fff;
}

.scm-tooltip-icon__text {
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    margin-top: 8px;
    padding: 8px 12px;
    background: #8b5cf6;
    color: #fff;
    font-size: var(--of-font-size-sm);
    font-weight: var(--of-font-weight-regular);
    line-height: 1.4;
    border-radius: 6px;
    white-space: normal;
    max-width: 360px;
    opacity: 0;
    visibility: hidden;
    transition: all 0.2s ease;
    z-index: 1000;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

.scm-tooltip-icon__text::after {
    content: '';
    position: absolute;
    bottom: 100%;
    left: 50%;
    transform: translateX(-50%);
    border: 6px solid transparent;
    border-bottom-color: #8b5cf6;
}

.scm-tooltip-icon:hover .scm-tooltip-icon__text {
    opacity: 1;
    visibility: visible;
}

.scm-toggle--small .scm-toggle__label {
    font-size: var(--of-font-size-sm);
}

/* ========== CHART AREA ========== */
.scm-chart-area {
    position: relative;
    min-height: 300px;
    background: #fff;
    flex-shrink: 0;
}

.scm-chart-loading {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 12px;
    background: #fff;
    color: #6b7280;
    font-size: var(--of-font-size-lg);
    z-index: 10;
}

.scm-chart-loading.hidden {
    display: none;
}

.scm-chart-main {
    width: 100%;
    height: 480px;
    min-height: 410px;
    position: relative;
}

.scm-chart-rsi {
    display: none;
    width: 100%;
    height: 120px;
    border-top: 1px solid #e5e7eb;
    background: #fff;
    position: relative;
    flex-shrink: 0;
}

.scm-chart-macd {
    display: none;
    width: 100%;
    height: 130px;
    border-top: 1px solid #e5e7eb;
    background: #fff;
    position: relative;
    flex-shrink: 0;
}

.scm-chart-adx {
    display: none;
    width: 100%;
    height: 120px;
    border-top: 1px solid #e5e7eb;
    background: #fff;
    position: relative;
    flex-shrink: 0;
}

.scm-chart-stochastic {
    display: none;
    width: 100%;
    height: 100px;
    border-top: 1px solid #e5e7eb;
    background: #fff;
    position: relative;
    flex-shrink: 0;
}

.scm-chart-volume {
    display: none;
    width: 100%;
    height: 90px;
    border-top: 1px solid #e5e7eb;
    background: #fff;
    position: relative;
    flex-shrink: 0;
}

/* ========== INDICATOR PANELS CONTAINER ========== */
.scm-indicator-panels {
    background: #fff;
}

/* Nur Rand zeigen wenn Indikatoren sichtbar */
.scm-indicator-panels.has-visible-indicators {
    border-top: 1px solid #e5e7eb;
}

/* Indikatoren innerhalb des neuen Containers */
.scm-indicator-panels .scm-chart-rsi,
.scm-indicator-panels .scm-chart-macd,
.scm-indicator-panels .scm-chart-adx,
.scm-indicator-panels .scm-chart-volume {
    border-top: 1px solid #e5e7eb;
}

/* ========== PERIODS ========== */
.scm-periods {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 12px 24px;
    background: #fff;
    border-top: 1px solid #e5e7eb;
}

/* Stillhalter hint + button inside periods bar */
.scm-periods__sp-hint {
    margin-left: auto;
    font-size: var(--of-font-size-md);
    font-weight: var(--of-font-weight-semibold);
    color: #1f2937;
}

.scm-periods .scm-overview-sp__toggle {
    /* no margin-left: auto since hint already pushes it right */
}

.scm-overview-sp__toggle--banner {
    background: var(--of-accent-violet, #8b5cf6) !important;
    color: #fff !important;
    border-color: var(--of-accent-violet, #8b5cf6) !important;
    font-weight: var(--of-font-weight-medium);
    padding: 8px 16px;
    font-size: var(--of-font-size-md);
    border-radius: 8px;
}

.scm-overview-sp__toggle--banner:hover {
    background: #7c3aed !important;
    border-color: #7c3aed !important;
    color: #fff !important;
}

.scm-overview-sp__toggle--banner.scm-overview-sp__toggle--active {
    background: #1f2937 !important;
    border-color: #1f2937 !important;
}

.scm-periods__btn {
    padding: 8px 16px;
    font-size: var(--of-font-size-md);
    font-weight: var(--of-font-weight-medium);
    color: #6b7280;
    background: transparent;
    border: none;
    border-radius: 20px;
    cursor: pointer;
    transition: all 0.15s ease;
}

.scm-periods__btn:hover {
    background: #f3f4f6;
    color: #1f2937;
}

.scm-periods__btn--active {
    background: #1f2937;
    color: #fff;
}

/* ========== KEY METRICS ========== */
/* Key Metrics Overlay (oben links im Chart) */
.scm-metrics-overlay {
    position: absolute;
    top: 8px;
    left: 68px;
    z-index: 5;
    display: flex;
    align-items: flex-start;
    gap: 0;
}

.scm-metrics-overlay__toggle {
    width: 22px;
    height: 22px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid #d1d5db;
    border-radius: 4px;
    background: rgba(255, 255, 255, 0.8);
    color: #9ca3af;
    font-size: var(--of-font-size-xl);
    font-weight: var(--of-font-weight-semibold);
    line-height: 1;
    cursor: pointer;
    transition: all 0.15s ease;
    flex-shrink: 0;
}

.scm-metrics-overlay__toggle:hover {
    border-color: #9ca3af;
    color: #374151;
}

.scm-metrics-overlay__toggle--active {
    color: var(--of-accent-violet, #8b5cf6);
}

.scm-metrics-overlay__content {
    display: flex;
    flex-direction: column;
    gap: 1px;
    margin-left: 4px;
    padding: 4px 0;
    background: transparent;
    font-size: var(--of-font-size-sm);
}

.scm-metrics-overlay__item {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    white-space: nowrap;
    line-height: 1.5;
}

.scm-metrics-overlay__label {
    display: inline-block;
    min-width: 72px;
    text-align: right;
    color: #9ca3af;
    font-weight: var(--of-font-weight-regular);
}

.scm-metrics-overlay__value {
    color: #1f2937;
    font-weight: var(--of-font-weight-semibold);
}

.scm-metrics-overlay__sub {
    color: #6b7280;
    font-size: var(--of-font-size-xs);
}

/* Dark mode */
[data-theme="dark"] .scm-metrics-overlay__toggle {
    background: rgba(30, 41, 59, 0.8);
    border-color: #475569;
    color: #94a3b8;
}

[data-theme="dark"] .scm-metrics-overlay__toggle:hover {
    color: #e2e8f0;
}

[data-theme="dark"] .scm-metrics-overlay__content {
    background: transparent;
}

[data-theme="dark"] .scm-metrics-overlay__label {
    color: #6b7280;
}

[data-theme="dark"] .scm-metrics-overlay__value {
    color: #e2e8f0;
}

[data-theme="dark"] .scm-metrics-overlay__sub {
    color: #94a3b8;
}

/* Earnings color coding (same as scanner column) */
.earnings-danger {
    color: #ef4444 !important;  /* Red: <=7 days */
}
.earnings-warning {
    color: #f59e0b !important;  /* Yellow: <=14 days */
}
.earnings-safe {
    color: #10b981 !important;  /* Green: >14 days */
}

/* ========== OVERVIEW SP TABLE (Stillhalter unter Metriken) ========== */
.scm-overview-sp__toggle-bar {
    display: flex;
    align-items: center;
    padding: 8px 24px;
    border-top: 1px solid #e5e7eb;
    background: #fff;
}

[data-theme="dark"] .scm-overview-sp__toggle-bar {
    background: #1e293b;
    border-top-color: #334155;
}

.scm-overview-sp__toggle {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    font-size: var(--of-font-size-base);
    font-weight: var(--of-font-weight-medium);
    color: #6b7280;
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 6px;
    cursor: pointer;
    transition: all 0.15s ease;
}

.scm-overview-sp__toggle:hover {
    border-color: var(--of-accent-violet, #8b5cf6);
    color: var(--of-accent-violet, #8b5cf6);
}

.scm-overview-sp__toggle--active {
    background: var(--of-accent-violet, #8b5cf6);
    color: #fff;
    border-color: var(--of-accent-violet, #8b5cf6);
}

.scm-overview-sp__toggle--active:hover {
    background: var(--of-accent-violet-dark, #7c3aed);
    border-color: var(--of-accent-violet-dark, #7c3aed);
    color: #fff;
}

[data-theme="dark"] .scm-overview-sp__toggle {
    color: #94a3b8;
    background: #1e293b;
    border-color: #475569;
}

[data-theme="dark"] .scm-overview-sp__toggle:hover {
    border-color: var(--of-accent-violet, #8b5cf6);
    color: var(--of-accent-violet, #8b5cf6);
}

[data-theme="dark"] .scm-overview-sp__toggle--active {
    background: var(--of-accent-violet, #8b5cf6);
    color: #fff;
    border-color: var(--of-accent-violet, #8b5cf6);
}

[data-theme="dark"] .scm-overview-sp__toggle--active:hover {
    background: var(--of-accent-violet-dark, #7c3aed);
    border-color: var(--of-accent-violet-dark, #7c3aed);
}

.scm-overview-sp {
    display: flex;
    flex-direction: column;
    border-top: 1px solid #e5e7eb;
    background: #fff;
    min-height: 120px;
    max-height: 340px;
}

[data-theme="dark"] .scm-overview-sp {
    background: #1e293b;
    border-top-color: #334155;
}

.scm-overview-sp__toolbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 6px 16px;
    background: #f9fafb;
    border-bottom: 1px solid #e5e7eb;
    flex-shrink: 0;
}

[data-theme="dark"] .scm-overview-sp__toolbar {
    background: #1e293b;
    border-bottom-color: #334155;
}

.scm-overview-sp__tabs {
    display: flex;
    gap: 2px;
    flex-shrink: 0;
    margin-right: 12px;
}

.scm-overview-sp__tab {
    padding: 3px 12px;
    font-size: var(--of-font-size-base);
    font-weight: var(--of-font-weight-medium);
    border: 1px solid #d1d5db;
    background: #fff;
    color: #6b7280;
    cursor: pointer;
    border-radius: 4px;
    transition: all 0.15s;
}

.scm-overview-sp__tab:hover {
    background: #f3f4f6;
    color: #374151;
}

.scm-overview-sp__tab--active {
    background: #14b8a6;
    color: #fff;
    border-color: #14b8a6;
}

.scm-overview-sp__tab--active:hover {
    background: #0d9488;
    border-color: #0d9488;
    color: #fff;
}

[data-theme="dark"] .scm-overview-sp__tab {
    border-color: #475569;
    background: #334155;
    color: #94a3b8;
}

[data-theme="dark"] .scm-overview-sp__tab:hover {
    background: #3b4c63;
    color: #e2e8f0;
}

[data-theme="dark"] .scm-overview-sp__tab--active {
    background: #14b8a6;
    color: #fff;
    border-color: #14b8a6;
}

[data-theme="dark"] .scm-overview-sp__tab--active:hover {
    background: #0d9488;
    border-color: #0d9488;
    color: #fff;
}

.scm-overview-sp__filters {
    font-size: var(--of-font-size-sm);
    color: #9ca3af;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.scm-overview-sp__right {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-shrink: 0;
}

.scm-overview-sp__count {
    font-size: var(--of-font-size-sm);
    color: #9ca3af;
    white-space: nowrap;
}

.scm-overview-sp__body {
    flex: 1;
    overflow-y: auto;
    min-height: 0;
}

.scm-overview-sp__body::-webkit-scrollbar {
    width: 6px;
}

.scm-overview-sp__body::-webkit-scrollbar-track {
    background: transparent;
}

.scm-overview-sp__body::-webkit-scrollbar-thumb {
    background: #d1d5db;
    border-radius: 3px;
}

.scm-overview-sp__body::-webkit-scrollbar-thumb:hover {
    background: #9ca3af;
}

/* ========== FUNDAMENTALS TAB ========== */
.scm-fundamentals {
    padding: 20px 24px;
}

.fundamentals-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: 16px;
}

.fundamentals-item {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 12px;
    background: #f9fafb;
    border-radius: 8px;
}

.fundamentals-item__label {
    font-size: var(--of-font-size-sm);
    color: #6b7280;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.fundamentals-item__value {
    font-size: var(--of-font-size-2xl);
    font-weight: var(--of-font-weight-semibold);
    color: #1f2937;
}

/* Fundamentals Metrics Row */
.fundamentals-metrics {
    padding: 16px 0;
    border-bottom: 1px solid #e5e7eb;
}

.fundamentals-section-title {
    font-size: var(--of-font-size-lg);
    font-weight: var(--of-font-weight-semibold);
    color: #1f2937;
    margin-bottom: 16px;
    display: flex;
    align-items: center;
    gap: 8px;
}

/* Stillhalter Info Tooltip - Violet Style */
.stillhalter-info-icon {
    position: relative;
    display: inline-flex;
    align-items: center;
    cursor: help;
}

.stillhalter-info-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 16px;
    height: 16px;
    background: transparent;
    color: var(--of-accent-violet, #8b5cf6);
    border: 1.5px solid var(--of-accent-violet, #8b5cf6);
    border-radius: 50%;
    font-size: var(--of-font-size-xs);
    font-weight: var(--of-font-weight-bold);
    line-height: 1;
    cursor: pointer;
    transition: all 0.15s;
}

.stillhalter-info-icon:hover .stillhalter-info-badge {
    background: var(--of-accent-violet, #8b5cf6);
    color: #fff;
}

.stillhalter-tooltip {
    display: none;
    position: absolute;
    left: 0;
    top: 100%;
    margin-top: 8px;
    background: #8b5cf6;
    color: #fff;
    padding: 12px 14px;
    border-radius: 8px;
    font-size: var(--of-font-size-sm);
    font-weight: var(--of-font-weight-regular);
    line-height: 1.6;
    white-space: nowrap;
    z-index: 1000;
    box-shadow: 0 4px 12px rgba(139, 92, 246, 0.4);
}

.stillhalter-tooltip::before {
    content: '';
    position: absolute;
    bottom: 100%;
    left: 12px;
    border: 6px solid transparent;
    border-bottom-color: #8b5cf6;
}

.stillhalter-tooltip strong {
    color: #fff;
}

.stillhalter-info-icon:hover .stillhalter-tooltip {
    display: block;
}

/* Metrics Sections */
.metrics-section {
    margin-bottom: 20px;
}

.metrics-section:last-child {
    margin-bottom: 0;
}

.metrics-section__title {
    font-size: var(--of-font-size-base);
    font-weight: var(--of-font-weight-semibold);
    color: #6b7280;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 10px;
}

/* Visual Metrics Grid (with bars) */
.metrics-visual-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
}

.metric-visual-item {
    background: #f9fafb;
    border-radius: 8px;
    padding: 12px;
}

.metric-visual-item__header {
    display: flex;
    justify-content: space-between;
    margin-bottom: 8px;
    font-size: var(--of-font-size-base);
}

.metric-visual-item__header span:first-child {
    color: #6b7280;
}

.metric-visual-item__header span:last-child {
    font-weight: var(--of-font-weight-semibold);
    color: #1f2937;
}

/* Progress Bar */
.metric-bar {
    height: 6px;
    background: #e5e7eb;
    border-radius: 3px;
    overflow: hidden;
}

.metric-bar__fill {
    height: 100%;
    border-radius: 3px;
    transition: width 0.3s ease;
}

/* Rating Grid */
.metrics-rating-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.metric-rating-item {
    display: flex;
    align-items: center;
    gap: 8px;
    background: #f9fafb;
    border-radius: 6px;
    padding: 8px 12px;
    font-size: var(--of-font-size-base);
}

.metric-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    flex-shrink: 0;
}

.metric-rating-item__label {
    color: #6b7280;
}

.metric-rating-item__value {
    font-weight: var(--of-font-weight-semibold);
    color: #1f2937;
    margin-left: auto;
}

@media (max-width: 900px) {
    .metrics-visual-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* ========== STILLHALTER METRICS ========== */
.stillhalter-grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 12px;
}

/* All items span 2 columns (same width) */
.stillhalter-metric {
    grid-column: span 2;
}

.stillhalter-metric {
    background: #f9fafb;
    border-radius: 8px;
    padding: 12px;
}

.stillhalter-metric__header {
    margin-bottom: 8px;
}

.stillhalter-metric__label {
    font-size: var(--of-font-size-base);
    font-weight: var(--of-font-weight-semibold);
    color: #374151;
}

/* Range Track */
.stillhalter-metric__range {
    margin-bottom: 4px;
}

.stillhalter-metric__track {
    position: relative;
    height: 10px;
    background: linear-gradient(to right, #e5e7eb 0%, #d1d5db 100%);
    border-radius: 5px;
    margin-bottom: 4px;
}

/* Sector Marker - Gray Square */
.stillhalter-metric__sector-square {
    position: absolute;
    top: -1px;
    width: 12px;
    height: 12px;
    background: #6b7280;
    border-radius: 2px;
    transform: translateX(-50%);
    border: 2px solid #fff;
    box-shadow: 0 1px 2px rgba(0,0,0,0.2);
    z-index: 1;
}

/* Current Value Marker - Colored Dot */
.stillhalter-metric__current-dot {
    position: absolute;
    top: -2px;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    transform: translateX(-50%);
    border: 2px solid #fff;
    box-shadow: 0 1px 3px rgba(0,0,0,0.25);
    z-index: 2;
}

/* Scale below track */
.stillhalter-metric__scale {
    display: flex;
    justify-content: space-between;
    font-size: var(--of-font-size-2xs);
    color: #9ca3af;
    padding: 0 2px;
}

/* Values section */
.stillhalter-metric__values {
    display: flex;
    gap: 12px;
    margin-top: 6px;
    font-size: var(--of-font-size-xs);
    color: #6b7280;
}

.metric-value-item {
    display: flex;
    align-items: center;
    gap: 4px;
}

.metric-square {
    width: 8px;
    height: 8px;
    border-radius: 2px;
    flex-shrink: 0;
}

.metric-square.sector {
    background: #6b7280;
}

.metric-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    flex-shrink: 0;
}

@media (max-width: 1100px) {
    .stillhalter-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    .stillhalter-metric {
        grid-column: span 1;
    }
}

.fundamentals-metrics .fundamentals-grid {
    grid-template-columns: repeat(8, 1fr);
    gap: 12px;
}

.fundamentals-metrics .fundamentals-item {
    padding: 8px 12px;
}

.fundamentals-metrics .fundamentals-item__value {
    font-size: var(--of-font-size-lg);
}

/* Fundamentals Charts */
.fundamentals-charts {
    padding: 16px 0;
}

.fundamentals-charts__loading,
.fundamentals-charts__empty,
.fundamentals-charts__error {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 200px;
    color: #9ca3af;
    font-size: var(--of-font-size-md);
}

.fundamentals-charts__error {
    color: #ef4444;
}

/* ═══ Stillhalter-Qualitaets-Score Panel ═══ */
.sq-row {
    display: grid;
    grid-template-columns: 3fr minmax(280px, 2fr);
    gap: 12px;
    margin: 12px 16px;
    align-items: stretch;
}
.sq-left-col, .sq-right-col {
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.sq-right-col .sq-panel {
    flex: 1;
}
.sq-sliders-section {
    border: 1px solid #e5e7eb;
    border-radius: 10px;
    background: #fff;
    overflow: hidden;
}
.sq-sliders-section .fundamentals-section-title {
    padding: 14px 16px;
    background: #f9fafb;
    border-bottom: 1px solid #e5e7eb;
    margin: 0;
    font-size: 15px;
    font-weight: 700;
}
.sq-sliders-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    padding: 14px 16px;
}
.sq-sliders-grid .stillhalter-metric {
    grid-column: span 1;
}
.sq-description-panel {
    border: 1px solid #e5e7eb;
    border-radius: 10px;
    background: #fff;
    overflow: hidden;
}
.sq-description-header {
    font-size: 15px;
    font-weight: 700;
    color: #1f2937;
    padding: 14px 16px;
    background: #f9fafb;
    border-bottom: 1px solid #e5e7eb;
}
.sq-description-text {
    padding: 14px 16px 8px;
    font-size: 13px;
    line-height: 1.6;
    color: #4b5563;
}
.sq-desc-toggle {
    display: block;
    background: none;
    border: none;
    color: #14b8a6;
    font-size: 12px;
    font-weight: 600;
    cursor: pointer;
    padding: 0 16px 12px;
}
.sq-desc-toggle:hover {
    color: #0d9488;
}
.sq-earnings-banner {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    border-left: 4px solid;
    border-radius: 6px;
    margin: 12px 16px 0;
    font-size: 13px;
}
.sq-earnings-badge {
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    padding: 2px 8px;
    border-radius: 4px;
    white-space: nowrap;
}
.sq-earnings-date {
    color: #6b7280;
    font-size: 12px;
}
.sq-panel {
    margin: 0;
    border: 1px solid #e5e7eb;
    border-radius: 10px;
    background: #fff;
    overflow: hidden;
}
.sq-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 14px 16px;
    background: #f9fafb;
    border-bottom: 1px solid #e5e7eb;
}
.sq-header__title {
    font-size: 15px;
    font-weight: 700;
    color: #1f2937;
}
.sq-badge {
    min-width: 44px;
    height: 32px;
    border-radius: 8px;
    display: flex;
    align-items: baseline;
    justify-content: center;
    font-size: 15px;
    font-weight: 700;
    color: #fff;
    padding: 0 10px;
    gap: 3px;
}
.sq-badge__max {
    font-size: 11px;
    font-weight: 400;
    opacity: 0.8;
}
/* Kategorie */
.sq-category {
    border-bottom: 1px solid #f3f4f6;
    padding: 8px 16px 10px;
}
.sq-category:last-child {
    border-bottom: none;
}
.sq-category__header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 6px;
}
.sq-category__label {
    font-weight: 600;
    font-size: 12px;
    color: #374151;
}
.sq-category__score {
    font-size: 11px;
    color: #6b7280;
}
/* Einzelnes Kriterium: Label | Wert | Progress Bar — alles in einer Zeile */
.sq-criterion {
    display: grid;
    grid-template-columns: minmax(80px, 1fr) 50px 60px;
    align-items: center;
    gap: 8px;
    padding: 3px 0;
    font-size: 11px;
    color: #4b5563;
}
.sq-criterion__label {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.sq-criterion__target {
    color: #9ca3af;
    font-size: 10px;
}
.sq-criterion__value {
    font-weight: 600;
    font-size: 11px;
    text-align: right;
}
.sq-criterion__value--na { color: #9ca3af; }
/* Inline Progress Bar neben dem Wert */
.sq-crit-bar {
    height: 6px;
    background: #f3f4f6;
    border-radius: 3px;
    overflow: hidden;
}
.sq-crit-bar__fill {
    height: 100%;
    border-radius: 3px;
    transition: width 0.3s ease;
}

/* ═══ Earnings-Historie Panel ═══ */
.sq-earnings-panel {
    border: 1px solid #e5e7eb;
    border-radius: 10px;
    background: #fff;
    overflow: hidden;
}
.sq-earnings-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 14px 16px;
    background: #f9fafb;
    border-bottom: 1px solid #e5e7eb;
    font-size: 15px;
    font-weight: 700;
    color: #1f2937;
}
.sq-earnings-move {
    font-size: 12px;
    font-weight: 600;
    color: #6b7280;
    background: #f3f4f6;
    padding: 3px 8px;
    border-radius: 4px;
}
.sq-earnings-detail {
    display: flex;
    justify-content: center;
    gap: 12px;
    padding: 6px 16px;
    font-size: 12px;
    color: #4b5563;
    background: #f9fafb;
    border-bottom: 1px solid #e5e7eb;
    min-height: 22px;
}
.sq-earnings-bar-col[data-bar-idx] {
    cursor: pointer;
}
.sq-earnings-bar-col[data-bar-idx]:hover .sq-earnings-bar {
    opacity: 0.8;
}
.sq-earnings-next {
    padding: 8px 16px;
    font-size: 12px;
    color: #4b5563;
    background: #fffbeb;
    border-bottom: 1px solid #e5e7eb;
}
.sq-earnings-chart {
    display: flex;
    align-items: flex-end;
    gap: 4px;
    padding: 16px 16px 8px;
    min-height: 90px;
}
.sq-earnings-bar-col {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    cursor: default;
}
.sq-earnings-bar-wrap {
    display: flex;
    align-items: flex-end;
    justify-content: center;
    height: 60px;
}
.sq-earnings-bar {
    width: 100%;
    min-width: 16px;
    max-width: 32px;
    border-radius: 3px 3px 0 0;
    position: relative;
    transition: height 0.3s ease;
}
.sq-earnings-bar-label {
    position: absolute;
    top: -16px;
    left: 50%;
    transform: translateX(-50%);
    font-size: 9px;
    font-weight: 600;
    white-space: nowrap;
    color: inherit;
}
.sq-earnings-bar--beat .sq-earnings-bar-label { color: #059669; }
.sq-earnings-bar--miss .sq-earnings-bar-label { color: #dc2626; }
.sq-earnings-bar-quarter {
    font-size: 9px;
    color: #9ca3af;
    margin-top: 4px;
    white-space: nowrap;
}
.sq-earnings-bar-eps {
    font-size: 10px;
    color: #6b7280;
    font-weight: 600;
}
.sq-earnings-summary {
    display: flex;
    gap: 6px;
    padding: 8px 16px 12px;
    font-size: 12px;
}
.sq-earnings-loading, .sq-earnings-empty {
    padding: 16px;
    text-align: center;
    color: #9ca3af;
    font-size: 12px;
}
.sq-dividend-info {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 16px;
    border-top: 1px solid #f3f4f6;
    font-size: 12px;
}
.sq-dividend-label {
    font-weight: 600;
    color: #374151;
    white-space: nowrap;
}
.sq-dividend-values {
    color: #6b7280;
}

/* Financial Charts Grid */
.fin-charts-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
}

.fin-chart-box {
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    padding: 16px;
}

.fin-chart-title {
    font-size: var(--of-font-size-md);
    font-weight: var(--of-font-weight-semibold);
    color: #1f2937;
    margin-bottom: 6px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.fcf-trend-label {
    font-size: var(--of-font-size-sm);
    font-weight: var(--of-font-weight-semibold);
    color: #1f2937;
    margin-left: auto;
    margin-right: 4px;
}

.fcf-trend-arrow {
    font-size: var(--of-font-size-3xl);
    font-weight: var(--of-font-weight-black);
    line-height: 1;
}

.fin-chart-legend {
    display: flex;
    gap: 16px;
    margin-bottom: 10px;
    font-size: var(--of-font-size-sm);
    color: #6b7280;
}

.fin-legend-item {
    display: flex;
    align-items: center;
    gap: 6px;
}

.fin-legend-bar {
    width: 12px;
    height: 10px;
    border-radius: 2px;
}

.fin-legend-line {
    width: 16px;
    height: 2px;
    border-radius: 1px;
}

.fin-chart-box canvas {
    display: block;
    max-width: 100%;
    cursor: crosshair;
}

/* Financial Chart Tooltip */
.fin-chart-tooltip {
    display: none;
    position: fixed;
    z-index: 10001;
    background: #1f2937;
    color: #fff;
    padding: 10px 14px;
    border-radius: 8px;
    font-size: var(--of-font-size-base);
    box-shadow: 0 4px 12px rgba(0,0,0,0.25);
    pointer-events: none;
    min-width: 140px;
}

.fin-tooltip-year {
    font-weight: var(--of-font-weight-bold);
    font-size: var(--of-font-size-md);
    margin-bottom: 8px;
    padding-bottom: 6px;
    border-bottom: 1px solid #374151;
}

.fin-tooltip-row {
    display: flex;
    justify-content: space-between;
    gap: 20px;
    margin-bottom: 4px;
}

.fin-tooltip-row:last-child {
    margin-bottom: 0;
}

.fin-tooltip-row span:first-child {
    color: #9ca3af;
}

.fin-tooltip-row span:last-child {
    font-weight: var(--of-font-weight-semibold);
}

/* Responsive: Stack charts on smaller screens */
@media (max-width: 900px) {
    .fin-charts-grid {
        grid-template-columns: 1fr;
    }

    .fundamentals-metrics .fundamentals-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

/* ========== OPTIONS TAB ========== */
/* Styles moved to OPTIONS CHAIN PANEL section below */

/* ========== FOOTER ========== */
/* Resize Handle */
.scm-resize-handle {
    flex-shrink: 0;
    height: 8px;
    cursor: ns-resize;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #e5e7eb;
    border-radius: 0 0 16px 16px;
    transition: background 0.15s;
    user-select: none;
}

.scm-resize-handle:hover,
.scm-resize-handle.is-dragging {
    background: #d1d5db;
}

.scm-resize-handle__grip {
    width: 40px;
    height: 3px;
    border-radius: 2px;
    background: #9ca3af;
    transition: background 0.15s;
}

.scm-resize-handle:hover .scm-resize-handle__grip,
.scm-resize-handle.is-dragging .scm-resize-handle__grip {
    background: #6b7280;
}

.scm-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 24px;
    background: #f9fafb;
    border-top: 1px solid #e5e7eb;
    flex-shrink: 0;
}

.scm-footer__left {
    display: flex;
    align-items: center;
    gap: 8px;
}

.scm-footer__status {
    font-size: var(--of-font-size-base);
    color: #6b7280;
}

.scm-footer__status::before {
    content: '';
    display: inline-block;
    width: 8px;
    height: 8px;
    background: #10b981;
    border-radius: 50%;
    margin-right: 8px;
}

.scm-footer__right {
    display: flex;
    align-items: center;
    gap: 8px;
}

.scm-footer__btn {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    font-size: var(--of-font-size-md);
    font-weight: var(--of-font-weight-medium);
    color: #374151;
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.15s ease;
}

.scm-footer__btn:hover {
    background: #f3f4f6;
    border-color: #d1d5db;
}

.scm-footer__btn.active {
    background: #14b8a6;
    border-color: #0d9488;
    color: #fff;
}

.scm-footer__btn.active:hover {
    background: #0d9488;
    border-color: #0d9488;
}

.scm-footer__btn--primary {
    background: var(--of-accent-violet, #8b5cf6);
    border-color: var(--of-accent-violet, #8b5cf6);
    color: #fff;
}

.scm-footer__btn--primary:hover {
    background: #7c3aed;
    border-color: #7c3aed;
}

/* ========== CHART MODAL — DARK MODE ========== */
[data-theme="dark"] .stock-chart-modal__container,
.ofma-dashboard[data-theme="dark"] .stock-chart-modal__container { background: #1e293b !important; box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.5); }
[data-theme="dark"] .stock-chart-modal__overlay,
.ofma-dashboard[data-theme="dark"] .stock-chart-modal__overlay { background: rgba(0, 0, 0, 0.6); }
[data-theme="dark"] .scm-header,
.ofma-dashboard[data-theme="dark"] .scm-header { border-bottom-color: #334155; }
[data-theme="dark"] .scm-header__type-badge { background: #334155; color: #94a3b8; }
[data-theme="dark"] .scm-header__name { color: #e2e8f0; }
[data-theme="dark"] .scm-header__nav-btn { background: #1e293b; border-color: #475569; color: #e2e8f0; }
[data-theme="dark"] .scm-header__nav-btn:hover { background: #334155; color: #f1f5f9; }

[data-theme="dark"] .scm-info { background: #0f172a; border-bottom-color: #334155; }
[data-theme="dark"] .scm-info__meta-label { color: #64748b; }
[data-theme="dark"] .scm-info__meta-value { color: #e2e8f0; }
[data-theme="dark"] .scm-info__iv-rank-inline { border-left-color: #334155; }
[data-theme="dark"] .scm-info__iv-rank-label { color: #64748b; }

[data-theme="dark"] .scm-tabs { background: #1e293b; border-bottom-color: #334155; }
[data-theme="dark"] .scm-tabs__btn { color: #94a3b8; }
[data-theme="dark"] .scm-tabs__btn:hover { color: #f1f5f9; }

[data-theme="dark"] .scm-tab-content { background: #1e293b; }

[data-theme="dark"] .scm-indicators { background: #0f172a; border-bottom-color: #334155; }
[data-theme="dark"] .scm-indicators__label { color: #64748b; }

[data-theme="dark"] .scm-chart-type-btns { background: #334155; }
[data-theme="dark"] .scm-chart-type-btn { color: #94a3b8; }
[data-theme="dark"] .scm-chart-type-btn:hover { color: #f1f5f9; }
[data-theme="dark"] .scm-chart-type-btn--active { background: #14b8a6; color: #fff; }

[data-theme="dark"] .scm-sr-btn { background: #334155; color: #94a3b8; }
[data-theme="dark"] .scm-sr-btn:hover { background: #475569; color: #f1f5f9; }
[data-theme="dark"] .scm-sr-btn--active { background: #14b8a6; color: #fff; }
[data-theme="dark"] .scm-sr-options__label { color: #94a3b8; }

[data-theme="dark"] .scm-fib-btn { background: #334155; color: #94a3b8; border-color: #475569; }
[data-theme="dark"] .scm-fib-btn:hover { background: #475569; color: #f1f5f9; }
[data-theme="dark"] .scm-fib-btn--active { background: #14b8a6; color: #fff; }

[data-theme="dark"] .scm-toggle__slider { background: #334155; }
[data-theme="dark"] .scm-toggle__slider::after { background: #94a3b8; }
[data-theme="dark"] .scm-toggle input:checked + .scm-toggle__slider::after { background: #fff; }
[data-theme="dark"] .scm-toggle__label { color: #94a3b8; }

[data-theme="dark"] .scm-tooltip-icon__circle { background: #334155; border-color: #475569; color: #94a3b8; }
[data-theme="dark"] .scm-tooltip-icon:hover .scm-tooltip-icon__circle { background: var(--of-accent-violet); border-color: var(--of-accent-violet); color: #fff; }
[data-theme="dark"] .scm-tooltip-icon__text { background: #0f172a; color: #e2e8f0; box-shadow: 0 4px 20px rgba(0,0,0,0.4); }

[data-theme="dark"] .scm-chart-area,
[data-theme="dark"] .scm-chart-main,
[data-theme="dark"] .scm-chart-rsi,
[data-theme="dark"] .scm-chart-macd,
[data-theme="dark"] .scm-chart-adx,
[data-theme="dark"] .scm-chart-stochastic,
[data-theme="dark"] .scm-chart-volume,
[data-theme="dark"] .scm-indicator-panels { background: #1e293b !important; }
[data-theme="dark"] .scm-chart-loading { background: #1e293b !important; color: #94a3b8; }
[data-theme="dark"] .scm-chart-rsi,
[data-theme="dark"] .scm-chart-macd,
[data-theme="dark"] .scm-chart-adx,
[data-theme="dark"] .scm-chart-stochastic,
[data-theme="dark"] .scm-chart-volume { border-top-color: #334155; }

[data-theme="dark"] .scm-periods { background: #1e293b; border-top-color: #334155; }
[data-theme="dark"] .scm-periods__sp-hint { color: #e2e8f0; }
[data-theme="dark"] .scm-periods__btn { color: #94a3b8; }
[data-theme="dark"] .scm-periods__btn:hover { color: #f1f5f9; }
[data-theme="dark"] .scm-periods__btn--active { color: var(--of-accent-teal); }

[data-theme="dark"] .scm-overview-sp__toggle--banner.scm-overview-sp__toggle--active { background: #f1f5f9 !important; color: #0f172a !important; border-color: #e2e8f0 !important; }

[data-theme="dark"] .scm-metrics-overlay { background: #0f172a; border-color: #334155; }
[data-theme="dark"] .scm-metrics-overlay__toggle { background: #334155; border-color: #475569; color: #94a3b8; }
[data-theme="dark"] .scm-metrics-overlay__toggle:hover { color: #f1f5f9; }
[data-theme="dark"] .scm-metrics-overlay__toggle--active { color: #e2e8f0; }
[data-theme="dark"] .scm-metrics-overlay__label { color: #64748b; }
[data-theme="dark"] .scm-metrics-overlay__value { color: #e2e8f0; }
[data-theme="dark"] .scm-metrics-overlay__sub { color: #64748b; }

[data-theme="dark"] .scm-overview-sp { background: #1e293b; border-color: #334155; }
[data-theme="dark"] .scm-overview-sp__toolbar { border-bottom-color: #334155; }
[data-theme="dark"] .scm-overview-sp__tab { color: #94a3b8; border-color: #334155; }
[data-theme="dark"] .scm-overview-sp__tab:hover { color: #f1f5f9; }
[data-theme="dark"] .scm-overview-sp__tab--active { color: var(--of-accent-teal); border-bottom-color: var(--of-accent-teal); }
[data-theme="dark"] .scm-overview-sp__count { color: #64748b; }
[data-theme="dark"] .scm-overview-sp__body::-webkit-scrollbar-track { background: #0f172a; }
[data-theme="dark"] .scm-overview-sp__body::-webkit-scrollbar-thumb { background: #334155; }

[data-theme="dark"] .scm-footer { background: #0f172a; border-top-color: #334155; }
[data-theme="dark"] .scm-footer__status { color: #94a3b8; }
[data-theme="dark"] .scm-footer__btn { background: #1e293b; border-color: #475569; color: #e2e8f0; }
[data-theme="dark"] .scm-footer__btn:hover { background: #334155; color: #f1f5f9; }
[data-theme="dark"] .scm-footer__btn.active { background: #14b8a6; border-color: #0d9488; color: #fff; }

[data-theme="dark"] .scm-resize-handle { background: #334155; }
[data-theme="dark"] .scm-resize-handle__grip { color: #64748b; }

[data-theme="dark"] .scm-chart-loading { background: rgba(15, 23, 42, 0.85); color: #94a3b8; }

/* Fundamentals Tab — Vollständiger Dark Mode */
[data-theme="dark"] .scm-fundamentals { color: #e2e8f0; }
[data-theme="dark"] .fundamentals-item { background: #0f172a; }
[data-theme="dark"] .fundamentals-item__label { color: #64748b; }
[data-theme="dark"] .fundamentals-item__value { color: #e2e8f0; }
[data-theme="dark"] .fundamentals-metrics { border-bottom-color: #334155; }
[data-theme="dark"] .fundamentals-section-title { color: #e2e8f0; }

/* Unternehmensprofil */
[data-theme="dark"] .sq-description-panel { background: #1e293b; border-color: #334155; }
[data-theme="dark"] .sq-description-header { background: #0f172a; border-bottom-color: #334155; color: #e2e8f0; }
[data-theme="dark"] .sq-description-text { color: #94a3b8; }

/* Stillhalter Qualität */
[data-theme="dark"] .sq-panel { background: #1e293b; border-color: #334155; }
[data-theme="dark"] .sq-header { background: #0f172a; border-bottom-color: #334155; }
[data-theme="dark"] .sq-header__title { color: #e2e8f0; }
[data-theme="dark"] .sq-category { border-bottom-color: #334155; }
[data-theme="dark"] .sq-category__label { color: #e2e8f0; }
[data-theme="dark"] .sq-category__score { color: #94a3b8; }
[data-theme="dark"] .sq-criterion { color: #94a3b8; }
[data-theme="dark"] .sq-criterion__value { color: #e2e8f0; }
[data-theme="dark"] .sq-criterion__target { color: #64748b; }
[data-theme="dark"] .sq-crit-bar { background: #334155; }

/* Earnings-Banner */
[data-theme="dark"] .sq-earnings-banner { background: rgba(245,158,11,0.1); }
[data-theme="dark"] .sq-earnings-date { color: #94a3b8; }
[data-theme="dark"] .sq-earnings-next { background: rgba(245,158,11,0.08); border-bottom-color: #334155; color: #94a3b8; }

/* Earnings-Historie */
[data-theme="dark"] .sq-earnings-panel { background: #1e293b; border-color: #334155; }
[data-theme="dark"] .sq-earnings-header { background: #0f172a; border-bottom-color: #334155; color: #e2e8f0; }
[data-theme="dark"] .sq-earnings-move { background: #334155; color: #94a3b8; }
[data-theme="dark"] .sq-earnings-detail { background: #0f172a; border-bottom-color: #334155; color: #94a3b8; }
[data-theme="dark"] .sq-earnings-bar-quarter { color: #64748b; }
[data-theme="dark"] .sq-earnings-bar-eps { color: #94a3b8; }
[data-theme="dark"] .sq-earnings-loading, [data-theme="dark"] .sq-earnings-empty { color: #64748b; }
[data-theme="dark"] .sq-dividend-info { border-top-color: #334155; }
[data-theme="dark"] .sq-dividend-label { color: #e2e8f0; }
[data-theme="dark"] .sq-dividend-values { color: #94a3b8; }

/* Stillhalter Metriken (Slider-Bereich) */
[data-theme="dark"] .sq-sliders-section { background: #1e293b; border-color: #334155; }
[data-theme="dark"] .sq-sliders-section .fundamentals-section-title { background: #0f172a; border-bottom-color: #334155; }
[data-theme="dark"] .stillhalter-metric { background: #0f172a; }
[data-theme="dark"] .stillhalter-metric__label { color: #e2e8f0; }
[data-theme="dark"] .stillhalter-metric__track { background: linear-gradient(to right, #334155 0%, #475569 100%); }
[data-theme="dark"] .stillhalter-metric__sector-square { border-color: #1e293b; }
[data-theme="dark"] .stillhalter-metric__current-dot { border-color: #1e293b; }
[data-theme="dark"] .stillhalter-metric__scale { color: #64748b; }
[data-theme="dark"] .stillhalter-metric__values { color: #94a3b8; }

/* Financial Charts */
[data-theme="dark"] .fin-chart-box { background: #1e293b; border-color: #334155; }
[data-theme="dark"] .fin-chart-title { color: #e2e8f0; }
[data-theme="dark"] .fcf-trend-label { color: #e2e8f0; }
[data-theme="dark"] .fin-chart-legend { color: #94a3b8; }

/* Options Tab — Header */
[data-theme="dark"] .options-panel-header { background: #0f172a; border-bottom-color: #334155; }
[data-theme="dark"] .options-view-toggle { background: #334155; }
[data-theme="dark"] .options-view-toggle__btn { color: #94a3b8; }
[data-theme="dark"] .options-view-toggle__btn:hover { color: #f1f5f9; }
[data-theme="dark"] .options-view-toggle__btn--active { background: #14b8a6; color: #fff; box-shadow: none; }
[data-theme="dark"] .options-columns-btn { background: #1e293b; border-color: #475569; color: #94a3b8; }
[data-theme="dark"] .options-columns-btn:hover { background: #334155; }

/* Options Tab — Expiry Tabs */
[data-theme="dark"] .options-expiry-tabs { background: #1e293b; border-bottom-color: #334155; }
[data-theme="dark"] .options-expiry-tab { background: #0f172a; border-color: #475569; color: #94a3b8; }
[data-theme="dark"] .options-expiry-tab:hover { background: #334155; border-color: #64748b; color: #f1f5f9; }
[data-theme="dark"] .options-expiry-tab--active { background: #14b8a6; border-color: #14b8a6; color: #fff; }
[data-theme="dark"] .options-expiry-tab--earnings { background: rgba(239,68,68,0.15); border-color: #ef4444; color: #f87171; }
[data-theme="dark"] .options-expiry-tab--earnings:hover { background: rgba(239,68,68,0.25); }
[data-theme="dark"] .options-expiry-tab--earnings.options-expiry-tab--active { background: #dc2626; color: #fff; }

/* Options Tab — Spaltenheader */
[data-theme="dark"] .options-chain-subheader { background: #0f172a; color: #94a3b8; border-bottom-color: #334155; }
[data-theme="dark"] .options-chain-subheader__strike { background: #334155; color: #e2e8f0; }

/* Options Tab — Zeilen */
[data-theme="dark"] .options-chain-row { border-bottom-color: #334155; }
[data-theme="dark"] .options-chain-row:hover { background: #0f172a; }
[data-theme="dark"] .options-chain-row--atm { background: rgba(251, 191, 36, 0.15); }
[data-theme="dark"] .options-chain-row--atm:hover { background: rgba(251, 191, 36, 0.25); }

/* Options Tab — Strike-Spalte */
[data-theme="dark"] .options-chain-row__strike { background: #0f172a; color: #e2e8f0; border-left-color: #334155; border-right-color: #334155; }
[data-theme="dark"] .options-chain-row__strike--sd1 { background: rgba(59, 130, 246, 0.2); color: #93c5fd; }
[data-theme="dark"] .options-chain-row__strike--sd2 { background: rgba(59, 130, 246, 0.08); color: #e2e8f0; }

/* Options Tab — Zellen-Textfarben */
[data-theme="dark"] .options-chain-cell { color: #e2e8f0; }
[data-theme="dark"] .options-chain-cell--highlight { color: #e2e8f0; }
[data-theme="dark"] .options-chain-cell--muted { color: #64748b; }

/* Options Tab — Altes Chain-System (chart-modal.css) */
[data-theme="dark"] .chart-modal__chain-calls,
[data-theme="dark"] .chart-modal__chain-puts { color: #e2e8f0; }
[data-theme="dark"] .chart-modal__chain-row:hover .chart-modal__chain-calls,
[data-theme="dark"] .chart-modal__chain-row:hover .chart-modal__chain-puts { background: rgba(255,255,255,0.03); }

/* Options Tab — Spalten-Modal */
[data-theme="dark"] .options-column-modal__content { background: #1e293b; border-color: #334155; box-shadow: 0 25px 50px -12px rgba(0,0,0,0.5); }
[data-theme="dark"] .options-column-modal__header { border-bottom-color: #334155; }
[data-theme="dark"] .options-column-modal__title { color: #e2e8f0; }
[data-theme="dark"] .options-column-modal__close { color: #64748b; }
[data-theme="dark"] .options-column-modal__close:hover { color: #f1f5f9; background: #334155; }
[data-theme="dark"] .options-column-modal__footer { border-top-color: #334155; background: #0f172a; }
[data-theme="dark"] .options-column-modal__btn--secondary { background: #1e293b; border-color: #475569; color: #94a3b8; }
[data-theme="dark"] .options-column-modal__btn--secondary:hover { background: #334155; color: #f1f5f9; }

/* Spalten-Modal — Linke Seite (Aktive Spalten) */
[data-theme="dark"] .options-column-section__title { color: #64748b; }
[data-theme="dark"] .options-column-active { background: #0f172a; border-color: #334155; }
[data-theme="dark"] .options-column-item { background: #1e293b; border-color: #475569; }
[data-theme="dark"] .options-column-item:hover { border-color: var(--of-accent-violet); }
[data-theme="dark"] .options-column-item--dragging { background: #0f172a; }
[data-theme="dark"] .options-column-item__name { color: #e2e8f0; }
[data-theme="dark"] .options-column-item__drag { color: #64748b; }
[data-theme="dark"] .options-column-item__info { color: #64748b; }
[data-theme="dark"] .options-column-item__remove { color: #64748b; }
[data-theme="dark"] .options-column-item__remove:hover { color: #f87171; background: rgba(239,68,68,0.15); }

/* Spalten-Modal — Rechte Seite (Verfügbare Spalten) */
[data-theme="dark"] .options-column-search { background: #0f172a; border-color: #475569; color: #e2e8f0; }
[data-theme="dark"] .options-column-search::placeholder { color: #64748b; }
[data-theme="dark"] .options-column-category__title { color: #64748b; }
[data-theme="dark"] .options-column-add-btn { background: #334155; color: #94a3b8; border-color: #475569; }
[data-theme="dark"] .options-column-add-btn:hover { background: #475569; color: #f1f5f9; }
[data-theme="dark"] .options-column-add-btn--active { background: var(--of-accent-violet); color: #fff; border-color: var(--of-accent-violet); }

/* SP Puts Tab */
[data-theme="dark"] .scm-sp-puts { color: #e2e8f0; }

/* Spread Builder */
[data-theme="dark"] .scm-spread-builder { color: #e2e8f0; }

/* ========== RESPONSIVE ========== */
@media (max-width: 1024px) {
    .scm-info__left,
    .scm-info__right {
        flex-wrap: wrap;
        gap: 16px 24px;
    }

    .scm-metrics-overlay__content {
        font-size: var(--of-font-size-xs);
    }
}

@media (max-width: 768px) {
    .stock-chart-modal__container {
        width: 100%;
        max-width: 100%;
        max-height: calc(100vh - 16px);
        border-radius: 0;
    }

    .scm-header {
        padding: 12px 16px;
    }

    .scm-header__name {
        font-size: var(--of-font-size-lg);
    }

    .scm-info {
        flex-direction: column;
        gap: 16px;
        padding: 16px;
    }

    .scm-info__left,
    .scm-info__right {
        gap: 16px 24px;
    }

    .scm-info__right .scm-info__meta-item {
        align-items: flex-start;
    }

    .scm-info__meta-value {
        font-size: var(--of-font-size-base);
    }

    .scm-indicators {
        flex-direction: column;
        gap: 12px;
    }

    .scm-indicators__left {
        width: 100%;
    }

    .scm-indicators__right {
        width: 100%;
        justify-content: flex-start;
    }

    .scm-indicators__toggles {
        gap: 10px;
    }

    .scm-periods {
        flex-wrap: wrap;
    }

    .scm-footer {
        flex-direction: column;
        gap: 12px;
    }

    .scm-footer__right {
        width: 100%;
        justify-content: center;
    }
}

/* ========================================
   OPTIONS CHAIN PANEL (Scanner Modal)
   ======================================== */

/* Container */
.scm-options {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0; /* Allow shrinking on small viewports (notebooks) */
    overflow: hidden;
}

/* Options Header */
.options-panel-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 24px;
    background: #f9fafb;
    border-bottom: 1px solid #e5e7eb;
    flex-shrink: 0;
}

.oc-toggles {
    display: flex;
    align-items: center;
    gap: 12px;
}

.oc-toggles .scm-tooltip-icon__text {
    min-width: 280px;
    max-width: 420px;
}

.options-panel-header__right {
    display: flex;
    align-items: center;
    gap: 8px;
}

.options-view-toggle {
    display: flex;
    background: #e5e7eb;
    border-radius: 6px;
    padding: 2px;
}

.options-view-toggle__btn {
    padding: 6px 14px;
    font-size: var(--of-font-size-base);
    font-weight: var(--of-font-weight-medium);
    color: #6b7280;
    background: transparent;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    transition: all 0.15s;
}

.options-view-toggle__btn:hover {
    color: #1f2937;
}

.options-view-toggle__btn--active {
    background: #fff;
    color: #1f2937;
    box-shadow: 0 1px 3px rgba(0,0,0,0.1);
}

.options-columns-btn {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    font-size: var(--of-font-size-base);
    font-weight: var(--of-font-weight-medium);
    color: #6b7280;
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 6px;
    cursor: pointer;
    transition: all 0.15s;
}

.options-columns-btn:hover {
    border-color: var(--of-accent-violet);
    color: var(--of-accent-violet);
}

/* Expiry Tabs */
.options-expiry-tabs {
    display: flex;
    gap: 6px;
    padding: 12px 24px;
    background: #fff;
    border-bottom: 1px solid #e5e7eb;
    overflow-x: auto;
    flex-shrink: 0;
}

.options-expiry-tab {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
    padding: 10px 16px;
    font-size: var(--of-font-size-md);
    font-weight: var(--of-font-weight-semibold);
    color: #374151;
    background: #f3f4f6;
    border: 2px solid #e5e7eb;
    border-radius: 8px;
    cursor: pointer;
    white-space: nowrap;
    transition: all 0.15s;
}

.options-expiry-tab:hover {
    background: #fff;
    border-color: #9ca3af;
}

.options-expiry-tab--active {
    background: #1f2937;
    border-color: #1f2937;
    color: #fff;
}

/* Earnings warning - red border */
.options-expiry-tab--earnings {
    border-color: #ef4444;
    background: #fef2f2;
    color: #dc2626;
}

.options-expiry-tab--earnings:hover {
    background: #fee2e2;
    border-color: #dc2626;
}

.options-expiry-tab--earnings.options-expiry-tab--active {
    background: #dc2626;
    border-color: #dc2626;
    color: #fff;
}

.options-expiry-tab__dte {
    font-size: var(--of-font-size-sm);
    font-weight: var(--of-font-weight-medium);
    opacity: 0.8;
}

/* Tab View Container */
.options-tab-view {
    flex: 1;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    min-height: 0; /* Important for flex children to shrink */
}

/* Options Chain Table (Tab View) */
.options-chain {
    flex: 1;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    min-height: 0; /* Important for flex children to shrink */
}

.options-chain-header {
    display: grid;
    grid-template-columns: 1fr 80px 1fr;
    background: #1f2937;
    color: #fff;
    font-size: var(--of-font-size-md);
    font-weight: var(--of-font-weight-bold);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    flex-shrink: 0;
}

.options-chain-header__calls,
.options-chain-header__puts {
    padding: 12px 12px;
    text-align: center;
}

.options-chain-header__calls {
    background: rgba(239, 68, 68, 0.25);
}

.options-chain-header__puts {
    background: rgba(34, 197, 94, 0.25);
}

.options-chain-header__strike {
    padding: 12px 12px;
    text-align: center;
    background: #374151;
}

/* Sub-header with column names */
.options-chain-subheader {
    display: grid;
    grid-template-columns: 1fr 80px 1fr;
    background: #f3f4f6;
    font-size: var(--of-font-size-sm);
    font-weight: var(--of-font-weight-bold);
    color: #374151;
    text-transform: uppercase;
    letter-spacing: 0.3px;
    border-bottom: 2px solid #e5e7eb;
    flex-shrink: 0;
}

.options-chain-subheader__calls,
.options-chain-subheader__puts {
    display: flex;
    padding: 10px 8px;
    gap: 4px;
}

.options-chain-subheader__calls {
    flex-direction: row-reverse;
}

/* Header cells - equal width */
.options-chain-subheader__calls span,
.options-chain-subheader__puts span {
    flex: 1;
    text-align: center;
    min-width: 0;
}

/* Tooltip dashed underline for score columns */
.oc-tooltip-label {
    border-bottom: 1px dashed var(--ofma-color-slate-400, #94a3b8);
    cursor: help;
}

.options-chain-subheader__strike {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 10px 8px;
    background: #e5e7eb;
    font-weight: var(--of-font-weight-bold);
}

/* Chain Body */
.options-chain-body {
    flex: 1;
    overflow-y: auto;
    min-height: 0; /* Important for flex scrolling */
}

/* Scrollbar styling */
.options-chain-body::-webkit-scrollbar {
    width: 8px;
}

.options-chain-body::-webkit-scrollbar-track {
    background: #f1f5f9;
}

.options-chain-body::-webkit-scrollbar-thumb {
    background: #cbd5e1;
    border-radius: 4px;
}

.options-chain-body::-webkit-scrollbar-thumb:hover {
    background: #94a3b8;
}

/* Chain Row */
.options-chain-row {
    display: grid;
    grid-template-columns: 1fr 80px 1fr;
    border-bottom: 1px solid #f3f4f6;
    font-size: var(--of-font-size-base);
    transition: background 0.1s;
}

.options-chain-row:hover {
    background: #f9fafb;
}

.options-chain-row--atm {
    background: #fef3c7;
}

.options-chain-row--atm:hover {
    background: #fde68a;
}

/* Call/Put cells */
.options-chain-row__calls,
.options-chain-row__puts {
    display: flex;
    align-items: center;
    padding: 8px 8px;
    cursor: pointer;
    gap: 4px;
}

.options-chain-row__calls {
    flex-direction: row-reverse;
}

.options-chain-row__calls:hover {
    background: rgba(239, 68, 68, 0.1);
}

.options-chain-row__puts:hover {
    background: rgba(34, 197, 94, 0.1);
}

/* ITM styling */
.options-chain-row__calls--itm {
    background: rgba(239, 68, 68, 0.08);
}

.options-chain-row__puts--itm {
    background: rgba(34, 197, 94, 0.08);
}

.options-chain-row__calls--sweet-spot {
    background: rgba(139, 92, 246, 0.06);
}

.options-chain-row__puts--sweet-spot {
    background: rgba(139, 92, 246, 0.06);
}

/* Strike column */
.options-chain-row__strike {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 8px;
    font-weight: var(--of-font-weight-semibold);
    color: #1f2937;
    background: #f9fafb;
    border-left: 1px solid #e5e7eb;
    border-right: 1px solid #e5e7eb;
}

/* Standard Deviation Bands (like IBKR) */
.options-chain-row__strike--sd1 {
    background: rgba(59, 130, 246, 0.25); /* 1σ - darker blue */
    color: #1e40af;
}

.options-chain-row__strike--sd2 {
    background: rgba(59, 130, 246, 0.10); /* 2σ - lighter blue */
    color: #1f2937;
}

/* Cell values */
.options-chain-cell {
    flex: 1;
    min-width: 0;
    text-align: center;
    font-variant-numeric: tabular-nums;
    color: #374151;
}

.options-chain-cell--highlight {
    font-weight: var(--of-font-weight-semibold);
    color: #1f2937;
}

.options-chain-cell--positive {
    color: #059669;
}

.options-chain-cell--negative {
    color: #dc2626;
}

.options-chain-cell--muted {
    color: #9ca3af;
}

/* Price Line - Thin line with pill badge */
.options-chain-priceline {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    height: 24px;
    position: relative;
}

.options-chain-priceline__calls,
.options-chain-priceline__puts {
    height: 2px;
    background: #10b981;
}

.options-chain-priceline__badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 3px 12px;
    font-size: var(--of-font-size-sm);
    font-weight: var(--of-font-weight-semibold);
    color: #fff;
    background: #10b981;
    border-radius: 12px;
    white-space: nowrap;
}

/* Option Type Badge */
.option-type-badge {
    display: inline-block;
    padding: 2px 8px;
    font-size: var(--of-font-size-xs);
    font-weight: var(--of-font-weight-semibold);
    border-radius: 4px;
    text-transform: uppercase;
}

.option-type-badge--call {
    background: rgba(239, 68, 68, 0.15);
    color: #dc2626;
}

.option-type-badge--put {
    background: rgba(34, 197, 94, 0.15);
    color: #059669;
}

/* ========================================
   OPTIONS COLUMN CONFIGURATOR MODAL
   ======================================== */
.options-column-modal {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 10001;
    background: rgba(15, 23, 42, 0.5);
    backdrop-filter: blur(4px);
    align-items: center;
    justify-content: center;
}

.options-column-modal.is-open {
    display: flex;
}

.options-column-modal__content {
    width: 90%;
    max-width: 800px;
    max-height: 80vh;
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.options-column-modal__header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px 24px;
    border-bottom: 1px solid #e5e7eb;
}

.options-column-modal__title {
    font-size: var(--of-font-size-2xl);
    font-weight: var(--of-font-weight-semibold);
    color: #1f2937;
    margin: 0;
}

.options-column-modal__close {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--of-font-size-4xl);
    color: #6b7280;
    background: transparent;
    border: none;
    border-radius: 6px;
    cursor: pointer;
}

.options-column-modal__close:hover {
    background: #f3f4f6;
    color: #1f2937;
}

.options-column-modal__body {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
    padding: 24px;
    flex: 1;
    overflow-y: auto;
}

.options-column-section {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.options-column-section__title {
    font-size: var(--of-font-size-base);
    font-weight: var(--of-font-weight-semibold);
    color: #6b7280;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.options-column-active {
    min-height: 200px;
    padding: 12px;
    background: #f9fafb;
    border: 2px dashed #e5e7eb;
    border-radius: 8px;
}

.options-column-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 6px;
    margin-bottom: 6px;
    cursor: grab;
    transition: all 0.15s;
}

.options-column-item:hover {
    border-color: var(--of-accent-violet);
}

.options-column-item:active {
    cursor: grabbing;
}

.options-column-item--dragging {
    opacity: 0.5;
    background: #f3f4f6;
    border-style: dashed;
}

.options-column-item--drag-over {
    border-color: var(--of-accent-violet);
    background: rgba(139, 92, 246, 0.1);
}

.options-column-item__drag {
    color: #9ca3af;
    font-size: var(--of-font-size-base);
    letter-spacing: -2px;
    cursor: grab;
    user-select: none;
}

.options-column-item__drag:active {
    cursor: grabbing;
}

.options-column-item__name {
    flex: 1;
    font-size: var(--of-font-size-md);
    font-weight: var(--of-font-weight-medium);
    color: #374151;
}

.options-column-item__info {
    color: #9ca3af;
    font-size: var(--of-font-size-lg);
    cursor: help;
    flex-shrink: 0;
}

.options-column-item__info:hover {
    color: var(--of-accent-teal);
}

.options-column-item__remove {
    width: 20px;
    height: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--of-font-size-lg);
    color: #9ca3af;
    background: transparent;
    border: none;
    border-radius: 4px;
    cursor: pointer;
}

.options-column-item__remove:hover {
    color: #ef4444;
    background: #fef2f2;
}

.options-column-available {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.options-column-search {
    width: 100%;
    padding: 8px 12px;
    font-size: var(--of-font-size-md);
    border: 1px solid #e5e7eb;
    border-radius: 6px;
}

.options-column-search:focus {
    outline: none;
    border-color: var(--of-accent-violet);
    box-shadow: 0 0 0 3px rgba(139, 92, 246, 0.1);
}

.options-column-category {
    margin-bottom: 16px;
}

.options-column-category__title {
    font-size: var(--of-font-size-sm);
    font-weight: var(--of-font-weight-semibold);
    color: #9ca3af;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 8px;
}

.options-column-category__list {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.options-column-add-btn {
    padding: 6px 12px;
    font-size: var(--of-font-size-base);
    font-weight: var(--of-font-weight-medium);
    color: #6b7280;
    background: #f3f4f6;
    border: 1px solid transparent;
    border-radius: 4px;
    cursor: pointer;
    transition: all 0.15s;
}

.options-column-add-btn:hover {
    background: #e5e7eb;
    color: #1f2937;
}

.options-column-add-btn--active {
    background: var(--of-accent-violet);
    color: #fff;
}

.options-column-modal__footer {
    display: flex;
    justify-content: space-between;
    padding: 16px 24px;
    border-top: 1px solid #e5e7eb;
    background: #f9fafb;
}

.options-column-modal__btn {
    padding: 8px 16px;
    font-size: var(--of-font-size-md);
    font-weight: var(--of-font-weight-medium);
    border-radius: 6px;
    cursor: pointer;
    transition: all 0.15s;
}

.options-column-modal__btn--secondary {
    color: #6b7280;
    background: #fff;
    border: 1px solid #e5e7eb;
}

.options-column-modal__btn--secondary:hover {
    background: #f3f4f6;
}

.options-column-modal__btn--primary {
    color: #fff;
    background: var(--of-accent-violet);
    border: none;
}

.options-column-modal__btn--primary:hover {
    background: #7c3aed;
}

/* Loading State */
.options-loading {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 60px 20px;
    color: #6b7280;
    font-size: var(--of-font-size-lg);
    gap: 12px;
}

.options-loading .spinner {
    width: 24px;
    height: 24px;
    border: 2px solid #e5e7eb;
    border-top-color: var(--of-accent-teal);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
}

/* Empty State */
.options-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 60px 20px;
    color: #6b7280;
    text-align: center;
}

.options-empty__icon {
    font-size: var(--of-font-size-7xl);
    margin-bottom: 16px;
    opacity: 0.5;
}

.options-empty__text {
    font-size: var(--of-font-size-lg);
    max-width: 300px;
}

/* ========================================
   OPTION INFO BAR (Below Chart - Collapsible)
   ======================================== */
.option-info-bar {
    background: #fff;
    border-radius: 8px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
    font-size: var(--of-font-size-md);
    margin: 12px 24px;
    overflow: hidden;
}

.option-info-bar--call {
    border-left: 4px solid #ef4444;
}

.option-info-bar--put {
    border-left: 4px solid #10b981;
}

.option-info-bar__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 16px;
    background: #f9fafb;
}

.option-info-bar__summary {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.option-info-bar__type {
    font-size: var(--of-font-size-sm);
    font-weight: var(--of-font-weight-bold);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: 3px 8px;
    border-radius: 4px;
}

.option-info-bar--call .option-info-bar__type {
    background: #ef4444;
    color: #fff;
}

.option-info-bar--put .option-info-bar__type {
    background: #10b981;
    color: #fff;
}

.option-info-bar__strike {
    font-weight: var(--of-font-weight-bold);
    font-size: var(--of-font-size-lg);
    color: #1f2937;
}

.option-info-bar__sep {
    color: #d1d5db;
}

.option-info-bar__item {
    color: #374151;
    font-variant-numeric: tabular-nums;
}

.option-info-bar__label {
    color: #9ca3af;
    font-size: var(--of-font-size-sm);
    margin-right: 4px;
}

.option-info-bar__actions {
    display: flex;
    align-items: center;
    gap: 4px;
}

.option-info-bar__toggle,
.option-info-bar__close {
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: none;
    border: 1px solid #e5e7eb;
    border-radius: 4px;
    color: #6b7280;
    cursor: pointer;
    transition: all 0.15s;
}

.option-info-bar__toggle:hover,
.option-info-bar__close:hover {
    background: #fff;
    border-color: #d1d5db;
    color: #374151;
}

.option-info-bar__toggle-icon {
    font-size: var(--of-font-size-xs);
    transition: transform 0.2s;
}

.option-info-bar--expanded .option-info-bar__toggle-icon {
    transform: rotate(180deg);
}

.option-info-bar__close {
    font-size: var(--of-font-size-3xl);
}

/* Details panel (expandable) */
.option-info-bar__details {
    padding: 16px;
    border-top: 1px solid #e5e7eb;
    background: #fff;
}

.option-info-bar__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
}

.option-info-bar__detail {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.option-info-bar__detail-label {
    font-size: var(--of-font-size-sm);
    color: #9ca3af;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.option-info-bar__detail-value {
    font-size: var(--of-font-size-lg);
    font-weight: var(--of-font-weight-semibold);
    color: #1f2937;
    font-variant-numeric: tabular-nums;
}

.option-info-bar__detail--highlight .option-info-bar__detail-value {
    font-size: var(--of-font-size-xl);
}

.option-info-bar--call .option-info-bar__detail--highlight .option-info-bar__detail-value {
    color: #ef4444;
}

.option-info-bar--put .option-info-bar__detail--highlight .option-info-bar__detail-value {
    color: #10b981;
}

/* Clickable calls/puts visual feedback */
.options-chain-row__calls[data-option],
.options-chain-row__puts[data-option] {
    cursor: pointer;
    transition: background 0.15s;
}

.options-chain-row__calls[data-option]:active {
    background: rgba(239, 68, 68, 0.2);
}

.options-chain-row__puts[data-option]:active {
    background: rgba(34, 197, 94, 0.2);
}

/* Tour: OTM/ATM Put-Bereich hervorheben (ITM irrelevant für Stillhalter) */
.options-chain--highlight-puts .options-chain-header__calls,
.options-chain--highlight-puts .options-chain-subheader__calls,
.options-chain--highlight-puts .options-chain-row__calls {
    opacity: 0.25;
}

/* ITM Puts ebenfalls dimmen — nicht relevant für Stillhalter */
.options-chain--highlight-puts .options-chain-row__puts--itm {
    opacity: 0.25;
}

/* OTM/ATM Puts hervorheben (alle Puts OHNE --itm) */
.options-chain--highlight-puts .options-chain-row__puts:not(.options-chain-row__puts--itm) {
    background: rgba(139, 92, 246, 0.06);
    box-shadow: inset 3px 0 0 0 rgba(139, 92, 246, 0.5);
}

.options-chain--highlight-puts .options-chain-row__puts--sweet-spot:not(.options-chain-row__puts--itm) {
    background: rgba(139, 92, 246, 0.12);
}

/* PUTS Header hervorheben */
.options-chain--highlight-puts .options-chain-header__puts {
    box-shadow: inset 0 -3px 0 0 rgba(139, 92, 246, 0.6);
}

.options-chain--highlight-puts .options-chain-subheader__puts {
    background: rgba(139, 92, 246, 0.08);
}

/* ========================================
   OPTION INFO POPUP (Click on Strike Marker)
   ======================================== */
.option-info-popup {
    background: #fff;
    border-radius: 8px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
    font-size: var(--of-font-size-md);
    min-width: 200px;
    max-width: 280px;
    border: 1px solid #e5e7eb;
    overflow: hidden;
}

.option-info-popup__header {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 12px;
    background: #f9fafb;
    border-bottom: 1px solid #e5e7eb;
}

.option-info-popup__title {
    font-weight: var(--of-font-weight-bold);
    font-size: var(--of-font-size-lg);
    color: #1f2937;
}

.option-info-popup__close {
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: none;
    border-radius: 4px;
    font-size: var(--of-font-size-3xl);
    color: #9ca3af;
    cursor: pointer;
    transition: all 0.15s;
}

.option-info-popup__close:hover {
    background: #e5e7eb;
    color: #374151;
}

.option-info-popup__body {
    padding: 12px;
}

.option-info-popup__row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 4px 0;
    border-bottom: 1px solid #f3f4f6;
}

.option-info-popup__row:last-child {
    border-bottom: none;
}

.option-info-popup__row span {
    color: #6b7280;
    font-size: var(--of-font-size-base);
}

.option-info-popup__row strong {
    color: #1f2937;
    font-weight: var(--of-font-weight-semibold);
    font-variant-numeric: tabular-nums;
}

.option-info-popup__row--highlight {
    background: rgba(139, 92, 246, 0.1);
    border-radius: 4px;
    padding: 6px 8px !important;
    margin: 4px -8px 0;
}

.option-info-popup__row--highlight span {
    color: #8b5cf6;
    font-weight: var(--of-font-weight-medium);
}

.option-info-popup__row--highlight strong {
    color: #7c3aed;
}

/* Option Type Badge */
.option-info-popup__badge {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 4px;
    font-size: var(--of-font-size-sm);
    font-weight: var(--of-font-weight-bold);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.option-info-popup__badge--put {
    background: rgba(16, 185, 129, 0.15);
    color: #059669;
    border: 1px solid rgba(16, 185, 129, 0.3);
}

.option-info-popup__badge--call {
    background: rgba(239, 68, 68, 0.15);
    color: #dc2626;
    border: 1px solid rgba(239, 68, 68, 0.3);
}

/* ========================================
   Stillhalter Tab
   ======================================== */

.scm-sp-puts {
    padding: 16px 24px;
    overflow: auto;
    max-height: calc(100vh - 300px);
}

.sp-puts-loading {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 40px 0;
    color: #6b7280;
    font-size: var(--of-font-size-md);
}

.sp-puts-info {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 16px;
    padding: 8px 12px;
    background: #f3f4f6;
    border-radius: 6px;
    margin-bottom: 12px;
    font-size: var(--of-font-size-base);
    color: #6b7280;
}

.sp-puts-info__filters {
    flex: 1 1 auto;
}

.sp-puts-info__val {
    font-weight: var(--of-font-weight-semibold);
    color: #374151;
}

.sp-puts-info__right {
    display: flex;
    align-items: center;
    gap: 12px;
}

.sp-puts-info__count {
    font-weight: var(--of-font-weight-semibold);
    color: #14b8a6;
}

.sp-puts-table-wrap {
    overflow-x: auto;
}

.sp-puts-table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--of-font-size-md);
    font-variant-numeric: tabular-nums;
}

.sp-puts-table th {
    position: sticky;
    top: 0;
    background: #f9fafb;
    padding: 6px 10px;
    text-align: left;
    font-size: var(--of-font-size-sm);
    font-weight: var(--of-font-weight-semibold);
    text-transform: uppercase;
    letter-spacing: 0.3px;
    color: #9ca3af;
    border-bottom: 2px solid #e5e7eb;
    white-space: nowrap;
}

.sp-puts-table td {
    padding: 5px 10px;
    text-align: left;
    border-bottom: 1px solid #f3f4f6;
    white-space: nowrap;
    color: #374151;
}

.sp-puts-table th[data-col="moneyness"],
.sp-puts-table td[data-col="moneyness"] {
    text-align: center;
}

.sp-puts-table tbody tr:hover {
    background: rgba(16, 185, 129, 0.06);
}

.sp-puts-strike {
    font-weight: var(--of-font-weight-bold);
}

.sp-puts-val--green { color: #059669; font-weight: var(--of-font-weight-semibold); }
.sp-puts-val--yellow { color: #d97706; font-weight: var(--of-font-weight-semibold); }
.sp-puts-val--red { color: #dc2626; font-weight: var(--of-font-weight-semibold); }
.sp-puts-val--gray { color: #9ca3af; }

/* Top 3 Zeilen */
.sp-puts-row--top {
    background: rgba(0, 0, 0, 0.02);
}

.sp-puts-row--top td {
    font-weight: var(--of-font-weight-medium);
}

.sp-puts-table th[data-col="pick"],
.sp-puts-table td[data-col="pick"] {
    width: 28px;
    text-align: center !important;
    padding: 5px 4px !important;
}

.sp-puts-rank {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    font-size: var(--of-font-size-sm);
    font-weight: var(--of-font-weight-bold);
    color: #fff;
}

.sp-puts-rank--1 { background: #d4a017; } /* Gold */
.sp-puts-rank--2 { background: #a0a0a0; } /* Silber */
.sp-puts-rank--3 { background: #cd7f32; } /* Bronze */

.sp-puts-usd {
    font-weight: var(--of-font-weight-semibold);
    color: #059669;
}

/* Score Badge */
.sp-puts-score-badge {
    display: inline-block;
    padding: 2px 6px;
    border-radius: 4px;
    font-size: var(--of-font-size-base);
    font-weight: var(--of-font-weight-bold);
    min-width: 28px;
    text-align: center;
}

.sp-puts-score-badge.sp-puts-val--green { background: rgba(5, 150, 105, 0.12); }
.sp-puts-score-badge.sp-puts-val--yellow { background: rgba(217, 119, 6, 0.12); }
.sp-puts-score-badge.sp-puts-val--red { background: rgba(220, 38, 38, 0.12); }

/* Clickable SP rows */
.sp-puts-row--clickable {
    cursor: pointer;
}

.sp-puts-row--clickable:hover {
    background: rgba(34, 197, 94, 0.06) !important;
}

.sp-puts-row--selected {
    background: rgba(34, 197, 94, 0.12) !important;
    box-shadow: inset 3px 0 0 #22c55e;
}

/* SC Calls rows: rote Hintergrundtoene (wie Optionskette) */
.sc-calls-row:hover {
    background: rgba(239, 68, 68, 0.06) !important;
}

.sc-calls-row.sp-puts-row--selected {
    background: rgba(239, 68, 68, 0.12) !important;
    box-shadow: inset 3px 0 0 #ef4444;
}

/* Stillhalter-Tabelle Puts/Calls Hintergrund */
.sp-puts-table--puts tbody tr {
    background: rgba(34, 197, 94, 0.03);
}

.sp-puts-table--puts tbody tr:hover {
    background: rgba(34, 197, 94, 0.08) !important;
}

.sp-puts-table--puts .sp-puts-row--top {
    background: rgba(34, 197, 94, 0.06);
}

.sp-puts-table--calls tbody tr {
    background: rgba(239, 68, 68, 0.03);
}

.sp-puts-table--calls tbody tr:hover {
    background: rgba(239, 68, 68, 0.08) !important;
}

.sp-puts-table--calls .sp-puts-row--top {
    background: rgba(239, 68, 68, 0.06);
}

/* Stillhalter header with tooltip icons */
.sp-puts-table th {
    white-space: nowrap;
}

/* SP Puts Column Modal: reuses .options-column-modal classes */

.sp-puts-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 48px 24px;
    text-align: center;
    color: #6b7280;
}

.sp-puts-empty__icon {
    font-size: var(--of-font-size-6xl);
    margin-bottom: 12px;
    opacity: 0.5;
}

.sp-puts-empty__text {
    font-size: var(--of-font-size-lg);
    font-weight: var(--of-font-weight-medium);
    margin-bottom: 8px;
}

.sp-puts-empty__filters {
    font-size: var(--of-font-size-base);
    color: #9ca3af;
}

/* ========================================
   Utility Color Classes
   ======================================== */
.text-success { color: #10b981; }
.text-warning { color: #f59e0b; }
.text-danger  { color: #ef4444; }

/* ========================================
   IB Bridge - Status Indicator (Footer)
   ======================================== */
.ib-status {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-left: 16px;
    cursor: default;
}

.ib-status-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #94a3b8;
    transition: background 0.3s ease;
}

.ib-status-dot--connected {
    background: #10b981;
    box-shadow: 0 0 4px rgba(16, 185, 129, 0.4);
}

.ib-status-dot--disconnected {
    background: #ef4444;
    box-shadow: 0 0 4px rgba(239, 68, 68, 0.4);
}

.ib-status-dot--download {
    background: #f59e0b;
    box-shadow: 0 0 4px rgba(245, 158, 11, 0.4);
}

.ib-status-label {
    font-size: var(--of-font-size-base);
    color: var(--of-text-muted, #94a3b8);
    white-space: nowrap;
}

.ib-status-label a {
    color: inherit;
    text-decoration: underline dotted;
    cursor: pointer;
}

.ib-status-label a:hover {
    color: var(--of-accent-teal, #14b8a6);
}

/* ========================================
   IB Bridge - Context Menu
   ======================================== */
.ib-context-menu {
    position: fixed;
    z-index: 1000001;
    background: var(--of-bg-card, #ffffff);
    border: 1px solid var(--of-border, #e2e8f0);
    border-radius: 8px;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15);
    min-width: 220px;
    padding: 0.5rem 0;
    opacity: 0;
    visibility: hidden;
    transform: scale(0.95) translateY(-10px);
    transition: all 0.15s ease;
}

.ib-context-menu.visible {
    opacity: 1;
    visibility: visible;
    transform: scale(1) translateY(0);
}

.ib-context-menu__header {
    padding: 0.6rem 1rem;
    border-bottom: 1px solid var(--of-border, #e2e8f0);
}

.ib-context-menu__symbol {
    display: block;
    font-size: var(--of-font-size-md);
    font-weight: var(--of-font-weight-bold);
    color: var(--of-text-primary, #1e293b);
}

.ib-context-menu__details {
    display: block;
    font-size: var(--of-font-size-sm);
    color: var(--of-text-muted, #94a3b8);
    margin-top: 2px;
}

.ib-context-menu__divider {
    height: 1px;
    background: var(--of-border, #e2e8f0);
    margin: 0.25rem 0;
}

.ib-context-menu__item {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    width: 100%;
    padding: 0.5rem 1rem;
    border: none;
    background: transparent;
    color: var(--of-text-primary, #1e293b);
    font-size: var(--of-font-size-md);
    text-align: left;
    cursor: pointer;
    transition: all 0.1s ease;
}

.ib-context-menu__item:hover {
    background: var(--of-bg-hover, #f1f5f9);
    color: var(--of-accent-teal, #0d9488);
}

.ib-context-menu__item--disabled {
    opacity: 0.4;
    pointer-events: none;
}

.ib-context-menu__icon {
    font-size: var(--of-font-size-lg);
    width: 1.25rem;
    text-align: center;
    font-style: normal;
}
.ib-context-menu__icon svg {
    vertical-align: middle;
}

.ib-context-menu__label {
    flex: 1;
}

/* ========================================
   IB Bridge - Order Modal
   ======================================== */
.ib-order-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10000;
    animation: ib-fade-in 0.15s ease;
}

@keyframes ib-fade-in {
    from { opacity: 0; }
    to { opacity: 1; }
}

.ib-order-modal {
    width: 540px;
    max-width: 95%;
    max-height: 90vh;
    overflow-y: auto;
    background: var(--of-bg-card, #ffffff);
    border: 1px solid var(--of-border, #e2e8f0);
    border-radius: 12px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.2);
    animation: ib-slide-up 0.2s ease;
}

@keyframes ib-slide-up {
    from { transform: translateY(20px); opacity: 0; }
    to { transform: translateY(0); opacity: 1; }
}

.ib-order-modal__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    border-bottom: 1px solid var(--of-border, #e2e8f0);
}

.ib-order-modal__title {
    font-size: var(--of-font-size-xl);
    font-weight: var(--of-font-weight-bold);
    color: var(--of-text-primary, #1e293b);
}

.ib-order-modal__header-right {
    display: flex;
    align-items: center;
    gap: 12px;
}

.ib-order-market-status {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: var(--of-font-size-sm);
    color: var(--of-text-muted, #94a3b8);
}

.ib-order-market-dot {
    display: inline-block;
    width: 8px;
    height: 8px;
    border-radius: 50%;
}

.ib-order-market-dot--open {
    background: #10b981;
    box-shadow: 0 0 4px rgba(16, 185, 129, 0.5);
}

.ib-order-market-dot--closed {
    background: #ef4444;
    box-shadow: 0 0 4px rgba(239, 68, 68, 0.4);
}

.ib-order-market-label {
    font-weight: var(--of-font-weight-medium);
}

.ib-order-modal__close {
    background: none;
    border: none;
    font-size: var(--of-font-size-4xl);
    color: var(--of-text-muted, #94a3b8);
    cursor: pointer;
    padding: 0 4px;
    line-height: 1;
}

.ib-order-modal__close:hover {
    color: var(--of-text-primary, #1e293b);
}

.ib-order-modal__body {
    padding: 20px;
}

.ib-order-modal__info {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px 16px;
    padding: 12px 16px;
    background: var(--of-bg-hover, #f1f5f9);
    border-radius: 8px;
    margin-bottom: 20px;
    font-size: var(--of-font-size-base);
}

.ib-order-modal__info-item {
    display: flex;
    justify-content: space-between;
}

.ib-order-modal__info-label {
    color: var(--of-text-muted, #94a3b8);
}

.ib-order-modal__info-value {
    font-weight: var(--of-font-weight-semibold);
    color: var(--of-text-primary, #1e293b);
}

.ib-order-field {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 12px;
}

.ib-order-field__label {
    font-size: 12px !important;
    font-weight: var(--of-font-weight-medium);
    color: var(--of-text-secondary, #475569);
    min-width: 100px;
}

.ib-order-field__input {
    flex: 1;
    max-width: 200px;
    height: 26px !important;
    padding: 3px 8px !important;
    border: 1px solid var(--of-border, #e2e8f0) !important;
    border-radius: 4px !important;
    font-size: 12px !important;
    font-family: inherit !important;
    line-height: 1.3 !important;
    color: var(--of-text-primary, #1e293b) !important;
    background-color: var(--of-bg-card, #ffffff) !important;
    box-sizing: border-box !important;
}

select.ib-order-field__input {
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
    padding-right: 22px !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='8' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 6px center !important;
    cursor: pointer;
}

.ib-order-field__input:focus {
    outline: none;
    border-color: var(--of-accent-teal, #0d9488);
    box-shadow: 0 0 0 2px rgba(13, 148, 136, 0.1);
}

.ib-order-field__input[readonly] {
    background: var(--of-bg-hover, #f1f5f9);
    color: var(--of-text-secondary, #475569);
    cursor: default;
}

.ib-order-field__input-wrap {
    display: flex;
    align-items: center;
    flex: 1;
    max-width: 200px;
    position: relative;
}

.ib-order-field__input--pct {
    padding-right: 30px;
}

.ib-order-field__suffix {
    position: absolute;
    right: 10px;
    font-size: var(--of-font-size-md);
    font-weight: var(--of-font-weight-semibold);
    color: var(--of-text-muted, #94a3b8);
    pointer-events: none;
}

.ib-order-modal__preview {
    margin-top: 16px;
    padding: 12px 16px;
    background: #f0fdf4;
    border: 1px solid #bbf7d0;
    border-radius: 8px;
    font-size: var(--of-font-size-base);
    display: none;
}

.ib-order-modal__preview.visible {
    display: block;
}

.ib-order-modal__preview-title {
    font-weight: var(--of-font-weight-bold);
    color: #166534;
    margin-bottom: 8px;
    font-size: var(--of-font-size-md);
}

.ib-order-modal__preview-row {
    display: flex;
    justify-content: space-between;
    padding: 3px 0;
    color: #15803d;
}

.ib-order-modal__preview-label {
    color: #166534;
}

.ib-order-modal__preview-value {
    font-weight: var(--of-font-weight-semibold);
}

.ib-order-modal__error {
    margin-top: 12px;
    padding: 10px 14px;
    background: #fef2f2;
    border: 1px solid #fecaca;
    border-radius: 8px;
    font-size: var(--of-font-size-base);
    color: #dc2626;
    display: none;
}

.ib-order-modal__error.visible {
    display: block;
}

/* SL-Warnung: SL > Spread-Breite (nicht erreichbar) */
.ib-order-sl-warning {
    display: none;
    margin-top: 10px;
    padding: 10px 12px;
    background: linear-gradient(135deg, #fffbeb, #fef3c7);
    border: 1px solid #fcd34d;
    border-left: 3px solid #f59e0b;
    border-radius: 6px;
    font-size: 12px;
    line-height: 1.45;
    color: #78350f;
}
.ib-order-sl-warning.visible {
    display: flex;
    gap: 10px;
    align-items: flex-start;
}
.ib-order-sl-warning__icon {
    font-size: 18px;
    line-height: 1;
    color: #d97706;
    flex-shrink: 0;
    margin-top: 1px;
}
.ib-order-sl-warning__body {
    flex: 1;
}
.ib-order-sl-warning__body strong {
    color: #92400e;
    font-weight: 700;
}
[data-theme="dark"] .ib-order-sl-warning {
    background: linear-gradient(135deg, rgba(245, 158, 11, 0.15), rgba(245, 158, 11, 0.08));
    border-color: rgba(245, 158, 11, 0.5);
    border-left-color: #f59e0b;
    color: #fde68a;
}
[data-theme="dark"] .ib-order-sl-warning__body strong { color: #fcd34d; }

.ib-order-modal__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    border-top: 1px solid var(--of-border, #e2e8f0);
}

.ib-order-btn {
    padding: 8px 16px;
    font-size: var(--of-font-size-md);
    font-weight: var(--of-font-weight-semibold);
    border: none;
    border-radius: 6px;
    cursor: pointer;
    transition: all 0.15s ease;
}

.ib-order-btn--cancel {
    background: transparent;
    color: var(--of-text-secondary, #475569);
    border: 1px solid var(--of-border, #e2e8f0);
}

.ib-order-btn--cancel:hover {
    background: var(--of-bg-hover, #f1f5f9);
}

.ib-order-btn--secondary {
    background: var(--of-accent-violet, #8b5cf6);
    color: #ffffff;
}

.ib-order-btn--secondary:hover {
    background: var(--of-accent-violet-dark, #6d28d9);
}

.ib-order-btn--primary {
    background: var(--of-accent-teal, #0d9488);
    color: #ffffff;
}

.ib-order-btn--primary:hover {
    background: #0f766e;
}

.ib-order-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

/* Collapsible Sections (TP/SL) */
.ib-order-section--collapsible {
    border-top: 1px solid var(--of-border, #e2e8f0);
    padding-top: 12px;
    margin-top: 12px;
}

.ib-order-section__toggle {
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    font-weight: var(--of-font-weight-semibold);
    font-size: var(--of-font-size-md);
    color: var(--of-text-primary, #1e293b);
    user-select: none;
}

.ib-order-section__toggle input[type="checkbox"] {
    accent-color: #0d9488;
}

.ib-order-section__content {
    padding-left: 24px;
    padding-top: 10px;
}

/* TWS Price Loading */
.ib-order-loading {
    color: var(--of-text-muted, #94a3b8);
    font-style: italic;
    font-size: var(--of-font-size-sm);
}

/* Full-width info items (OF Bid/Ask, TWS Bid/Ask) */
.ib-order-modal__info-item--full {
    grid-column: 1 / -1;
    border-top: 1px solid var(--of-border, #e2e8f0);
    padding-top: 6px;
    margin-top: 2px;
}

.ib-order-modal__info-item--full + .ib-order-modal__info-item--full {
    border-top: none;
    padding-top: 0;
    margin-top: 0;
}

/* TWS Price Highlight */
.ib-order-modal__info-item--tws .ib-order-modal__info-value {
    color: #0d9488;
    font-weight: var(--of-font-weight-bold);
}

.ib-order-modal__info-item--tws .ib-order-modal__info-label {
    color: #0d9488;
    font-weight: var(--of-font-weight-semibold);
}

/* Limit-Preis: Quell-Indikator (OF Mid / TWS Mid) und Refresh-Button */
.ib-order-field__label {
    display: flex;
    align-items: center;
    gap: 8px;
}
.ib-order-limit-source {
    display: inline-block;
    font-size: 11px;
    font-weight: var(--of-font-weight-semibold);
    padding: 1px 6px;
    border-radius: 10px;
    background: var(--of-bg-muted, #f1f5f9);
    color: var(--of-text-muted, #64748b);
    line-height: 1.4;
}
.ib-order-limit-source--tws {
    background: rgba(13, 148, 136, 0.12);
    color: #0d9488;
}
.ib-order-limit-refresh {
    background: transparent;
    border: 1px solid var(--of-border, #e2e8f0);
    border-radius: 4px;
    width: 22px;
    height: 22px;
    line-height: 1;
    font-size: 14px;
    color: var(--of-text-muted, #64748b);
    cursor: pointer;
    padding: 0;
    transition: all 0.15s ease;
}
.ib-order-limit-refresh:hover {
    border-color: #0d9488;
    color: #0d9488;
    background: rgba(13, 148, 136, 0.06);
}
.ib-order-limit-refresh--loading {
    pointer-events: none;
    color: #0d9488;
    animation: ib-order-spin 0.8s linear infinite;
}
@keyframes ib-order-spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

.ib-order-modal__footer-left {
    display: flex;
    gap: 4px;
}

.ib-order-modal__footer-right {
    display: flex;
    gap: 8px;
}

/* Icon Buttons */
.ib-order-btn--icon {
    background: transparent;
    border: 1px solid var(--of-border, #e2e8f0);
    border-radius: 6px;
    padding: 6px 10px;
    font-size: var(--of-font-size-2xl);
    cursor: pointer;
    transition: all 0.15s ease;
    line-height: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.ib-order-btn--icon:hover {
    border-color: #0d9488;
    color: #0d9488;
}

/* ========================================
   IB Bridge - Toast Notification
   ======================================== */
.ib-toast {
    position: fixed;
    bottom: 24px;
    right: 24px;
    padding: 12px 20px;
    border-radius: 8px;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15);
    z-index: 1000002;
    opacity: 0;
    visibility: hidden;
    transform: translateY(20px);
    transition: all 0.3s ease;
    font-size: var(--of-font-size-md);
    font-weight: var(--of-font-weight-medium);
    max-width: 400px;
    background: var(--of-bg-card, #ffffff);
    border: 1px solid var(--of-border, #e2e8f0);
    color: var(--of-text-primary, #1e293b);
}

.ib-toast.visible {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.ib-toast--success {
    border-color: #10b981;
    color: #065f46;
}

.ib-toast--error {
    border-color: #ef4444;
    color: #991b1b;
}

.ib-toast--info {
    border-color: #3b82f6;
    color: #1e40af;
}

/* ========================================
   IB Bridge - Market Status (Chart Footer)
   ======================================== */
.ib-market-status {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-left: 12px;
    padding-left: 12px;
    border-left: 1px solid var(--of-border, #e2e8f0);
    cursor: default;
}

.ib-market-status__dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    flex-shrink: 0;
    transition: background 0.3s ease;
}

.ib-market-status__dot--open {
    background: #10b981;
    box-shadow: 0 0 4px rgba(16, 185, 129, 0.4);
}

.ib-market-status__dot--closed {
    background: #ef4444;
    box-shadow: 0 0 4px rgba(239, 68, 68, 0.4);
}

.ib-market-status__label {
    font-size: var(--of-font-size-base);
    color: var(--of-text-muted, #94a3b8);
    white-space: nowrap;
}

/* Version Label (Chart Footer) */
.ib-version {
    font-size: var(--of-font-size-xs);
    color: var(--of-text-muted, #94a3b8);
    opacity: 0.6;
    margin-left: 12px;
    padding-left: 12px;
    border-left: 1px solid var(--of-border, #e2e8f0);
    white-space: nowrap;
}

/* Strategy Dropdown: Disabled Options + Custom Fields */
#ib-order-strategy option:disabled {
    color: var(--of-text-muted, #94a3b8);
    font-style: italic;
}

#ib-order-strategy optgroup {
    font-weight: var(--of-font-weight-semibold);
    font-size: var(--of-font-size-base);
    color: var(--of-text-secondary, #475569);
}

.ib-order-custom-fields {
    padding: 8px 0 0 0;
    display: flex;
    gap: 12px;
}

.ib-order-custom-fields .ib-order-field {
    flex: 1;
}

/* ========================================
   IB Bridge - Spread / Multi-Leg Order
   ======================================== */

/* Spread Info Container */
.ib-order-spread-info {
    border: 1px solid var(--of-border, #e2e8f0);
    border-radius: 8px;
    padding: 12px;
    margin-bottom: 12px;
    background: var(--of-bg-subtle, #f8fafc);
}

/* Single Leg Row */
.ib-order-spread-leg {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 0;
}

.ib-order-spread-leg + .ib-order-spread-leg {
    border-top: 1px solid var(--of-border, #e2e8f0);
}

/* Leg Badge (SELL / BUY) */
.ib-order-spread-leg__badge {
    font-size: var(--of-font-size-sm);
    font-weight: var(--of-font-weight-bold);
    padding: 2px 8px;
    border-radius: 4px;
    flex-shrink: 0;
    letter-spacing: 0.3px;
    min-width: 40px;
    text-align: center;
}

.ib-order-spread-leg__badge--sell {
    background: rgba(239, 68, 68, 0.12);
    color: #dc2626;
}

.ib-order-spread-leg__badge--buy {
    background: rgba(16, 185, 129, 0.12);
    color: #059669;
}

/* Leg Label */
.ib-order-spread-leg__label {
    font-size: var(--of-font-size-md);
    font-weight: var(--of-font-weight-medium);
    color: var(--of-text-primary, #1e293b);
    flex: 1;
    min-width: 0;
}

/* Leg Value / Select */
.ib-order-spread-leg__value {
    font-size: var(--of-font-size-md);
    font-weight: var(--of-font-weight-semibold);
    color: var(--of-text-primary, #1e293b);
    white-space: nowrap;
}

.ib-order-spread-leg select {
    font-size: var(--of-font-size-base);
    padding: 4px 8px;
    border: 1px solid var(--of-border, #e2e8f0);
    border-radius: 6px;
    background: var(--of-bg-card, #fff);
    color: var(--of-text-primary, #1e293b);
    max-width: 280px;
    min-width: 200px;
}

/* Spread Metrics (3-column: Breite | Risiko | Gewinn) */
.ib-order-spread-metrics {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid var(--of-border, #e2e8f0);
}

.ib-order-spread-metrics__block {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 6px;
    text-align: center;
}

.ib-order-spread-metrics__block + .ib-order-spread-metrics__block {
    border-left: 1px solid var(--of-border, #e2e8f0);
}

.ib-order-spread-metrics__row {
    display: flex;
    flex-direction: column;
    gap: 1px;
}

.ib-order-spread-metrics__label {
    font-size: var(--of-font-size-sm);
    color: var(--of-text-muted, #94a3b8);
    font-weight: var(--of-font-weight-medium);
}

.ib-order-spread-metrics__value {
    font-size: var(--of-font-size-lg);
    font-weight: var(--of-font-weight-bold);
    color: var(--of-text-primary, #1e293b);
}

.ib-order-spread-metrics__value--credit {
    color: #059669;
}

.ib-order-spread-metrics__value--risk {
    color: #dc2626;
}

.ib-order-spread-metrics__value--profit {
    color: #059669;
}

.ib-order-spread-metrics__input {
    font-size: var(--of-font-size-lg);
    font-weight: var(--of-font-weight-bold);
    color: var(--of-text-primary, #1e293b);
    padding: 3px 8px;
    border: 1px solid var(--of-border, #e2e8f0);
    border-radius: 4px;
    background: var(--of-bg-card, #fff);
    width: 72px;
    text-align: center;
    margin: 0 auto;
}

.ib-order-spread-metrics__input:focus {
    outline: none;
    border-color: var(--of-accent-teal, #0d9488);
    box-shadow: 0 0 0 2px rgba(13, 148, 136, 0.15);
}

/* Tooltips in Spread-Metriken: links-ausgerichtet (Block 1 + 2) */
.ib-order-spread-metrics .scm-tooltip-icon__text {
    left: 0;
    transform: none;
    min-width: 200px;
}

.ib-order-spread-metrics .scm-tooltip-icon__text::after {
    left: 12px;
    transform: none;
}

/* Letzter Block (rechts): Tooltip rechts-ausgerichtet */
.ib-order-spread-metrics__block:last-child .scm-tooltip-icon__text {
    left: auto;
    right: 0;
}

.ib-order-spread-metrics__block:last-child .scm-tooltip-icon__text::after {
    left: auto;
    right: 12px;
}

/* IC Separator */
.ib-order-spread-separator {
    border-top: 1px dashed #d1d5db;
    margin: 8px 0;
}
[data-theme="dark"] .ib-order-spread-separator {
    border-top-color: #475569;
}

/* ========== FLAT VIEW ========== */
.options-flat-view {
    flex: 1;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    min-height: 0; /* Allow flex child to shrink below content size */
}

.options-flat-filters {
    display: flex;
    gap: 12px;
    padding: 12px 24px;
    background: #f9fafb;
    border-bottom: 1px solid #e5e7eb;
    flex-wrap: wrap;
}

.options-flat-filter {
    display: flex;
    align-items: center;
    gap: 6px;
}

.options-flat-filter__label {
    font-size: var(--of-font-size-sm);
    font-weight: var(--of-font-weight-medium);
    color: #6b7280;
    text-transform: uppercase;
}

.options-flat-filter__select,
.options-flat-filter__input {
    padding: 6px 10px;
    font-size: var(--of-font-size-base);
    border: 1px solid #e5e7eb;
    border-radius: 4px;
    background: #fff;
}

.options-flat-filter__input {
    width: 70px;
}

.options-flat-filter--stats {
    margin-left: auto;
    gap: 16px;
}

.options-flat-stats {
    font-size: var(--of-font-size-base);
    color: var(--of-text-muted);
}

.options-flat-stats strong {
    font-weight: var(--of-font-weight-semibold);
    color: var(--of-accent-teal);
}

.options-flat-limit-hint {
    color: var(--of-status-warning, #f59e0b);
    font-style: italic;
}

.options-flat-table-wrap {
    flex: 1;
    overflow-y: auto;
    min-height: 0; /* Critical: allows flex child to shrink below content size */
}

.options-flat-table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--of-font-size-base);
}

.options-flat-table thead {
    position: sticky;
    top: 0;
    z-index: 10;
}

.options-flat-table th {
    padding: 10px 12px;
    text-align: left;
    font-size: var(--of-font-size-xs);
    font-weight: var(--of-font-weight-semibold);
    color: #6b7280;
    text-transform: uppercase;
    letter-spacing: 0.3px;
    background: #f9fafb;
    border-bottom: 1px solid #e5e7eb;
    cursor: pointer;
    white-space: nowrap;
}

.options-flat-table th:hover {
    background: #f3f4f6;
}

.options-flat-table th.sorted-asc::after {
    content: ' \25B2';
    font-size: var(--of-font-size-3xs);
}

.options-flat-table th.sorted-desc::after {
    content: ' \25BC';
    font-size: var(--of-font-size-3xs);
}

.options-flat-table tbody {
    overflow-y: auto;
}

.options-flat-table td {
    padding: 8px 12px;
    border-bottom: 1px solid #f3f4f6;
    font-variant-numeric: tabular-nums;
}

.options-flat-table tr:hover {
    background: #f9fafb;
}

.options-flat-table__row--sweet-spot {
    background: rgba(139, 92, 246, 0.06);
}

/* =====================================================
   EXPAND COLUMN - Best Option per Symbol
   ===================================================== */
.expand-col {
    width: 55px;
    min-width: 55px;
    max-width: 55px;
    text-align: center;
    padding: 0 4px !important;
    position: relative;
}

thead .expand-col {
    border-bottom: 1px solid var(--of-border, #1e293b);
    font-size: var(--of-font-size-sm);
    font-weight: var(--of-font-weight-semibold);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--of-text-muted, #64748b);
}

/* Expand Button (Chevron + Count) */
.expand-btn {
    background: none;
    border: none;
    cursor: pointer;
    color: var(--of-text-secondary, #94a3b8);
    padding: 2px;
    display: inline-flex;
    align-items: center;
    gap: 2px;
    line-height: 1;
    position: relative;
    min-width: 18px;
    min-height: 18px;
    justify-content: center;
}

.expand-btn:hover {
    color: var(--of-accent-teal, #14b8a6);
}

.expand-btn .expand-icon {
    transition: transform 0.2s ease;
    flex-shrink: 0;
}

.expand-btn.expanded .expand-icon {
    transform: rotate(90deg);
}

.expand-btn .expand-count {
    font-size: var(--of-font-size-sm);
    color: var(--of-text-muted, #64748b);
}

/* =====================================================
   LOADING: OptionFinder Spinner (Teal + Violet)
   ===================================================== */

/* Beim Laden: Chevron + Count verstecken, Spinner zeigen */
.expand-btn.loading .expand-icon,
.expand-btn.loading .expand-count {
    display: none !important;
}

.expand-spinner {
    display: inline-block;
    width: 14px;
    height: 14px;
    border: 2px solid rgba(255, 255, 255, 0.15);
    border-top-color: #14b8a6;
    border-radius: 50%;
    animation: of-expand-spin 0.7s linear infinite;
}

@keyframes of-expand-spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

/* Cursor: progress auf ganzer Tabelle waehrend Expand */
.ofma-scanner__table.expand-loading,
.ofma-scanner__table.expand-loading * {
    cursor: progress !important;
}

/* =====================================================
   EXPANDED ROWS - Baumstruktur
   ===================================================== */
.expanded-row {
    background: var(--of-bg-card, #1e293b) !important;
}

.expanded-row:hover {
    background: var(--of-bg-hover, #253347) !important;
}

/* Baumstruktur-Zeichen: ├ und └ in Teal, zentriert */
.expand-tree {
    color: #14b8a6 !important;
    font-size: var(--of-font-size-lg) !important;
    font-weight: var(--of-font-weight-regular) !important;
    text-align: center !important;
    vertical-align: middle !important;
    border-left: 2px solid #14b8a6 !important;
    padding-left: 0 !important;
    padding-right: 4px !important;
}

/* Letzte Zeile: kein border-left (Linie endet) */
.expand-tree--last {
    border-left-color: transparent !important;
}

/* =====================================================
   OPTIONS-SCANNER HEADER - Gleicher Stil wie Aktien-Scanner
   ===================================================== */

/* Override: th-content als Inline (Label + Tooltip) statt Column-Layout */
.ofma-scanner__table th .th-content {
    display: inline !important;
    flex-direction: unset !important;
    vertical-align: middle;
}

/* th-icons Container (Sort + Filter) */
.ofma-scanner__table th .th-icons {
    display: inline-flex;
    align-items: center;
    margin-left: 6px;
    gap: 4px;
    vertical-align: middle;
    position: relative;
    z-index: 12;
}

/* Sort-Icon */
.ofma-scanner__table th .sort-icon {
    font-size: var(--of-font-size-xs);
    opacity: 0.6;
    min-width: 14px;
    text-align: center;
    color: var(--of-text-muted, #64748b);
}

.ofma-scanner__table th .sort-icon .sort-neutral {
    font-size: var(--of-font-size-3xs);
    letter-spacing: -1px;
    opacity: 0.5;
}

.ofma-scanner__table th.sorted .sort-icon {
    opacity: 1;
    color: var(--of-accent-teal, #14b8a6);
    font-weight: var(--of-font-weight-bold);
}

/* Filter-Icon (Triangle) */
.ofma-scanner__table th .th-filter {
    font-size: var(--of-font-size-sm);
    color: var(--of-text-secondary, #94a3b8);
    cursor: pointer;
    padding: 2px 4px;
    border-radius: 3px;
    transition: all 0.15s;
    line-height: 1;
    border: 1px solid var(--of-border, #1e293b);
    background: var(--of-bg-subtle, #1a2332);
    position: relative;
    z-index: 15;
    /* Reset button-styles from .filter-btn */
    width: auto;
    height: auto;
    display: inline;
}

.ofma-scanner__table th .th-filter:hover {
    color: var(--of-accent-teal, #14b8a6);
    background: rgba(13, 148, 136, 0.15);
    border-color: var(--of-accent-teal, #14b8a6);
}

.ofma-scanner__table th .th-filter.active,
.ofma-scanner__table th .th-filter.has-filter {
    color: white;
    background: var(--of-accent-teal, #14b8a6);
    border-color: var(--of-accent-teal, #14b8a6);
}

/* Sortable TH: Cursor pointer */
.ofma-scanner__table th.sortable {
    cursor: pointer;
}

.ofma-scanner__table th.sortable:hover {
    color: var(--of-accent-teal, #14b8a6);
}

/* Tooltip Help-Icon (Violet Circle mit ?) - global, gilt fuer beide Scanner */
.ofma-scanner__table .th-help {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 14px;
    height: 14px;
    background: transparent;
    border: 1px solid var(--of-accent-violet, #8b5cf6);
    border-radius: 50%;
    font-size: var(--of-font-size-2xs);
    font-weight: var(--of-font-weight-semibold);
    color: var(--of-accent-violet, #8b5cf6);
    cursor: help;
    margin-left: 0.375rem;
    transition: all 0.15s;
    flex-shrink: 0;
    vertical-align: middle;
}

.ofma-scanner__table .th-help:hover {
    background: var(--of-accent-violet, #8b5cf6);
    color: white;
}

/* ==========================================================================
   SPREAD BUILDER
   ========================================================================== */

.scm-spread-builder { padding: 8px 14px; display: flex; flex-direction: column; flex: 1; min-height: 0; overflow: visible; }

/* Header */
.sb-header { margin-bottom: 8px; display: flex; align-items: baseline; gap: 10px; flex-shrink: 0; }
.sb-header__strategy { display: flex; align-items: center; gap: 6px; }
.sb-header__label { font-size: var(--of-font-size-xs); text-transform: uppercase; color: #9ca3af; font-weight: 600; letter-spacing: 0.5px; }
.sb-header__strategy-name { font-size: var(--of-font-size-md); font-weight: 700; color: #111827; display: flex; align-items: center; gap: 4px; }
.sb-strategy-toggle { display: flex; gap: 2px; background: #f1f5f9; border-radius: 5px; padding: 2px; }
.sb-strategy-btn {
    padding: 3px 10px; border: none; background: transparent;
    font-size: var(--of-font-size-sm); font-weight: 600; cursor: pointer;
    border-radius: 4px; color: #64748b; display: flex; align-items: center; gap: 4px;
    transition: all 0.15s; line-height: 1.4;
}
.sb-strategy-btn:hover { color: #334155; }
.sb-strategy-btn--active { background: #fff; color: #111827; box-shadow: 0 1px 2px rgba(0,0,0,0.1); }
.sb-header__info { font-size: var(--of-font-size-sm); color: #9ca3af; }

/* Controls – angelehnt an Trade Map Filter-Styles */
.sb-controls { margin-bottom: 6px; flex-shrink: 0; }
.sb-controls__row { display: flex; gap: 10px; align-items: flex-end; flex-wrap: wrap; }
.sb-field { display: flex; flex-direction: column; gap: 2px; }
.sb-field__label { font-size: var(--of-font-size-xs); font-weight: 600; text-transform: uppercase; color: var(--of-text-muted, #94a3b8); letter-spacing: 0.04em; line-height: 1; }
.sb-field__select {
    padding: 3px 20px 3px 6px !important; font-size: var(--of-font-size-base) !important; border: 1px solid var(--of-border, #e2e8f0) !important; border-radius: 4px !important;
    background-color: var(--of-bg-card, #fff) !important; color: var(--of-text-primary, #1e293b) !important; height: 24px !important; cursor: pointer;
    -webkit-appearance: none !important; -moz-appearance: none !important; appearance: none !important; line-height: 1.3 !important;
    font-family: inherit !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='8' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important; background-position: right 5px center !important;
}
.sb-field__select option { font-size: var(--of-font-size-base) !important; padding: 2px 6px !important; }
.sb-field__select:focus { outline: none; border-color: #14b8a6; box-shadow: 0 0 0 2px rgba(20,184,166,0.12); }
.sb-field__value { font-size: var(--of-font-size-base); font-weight: 600; color: var(--of-text-primary, #1e293b); padding: 3px 0; height: 24px; display: flex; align-items: center; }
.sb-field__strike-value { color: var(--of-text-primary, #1e293b); }
.sb-field__strike-note { font-size: var(--of-font-size-2xs); color: var(--of-text-muted, #94a3b8); margin-left: 4px; font-weight: 400; }
.sb-field__value--box {
    background: #f9fafb; border: 1px solid #f3f4f6; border-radius: 4px;
    padding: 3px 8px !important; height: 24px !important;
}

/* Width Buttons */
.sb-width-btns { display: flex; gap: 3px; }
.sb-width-btn {
    padding: 2px 8px; font-size: var(--of-font-size-base); font-weight: 600; border: 1px solid var(--of-border, #e2e8f0);
    border-radius: 4px; background: var(--of-bg-card, #fff); color: #374151; cursor: pointer; transition: all 0.15s; height: 24px;
}
.sb-width-btn:hover { background: #14b8a6; color: #fff; border-color: #14b8a6; }
.sb-width-btn--active { background: #14b8a6; color: #fff; border-color: #14b8a6; }
.sb-width-input {
    width: 48px !important; height: 24px !important; padding: 3px 4px !important;
    border: 1px solid var(--of-border, #e2e8f0) !important; border-radius: 4px !important;
    background-color: var(--of-bg-card, #fff) !important; color: var(--of-text-primary, #1e293b) !important;
    font-size: var(--of-font-size-base) !important; font-family: inherit !important;
    text-align: center; font-variant-numeric: tabular-nums;
    -moz-appearance: textfield;
}
.sb-width-input::-webkit-outer-spin-button,
.sb-width-input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.sb-width-input:focus { outline: none; border-color: #14b8a6 !important; box-shadow: 0 0 0 2px rgba(20,184,166,0.12); }
.sb-width-input::placeholder { color: var(--of-text-muted, #94a3b8); font-size: var(--of-font-size-xs); }

/* IC Dual-Side Layout */
.sb-ic-sides { display: flex; flex-direction: row; gap: 8px; }
.sb-ic-side { flex: 1; min-width: 0; padding: 6px 8px; border: 1px solid #e2e8f0; border-radius: 6px; background: #fafbfc; }
.sb-ic-side__label {
    font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em;
    color: #64748b; margin-bottom: 4px;
}
.sb-ic-side .sb-controls__row { gap: 6px; }
.sb-ic-side .sb-width-btn { padding: 2px 5px; font-size: 10px; }
.dark-mode .sb-ic-side, [data-theme="dark"] .sb-ic-side { background: #111827; border-color: #1f2937; }
.dark-mode .sb-ic-side__label, [data-theme="dark"] .sb-ic-side__label { color: #9ca3af; }

/* Section Labels */
.sb-section-label {
    font-size: var(--of-font-size-xs); font-weight: 600; text-transform: uppercase;
    color: var(--of-text-muted, #94a3b8); letter-spacing: 0.04em; margin-bottom: 3px;
}
.sb-section-label__note { font-weight: 400; text-transform: none; letter-spacing: 0; font-size: 10px; }
.dark-mode .sb-section-label, [data-theme="dark"] .sb-section-label { color: #9ca3af; }

/* Legs */
.sb-legs {
    display: flex; align-items: center; gap: 8px; padding: 4px 10px;
    background: #f9fafb; border-radius: 4px; margin-bottom: 6px; flex-wrap: wrap; flex-shrink: 0;
}
.sb-legs__plus { font-size: var(--of-font-size-base); font-weight: 700; color: var(--of-text-muted, #94a3b8); }
.sb-leg { display: flex; align-items: center; gap: 5px; }
.sb-leg__badge {
    font-size: var(--of-font-size-2xs); font-weight: 700; padding: 1px 5px; border-radius: 3px;
    letter-spacing: 0.5px; flex-shrink: 0;
}
.sb-leg--sell__badge { background: #fef2f2; color: #dc2626; border: 1px solid #fecaca; }
.sb-leg--buy__badge { background: #f0fdf4; color: #16a34a; border: 1px solid #bbf7d0; }
.sb-leg__desc { font-size: var(--of-font-size-sm); color: #374151; }
.sb-legs__sep { flex: 1; }
.sb-legs__greek-group {
    display: inline-flex; align-items: center; gap: 3px;
    padding: 2px 6px; background: rgba(0,0,0,0.03); border-radius: 3px;
}
.sb-legs__greek-label {
    font-size: var(--of-font-size-2xs); font-weight: 600; text-transform: uppercase;
    color: var(--of-text-muted, #94a3b8); letter-spacing: 0.3px;
}
.sb-legs__greek {
    font-size: var(--of-font-size-sm); font-weight: 700; font-variant-numeric: tabular-nums;
    color: var(--of-text-secondary, #475569); white-space: nowrap;
}
.sb-legs__greek.of-val--positive { color: #059669; }
.sb-legs__greek.of-val--negative { color: #dc2626; }
.sb-legs__greek-group .scm-tooltip-icon { margin-left: 0; }
.sb-legs__greek-group .scm-tooltip-icon__circle { width: 12px; height: 12px; font-size: 8px; }
.sb-legs__greek-group .scm-tooltip-icon__text { min-width: 200px; left: auto; right: 0; transform: none; text-transform: none; }
.sb-legs__greek-group .scm-tooltip-icon__text::after { left: auto; right: 8px; transform: none; }

/* Dark Mode Greeks */
.dark-mode .sb-legs__greek-group, [data-theme="dark"] .sb-legs__greek-group { background: rgba(255,255,255,0.05); }
.dark-mode .sb-legs__greek, [data-theme="dark"] .sb-legs__greek { color: #d1d5db; }
.dark-mode .sb-legs__greek.of-val--positive, [data-theme="dark"] .sb-legs__greek.of-val--positive { color: #34d399; }
.dark-mode .sb-legs__greek.of-val--negative, [data-theme="dark"] .sb-legs__greek.of-val--negative { color: #f87171; }

/* Metrics Grid */
.sb-metrics {
    display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px;
    margin-bottom: 6px; flex-shrink: 0;
}
.sb-metric {
    text-align: center; padding: 4px 3px; background: #f9fafb;
    border-radius: 4px; border: 1px solid #f3f4f6; position: relative;
}
.sb-metric__label { display: block; font-size: var(--of-font-size-2xs); text-transform: uppercase; color: #9ca3af; font-weight: 600; margin-bottom: 2px; letter-spacing: 0.3px; }
.sb-metric__value { display: block; font-size: var(--of-font-size-base); font-weight: 700; color: var(--ofma-val-neutral, #1e293b); }
.sb-metric__value.of-val--positive { color: #059669; }
.sb-metric__value.of-val--negative { color: #dc2626; }

/* Tooltip-Icons in Metriken (kleiner als Standard) */
.sb-metric .scm-tooltip-icon { margin-left: 1px; vertical-align: middle; }
.sb-metric .scm-tooltip-icon__circle {
    width: 12px; height: 12px; font-size: 8px;
}
.sb-metric .scm-tooltip-icon__text {
    min-width: 200px; left: auto; right: 0; transform: none; text-transform: none;
}
.sb-metric .scm-tooltip-icon__text::after {
    left: auto; right: 8px; transform: none;
}
/* Erste Metrics: Tooltip nach rechts öffnen */
.sb-metric:nth-child(-n+2) .scm-tooltip-icon__text {
    left: 0; right: auto;
}
.sb-metric:nth-child(-n+2) .scm-tooltip-icon__text::after {
    left: 8px; right: auto;
}

/* P&L Chart */
.sb-chart-wrap { margin-bottom: 8px; position: relative; flex: 1; min-height: 0; display: flex; flex-direction: column; margin-left: -8px; margin-right: -8px; }
.sb-chart-overlay {
    position: absolute; top: 28px; left: 48px; z-index: 10;
    display: flex; flex-direction: column; gap: 3px;
}
.sb-chart-badges { display: flex; gap: 4px; }
#sb-pnl-chart { width: 100%; flex: 1; min-height: 0; }

/* Actions — gleiche Größe wie scm-footer__btn */
.sb-actions { display: flex; gap: 8px; justify-content: flex-end; align-items: center; flex-shrink: 0; }
.sb-action-btn {
    display: flex; align-items: center; gap: 6px;
    padding: 8px 16px; font-size: var(--of-font-size-md); font-weight: var(--of-font-weight-medium);
    border-radius: 8px; cursor: pointer; transition: all 0.15s; text-decoration: none;
    border: 1px solid;
}
.sb-action-btn--primary { background: #14b8a6; color: #fff; border-color: #0d9488; }
.sb-action-btn--primary:hover { background: #0d9488; border-color: #0d9488; }
.sb-action-btn--secondary { background: #fff; color: #374151; border-color: #e5e7eb; }
.sb-action-btn--secondary:hover { background: #f3f4f6; border-color: #d1d5db; }

/* Loading & Error */
.sb-loading {
    display: flex; align-items: center; justify-content: center; gap: 8px;
    padding: 40px; color: #6b7280; font-size: var(--of-font-size-sm);
}
.sb-error { padding: 20px; text-align: center; color: #ef4444; font-size: var(--of-font-size-sm); }

/* Dark Mode — Spread Builder */
.dark-mode .sb-header__strategy-name, [data-theme="dark"] .sb-header__strategy-name { color: #e2e8f0; }
.dark-mode .sb-strategy-toggle, [data-theme="dark"] .sb-strategy-toggle { background: #1f2937; }
.dark-mode .sb-strategy-btn, [data-theme="dark"] .sb-strategy-btn { color: #9ca3af; }
.dark-mode .sb-strategy-btn:hover, [data-theme="dark"] .sb-strategy-btn:hover { color: #d1d5db; }
.dark-mode .sb-strategy-btn--active, [data-theme="dark"] .sb-strategy-btn--active { background: #374151; color: #e2e8f0; box-shadow: 0 1px 2px rgba(0,0,0,0.3); }
.dark-mode .sb-header__info, [data-theme="dark"] .sb-header__info { color: #9ca3af; }
.dark-mode .sb-field__select, [data-theme="dark"] .sb-field__select { background-color: #1f2937 !important; color: #f9fafb !important; border-color: #374151 !important; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='8' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E") !important; }
.dark-mode .sb-field__select:focus, [data-theme="dark"] .sb-field__select:focus { border-color: #14b8a6; }
.dark-mode .sb-field__value, .dark-mode .sb-field__strike-value, [data-theme="dark"] .sb-field__value, [data-theme="dark"] .sb-field__strike-value { color: #e2e8f0; }
.dark-mode .sb-width-btn, [data-theme="dark"] .sb-width-btn { background: #1f2937; color: #d1d5db; border-color: #374151; }
.dark-mode .sb-width-btn:hover, [data-theme="dark"] .sb-width-btn:hover { background: #14b8a6; color: #fff; border-color: #14b8a6; }
.dark-mode .sb-width-btn--active, [data-theme="dark"] .sb-width-btn--active { background: #14b8a6; color: #fff; border-color: #14b8a6; }
.dark-mode .sb-width-input, [data-theme="dark"] .sb-width-input { background-color: #1f2937 !important; color: #f9fafb !important; border-color: #374151 !important; }
.dark-mode .sb-field__value--box, [data-theme="dark"] .sb-field__value--box { background: #1f2937; border-color: #374151; }
.dark-mode .sb-legs, [data-theme="dark"] .sb-legs { background: #1f2937; }
.dark-mode .sb-leg__desc, [data-theme="dark"] .sb-leg__desc { color: #d1d5db; }
.dark-mode .sb-leg--sell__badge, [data-theme="dark"] .sb-leg--sell__badge { background: rgba(220,38,38,0.15); border-color: rgba(220,38,38,0.3); }
.dark-mode .sb-leg--buy__badge, [data-theme="dark"] .sb-leg--buy__badge { background: rgba(22,163,74,0.15); border-color: rgba(22,163,74,0.3); }
.dark-mode .sb-metric, [data-theme="dark"] .sb-metric { background: #1f2937; border-color: #374151; }
.dark-mode .sb-metric__value, [data-theme="dark"] .sb-metric__value { color: #e2e8f0; }
.dark-mode .sb-metric__value.of-val--positive, [data-theme="dark"] .sb-metric__value.of-val--positive { color: #34d399; }
.dark-mode .sb-metric__value.of-val--negative, [data-theme="dark"] .sb-metric__value.of-val--negative { color: #f87171; }
/* Exit Rules (TP/SL) — Badges im Chart-Header */
.sb-exit-badge {
    display: inline-flex; align-items: center; justify-content: center;
    padding: 1px 6px; border-radius: 3px; cursor: pointer;
    font-size: var(--of-font-size-2xs); font-weight: 700; letter-spacing: 0.5px;
    border: 1px solid; transition: all 0.15s; user-select: none;
}
.sb-exit-badge--tp {
    background: #f0fdf4; color: #16a34a; border-color: #bbf7d0;
}
.sb-exit-badge--tp:hover, .sb-exit-badge--tp.sb-exit-badge--active {
    background: #16a34a; color: #fff; border-color: #16a34a;
}
.sb-exit-badge--sl {
    background: #fef2f2; color: #dc2626; border-color: #fecaca;
}
.sb-exit-badge--sl:hover, .sb-exit-badge--sl.sb-exit-badge--active {
    background: #dc2626; color: #fff; border-color: #dc2626;
}

/* Exit Detail (aufklappbar unter den Badges, innerhalb Chart-Overlay) */
.sb-exit-detail {
    display: flex; align-items: center; gap: 6px;
}
.sb-exit-field {
    display: flex; align-items: center; gap: 6px;
}
.sb-exit-field__label {
    font-size: var(--of-font-size-2xs); font-weight: 600; text-transform: uppercase;
    color: var(--of-text-muted, #94a3b8); white-space: nowrap;
}
.sb-exit-field__input-wrap {
    display: flex; align-items: center; position: relative;
}
.sb-exit-field__input {
    width: 56px; height: 22px; padding: 2px 22px 2px 6px;
    border: 1px solid var(--of-border, #e2e8f0); border-radius: 4px;
    background: var(--of-bg-card, #fff); color: var(--of-text-primary, #1e293b);
    font-size: var(--of-font-size-base); font-family: inherit; text-align: right;
    font-variant-numeric: tabular-nums; -moz-appearance: textfield;
}
.sb-exit-field__input::-webkit-outer-spin-button,
.sb-exit-field__input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.sb-exit-field__input:focus { outline: none; border-color: #14b8a6; box-shadow: 0 0 0 2px rgba(20,184,166,0.12); }
.sb-exit-field__suffix {
    position: absolute; right: 5px;
    font-size: var(--of-font-size-sm); font-weight: 600;
    color: var(--of-text-muted, #94a3b8); pointer-events: none;
}
.sb-exit-field__result {
    font-size: var(--of-font-size-xs); font-weight: 600; white-space: nowrap;
}

/* Dark Mode — Exit Rules */
.dark-mode .sb-exit-badge--tp, [data-theme="dark"] .sb-exit-badge--tp { background: rgba(22,163,74,0.15); color: #4ade80; border-color: rgba(22,163,74,0.3); }
.dark-mode .sb-exit-badge--tp:hover, .dark-mode .sb-exit-badge--tp.sb-exit-badge--active, [data-theme="dark"] .sb-exit-badge--tp:hover, [data-theme="dark"] .sb-exit-badge--tp.sb-exit-badge--active { background: #16a34a; color: #fff; border-color: #16a34a; }
.dark-mode .sb-exit-badge--sl, [data-theme="dark"] .sb-exit-badge--sl { background: rgba(220,38,38,0.15); color: #f87171; border-color: rgba(220,38,38,0.3); }
.dark-mode .sb-exit-badge--sl:hover, .dark-mode .sb-exit-badge--sl.sb-exit-badge--active, [data-theme="dark"] .sb-exit-badge--sl:hover, [data-theme="dark"] .sb-exit-badge--sl.sb-exit-badge--active { background: #dc2626; color: #fff; border-color: #dc2626; }
.dark-mode .sb-exit-field__input, [data-theme="dark"] .sb-exit-field__input { background: #111827; color: #e2e8f0; border-color: #374151; }

.dark-mode .sb-action-btn--secondary, [data-theme="dark"] .sb-action-btn--secondary { background: #1f2937; color: #d1d5db; border-color: #4b5563; }
.dark-mode .sb-action-btn--secondary:hover, [data-theme="dark"] .sb-action-btn--secondary:hover { background: #374151; border-color: #4b5563; }

/* Modal-Only Mode: Alles ausblenden, nur Chart-Modal sichtbar */
html:has(body.ofma-modal-only) {
    background: transparent !important;
}
body.ofma-modal-only {
    overflow: hidden;
    background: transparent !important;
}
body.ofma-modal-only > *:not(script):not(link):not(style) {
    visibility: hidden;
}
body.ofma-modal-only .stock-chart-modal,
body.ofma-modal-only .stock-chart-modal * {
    visibility: visible;
}
body.ofma-modal-only .stock-chart-modal__overlay {
    background: transparent;
    opacity: 1;
}
body.ofma-modal-only .ofma-tour-overlay,
body.ofma-modal-only .ofma-tour-highlight,
body.ofma-modal-only .ofma-tour-tooltip {
    visibility: visible;
}
