/* ===================================================================
 * Test Report feature styles (.report-*).
 *
 * Extracted from public/styles.css. Load order in index.html keeps
 * this file AFTER components/components.css and BEFORE styles.css.
 * =================================================================== */

@layer features {

.report-metrics-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  align-items: stretch;
}
.report-metrics-card {
  min-height: 140px;
  display: flex;
  flex-direction: column;
}
.report-metrics-card .kpi-value { font-size: 26px; margin-bottom: 4px }
.report-metrics-card .kpi-label { font-size: var(--font-size-sm); font-weight: var(--font-weight-bold); }
.report-metrics-card .kpi-sublabel { font-size: 10px; margin-top: 2px }
.report-by-project-chart { margin-top: 12px; flex: 1; min-height: 0; display: flex; flex-direction: column }
.report-by-project-chart .distribution-chart-wrap { min-height: 100px }
.report-by-project-chart .column-chart-wrap {
  min-height: 140px;
  height: auto;
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 8px 0 0 0;
  overflow: visible;
}

.report-sticky-header {
  background: var(--color-bg-surface);
  margin-left: -24px;
  margin-right: -24px;
  padding-left: 24px;
  padding-right: 24px;
  padding-top: 0;            /* tabs sit flush at top — no extra space above */
  margin-bottom: 20px;
  padding-bottom: 12px;
}

.report-sticky-header::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 1px;
  background: var(--color-border-default);
}

/* Test Overview tab: only the project filter is hidden (project filter is
 * not applied for Overview metrics). Interval selector, Refresh button, and
 * "Last updated" label remain visible. */
.report-sticky-header.overview-active #reportProjectBlock {
  display: none !important;
}

.report-sticky-header.quality-health-active #reportProjectBlock {
  display: flex !important;
}

.report-sticky-header.test-automation-active .report-date-range-block {
  display: none !important;
}

.report-sticky-header.quality-health-active .report-date-range-block {
  display: none !important;
}

.report-date-range-block,
.report-project-block,
.report-iteration-block {
  display: flex;
  align-items: center;
  gap: 8px;
}

.report-iteration-block.hidden {
  display: none !important;
}

.report-label {
  margin: 0;
  font-size: 13px;
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-secondary);
}

.report-interval-select,
.report-project-select {
  width: auto;
  min-width: 180px;
  padding: 8px 12px;
  font-size: var(--font-size-sm);
}

.report-interval-select {
  min-width: 120px;
}

.report-refresh-btn {
  padding: 8px 16px;
  font-size: 13px;
  font-weight: var(--font-weight-semibold);
  background: var(--color-accent);
  color: var(--color-text-primary);
  border: none;
  cursor: pointer;
  transition: all 0.2s ease;
}

.report-refresh-btn:hover {
  background: var(--color-accent-hover);
}

.report-refresh-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.report-message,
.report-error {
  padding: 16px;
  margin-bottom: 16px;
  border-radius: 5px;
  font-size: var(--font-size-sm);
}

.report-message {
  background: var(--color-bg-surface-alt);
  border: 1px solid var(--color-border-default);
  color: var(--color-text-secondary);
}

/* .report-loading: styling now comes from .ds-loading-center
 * (centered, no box) — no feature-scoped overrides needed. */

.report-error {
  background: var(--color-danger-bg);
  border: 1px solid var(--c-secondary-100);
  color: var(--color-danger-text);
}

.report-content {
  margin-top: 8px;
}

/* (Legacy `.report-meta` + `.report-meta-header` rules removed — both are
 * unused, and the legacy `.report-meta { border-top: 1px }` was the stray
 * horizontal line that appeared above the meta in the tab-scoped controls
 * row. The active `.report-meta` rule lives lower in this file.) */

.report-date-range {
  font-weight: var(--font-weight-medium);
  color: var(--color-text-secondary);
}

.report-last-updated {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
}

.report-tabs-row {
  display: flex;
  align-items: stretch;
  margin-bottom: 12px;
}
/* Make .ds-tabs span the full row width so its border-bottom (the divider
 * line under the tabs) extends continuously across the whole page, with
 * no visible gap to the right of the last tab. */
.report-tabs-row > .ds-tabs {
  flex: 1;
  min-width: 0;
}

/* The tab-scoped controls row (filters/refresh on the left, meta on the right). */
.report-meta {
  display: flex;
  align-items: center;
  gap: 16px;
  font-size: 13px;
  color: var(--color-text-secondary);
  flex-shrink: 0;
}

.report-meta .report-date-range {
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-primary);
}

.report-meta .report-last-updated {
  font-size: 13px;
  color: var(--color-text-secondary);
}

.report-section-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}

.report-section-tab {
  padding: 10px 16px;
  font-size: 13px;
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-secondary);
  background: transparent;
  border: none;
  border-radius: 6px;
  margin-bottom: 0;
  cursor: pointer;
  transition: color 0.2s, background 0.2s;
}

.report-section-tab:hover,
.report-section-tab:focus-visible {
  color: var(--color-text-inverse);
  background: var(--color-bg-sidebar);
}

.report-section-tab.active {
  color: var(--color-text-inverse);
  background: var(--color-bg-sidebar);
}

.report-section-tab.active:hover,
.report-section-tab.active:focus-visible {
  color: var(--color-text-inverse);
  background: var(--color-bg-sidebar);
}

.report-section-panel {
  margin-bottom: 16px;
}

.report-section-panel.hidden {
  display: none;
}

.report-subsection {
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px solid var(--color-border-default);
}

.report-subsection-title {
  font-size: 13px;
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-secondary);
  margin-top: 20px;
  margin-bottom: 10px;
  text-transform: uppercase;
  letter-spacing: 0.3px;
}

.report-subsection-title:first-child {
  margin-top: 0;
}

.report-list {
  margin: 0;
  padding-left: 20px;
  font-size: var(--font-size-sm);
  color: var(--color-text-primary);
  line-height: 1.6;
}

.report-list li {
  margin-bottom: 4px;
}


/* Merged from legacy styles.css */
/* Clickable KPI cards (work items list) */
.kpi-card-clickable { cursor: pointer; transition: box-shadow 0.2s ease, border-color 0.2s ease }
.kpi-card-clickable:hover { box-shadow: 0 2px 8px rgba(0,0,0,0.12); border-color: var(--color-accent) }

/* Work items modal */
.work-items-modal-body { width: 800px; max-width: 95vw; max-height: 85vh; display: flex; flex-direction: column; resize: both; overflow: auto; min-width: 480px; min-height: 320px }
.work-items-modal-title { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px }
.work-items-modal-close { background: none; border: none; font-size: var(--font-size-xl); line-height: 1; cursor: pointer; color: var(--color-text-secondary); padding: 0 8px; box-shadow: none }
.work-items-modal-close:hover { color: var(--color-text-primary) }
.work-items-modal-table-wrap { overflow: auto; flex: 1; min-height: 200px; border: 1px solid var(--color-border-default); margin-bottom: 12px }
.work-items-table { width: 100%; border-collapse: collapse; font-size: 13px }
.work-items-table th { text-align: left; padding: 10px 12px; background: var(--color-bg-surface-alt); border-bottom: 1px solid var(--color-border-default); font-weight: var(--font-weight-semibold); color: var(--color-text-primary) }
.work-items-table td { padding: 8px 12px; border-bottom: 1px solid var(--color-border-subtle) }
.work-items-table tbody tr:hover { background: var(--color-bg-surface-alt) }
.work-items-table .wi-id-link { color: var(--color-text-link); text-decoration: none; font-weight: var(--font-weight-medium) }
.work-items-table .wi-id-link:hover { text-decoration: underline }
.work-items-modal-hint { margin: 0; font-size: var(--font-size-xs); color: var(--color-text-secondary) }
.work-items-table th.wi-filterable { position: relative; cursor: default; white-space: nowrap }
.wi-filter-btn { background: none; border: none; cursor: pointer; padding: 2px 4px; margin-left: 4px; color: var(--color-text-muted); font-size: var(--font-size-xs); line-height: 1; vertical-align: middle; box-shadow: none }
.wi-filter-btn:hover, .wi-filter-btn.active { color: var(--color-text-link) }
.wi-filter-dropdown { display: none; position: absolute; top: 100%; left: 0; min-width: 180px; max-height: 260px; background: var(--color-bg-surface); border: 1px solid var(--color-border-default); border-radius: 6px; box-shadow: 0 4px 12px rgba(0,0,0,0.12); z-index: 1000; font-weight: var(--font-weight-regular); overflow: hidden; flex-direction: column }
.wi-filter-dropdown.open { display: flex }
.wi-filter-dd-list { overflow-y: auto; flex: 1; padding: 4px 0 }
.wi-filter-dropdown label { display: flex; align-items: center; gap: 8px; padding: 6px 12px; font-size: 13px; color: var(--color-text-primary); cursor: pointer; white-space: nowrap }
.wi-filter-dropdown label:hover { background: var(--color-bg-surface-alt) }
.wi-filter-dropdown input[type="checkbox"] { margin: 0; accent-color: var(--color-text-link); flex-shrink: 0; width: 15px; height: 15px }
.wi-filter-dropdown .wi-filter-dd-actions { display: flex; gap: 8px; padding: 6px 12px; border-top: 1px solid var(--color-border-default); flex-shrink: 0 }
.wi-filter-dropdown .wi-filter-dd-btn { font-size: 11px; padding: 3px 8px; border: 1px solid var(--color-border-default); border-radius: var(--radius-sm); background: var(--color-bg-surface); cursor: pointer; color: var(--color-text-secondary); box-shadow: none }
.wi-filter-dropdown .wi-filter-dd-btn:hover { background: var(--color-bg-surface-alt); color: var(--color-text-primary) }
.work-item-status-badge {
  display: inline-flex;
  align-items: center;
  padding: 3px 8px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: var(--font-weight-semibold);
  line-height: 1.2;
  white-space: nowrap;
}




.work-item-type-badge {
  display: inline-flex;
  align-items: center;
  padding: 3px 8px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: var(--font-weight-semibold);
  line-height: 1.2;
  white-space: nowrap;
}


.distribution-legend-item-clickable { cursor: pointer; transition: opacity 0.15s ease }
.distribution-legend-item-clickable:hover { opacity: 0.85 }
.distribution-legend-item-clickable .legend-text { text-decoration: underline; text-decoration-style: dotted }





.bugs-layout-section { display: flex; flex-direction: column; gap: 28px; }
.bugs-subsection-title {
  font-size: 13px;
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.06em;
  color: var(--color-text-primary);
  margin-bottom: 12px;
  margin-top: 4px;
  padding-bottom: 6px;
  border-bottom: 1px solid var(--color-border-default);
}
.bugs-subsection-title:first-child { margin-top: 0; }

.bugs-old-requirements,
.bugs-old-testcase,
.bugs-old-issues {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 20px;
  align-items: stretch;
}
.bugs-old-requirements .kpi-card,
.bugs-old-testcase .kpi-card,
.bugs-old-issues .kpi-card {
  min-height: 0;
}
.bugs-old-testcase-row2 {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  gap: 20px;
  align-items: stretch;
  margin-top: -8px;
  margin-bottom: 8px;
}
.bugs-old-testcase-row2 .bugs-small-cards-wrap {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  gap: 20px;
  align-items: stretch;
  min-height: 0;
}
.bugs-small-cards-wrap {
  grid-column: 1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  align-items: stretch;
  min-height: 0;
}
.bugs-small-card {
  min-height: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.bugs-small-card .kpi-value { font-size: var(--font-size-xl); }
.bugs-old-testcase-row2 .kpi-card {
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border-default);
  border-radius: var(--radius-md);
  padding: 16px;
}
@media (max-width: 900px) {
  .bugs-old-requirements, .bugs-old-testcase, .bugs-old-issues { grid-template-columns: 1fr 1fr; }
  .bugs-old-testcase-row2 { grid-template-columns: 1fr; }
  .bugs-old-testcase-row2 .bugs-small-cards-wrap { grid-template-columns: 1fr 1fr; }
  .bugs-small-cards-wrap { grid-column: 1 / -1; grid-template-columns: 1fr 1fr; }
}
@media (max-width: 560px) {
  .bugs-old-requirements, .bugs-old-testcase, .bugs-old-issues { grid-template-columns: 1fr; }
  .bugs-old-testcase-row2 { grid-template-columns: 1fr; }
  .bugs-old-testcase-row2 .bugs-small-cards-wrap { grid-template-columns: 1fr; }
  .bugs-small-cards-wrap { grid-template-columns: 1fr; }
}

.bugs-old-requirements .kpi-card,
.bugs-old-testcase .kpi-card,
.bugs-old-issues .kpi-card {
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border-default);
  border-radius: var(--radius-md);
  padding: 16px;
  min-height: 120px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}
.bugs-old-requirements .kpi-value,
.bugs-old-testcase .kpi-value,
.bugs-old-issues .kpi-value { font-size: 28px; margin-bottom: 4px; }
.bugs-lead-card .kpi-value { font-size: 36px; font-weight: var(--font-weight-bold); margin-bottom: 6px; color: var(--c-neutral-900); }
.bugs-lead-card .kpi-label,
.bugs-old-requirements .kpi-label,
.bugs-old-testcase .kpi-label,
.bugs-old-issues .kpi-label { font-size: 11px; color: var(--color-text-secondary); text-transform: uppercase; letter-spacing: 0.03em; line-height: 1.3; }

.bugs-old-bottom-row {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 20px;
  align-items: stretch;
}
.bugs-old-bottom-row .bugs-small-cards-wrap {
  grid-column: 1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  align-items: stretch;
  min-height: 0;
}
.bugs-old-bottom-row .bugs-small-cards-wrap .kpi-card {
  min-height: 0;
}
@media (max-width: 900px) {
  .bugs-old-bottom-row { grid-template-columns: 1fr 1fr; }
  .bugs-old-bottom-row .bugs-small-cards-wrap { grid-column: 1 / -1; }
}
@media (max-width: 560px) {
  .bugs-old-bottom-row { grid-template-columns: 1fr; }
  .bugs-old-bottom-row .bugs-small-cards-wrap { grid-template-columns: 1fr; }
}

.bugs-old-bottom-row .kpi-card {
  min-height: 100px;
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border-default);
  border-radius: var(--radius-md);
  padding: 16px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
}
.bugs-old-bottom-row .kpi-value { font-size: 26px; font-weight: var(--font-weight-bold); margin-bottom: 6px; }
.bugs-old-bottom-row .kpi-label { font-size: 11px; color: var(--color-text-secondary); text-transform: uppercase; letter-spacing: 0.03em; }
.bugs-old-bottom-row .distribution-card .distribution-chart-wrap { min-height: 90px; }
.distribution-card .kpi-label { font-size: 11px; margin-bottom: 10px; color: var(--color-text-secondary); text-transform: uppercase; letter-spacing: 0.03em; }
.distribution-card .distribution-chart-wrap { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }

#kpiBugLeakageCardSingle.kpi-card-status-green { background: rgba(16,185,129,0.12); border-left: 4px solid var(--c-success-500); }
#kpiBugLeakageCardSingle.kpi-card-status-yellow { background: rgba(245,158,11,0.12); border-left: 4px solid var(--c-warning-500); }
#kpiBugLeakageCardSingle.kpi-card-status-red { background: rgba(239,68,68,0.12); border-left: 4px solid var(--c-danger-500); }
#kpiDefectDensityCardSingle.kpi-card-status-green { background: rgba(16,185,129,0.12); border-left: 4px solid var(--c-success-500); }
#kpiDefectDensityCardSingle.kpi-card-status-yellow { background: rgba(245,158,11,0.12); border-left: 4px solid var(--c-warning-500); }
#kpiDefectDensityCardSingle.kpi-card-status-red { background: rgba(239,68,68,0.12); border-left: 4px solid var(--c-danger-500); }
#kpiUserStoryCoverageCardSingle.kpi-card-status-green { background: rgba(16,185,129,0.12); border-left: 4px solid var(--c-success-500); }
#kpiUserStoryCoverageCardSingle.kpi-card-status-yellow { background: rgba(245,158,11,0.12); border-left: 4px solid var(--c-warning-500); }
#kpiUserStoryCoverageCardSingle.kpi-card-status-red { background: rgba(239,68,68,0.12); border-left: 4px solid var(--c-danger-500); }

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

/* Quality Health tab */
.quality-health-meta {
  font-size: var(--font-size-xs);
  color: var(--color-text-secondary);
  margin-bottom: 12px;
}
.quality-health-trend-chart {
  margin-bottom: 24px;
  min-height: 120px;
}
.quality-health-trend-chart .column-chart-wrap {
  min-height: 100px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.quality-health-metric-trends {
  display: flex;
  flex-direction: column;
  gap: 28px;
  margin-bottom: 24px;
}
.quality-health-metric-trends .qh-trend-section {
  padding-top: 24px;
  margin-top: 24px;
  border-top: 1px solid var(--color-border-default);
}
.quality-health-metric-trends .qh-trend-section:first-child {
  padding-top: 0;
  margin-top: 0;
  border-top: none;
}
.quality-health-metric-trends-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(400px, 1fr));
  gap: 20px;
  margin-top: 16px;
}
@media (max-width: 900px) {
  .quality-health-metric-trends-grid {
    grid-template-columns: 1fr;
  }
}
.quality-health-trend-card {
  background: var(--color-bg-surface-alt);
  border: 1px solid var(--color-border-default);
  border-radius: var(--radius-md);
  padding: 16px;
  min-height: 220px;
}
.quality-health-trend-card .line-chart-title {
  font-size: 13px;
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-primary);
  margin-bottom: 12px;
}
.line-chart-wrap {
  width: 100%;
  height: 180px;
  min-width: 350px;
}
.line-chart-wrap svg.line-chart-svg {
  width: 100%;
  height: 100%;
  display: block;
}
/* Line / Combo chart — tracks MUI X Charts axis + gridline defaults. */
.line-chart-axis {
  font-size: 12px;                                      /* MUI tick label */
  font-family: var(--font-family-sans);
  fill: var(--chart-text);                              /* rgba(0,0,0,0.6) */
}
.line-chart-grid-line {
  stroke: var(--chart-grid);                            /* rgba(0,0,0,0.12) */
  stroke-width: 1;
}
.line-chart-area {
  fill: var(--line-chart-area-fill, rgba(46, 150, 255, 0.18));  /* MUI series-2 @ 18% */
}

/* Velocity Chart Styles */
.velocity-chart-svg {
  overflow: visible;
}
/* Velocity chart — MUI X behavior on bar hover: subtle brightness lift
 * with the standard MUI motion curve (no opacity dip, which fights the
 * gridline contrast). */
.velocity-bar-segment {
  transition: filter 150ms cubic-bezier(0.4, 0, 0.2, 1);
}
.velocity-bar-segment:hover {
  filter: brightness(1.08);
}
.velocity-chart-title {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-primary);
}

/* Velocity chart container */
.velocity-chart-container {
  background: var(--color-bg-surface-alt);
  border: 1px solid var(--color-border-default);
  border-radius: var(--radius-md);
  padding: 20px;
  margin-bottom: 24px;
  min-height: 400px;
}
.quality-health-sections { display: flex; flex-direction: column; gap: 28px; }
#qualityHealthSections.hidden { display: none !important; }
.quality-health-section-title {
  font-size: 13px;
  font-weight: var(--font-weight-bold);
  color: var(--c-neutral-900);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: 12px;
  padding-bottom: 4px;
  border-bottom: 1px solid var(--color-border-default);
}
.quality-health-cards {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 16px;
}
.quality-health-cards .report-metrics-card { min-height: 100px; }

/* Horizontal bar chart (coverage, leakage, density by project) – compact so 8 rows fit without scroll */
.horizontal-bar-row {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 22px;
}
.horizontal-bar-label {
  flex: 0 0 130px;
  font-size: 11px;
  color: var(--color-text-primary);
  line-height: 1.2;
  word-break: break-word;
  overflow-wrap: break-word;
  min-width: 0;
}
/* Horizontal bar — MUI: lighter track tint + 4px rounded ends, transitions
 * tuned to the MUI charts cubic-bezier so width changes feel consistent. */
.horizontal-bar-track {
  flex: 1;
  min-width: 60px;
  height: 12px;
  background: var(--chart-grid);
  border-radius: 4px;
  overflow: visible;
  display: flex;
}
.horizontal-bar-fill {
  height: 100%;
  min-width: 8px;
  border-radius: 4px;
  transition: width 250ms cubic-bezier(0.4, 0, 0.2, 1);
}
.horizontal-bar-fill[data-zero="true"] {
  min-width: 8px;
  background: var(--chart-status-none) !important;
}
.horizontal-bar-value {
  flex: 0 0 44px;
  font-size: 11px;
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-primary);
  text-align: right;
}

/* Horizontal stacked bar (Total Issues by project, Bug / _bug) */
.stacked-bar-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 12px 20px;
  margin-bottom: 10px;
  font-size: 11px;
  color: var(--color-text-primary);
}
.stacked-bar-legend-item {
  display: flex;
  align-items: center;
  gap: 6px;
}
.stacked-bar-legend-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}
.stacked-bar-legend-text { font-weight: var(--font-weight-medium) }
.stacked-bar-chart {
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-height: 80px;
}
.stacked-bar-row {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 24px;
}
.stacked-bar-main {
  flex: 1;
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 10px;
}
.stacked-bar-main-clickable {
  cursor: pointer;
  transition: background-color 0.2s ease, opacity 0.2s ease;
  border-radius: var(--radius-sm);
}
.stacked-bar-main-clickable:hover {
  background-color: rgba(0, 0, 0, 0.05);
}
.stacked-bar-label {
  flex: 0 0 140px;
  font-size: 11px;
  color: var(--color-text-primary);
  font-weight: var(--font-weight-medium);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
/* Stacked horizontal bar — MUI: lighter track tint behind the segments,
 * 4px rounded outer corners, fade-in cubic-bezier on segment changes. */
.stacked-bar-track {
  flex: 1;
  display: flex;
  flex-direction: row;
  min-width: 0;
  height: 20px;
  border-radius: 4px;
  overflow: hidden;
  background: var(--chart-grid);
}
.stacked-bar-segment {
  height: 100%;
  min-width: 2px;
  transition: width 250ms cubic-bezier(0.4, 0, 0.2, 1);
}
.stacked-bar-segment-clickable {
  cursor: pointer;
  transition: width 250ms cubic-bezier(0.4, 0, 0.2, 1),
              filter 0.15s ease, opacity 0.15s ease;
}
.stacked-bar-segment-clickable:hover {
  filter: brightness(1.08);
}
.stacked-bar-value {
  flex: 0 0 36px;
  font-size: 11px;
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-primary);
  text-align: right;
}

.priority-stacked-wrap {
  margin-top: 10px;
  padding-top: 8px;
  border-top: 1px solid var(--color-border-subtle);
}
.priority-stacked-wrap .stacked-bar-legend {
  margin-bottom: 4px;
  flex-wrap: wrap;
  gap: 6px;
}
.priority-stacked-wrap .stacked-bar-legend:empty {
  display: none;
}
.priority-stacked-wrap .stacked-bar-legend-item { font-size: 10px }
.priority-stacked-wrap .stacked-bar-legend-dot { width: 6px; height: 6px }
.priority-stacked-wrap .stacked-bar-chart { min-height: 28px; gap: 4px }
.priority-stacked-wrap .stacked-bar-row { min-height: 18px }
.priority-stacked-wrap .stacked-bar-label { flex: 0 0 0; width: 0; overflow: hidden }
.priority-stacked-wrap .stacked-bar-track { height: 14px }
.priority-stacked-wrap .stacked-bar-value { flex: 0 0 28px; font-size: 10px }
/* Test Report tab – real-time testing statistics */
.test-report-panel {
  /* border-left bar removed for clean MODEC layout */
}

.test-report-header {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 0;
}

.test-report-header .panel-title {
  margin-bottom: 0;
}

.test-report-header-right {
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
  margin-left: auto;
}

.test-report-controls {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.kpi-cards {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 16px;
  margin-bottom: 20px;
}

.kpi-card {
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border-default);
  border-radius: 5px;
  padding: 20px;
  box-shadow: 0 1px 2px rgba(0,0,0,0.05);
  transition: all 0.2s ease;
}

.kpi-card:hover {
  border-color: var(--color-border-default);
  box-shadow: 0 2px 6px rgba(0,0,0,0.08);
}

.kpi-card-highlight {
  border-left: 4px solid var(--color-accent);
  background: var(--color-bg-surface-alt);
}

.kpi-card-status-green {
  border-left: 4px solid var(--c-success-500);
  background: var(--color-success-bg);
}

.kpi-card-status-yellow {
  border-left: 4px solid var(--c-warning-500);
  background: var(--color-warning-bg);
}

.kpi-card-status-red {
  border-left: 4px solid var(--c-danger-500);
  background: var(--color-danger-bg);
}

.kpi-value {
  font-size: 28px;
  font-weight: var(--font-weight-bold);
  color: var(--color-text-primary);
  line-height: 1.2;
  margin-bottom: 6px;
}

.kpi-label {
  font-size: 13px;
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.3px;
}

.kpi-sublabel {
  font-size: 11px;
  color: var(--color-text-muted);
  margin-top: 4px;
  font-weight: var(--font-weight-regular);
}

/* Quality Health tab: sections + structured layout (primary row + breakdown) */
.quality-health-section {
  padding-top: 24px;
  margin-top: 24px;
  border-top: 1px solid var(--color-border-default);
}

.quality-health-section:first-child {
  padding-top: 0;
  margin-top: 0;
  border-top: none;
}

.quality-health-section-title {
  font-size: 18px;
  font-weight: var(--font-weight-bold);
  color: var(--color-text-primary);
  margin: 0 0 16px 0;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}






/* Defect Leakage & Defect Density: fixed height */
.kpi-card.quality-health-kpi-fixed-height {
  min-height: 140px;
}

/* Column chart (RCA) */
.column-chart-wrap {
  display: flex;
  align-items: stretch;
  gap: 12px;
  min-height: 180px;
  height: 180px;
  padding: 16px 0 0 0;
}





.kpi-card-primary .kpi-value {
  font-size: 32px;
}


/* Distribution pie charts */
.distribution-chart-wrap {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  min-height: 100px;
}

.distribution-pie {
  width: 100px;
  height: 100px;
  min-width: 100px;
  min-height: 100px;
  border-radius: 50%;
  flex-shrink: 0;
}

.distribution-legend {
  margin: 0;
  padding: 0;
  list-style: none;
  font-size: 11px;
  color: var(--color-text-primary);
  line-height: 1.5;
}

.distribution-legend li {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 4px;
}

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

.distribution-legend .legend-text {
  flex: 1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Code Insights — Git / PR metrics */
.code-insights-panel {
  /* border-left bar removed for clean MODEC layout */
}

.code-insights-header .report-sticky-header {
  position: relative;
}

.code-insights-hint {
  font-size: 13px;
  color: var(--color-text-secondary);
  margin: 0 0 16px;
  max-width: 900px;
  line-height: 1.5;
}

.code-insights-meta {
  font-size: var(--font-size-xs);
  color: var(--color-text-secondary);
  margin-bottom: 16px;
}

.code-insights-summary {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 12px;
  margin-bottom: 24px;
}

.code-insights-kpi {
  border: 1px solid var(--color-border-default);
  padding: 12px 14px;
  background: var(--color-bg-surface-alt);
}

.code-insights-kpi-value {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  color: var(--color-text-primary);
}

.code-insights-kpi-label {
  font-size: 11px;
  color: var(--color-text-secondary);
  margin-top: 4px;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.code-insights-section {
  margin-bottom: 28px;
}

.code-insights-section-title {
  font-weight: var(--font-weight-semibold);
  font-size: var(--font-size-sm);
  color: var(--color-text-primary);
  margin-bottom: 12px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--color-border-default);
}

.git-metrics-merge-chart {
  display: flex;
  flex-direction: column;
  gap: 8px;
  max-width: 640px;
}

.git-metrics-bar-row {
  display: grid;
  grid-template-columns: 100px 1fr 32px;
  align-items: center;
  gap: 10px;
  font-size: var(--font-size-xs);
}

.git-metrics-bar-label {
  color: var(--color-text-secondary);
  font-variant-numeric: tabular-nums;
}

.git-metrics-bar-track {
  height: 10px;
  background: var(--color-border-default);
  border-radius: 5px;
  overflow: hidden;
}

.git-metrics-bar-fill {
  height: 100%;
  background: var(--color-accent);
  border-radius: 5px;
  min-width: 2px;
  transition: width 0.2s ease;
}

.git-metrics-bar-count {
  text-align: right;
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-primary);
}

.git-metrics-table-wrap {
  overflow-x: auto;
  border: 1px solid var(--color-border-default);
}

.git-metrics-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}

.git-metrics-table th,
.git-metrics-table td {
  padding: 10px 12px;
  text-align: left;
  border-bottom: 1px solid var(--color-border-default);
}

.git-metrics-table th {
  background: var(--color-bg-surface-alt);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-primary);
  white-space: nowrap;
}

.git-metrics-table tbody tr:hover {
  background: var(--color-bg-surface-alt);
}

.git-metrics-repo-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 12px;
}

.git-metrics-repo-card {
  border: 1px solid var(--color-border-default);
  padding: 14px;
  background: var(--color-bg-surface);
}

.git-metrics-repo-name {
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-primary);
  margin-bottom: 8px;
}

.git-metrics-repo-stats {
  font-size: var(--font-size-xs);
  color: var(--color-text-secondary);
  line-height: 1.45;
}

.git-metrics-repo-missing {
  font-size: var(--font-size-xs);
  color: var(--color-warning-text);
}
} /* end @layer features */
