/* =====================================================================
 * settings.css — Einstellungsseite + Multi-Page-Chrome.
 * Alle Werte über Tokens aus design-tokens.css. Keine Hex/rgb/px-Werte
 * ausserhalb der Tokens.
 * ===================================================================== */

/* ---------- Topbar-Erweiterung ------------------------------------------- */

.topbar__nav {
    display: flex;
    gap: var(--space-1);
    margin-left: var(--space-4);
}

.topbar__nav-link {
    appearance: none;
    background: transparent;
    border: 1px solid transparent;
    color: var(--color-text-subtle);
    padding: var(--space-1) var(--space-3);
    font-family: var(--font-mono);
    font-size: var(--font-size-micro);
    letter-spacing: var(--letter-spacing-caps);
    text-transform: uppercase;
    cursor: pointer;
    border-radius: var(--radius-sm);
    transition: color var(--duration-fast) var(--ease-out),
                border-color var(--duration-fast) var(--ease-out),
                background var(--duration-fast) var(--ease-out),
                box-shadow var(--duration-fast) var(--ease-out);
    position: relative;
}

.topbar__nav-link:hover {
    color: var(--color-text);
    background: var(--color-surface-hover);
}

.topbar__nav-link[data-aktiv="true"] {
    color: var(--color-accent);
    border-color: hsl(var(--hsl-accent-500) / 0.4);
    background: var(--color-accent-soft);
    font-weight: var(--font-weight-medium);
}

.topbar__settings-btn {
    appearance: none;
    background: transparent;
    border: 1px solid var(--color-border);
    color: var(--color-text-muted);
    padding: var(--space-1) var(--space-2);
    font-family: var(--font-mono);
    font-size: var(--font-size-small);
    cursor: pointer;
    border-radius: var(--radius-sm);
    transition: color var(--duration-fast) var(--ease-out),
                border-color var(--duration-fast) var(--ease-out),
                background var(--duration-fast) var(--ease-out);
    line-height: 1;
}

.topbar__settings-btn:hover {
    color: var(--color-text);
    border-color: var(--color-border-strong);
    background: var(--color-surface-hover);
}

.topbar__settings-btn[data-aktiv="true"] {
    color: var(--color-accent);
    border-color: hsl(var(--hsl-accent-500) / 0.4);
    background: var(--color-accent-soft);
}

/* ---------- Settings-Page ------------------------------------------------ */

.settings {
    padding: var(--space-6);
    max-width: var(--layout-content-max);
    display: flex;
    flex-direction: column;
    gap: var(--space-6);
}

.settings__head {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
    padding-bottom: var(--space-4);
    border-bottom: 1px solid var(--color-border);
}

.settings__title {
    font-size: var(--font-size-h1);
    color: var(--color-text);
    font-weight: var(--font-weight-semibold);
    letter-spacing: var(--letter-spacing-tight);
}

.settings__subtitle {
    font-family: var(--font-mono);
    font-size: var(--font-size-micro);
    letter-spacing: var(--letter-spacing-caps);
    text-transform: uppercase;
    color: var(--color-text-subtle);
}

/* Status-Übersicht oben */
.status-uebersicht {
    border: 1px solid var(--color-border);
    background: var(--color-surface-1);
    padding: var(--space-4);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4);
    flex-wrap: wrap;
}

.status-uebersicht__zaehler {
    font-family: var(--font-mono);
    font-size: var(--font-size-h2);
    color: var(--color-text);
    letter-spacing: var(--letter-spacing-tight);
}

.status-uebersicht__zaehler-num {
    color: var(--color-accent);
    font-weight: var(--font-weight-semibold);
}

.status-uebersicht__warnung {
    font-family: var(--font-mono);
    font-size: var(--font-size-small);
    color: var(--color-phase-abgewandert-text);
    border: 1px solid var(--color-phase-abgewandert-border);
    background: var(--color-phase-abgewandert-bg);
    padding: var(--space-1) var(--space-3);
    border-radius: var(--radius-xs);
    letter-spacing: var(--letter-spacing-caps);
    text-transform: uppercase;
}

.status-uebersicht__ampeln {
    display: flex;
    gap: var(--space-3);
    flex-wrap: wrap;
}

.ampel {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    font-family: var(--font-mono);
    font-size: var(--font-size-micro);
    letter-spacing: var(--letter-spacing-caps);
    text-transform: uppercase;
    color: var(--color-text-muted);
    padding: var(--space-1) var(--space-2);
    border: 1px solid var(--color-border-subtle);
    border-radius: var(--radius-xs);
}

.ampel__dot {
    width: 8px;
    height: 8px;
    border-radius: 1px;
    background: var(--color-text-subtle);
}

.ampel[data-status="verbunden"] .ampel__dot {
    background: var(--color-phase-aktiv-solid);
}

.ampel[data-status="getrennt"] .ampel__dot {
    background: var(--color-text-subtle);
}

.ampel[data-status="fehler"] .ampel__dot {
    background: var(--color-phase-abgewandert-solid);
}

.ampel[data-kritisch="true"][data-status="getrennt"] {
    color: var(--color-phase-abgewandert-text);
    border-color: var(--color-phase-abgewandert-border);
}

.ampel[data-kritisch="true"][data-status="getrennt"] .ampel__dot {
    background: var(--color-phase-abgewandert-solid);
}

/* ---------- Integrations-Karten ------------------------------------------ */

.integrationen-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: var(--space-4);
}

.integration-karte {
    border: 1px solid var(--color-border);
    background: var(--color-surface-1);
    padding: var(--space-4);
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

.integration-karte__head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--space-3);
}

.integration-karte__titel-block {
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
}

.integration-karte__name {
    font-family: var(--font-mono);
    font-size: var(--font-size-body);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text);
    letter-spacing: var(--letter-spacing-caps);
    text-transform: uppercase;
}

.integration-karte__beschreibung {
    font-size: var(--font-size-small);
    color: var(--color-text-muted);
}

.integration-karte__kritisch {
    font-family: var(--font-mono);
    font-size: var(--font-size-micro);
    letter-spacing: var(--letter-spacing-caps);
    text-transform: uppercase;
    color: var(--color-badge-stub-fg);
    border: 1px solid var(--color-badge-stub-border);
    background: var(--color-badge-stub-bg);
    padding: 1px var(--space-2);
    border-radius: var(--radius-xs);
    align-self: flex-start;
}

.integration-karte__status-zeile {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-3);
    border-top: 1px solid var(--color-border-subtle);
    padding-top: var(--space-3);
}

.integration-karte__status-text {
    font-family: var(--font-mono);
    font-size: var(--font-size-small);
    letter-spacing: var(--letter-spacing-caps);
    text-transform: uppercase;
    color: var(--color-text-muted);
}

.integration-karte__token-vorschau {
    font-family: var(--font-mono);
    font-size: var(--font-size-micro);
    color: var(--color-text-subtle);
    margin-top: var(--space-1);
}

/* Bloomberg-Toggle: kantig, monospace */
.toggle {
    appearance: none;
    width: 44px;
    height: 22px;
    border: 1px solid var(--color-border-strong);
    background: var(--color-surface-2);
    position: relative;
    cursor: pointer;
    border-radius: 0;
    transition: border-color var(--duration-fast) var(--ease-out),
                background var(--duration-fast) var(--ease-out);
}

.toggle::after {
    content: "";
    position: absolute;
    top: 2px;
    left: 2px;
    width: 16px;
    height: 16px;
    background: var(--color-text-subtle);
    transition: left var(--duration-fast) var(--ease-out),
                background var(--duration-fast) var(--ease-out);
}

.toggle[data-aktiv="true"] {
    border-color: var(--color-accent);
    background: var(--color-accent-soft);
}

.toggle[data-aktiv="true"]::after {
    left: 24px;
    background: var(--color-accent);
}

.toggle:focus-visible {
    box-shadow: var(--shadow-focus);
}

.integration-karte__aktionen {
    display: flex;
    gap: var(--space-2);
}

.btn {
    appearance: none;
    background: transparent;
    border: 1px solid var(--color-border-strong);
    color: var(--color-text);
    font-family: var(--font-mono);
    font-size: var(--font-size-small);
    letter-spacing: var(--letter-spacing-caps);
    text-transform: uppercase;
    padding: var(--space-2) var(--space-3);
    cursor: pointer;
    border-radius: var(--radius-xs);
    transition: border-color var(--duration-fast) var(--ease-out),
                background var(--duration-fast) var(--ease-out),
                color var(--duration-fast) var(--ease-out);
}

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

.btn--primary {
    background: var(--color-accent);
    color: var(--color-text-inverse);
    border-color: var(--color-accent);
}

.btn--primary:hover {
    background: var(--color-accent-hover);
    color: var(--color-text-inverse);
}

.btn--ghost {
    color: var(--color-text-muted);
}

.btn--gefahr {
    border-color: var(--color-phase-abgewandert-border);
    color: var(--color-phase-abgewandert-text);
}

.btn--gefahr:hover {
    background: var(--color-phase-abgewandert-bg);
    color: var(--color-phase-abgewandert-text);
}

/* ---------- Modal -------------------------------------------------------- */

.modal-backdrop {
    position: fixed;
    inset: 0;
    background: hsl(var(--hsl-neutral-950) / 0.7);
    z-index: 50;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--space-4);
}

.modal {
    background: var(--color-surface-1);
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-lg);
    width: 100%;
    max-width: 480px;
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
    padding: var(--space-5);
}

.modal__title {
    font-family: var(--font-mono);
    font-size: var(--font-size-h3);
    text-transform: uppercase;
    letter-spacing: var(--letter-spacing-caps);
    color: var(--color-text);
}

.modal__hinweis {
    font-size: var(--font-size-small);
    color: var(--color-text-muted);
    border-left: 2px solid var(--color-accent);
    background: var(--color-accent-soft);
    padding: var(--space-2) var(--space-3);
    font-family: var(--font-mono);
}

.modal__feld {
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
}

.modal__label {
    font-family: var(--font-mono);
    font-size: var(--font-size-micro);
    letter-spacing: var(--letter-spacing-caps);
    text-transform: uppercase;
    color: var(--color-text-subtle);
}

.modal__input {
    background: var(--color-surface-2);
    border: 1px solid var(--color-border);
    color: var(--color-text);
    font-family: var(--font-mono);
    font-size: var(--font-size-body);
    padding: var(--space-2) var(--space-3);
    border-radius: var(--radius-xs);
    width: 100%;
}

.modal__input:focus-visible {
    border-color: var(--color-accent);
    box-shadow: var(--shadow-focus);
}

.modal__aktionen {
    display: flex;
    justify-content: flex-end;
    gap: var(--space-2);
    border-top: 1px solid var(--color-border-subtle);
    padding-top: var(--space-3);
}

/* ---------- Multi-Page-Shell-Anpassung ----------------------------------- */

/* Settings + Pipeline + Übersicht nutzen die volle Breite, kein Two-Pane */
.shell--single {
    display: block;
    height: calc(100vh - var(--layout-topbar-height));
    overflow-y: auto;
    background: var(--color-bg);
}

/* ---------- Übersicht-Seite ---------------------------------------------- */

.uebersicht {
    padding: var(--space-6);
    display: flex;
    flex-direction: column;
    gap: var(--space-6);
    max-width: var(--layout-content-max);
}

.uebersicht__head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: var(--space-6);
    flex-wrap: wrap;
    padding-bottom: var(--space-4);
    border-bottom: 1px solid var(--color-border);
}

.kpi-strip {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    border: 1px solid var(--color-border);
    background: var(--color-surface-1);
}

.kpi-strip .kpi:last-child { border-right: 0; }

.phasen-bar {
    display: flex;
    height: 8px;
    margin-top: var(--space-2);
    border: 1px solid var(--color-border-subtle);
}

.phasen-bar__segment {
    flex: 0 0 auto;
}

.phasen-bar__segment[data-phase="neu"]           { background: var(--color-phase-neu-solid); }
.phasen-bar__segment[data-phase="aktiv"]         { background: var(--color-phase-aktiv-solid); }
.phasen-bar__segment[data-phase="passiv"]        { background: var(--color-phase-passiv-solid); }
.phasen-bar__segment[data-phase="reaktivierung"] { background: var(--color-phase-reaktivierung-solid); }
.phasen-bar__segment[data-phase="abgewandert"]   { background: var(--color-phase-abgewandert-solid); }

.phasen-legende {
    display: flex;
    gap: var(--space-3);
    margin-top: var(--space-1);
    flex-wrap: wrap;
    font-family: var(--font-mono);
    font-size: var(--font-size-micro);
    color: var(--color-text-subtle);
    letter-spacing: var(--letter-spacing-caps);
    text-transform: uppercase;
}

.phasen-legende__item {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
}

.phasen-legende__dot {
    width: 8px;
    height: 8px;
    display: inline-block;
}

.phasen-legende__dot[data-phase="neu"]           { background: var(--color-phase-neu-solid); }
.phasen-legende__dot[data-phase="aktiv"]         { background: var(--color-phase-aktiv-solid); }
.phasen-legende__dot[data-phase="passiv"]        { background: var(--color-phase-passiv-solid); }
.phasen-legende__dot[data-phase="reaktivierung"] { background: var(--color-phase-reaktivierung-solid); }
.phasen-legende__dot[data-phase="abgewandert"]   { background: var(--color-phase-abgewandert-solid); }

.uebersicht__suche {
    display: flex;
    gap: var(--space-3);
    align-items: center;
    flex-wrap: wrap;
}

.suche-input {
    background: var(--color-surface-1);
    border: 1px solid var(--color-border);
    color: var(--color-text);
    font-family: var(--font-mono);
    font-size: var(--font-size-small);
    padding: var(--space-2) var(--space-3);
    border-radius: var(--radius-xs);
    min-width: 240px;
}

.suche-input:focus-visible {
    border-color: var(--color-accent);
    box-shadow: var(--shadow-focus);
}

.sortier-select {
    background: var(--color-surface-1);
    border: 1px solid var(--color-border);
    color: var(--color-text);
    font-family: var(--font-mono);
    font-size: var(--font-size-small);
    padding: var(--space-2) var(--space-3);
    border-radius: var(--radius-xs);
    cursor: pointer;
}

/* Briefing-Stapel (Mehrwert-Element aus früherer Iteration) */
.briefing {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: var(--space-4);
}

.briefing-stapel {
    border: 1px solid var(--color-border);
    background: var(--color-surface-1);
    display: flex;
    flex-direction: column;
}

.briefing-stapel__head {
    padding: var(--space-2) var(--space-3);
    border-bottom: 1px solid var(--color-border);
    background: var(--color-surface-2);
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-family: var(--font-mono);
    font-size: var(--font-size-micro);
    letter-spacing: var(--letter-spacing-caps);
    text-transform: uppercase;
    color: var(--color-text-muted);
}

.briefing-stapel__count {
    color: var(--color-accent);
    font-variant-numeric: tabular-nums;
}

.briefing-stapel__body {
    display: flex;
    flex-direction: column;
}

.briefing-stapel__item {
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding: var(--space-2) var(--space-3);
    border-bottom: 1px solid var(--color-border-subtle);
    cursor: pointer;
    transition: background var(--duration-instant) var(--ease-out);
}

.briefing-stapel__item:last-child { border-bottom: 0; }

.briefing-stapel__item:hover {
    background: var(--color-surface-hover);
}

.briefing-stapel__item-name {
    font-size: var(--font-size-small);
    color: var(--color-text);
}

.briefing-stapel__item-sub {
    font-family: var(--font-mono);
    font-size: var(--font-size-micro);
    color: var(--color-text-subtle);
    letter-spacing: var(--letter-spacing-caps);
    text-transform: uppercase;
}

.briefing-stapel__leer {
    padding: var(--space-3);
    color: var(--color-text-subtle);
    font-family: var(--font-mono);
    font-size: var(--font-size-micro);
    text-align: center;
    letter-spacing: var(--letter-spacing-caps);
    text-transform: uppercase;
}

/* ---------- Pipeline-Seite ----------------------------------------------- */

.pipeline {
    padding: var(--space-6);
    display: flex;
    flex-direction: column;
    gap: var(--space-6);
    max-width: var(--layout-content-max);
}

.pipeline__head {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
    padding-bottom: var(--space-4);
    border-bottom: 1px solid var(--color-border);
}

.pipeline__inhalt {
    display: flex;
    flex-direction: column;
    gap: var(--space-6);
}

.pipeline-gruppe {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

.pipeline-gruppe__titel {
    font-family: var(--font-mono);
    font-size: var(--font-size-micro);
    letter-spacing: var(--letter-spacing-caps);
    text-transform: uppercase;
    color: var(--color-text-subtle);
    padding-bottom: var(--space-2);
    border-bottom: 1px solid var(--color-border-subtle);
}

.pipeline-tabelle {
    display: flex;
    flex-direction: column;
    border: 1px solid var(--color-border);
    background: var(--color-surface-1);
}

.pipeline-zeile {
    display: grid;
    grid-template-columns: 1.6fr 0.7fr 1.2fr 0.6fr 0.6fr;
    gap: var(--space-3);
    padding: var(--space-2) var(--space-4);
    border-bottom: 1px solid var(--color-border-subtle);
    align-items: center;
    cursor: pointer;
    transition: background var(--duration-instant) var(--ease-out);
}

.pipeline-zeile:last-child { border-bottom: 0; }

.pipeline-zeile:hover {
    background: var(--color-surface-hover);
}

.pipeline-zeile--head {
    background: var(--color-surface-2);
    font-family: var(--font-mono);
    font-size: var(--font-size-micro);
    letter-spacing: var(--letter-spacing-caps);
    text-transform: uppercase;
    color: var(--color-text-subtle);
    cursor: default;
}

.pipeline-zeile--head:hover { background: var(--color-surface-2); }

.pipeline-zeile__name {
    color: var(--color-text);
    font-size: var(--font-size-small);
}

.pipeline-zeile__num {
    font-family: var(--font-mono);
    font-variant-numeric: tabular-nums;
    color: var(--color-text-muted);
    font-size: var(--font-size-small);
    text-align: right;
}

/* Sparkline (12 Wochen, neueste rechts) */
.sparkline {
    display: flex;
    align-items: flex-end;
    gap: 2px;
    height: 22px;
}

.sparkline__bar {
    flex: 1 1 auto;
    background: var(--color-accent-soft);
    border-bottom: 1px solid var(--color-border-subtle);
    min-height: 2px;
}

.sparkline[data-tendenz="steigend"] .sparkline__bar { background: var(--color-phase-aktiv-solid); }
.sparkline[data-tendenz="stabil"] .sparkline__bar   { background: var(--color-phase-neu-solid); }
.sparkline[data-tendenz="schwankend"] .sparkline__bar { background: var(--color-phase-passiv-solid); }
.sparkline[data-tendenz="sinkend"] .sparkline__bar  { background: var(--color-phase-reaktivierung-solid); }
.sparkline[data-tendenz="verloren"] .sparkline__bar { background: var(--color-phase-abgewandert-solid); }
.sparkline[data-tendenz="neutral"] .sparkline__bar  { background: var(--color-text-subtle); }

.tendenz-pill {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    font-family: var(--font-mono);
    font-size: var(--font-size-micro);
    letter-spacing: var(--letter-spacing-caps);
    text-transform: uppercase;
    padding: 1px var(--space-2);
    border: 1px solid;
    border-radius: var(--radius-xs);
}

.tendenz-pill[data-tendenz="steigend"] {
    color: var(--color-phase-aktiv-text);
    border-color: var(--color-phase-aktiv-border);
    background: var(--color-phase-aktiv-bg);
}
.tendenz-pill[data-tendenz="stabil"] {
    color: var(--color-phase-neu-text);
    border-color: var(--color-phase-neu-border);
    background: var(--color-phase-neu-bg);
}
.tendenz-pill[data-tendenz="schwankend"] {
    color: var(--color-phase-passiv-text);
    border-color: var(--color-phase-passiv-border);
    background: var(--color-phase-passiv-bg);
}
.tendenz-pill[data-tendenz="sinkend"] {
    color: var(--color-phase-reaktivierung-text);
    border-color: var(--color-phase-reaktivierung-border);
    background: var(--color-phase-reaktivierung-bg);
}
.tendenz-pill[data-tendenz="verloren"] {
    color: var(--color-phase-abgewandert-text);
    border-color: var(--color-phase-abgewandert-border);
    background: var(--color-phase-abgewandert-bg);
}
.tendenz-pill[data-tendenz="neutral"] {
    color: var(--color-text-muted);
    border-color: var(--color-border);
    background: var(--color-surface-2);
}

/* ---------- Breadcrumb (Detail-View) ------------------------------------- */

.breadcrumb {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    font-family: var(--font-mono);
    font-size: var(--font-size-micro);
    letter-spacing: var(--letter-spacing-caps);
    text-transform: uppercase;
    color: var(--color-text-subtle);
    padding: var(--space-3) var(--space-6);
    border-bottom: 1px solid var(--color-border-subtle);
    background: var(--color-surface-1);
}

.breadcrumb__link {
    color: var(--color-text-muted);
    cursor: pointer;
    background: transparent;
    border: 0;
    font: inherit;
    letter-spacing: inherit;
    text-transform: inherit;
    padding: 0;
}

.breadcrumb__link:hover {
    color: var(--color-accent);
}

.breadcrumb__sep {
    color: var(--color-text-subtle);
}

.breadcrumb__aktuell {
    color: var(--color-text);
}

/* ---------- Detail-View im Single-Layout --------------------------------- */

.shell--detail {
    display: flex;
    flex-direction: column;
    height: calc(100vh - var(--layout-topbar-height));
    overflow-y: auto;
    background: var(--color-bg);
}

.shell--detail .detail-region {
    border-right: 0;
    overflow-y: visible;
}

/* K-013: Token-Speicher-Warnung (temporäres Banner, 6 s sichtbar) */
.settings__token-warnung {
    padding: var(--space-2) var(--space-3);
    margin-bottom: var(--space-3);
    border-radius: var(--radius-sm);
    background: hsl(var(--color-warning-bg, 45 90% 92%));
    color: hsl(var(--color-warning-fg, 35 60% 20%));
    border: 1px solid hsl(var(--color-warning-border, 40 80% 75%));
    font-size: var(--font-size-sm);
}
