/* =====================================================================
 * argo-team-kpi.css — Sprint-KPI-Übersicht für Christoph (Teamleiter)
 * ---------------------------------------------------------------------
 * Baut ausschliesslich auf design-tokens.css auf.
 * Null Hex-Codes, null rgb()-Literale — nur var(--...).
 * ===================================================================== */

/* ---------- DEMO-Banner ----------------------------------------------- */

.team-kpi-demo {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-1) var(--space-3);
    background: var(--color-warn-bg-soft);
    border: 1px solid var(--color-warn-border);
    border-radius: var(--radius-pill);
    font-size: var(--font-size-micro);
    font-weight: var(--font-weight-semibold);
    letter-spacing: var(--letter-spacing-caps);
    text-transform: uppercase;
    color: var(--color-warn-text-soft);
}

.team-kpi-demo::before {
    content: "●";
    color: var(--color-warn-border);
    animation: kpi-demo-blink 2s ease-in-out infinite;
}

@keyframes kpi-demo-blink {
    0%, 100% { opacity: 1; }
    50%       { opacity: 0.3; }
}

/* ---------- Sprint-Header --------------------------------------------- */

.team-kpi-header {
    background: var(--color-surface-1);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--space-5) var(--space-6);
    box-shadow: var(--shadow-md);
    margin-bottom: var(--space-6);
    position: relative;
    overflow: hidden;
}

/* Accent-Linie oben */
.team-kpi-header::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: var(--color-accent);
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}

.team-kpi-header__top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--space-4);
    flex-wrap: wrap;
    margin-bottom: var(--space-4);
}

.team-kpi-header__titel-block {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.team-kpi-header__label {
    font-size: var(--font-size-micro);
    font-weight: var(--font-weight-semibold);
    letter-spacing: var(--letter-spacing-caps);
    text-transform: uppercase;
    color: var(--color-text-subtle);
}

.team-kpi-header__titel {
    font-size: var(--font-size-h2);
    font-weight: var(--font-weight-bold);
    letter-spacing: var(--letter-spacing-tight);
    color: var(--color-text);
    margin: 0;
    line-height: var(--line-height-tight);
}

.team-kpi-header__sub {
    font-size: var(--font-size-small);
    color: var(--color-text-muted);
    font-family: var(--font-mono);
}

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

/* Gesamtzahl-Badge */
.team-kpi-header__count {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
}

.team-kpi-header__count-zahl {
    font-size: var(--font-size-h1);
    font-weight: var(--font-weight-bold);
    font-family: var(--font-mono);
    font-variant-numeric: tabular-nums;
    color: var(--color-text);
    line-height: var(--line-height-tight);
}

.team-kpi-header__count-zahl--warn {
    color: var(--ampel-rot-text);
}

.team-kpi-header__count-label {
    font-size: var(--font-size-micro);
    color: var(--color-text-subtle);
    text-transform: uppercase;
    letter-spacing: var(--letter-spacing-caps);
    white-space: nowrap;
}

/* Fortschrittsbalken */
.team-kpi-header__fortschritt {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.team-kpi-header__fortschritt-zeile {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4);
}

.team-kpi-header__fortschritt-text {
    font-size: var(--font-size-small);
    color: var(--color-text-muted);
    font-family: var(--font-mono);
    white-space: nowrap;
}

.team-kpi-header__fortschritt-pct {
    font-size: var(--font-size-small);
    font-weight: var(--font-weight-semibold);
    font-family: var(--font-mono);
    color: var(--color-text);
}

.team-kpi-header__fortschritt-pct--rot  { color: var(--ampel-rot-text); }
.team-kpi-header__fortschritt-pct--gelb { color: var(--ampel-gelb-text); }
.team-kpi-header__fortschritt-pct--gruen { color: var(--ampel-gruen-text); }

.team-kpi-header__bar-track {
    height: 10px;
    background: var(--color-surface-2);
    border-radius: var(--radius-pill);
    overflow: hidden;
    border: 1px solid var(--color-border-subtle);
}

.team-kpi-header__bar-fill {
    height: 100%;
    border-radius: var(--radius-pill);
    transition: width var(--duration-slow) var(--ease-out);
    background: var(--color-accent);
}

.team-kpi-header__bar-fill--rot  { background: var(--ampel-rot); }
.team-kpi-header__bar-fill--gelb { background: var(--ampel-gelb); }
.team-kpi-header__bar-fill--gruen { background: var(--ampel-gruen); }

/* Ziel-Marker auf dem Fortschrittsbalken */
.team-kpi-header__bar-wrapper {
    position: relative;
}

/* Kontext-Hinweis unter dem Fortschrittsbalken */
.team-kpi-header__hinweis {
    margin-top: var(--space-3);
    padding: var(--space-2) var(--space-3);
    background: var(--ampel-rot-bg);
    border-left: 3px solid var(--ampel-rot-border);
    border-radius: var(--radius-sm);
    font-size: var(--font-size-small);
    color: var(--ampel-rot-text);
    line-height: var(--line-height-normal);
}

.team-kpi-header__hinweis--gelb {
    background: var(--ampel-gelb-bg);
    border-left-color: var(--ampel-gelb-border);
    color: var(--ampel-gelb-text);
}

.team-kpi-header__hinweis--gruen {
    background: var(--ampel-gruen-bg);
    border-left-color: var(--ampel-gruen-border);
    color: var(--ampel-gruen-text);
}

/* ---------- KPI-Grid -------------------------------------------------- */

.team-kpi-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-4);
}

@media (max-width: 1200px) {
    .team-kpi-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 720px) {
    .team-kpi-grid {
        grid-template-columns: 1fr;
    }
}

/* ---------- KPI-Karte pro Person -------------------------------------- */

.team-kpi-card {
    background: var(--color-surface-1);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--space-4);
    box-shadow: var(--shadow-sm);
    transition: box-shadow var(--duration-fast) var(--ease-out),
                transform var(--duration-fast) var(--ease-out),
                border-color var(--duration-fast) var(--ease-out);
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    position: relative;
}

.team-kpi-card:hover {
    box-shadow: var(--shadow-md);
    transform: translateY(-1px);
    border-color: var(--color-border-strong);
}

/* Roter Rand wenn unter Ziel */
.team-kpi-card--unter-ziel {
    border-left: 3px solid var(--ampel-rot-border);
}

.team-kpi-card--im-ziel {
    border-left: 3px solid var(--ampel-gruen-border);
}

.team-kpi-card--nahe-ziel {
    border-left: 3px solid var(--ampel-gelb-border);
}

/* Inaktiv-DM gedimmt */
.team-kpi-card--inaktiv {
    opacity: 0.55;
    border-left: 3px solid var(--color-border-strong);
}

/* ---------- Karten-Kopf: Avatar + Name ------------------------------- */

.team-kpi-card__header {
    display: flex;
    align-items: center;
    gap: var(--space-3);
}

.team-kpi-card__avatar {
    width: 40px;
    height: 40px;
    border-radius: var(--radius-pill);
    background: var(--color-accent-soft);
    border: 1.5px solid var(--color-accent);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-mono);
    font-size: var(--font-size-small);
    font-weight: var(--font-weight-bold);
    color: var(--color-accent);
    flex-shrink: 0;
    letter-spacing: 0;
    line-height: 1;
    user-select: none;
}

/* Avatar-Farb-Varianten nach Ampel */
.team-kpi-card--unter-ziel .team-kpi-card__avatar {
    background: var(--ampel-rot-bg);
    border-color: var(--ampel-rot-border);
    color: var(--ampel-rot-text);
}

.team-kpi-card--nahe-ziel .team-kpi-card__avatar {
    background: var(--ampel-gelb-bg);
    border-color: var(--ampel-gelb-border);
    color: var(--ampel-gelb-text);
}

.team-kpi-card--im-ziel .team-kpi-card__avatar {
    background: var(--ampel-gruen-bg);
    border-color: var(--ampel-gruen-border);
    color: var(--ampel-gruen-text);
}

.team-kpi-card__name-block {
    flex: 1;
    min-width: 0;
}

.team-kpi-card__name {
    font-size: var(--font-size-body);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: var(--line-height-tight);
}

.team-kpi-card__rolle {
    font-size: var(--font-size-micro);
    color: var(--color-text-subtle);
    text-transform: uppercase;
    letter-spacing: var(--letter-spacing-caps);
    margin-top: 2px;
}

/* Sprint-Mini-Balken direkt unter dem Namen */
.team-kpi-card__mini-bar-track {
    height: 4px;
    background: var(--color-surface-2);
    border-radius: var(--radius-pill);
    overflow: hidden;
    margin-top: var(--space-2);
}

.team-kpi-card__mini-bar-fill {
    height: 100%;
    border-radius: var(--radius-pill);
    transition: width var(--duration-slow) var(--ease-out);
}

.team-kpi-card__mini-bar-fill--rot   { background: var(--ampel-rot); }
.team-kpi-card__mini-bar-fill--gelb  { background: var(--ampel-gelb); }
.team-kpi-card__mini-bar-fill--gruen { background: var(--ampel-gruen); }

/* ---------- Trennlinie ------------------------------------------------ */

.team-kpi-card__divider {
    height: 1px;
    background: var(--color-border-subtle);
    margin: 0;
}

/* ---------- Metric-Zeilen --------------------------------------------- */

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

.team-kpi-card__metric {
    display: grid;
    grid-template-columns: 10px 1fr auto;
    gap: var(--space-2);
    align-items: center;
    padding: var(--space-1) var(--space-2);
    border-radius: var(--radius-xs);
    transition: background var(--duration-instant) var(--ease-out);
    min-height: 28px;
}

.team-kpi-card__metric:hover {
    background: var(--color-surface-2);
}

/* Ampel-Dot */
.team-kpi-card__metric-dot {
    width: 8px;
    height: 8px;
    border-radius: var(--radius-pill);
    flex-shrink: 0;
}

.team-kpi-card__metric-dot--rot   { background: var(--ampel-rot); }
.team-kpi-card__metric-dot--gelb  { background: var(--ampel-gelb); }
.team-kpi-card__metric-dot--gruen { background: var(--ampel-gruen); }
.team-kpi-card__metric-dot--grau  { background: var(--color-border-strong); }

/* Label */
.team-kpi-card__metric-label {
    font-size: var(--font-size-small);
    color: var(--color-text-muted);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Wert */
.team-kpi-card__metric-wert {
    font-family: var(--font-mono);
    font-size: var(--font-size-small);
    font-weight: var(--font-weight-semibold);
    font-variant-numeric: tabular-nums;
    color: var(--color-text);
    text-align: right;
    white-space: nowrap;
}

.team-kpi-card__metric-wert--rot   { color: var(--ampel-rot-text); }
.team-kpi-card__metric-wert--gelb  { color: var(--ampel-gelb-text); }
.team-kpi-card__metric-wert--gruen { color: var(--ampel-gruen-text); }

/* ---------- Fuehrungsimpuls ------------------------------------------ */

.team-kpi-card__impuls {
    font-size: var(--font-size-micro);
    color: var(--color-text-subtle);
    line-height: var(--line-height-normal);
    padding: var(--space-2) var(--space-3);
    background: var(--color-surface-2);
    border-radius: var(--radius-sm);
    border-left: 2px solid var(--color-accent);
    font-style: italic;
}

/* ---------- Legende --------------------------------------------------- */

.team-kpi-legend {
    display: flex;
    align-items: center;
    gap: var(--space-6);
    flex-wrap: wrap;
    padding: var(--space-4) var(--space-5);
    background: var(--color-surface-1);
    border: 1px solid var(--color-border-subtle);
    border-radius: var(--radius-md);
    margin-top: var(--space-5);
}

.team-kpi-legend__titel {
    font-size: var(--font-size-micro);
    font-weight: var(--font-weight-semibold);
    letter-spacing: var(--letter-spacing-caps);
    text-transform: uppercase;
    color: var(--color-text-subtle);
    white-space: nowrap;
}

.team-kpi-legend__items {
    display: flex;
    align-items: center;
    gap: var(--space-5);
    flex-wrap: wrap;
    flex: 1;
}

.team-kpi-legend__item {
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.team-kpi-legend__dot {
    width: 8px;
    height: 8px;
    border-radius: var(--radius-pill);
    flex-shrink: 0;
}

.team-kpi-legend__dot--rot   { background: var(--ampel-rot); }
.team-kpi-legend__dot--gelb  { background: var(--ampel-gelb); }
.team-kpi-legend__dot--gruen { background: var(--ampel-gruen); }
.team-kpi-legend__dot--grau  { background: var(--color-border-strong); }

.team-kpi-legend__text {
    font-size: var(--font-size-micro);
    color: var(--color-text-muted);
    white-space: nowrap;
}

.team-kpi-legend__sep {
    width: 1px;
    height: 1.2em;
    background: var(--color-border-subtle);
    flex-shrink: 0;
}

/* KPI-Definitionen rechts */
.team-kpi-legend__definitionen {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    flex-wrap: wrap;
    font-size: var(--font-size-micro);
    color: var(--color-text-subtle);
    font-family: var(--font-mono);
}

.team-kpi-legend__def {
    white-space: nowrap;
}

.team-kpi-legend__def strong {
    color: var(--color-text-muted);
    font-weight: var(--font-weight-semibold);
}

/* ---------- Container ------------------------------------------------- */

.team-kpi-container {
    margin-bottom: var(--space-8);
}

.team-kpi-section-label {
    font-size: var(--font-size-micro);
    font-weight: var(--font-weight-semibold);
    letter-spacing: var(--letter-spacing-caps);
    text-transform: uppercase;
    color: var(--color-text-subtle);
    margin-bottom: var(--space-3);
    display: flex;
    align-items: center;
    gap: var(--space-3);
}

.team-kpi-section-label::after {
    content: "";
    flex: 1;
    height: 1px;
    background: var(--color-border-subtle);
}

/* ---------- Reduced Motion ------------------------------------------- */

@media (prefers-reduced-motion: reduce) {
    .team-kpi-card,
    .team-kpi-header__bar-fill,
    .team-kpi-card__mini-bar-fill,
    .team-kpi-card__metric {
        transition: none;
    }
    .team-kpi-demo::before {
        animation: none;
    }
}
