.kpiDash {
  --kpi-blue-900: var(--blue-900, #0b3a66);
  --kpi-blue-700: var(--blue-700, #0f5fa6);
  --kpi-blue-500: var(--blue-600, #1a71c7);
  --kpi-blue-300: var(--blue-400, #7cb8ff);
  --kpi-blue-100: var(--surface-soft, #f4f8fd);

  --kpi-gray-950: var(--text-900, #0f172a);
  --kpi-gray-700: var(--muted, #475569);
  --kpi-gray-600: #5b6f8a;
  --kpi-gray-500: #6f819a;
  --kpi-gray-300: #c7d4e4;
  --kpi-gray-200: #dde7f2;
  --kpi-gray-100: var(--surface-soft, #f4f8fd);

  --kpi-ink: var(--text-900, #0f172a);
  --kpi-muted: var(--muted, #475569);
  --kpi-border: var(--border, rgba(15, 95, 166, 0.16));
  --kpi-border-soft: var(--border-soft, rgba(15, 95, 166, 0.12));
  --kpi-divider: rgba(15, 95, 166, 0.1);
  --kpi-surface: var(--surface-soft, #f4f8fd);
  --kpi-card: var(--surface, #ffffff);
  --kpi-ok: #1f6d4f;
  --kpi-warn: #5f6f84;
  --kpi-critical: var(--blue-700, #0f5fa6);

  --kpi-radius-sm: var(--radius-12, 12px);
  --kpi-radius-md: var(--radius-16, 16px);
  --kpi-radius-lg: var(--radius-tile, 18px);

  --kpi-shadow-card: var(--shadow-sm, 0 6px 18px rgba(19, 41, 75, 0.06));
  --kpi-shadow-soft: var(
    --shadow-sm,
    0 1px 3px rgba(19, 41, 75, 0.06),
    0 8px 22px rgba(19, 41, 75, 0.05)
  );

  --kpi-space-1: var(--space-1, 0.25rem);
  --kpi-space-2: var(--space-2, 0.5rem);
  --kpi-space-3: var(--space-3, 0.75rem);
  --kpi-space-4: var(--space-4, 1rem);
  --kpi-space-5: var(--space-5, 1.25rem);

  --kpi-title-xl: 1.14rem;
  --kpi-title-lg: 1rem;
  --kpi-title-md: 0.85rem;

  --kpi-font-ui: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue",
    Arial, sans-serif;
  margin-top: 1rem;
  color: var(--kpi-ink);
  font-family: var(--kpi-font-ui);
}

.kpiDash__loading,
.kpiDash__empty {
  border: 1px solid var(--kpi-border-soft);
  border-radius: var(--kpi-radius-md);
  background: linear-gradient(145deg, #ffffff 0%, var(--kpi-surface) 100%);
  padding: var(--kpi-space-5);
  box-shadow: var(--kpi-shadow-soft);
}

.kpiDash__loading h3,
.kpiDash__empty h3 {
  margin: 0;
  font-size: var(--kpi-title-xl);
  color: var(--kpi-blue-900);
}

.kpiDash__loading p,
.kpiDash__empty p {
  margin: 0.4rem 0 0;
  color: var(--kpi-muted);
  line-height: 1.45;
}

@keyframes kpiDashShimmer {
  0% {
    background-position: 100% 0;
  }

  100% {
    background-position: -100% 0;
  }
}

.kpiDash__loadingShell {
  display: grid;
  gap: var(--kpi-space-4);
}

.kpiDash__loadingShell .kpiDash__shell,
.kpiDash__loadingShell .kpiDash__exec,
.kpiDash__loadingShell .kpiDash__charts,
.kpiDash__loadingShell .kpiDash__stockGrid,
.kpiDash__loadingShell .kpiDash__loadingList {
  display: grid;
  gap: var(--kpi-space-4);
}

.kpiDash__loadingShell .kpiDash__exec,
.kpiDash__loadingShell .kpiDash__charts {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.kpiDash__loadingShell .kpiDash__stockGrid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.kpiDash__loadingPanel {
  border: 1px solid var(--kpi-border-soft);
  border-radius: var(--kpi-radius-md);
  background: linear-gradient(145deg, #ffffff 0%, var(--kpi-surface) 100%);
  padding: var(--kpi-space-4);
  box-shadow: var(--kpi-shadow-card);
  min-width: 0;
}

.kpiDash__loadingPanel--tall {
  min-height: clamp(230px, 42vh, 320px);
}

.kpiDash__loadingPanel--medium {
  min-height: clamp(150px, 28vh, 220px);
}

.kpiDash__loadingPanel--table {
  min-height: clamp(220px, 38vh, 300px);
}

.kpiDash__loadingPanel--stock {
  min-height: 124px;
}

.kpiDash__loadingList {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.kpiDash__skeletonLine,
.kpiDash__skeletonBlock,
.kpiDash__skeletonDot {
  position: relative;
  overflow: hidden;
  border-radius: 999px;
  background: linear-gradient(
    90deg,
    rgba(219, 229, 241, 0.62) 0%,
    rgba(255, 255, 255, 0.94) 50%,
    rgba(219, 229, 241, 0.62) 100%
  );
  background-size: 200% 100%;
  animation: kpiDashShimmer 1.45s linear infinite;
}

.kpiDash__skeletonLine {
  height: 0.82rem;
}

.kpiDash__skeletonLine--title {
  width: min(240px, 78%);
  height: 1.05rem;
}

.kpiDash__skeletonLine--subtitle {
  width: min(320px, 92%);
}

.kpiDash__skeletonLine--meta {
  width: 86px;
}

.kpiDash__skeletonLine--metric {
  width: 78px;
  height: 1.85rem;
}

.kpiDash__skeletonLine--short {
  width: 42%;
}

.kpiDash__skeletonLine--tiny {
  width: 28%;
}

.kpiDash__skeletonBlock {
  border-radius: var(--kpi-radius-sm);
  min-height: 110px;
}

.kpiDash__skeletonBlock--chart {
  min-height: clamp(230px, 42vh, 320px);
}

.kpiDash__skeletonBlock--bar {
  min-height: 10px;
  border-radius: 999px;
}

.kpiDash__skeletonDot {
  width: 0.82rem;
  height: 0.82rem;
}

.kpiDash__loadingHead {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--kpi-space-4);
}

.kpiDash__loadingStack {
  display: grid;
  gap: 0.62rem;
  min-width: 0;
}

.kpiDash__loadingRow {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.kpiDash__loadingBars {
  display: grid;
  gap: 0.7rem;
  margin-top: 1rem;
}

.kpiDash__loadingBars .kpiDash__loadingRow:nth-child(2) .kpiDash__skeletonBlock--bar {
  width: 88%;
}

.kpiDash__loadingBars .kpiDash__loadingRow:nth-child(3) .kpiDash__skeletonBlock--bar {
  width: 72%;
}

.kpiDash__loadingBars .kpiDash__loadingRow:nth-child(4) .kpiDash__skeletonBlock--bar {
  width: 61%;
}

.kpiDash__loadingBars .kpiDash__skeletonBlock--bar {
  width: 100%;
}

.kpiDash__reportRoot {
  background: #ffffff;
}

.kpiDash__pdfSnapshot {
  position: fixed;
  left: -24000px;
  top: 0;
  width: 1280px;
  background: #ffffff;
  z-index: 1;
  pointer-events: none;
}

.kpiDash__pdfSnapshot,
.kpiDash__pdfSnapshot * {
  -webkit-print-color-adjust: exact !important;
  print-color-adjust: exact !important;
}

.kpiDash__pdfSnapshot .kpiDash__pdfSnapshotPage {
  width: 100%;
  background: #ffffff;
}

.kpiDash__pdfSnapshot .site-header {
  position: static !important;
  left: auto !important;
  top: auto !important;
  width: 100% !important;
  max-width: none !important;
}

.kpiDash__pdfSnapshot .site-topbar,
.kpiDash__pdfSnapshot .topbar,
.kpiDash__pdfSnapshot .site-topbar__inner {
  width: 100% !important;
  max-width: none !important;
}

.kpiDash__pdfSnapshot .site-nav {
  display: none !important;
}

.kpiDash__pdfSnapshot .logo-strip {
  margin-bottom: 16px !important;
}

.kpiDash__pdfSnapshot .kpiDash__reportRoot {
  margin: 22px 0 0;
}

.kpiDash__pdfSnapshot .kpiDash__reportHeader,
.kpiDash__pdfSnapshot .kpiDash__execPanel,
.kpiDash__pdfSnapshot .kpiDash__panel,
.kpiDash__pdfSnapshot .kpiDash__funnel,
.kpiDash__pdfSnapshot .kpiDash__stock,
.kpiDash__pdfSnapshot .kpiDash__tableWrap,
.kpiDash__pdfSnapshot .kpiDash__chart,
.kpiDash__pdfSnapshot .ppccr-sankey {
  break-inside: avoid;
  page-break-inside: avoid;
}

.kpiDash__shell {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--kpi-space-4);
  align-items: start;
}

.kpiDash__reportHeader {
  border: 1px solid var(--kpi-border-soft);
  border-radius: var(--kpi-radius-md);
  background: var(--kpi-card);
  padding: var(--kpi-space-4);
  box-shadow: var(--kpi-shadow-card);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--kpi-space-4);
}

.kpiDash__reportHeadMain h3 {
  margin: 0;
  font-size: 1.08rem;
  font-weight: 650;
  letter-spacing: -0.01em;
  color: var(--kpi-ink);
}

.kpiDash__reportHeadMain p {
  margin: 0.22rem 0 0;
  font-size: 0.79rem;
  color: var(--kpi-muted);
}

.kpiDash__reportHeadMeta {
  display: grid;
  justify-items: end;
  gap: 0.34rem;
}

.kpiDash__reportUpdated {
  margin: 0;
  font-size: 0.73rem;
  color: var(--kpi-gray-600);
  font-variant-numeric: tabular-nums;
}

.kpiDash__reportExportedAt {
  margin: 0;
  display: none;
  font-size: 0.73rem;
  color: var(--kpi-gray-600);
  font-variant-numeric: tabular-nums;
}

.kpiDash__reportActions {
  display: inline-flex;
  gap: 0.34rem;
}

.kpiDash__reportBtn {
  appearance: none;
  border: 1px solid var(--kpi-border);
  border-radius: var(--radius-pill, 999px);
  background: var(--surface, #fff);
  color: var(--kpi-ink);
  font: inherit;
  font-size: 0.74rem;
  font-weight: 600;
  line-height: 1;
  padding: 0.38rem 0.7rem;
  cursor: pointer;
  transition: background-color 120ms ease, border-color 120ms ease;
}

.kpiDash__reportBtn:hover:not(:disabled) {
  background: var(--kpi-blue-100);
  border-color: rgba(15, 95, 166, 0.3);
}

.kpiDash__reportBtn:focus-visible {
  outline: var(--focus, 3px solid rgba(42, 137, 230, 0.7));
  outline-offset: 2px;
}

.kpiDash__reportBtn:disabled {
  opacity: 0.56;
  cursor: not-allowed;
}

.kpiDash__reportBtn--primary {
  background: rgba(15, 95, 166, 0.12);
  border-color: rgba(15, 95, 166, 0.26);
}

.kpiDash__reportStatus {
  display: inline-flex;
  align-items: center;
  gap: 0.36rem;
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--kpi-gray-700);
}

.kpiDash__reportStatusDot {
  width: 0.56rem;
  height: 0.56rem;
  border-radius: 999px;
  box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.9);
}

.kpiDash__reportStatusIcon {
  width: 0.86rem;
  height: 0.86rem;
  border-radius: 999px;
  border: 1px solid rgba(145, 161, 181, 0.34);
  color: #6f7f95;
  background: rgba(145, 161, 181, 0.1);
  font-size: 0.62rem;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  text-transform: lowercase;
}

.kpiDash__reportStatus--ok .kpiDash__reportStatusDot {
  background: #28a06e;
}

.kpiDash__reportStatus--warn .kpiDash__reportStatusDot {
  background: #91a1b5;
}

.kpiDash__reportRoot.kpiDash--exporting .kpiDash__reportActions {
  display: none;
}

.kpiDash__reportRoot.kpiDash--exporting .kpiDash__reportExportedAt {
  display: block;
}

.kpiDash__reportRoot.kpiDash--exporting .kpiDash__reportUpdated,
.kpiDash__reportRoot.kpiDash--exporting .kpiDash__reportStatus {
  display: none;
}

.kpiDash__reportRoot.kpiDash--exporting .kpiDash__summaryBarSegment--fit {
  background: linear-gradient(95deg, #0f5497, #2a7bc6);
}

.kpiDash__reportRoot.kpiDash--exporting .kpiDash__summaryBarSegment--outside {
  background: linear-gradient(95deg, #6aa9e6, #8ebef0);
}

.kpiDash__reportRoot.kpiDash--exporting .kpiDash__trk {
  --trk-ring-main-1: #0b4e8d;
  --trk-ring-main-2: #1b6db4;
  --trk-ring-main-3: #3f93da;
  --trk-ring-track-1: #d2e3f3;
  --trk-ring-track-2: #e8f1f9;
  --trk-ring-edge: rgba(12, 78, 141, 0.26);
  --trk-ring-shadow: rgba(13, 59, 106, 0.18);
}

.kpiDash__reportRoot.kpiDash--exporting .kpiDash__trkGauge::before,
.kpiDash__reportRoot.kpiDash--exporting .kpiDash__trkGauge::after {
  display: none;
}

.kpiDash__reportRoot.kpiDash--exporting .kpiDash__flowProgress {
  background: linear-gradient(180deg, #dce9f7, #c7dcf2);
  border-color: rgba(107, 153, 205, 0.58);
}

.kpiDash__reportRoot.kpiDash--exporting .kpiDash__flowProgressFill {
  background: linear-gradient(90deg, #155a9c, #4a96da);
}

.kpiDash__reportRoot.kpiDash--exporting .kpiDash__table--flow tbody td:nth-child(3),
.kpiDash__reportRoot.kpiDash--exporting .kpiDash__table--flow tbody td:nth-child(6) {
  vertical-align: middle;
}

.kpiDash__reportRoot.kpiDash--exporting .kpiDash__flowCell {
  grid-template-columns: 3ch minmax(4.35rem, 4.75rem);
  align-items: center;
  column-gap: 0.22rem;
}

.kpiDash__reportRoot.kpiDash--exporting .kpiDash__flowPrimary {
  width: 3ch;
  min-width: 3ch;
  padding: 0;
  border-radius: 0;
  border: 0;
  background: transparent;
  text-align: right;
  font-weight: 600;
}

.kpiDash__reportRoot.kpiDash--exporting .kpiDash__flowProgress {
  min-width: 4.35rem;
  width: 4.35rem;
  height: 0.88rem;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.78);
}

.kpiDash__reportRoot.kpiDash--exporting .kpiDash__flowProgress::after {
  display: none;
}

.kpiDash__reportRoot.kpiDash--exporting .kpiDash__flowProgressLabel {
  font-size: 0.59rem;
  letter-spacing: 0.02em;
  text-shadow: none;
}

.kpiDash__reportRoot.kpiDash--exporting .kpiDash__informCell {
  grid-template-columns: minmax(1.92rem, auto) minmax(4.85rem, auto);
  align-items: center;
  justify-content: center;
  gap: 0.22rem;
}

.kpiDash__reportRoot.kpiDash--exporting .kpiDash__informTotal {
  min-width: 1.92rem;
  height: 1.14rem;
  padding: 0 0.42rem;
  border-radius: 7px;
  font-size: 0.79rem;
  font-weight: 760;
  color: #0f3f72;
  border-color: rgba(76, 134, 197, 0.66);
  background:
    linear-gradient(160deg, rgba(230, 242, 255, 0.98), rgba(190, 217, 246, 0.95));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.92);
}

.kpiDash__reportRoot.kpiDash--exporting .kpiDash__informDetail {
  min-width: 4.85rem;
  width: auto;
  justify-content: flex-start;
}

.kpiDash__reportRoot.kpiDash--exporting .kpiDash__informSplit {
  width: 4.85rem;
  padding: 0.07rem 0.1rem;
  gap: 0.1rem;
  box-shadow: none;
  background: #f3f8fe;
}

.kpiDash__reportRoot.kpiDash--exporting .kpiDash__informSplitSep {
  height: 0.56rem;
}

.kpiDash__reportRoot.kpiDash--exporting .kpiDash__informChip--neg {
  background: linear-gradient(145deg, #165b9d, #2d7cc3);
}

.kpiDash__reportRoot.kpiDash--exporting .kpiDash__informChip--pos {
  background: linear-gradient(145deg, #d2e6fa, #afcfee);
  border-color: rgba(102, 154, 206, 0.72);
}

.kpiDash__reportRoot.kpiDash--exporting .kpiDash__informChip {
  min-width: 1.56rem;
  width: auto;
  height: 0.92rem;
  padding: 0 0.24rem;
  box-shadow: none;
}

.kpiDash__reportRoot.kpiDash--exporting .kpiDash__informChipSign {
  width: 0.66rem;
  height: 0.66rem;
  margin-right: 0.1rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.18);
  font-size: 0.54rem;
}

.kpiDash__reportRoot.kpiDash--exporting .kpiDash__informChip--pos .kpiDash__informChipSign {
  background: rgba(255, 255, 255, 0.56);
}

.kpiDash__reportRoot.kpiDash--exporting .kpiDash__informChipValue {
  font-size: 0.64rem;
}

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

.kpiDash__exec {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--kpi-space-4);
  align-items: stretch;
}

.kpiDash__exec > .kpiDash__execPanel {
  height: 100%;
}

.kpiDash__execPanel {
  border: 1px solid var(--kpi-border-soft);
  border-radius: var(--kpi-radius-md);
  background: var(--kpi-card);
  padding: var(--kpi-space-4);
  box-shadow: var(--kpi-shadow-card);
}

.kpiDash__execHeader {
  align-items: flex-start;
  margin-bottom: 0.55rem;
}

.kpiDash__execHeader h4 {
  font-size: var(--kpi-title-lg);
  font-weight: 620;
  letter-spacing: 0.01em;
}

.kpiDash__execHeader p {
  font-size: 0.79rem;
  color: var(--kpi-gray-600);
}

.kpiDash__summaryHeadTotal {
  margin-left: auto;
  font-size: clamp(1.56rem, 2.45vw, 2.04rem);
  line-height: 0.92;
  font-weight: 700;
  color: var(--kpi-blue-900);
  text-align: right;
  font-variant-numeric: tabular-nums;
}

.kpiDash__exec .kpiDash__summaryCard {
  border-color: transparent;
  background: transparent;
  box-shadow: none;
  padding: 0;
}

.kpiDash__exec .kpiDash__fitFlow {
  border: 1px solid var(--kpi-border-soft);
  border-radius: var(--kpi-radius-md);
  padding: var(--kpi-space-4);
  background: var(--kpi-card);
  box-shadow: var(--kpi-shadow-card);
}

.kpiDash__exec .kpiDash__fitFlowDonutPanel {
  background: linear-gradient(150deg, #ffffff, rgba(234, 243, 255, 0.44));
}

.kpiDash__summary {
  display: block;
}

.kpiDash__summary.kpiDash__execPanel {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  row-gap: 0.26rem;
}

.kpiDash__summary .kpiDash__execHeader {
  margin-bottom: 0.14rem;
}

.kpiDash__summaryCard {
  border: 0;
  border-radius: 0;
  background: transparent;
  padding: 0;
  box-shadow: none;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 100%;
  gap: 0.86rem;
}

.kpiDash__summaryTop {
  display: flex;
  justify-content: flex-end;
  align-items: baseline;
  gap: 0.24rem;
}

.kpiDash__summaryLabel {
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: var(--kpi-gray-500);
}

.kpiDash__summaryValue {
  font-size: clamp(1.8rem, 3vw, 2.35rem);
  line-height: 1;
  font-weight: 700;
  color: var(--kpi-blue-900);
  text-align: right;
  justify-self: end;
}

.kpiDash__summaryDistribution {
  display: grid;
  gap: 0.62rem;
  border-top: 1px solid var(--kpi-divider);
  padding-top: 0.58rem;
}

.kpiDash__summaryBar {
  position: relative;
  display: flex;
  width: 100%;
  height: 10px;
  border-radius: 999px;
  overflow: visible;
  background: var(--kpi-blue-100);
}

.kpiDash__summaryBarSegment {
  position: relative;
  display: block;
  height: 100%;
  cursor: default;
}

.kpiDash__summaryBarSegment:focus-visible {
  outline: 2px solid rgba(42, 137, 230, 0.45);
  outline-offset: 3px;
}

.kpiDash__summaryBarSegment + .kpiDash__summaryBarSegment {
  box-shadow: inset 2px 0 0 rgba(255, 255, 255, 0.95);
}

.kpiDash__summaryBarSegment--fit {
  border-radius: 999px 0 0 999px;
  background: linear-gradient(90deg, var(--kpi-blue-900), #0a62af);
}

.kpiDash__summaryBarSegment--outside {
  border-radius: 0 999px 999px 0;
  background: linear-gradient(90deg, var(--kpi-blue-500), var(--kpi-blue-300));
}

.kpiDash__summaryBarSegment::before,
.kpiDash__summaryBarSegment::after {
  opacity: 0;
  pointer-events: none;
  transition: opacity 120ms ease, transform 120ms ease;
}

.kpiDash__summaryBarSegment::before {
  content: "";
  position: absolute;
  left: 50%;
  bottom: calc(100% + 2px);
  transform: translate(-50%, 3px);
  border-width: 5px;
  border-style: solid;
  border-color: #ffffff transparent transparent transparent;
  filter: drop-shadow(0 1px 0 rgba(19, 41, 75, 0.14));
  z-index: 7;
}

.kpiDash__summaryBarSegment::after {
  content: attr(data-kpi-tooltip);
  position: absolute;
  left: 50%;
  bottom: calc(100% + 10px);
  transform: translate(-50%, 3px);
  white-space: nowrap;
  font-size: 0.68rem;
  line-height: 1.2;
  color: var(--kpi-ink);
  background: #ffffff;
  border: 1px solid var(--kpi-border-soft);
  border-radius: 9px;
  padding: 0.28rem 0.46rem;
  box-shadow: 0 8px 20px rgba(19, 41, 75, 0.14);
  z-index: 8;
}

.kpiDash__summaryBarSegment:hover::before,
.kpiDash__summaryBarSegment:hover::after,
.kpiDash__summaryBarSegment:focus-visible::before,
.kpiDash__summaryBarSegment:focus-visible::after {
  opacity: 1;
  transform: translate(-50%, 0);
}

.kpiDash__summarySplit {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.66rem;
}

.kpiDash__summaryMainMetric {
  display: grid;
  grid-template-columns: auto auto 3ch 1fr;
  grid-template-areas:
    "dot label value ."
    ". meta meta .";
  column-gap: 0.42rem;
  row-gap: 0.08rem;
  align-items: center;
  padding: 0.24rem 0 0.16rem;
  border: 0;
  border-radius: 0;
  background: transparent;
}

.kpiDash__summaryMainDot {
  grid-area: dot;
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 999px;
  margin-top: 0;
  align-self: center;
}

.kpiDash__summaryMainDot--fit {
  background: var(--kpi-blue-900);
}

.kpiDash__summaryMainDot--outside {
  background: var(--kpi-blue-500);
}

.kpiDash__summaryMainLabel {
  grid-area: label;
  font-size: 0.74rem;
  color: var(--kpi-gray-600);
}

.kpiDash__summaryMainValue {
  grid-area: value;
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--kpi-blue-900);
  font-variant-numeric: tabular-nums;
  width: 3ch;
  text-align: left;
  justify-self: start;
}

.kpiDash__summaryMainMeta {
  grid-area: meta;
  font-size: 0.69rem;
  color: var(--kpi-gray-500);
}

.kpiDash__summaryReasons {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.64rem;
  border-top: 1px solid var(--kpi-divider);
  padding-top: 0.7rem;
}

.kpiDash__summaryReasonsScope {
  grid-column: 1 / -1;
  margin: 0;
  font-size: 0.68rem;
  color: var(--kpi-gray-500);
  letter-spacing: 0.01em;
}

.kpiDash__summaryBadge {
  border: 1px solid rgba(60, 127, 195, 0.24);
  border-radius: var(--kpi-radius-sm);
  background: linear-gradient(
    160deg,
    rgba(238, 246, 255, 0.92),
    rgba(248, 252, 255, 0.98)
  );
  box-shadow: 0 4px 12px rgba(18, 72, 128, 0.06);
  min-height: 76px;
  padding: 0.58rem 0.62rem;
  display: grid;
  justify-items: center;
  align-content: center;
  text-align: center;
  gap: 0.18rem;
}

.kpiDash__summaryBadgeLabel {
  font-size: 0.72rem;
  color: var(--kpi-gray-600);
  text-align: center;
  width: 100%;
}

.kpiDash__summaryBadgeValue {
  display: inline-flex;
  align-items: baseline;
  gap: 0.18rem;
  font-size: 1rem;
  font-weight: 700;
  color: var(--kpi-blue-900);
  line-height: 1.08;
  font-variant-numeric: tabular-nums;
  text-align: center;
  justify-self: center;
}

.kpiDash__summaryBadgePct {
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--kpi-gray-600);
  letter-spacing: 0.01em;
}

.kpiDash__fitFlow {
  min-width: 0;
}

.kpiDash__fitFlowBody {
  display: grid;
  gap: var(--kpi-space-3);
}

.kpiDash__fitFlowSplit {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--kpi-space-3);
  align-items: stretch;
}

.kpiDash__fitFlowPanel {
  border: 1px solid var(--kpi-border-soft);
  border-radius: var(--kpi-radius-sm);
  background: var(--kpi-card);
  padding: 0.68rem 0.72rem;
  min-width: 0;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.68);
}

.kpiDash__fitFlowPanel .kpiDash__fitOutcome,
.kpiDash__fitFlowPanel .kpiDash__trk {
  border-top: 0;
  padding-top: 0;
}

.kpiDash__fitFlowPanel .kpiDash__fitOutcome {
  gap: var(--kpi-space-2);
}

.kpiDash__fitFlowPanel--outcome {
  display: flex;
}

.kpiDash__fitFlowPanel--trk {
  display: flex;
}

.kpiDash__fitFlowPanel--outcome .kpiDash__fitOutcome {
  flex: 1;
  min-height: 100%;
  display: grid;
  grid-template-rows: auto auto auto;
  align-content: space-between;
  gap: 0.52rem;
}

.kpiDash__fitFlowPanel--trk .kpiDash__trk {
  flex: 1;
  min-height: 100%;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: 0.44rem;
}

.kpiDash__fitFlowPanel .kpiDash__trkHead {
  flex-direction: row;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.35rem;
}

.kpiDash__fitFlowPanel .kpiDash__trkSub {
  display: none;
}

.kpiDash__fitFlowPanel .kpiDash__trkStatus {
  white-space: nowrap;
}

.kpiDash__fitFlowPanel .kpiDash__trkBody {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: stretch;
  border: 0;
  background: transparent;
  box-shadow: none;
  padding: 0;
  gap: 0.48rem;
  min-height: 100%;
  height: 100%;
}

.kpiDash__fitFlowPanel .kpiDash__trkKpi {
  min-height: 100%;
  grid-template-rows: auto auto 1fr auto;
  align-content: stretch;
}

.kpiDash__fitFlowPanel .kpiDash__trkGap {
  font-size: 0.63rem;
  min-height: 1.05rem;
  display: inline-flex;
  align-items: center;
  margin: 0.06rem 0;
}

.kpiDash__fitFlowPanel .kpiDash__trkFactLine {
  margin-top: auto;
  align-self: start;
}

.kpiDash__fitFlowPanel .kpiDash__trkGaugeWrap {
  justify-items: end;
  align-items: end;
}

.kpiDash__fitFlowPanel .kpiDash__trkGauge {
  width: 76px;
  height: 76px;
}

.kpiDash__fitFlowPanel .kpiDash__trkGaugeGoal {
  display: none;
}

.kpiDash__fitFlowHint {
  justify-self: end;
  font-size: 0.64rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--kpi-gray-500);
}

.kpiDash__fitFlowSteps {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 0.7rem;
}

.kpiDash__fitStep {
  position: relative;
  border: 1px solid var(--kpi-border-soft);
  border-radius: var(--kpi-radius-sm);
  background: linear-gradient(150deg, #ffffff, rgba(234, 243, 255, 0.55));
  padding: 0.58rem 0.62rem;
  display: grid;
  gap: 0.3rem;
  min-width: 0;
  box-shadow: 0 2px 8px rgba(19, 41, 75, 0.04);
}

.kpiDash__fitStepArrow {
  position: absolute;
  right: -0.56rem;
  top: 50%;
  transform: translateY(-50%);
  color: #8ba0bf;
  font-size: 0.85rem;
  font-weight: 700;
}

.kpiDash__fitStepLabel {
  font-size: 0.69rem;
  color: var(--kpi-gray-600);
  line-height: 1.2;
  min-height: 2.05em;
}

.kpiDash__fitStepRow {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.3rem;
}

.kpiDash__fitStepValue {
  font-size: 1.18rem;
  font-weight: 700;
  color: var(--kpi-blue-900);
  line-height: 1.1;
  letter-spacing: -0.01em;
  font-variant-numeric: tabular-nums;
}

.kpiDash__fitStepBadge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 3.1em;
  border-radius: 999px;
  border: 1px solid transparent;
  padding: 0.08rem 0.42rem;
  font-size: 0.64rem;
  line-height: 1.1;
  font-weight: 700;
  letter-spacing: 0.01em;
  font-variant-numeric: tabular-nums;
}

.kpiDash__fitStepBadge--base {
  color: #5f7496;
  background: rgba(111, 132, 166, 0.12);
  border-color: rgba(111, 132, 166, 0.22);
}

.kpiDash__fitStepBadge--mid {
  color: #3269a8;
  background: rgba(60, 127, 195, 0.14);
  border-color: rgba(60, 127, 195, 0.24);
}

.kpiDash__fitStepBadge--full {
  color: #0f4f8d;
  background: rgba(30, 111, 191, 0.18);
  border-color: rgba(30, 111, 191, 0.28);
}

.kpiDash__fitStepMeta,
.kpiDash__fitStepDetail {
  font-size: 0.7rem;
  color: var(--kpi-gray-600);
}

.kpiDash__fitOutcome {
  border-top: 1px solid var(--kpi-divider);
  padding-top: var(--kpi-space-3);
  display: grid;
  gap: var(--kpi-space-2);
}

.kpiDash__fitOutcomeHeader {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--kpi-space-2);
}

.kpiDash__fitOutcomeHeader h5 {
  margin: 0;
  font-size: var(--kpi-title-md);
  font-weight: 620;
  color: var(--kpi-blue-900);
}

.kpiDash__fitOutcomeTotal {
  font-size: 1rem;
  line-height: 1;
  font-weight: 700;
  color: var(--kpi-blue-900);
  font-variant-numeric: tabular-nums;
}

.kpiDash__fitOutcomeBar {
  position: relative;
  display: flex;
  width: 100%;
  height: 10px;
  border-radius: 999px;
  overflow: visible;
  background: transparent;
  cursor: default;
  isolation: isolate;
}

.kpiDash__fitOutcomeBarWrap {
  position: relative;
}

.kpiDash__fitOutcomeBar::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 999px;
  background: var(--kpi-blue-100);
  z-index: 0;
}

.kpiDash__fitOutcomeSegment {
  display: block;
  position: relative;
  height: 100%;
  z-index: 1;
  cursor: default;
}

.kpiDash__fitOutcomeSegment:focus-visible {
  outline: 2px solid rgba(38, 124, 205, 0.42);
  outline-offset: 3px;
}

.kpiDash__fitOutcomeBar[data-has-split="true"] .kpiDash__fitOutcomeSegment--neg {
  border-radius: 999px 0 0 999px;
}

.kpiDash__fitOutcomeSegment--neg {
  background: linear-gradient(90deg, #1a6ebb, #58a0e3);
}

.kpiDash__fitOutcomeBar[data-has-split="true"] .kpiDash__fitOutcomeSegment--neg::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  right: -1px;
  width: 2px;
  background: rgba(255, 255, 255, 0.88);
  z-index: 2;
}

.kpiDash__fitOutcomeBar[data-has-split="true"] .kpiDash__fitOutcomeSegment--pos {
  border-radius: 0 999px 999px 0;
}

.kpiDash__fitOutcomeBar[data-has-split="false"] .kpiDash__fitOutcomeSegment {
  border-radius: 999px;
}

.kpiDash__fitOutcomeSegment--pos {
  background: linear-gradient(90deg, #88bdf2, #b9dbfb);
}

.kpiDash__fitOutcomeSegmentTip {
  position: absolute;
  left: 50%;
  bottom: calc(100% + 8px);
  transform: translate(-50%, 4px);
  opacity: 0;
  pointer-events: none;
  display: inline-flex;
  white-space: nowrap;
  padding: 0.3rem 0.5rem;
  border: 1px solid var(--kpi-border-soft);
  border-radius: 9px;
  background: #ffffff;
  color: var(--kpi-gray-700);
  font-size: 0.64rem;
  line-height: 1.2;
  font-variant-numeric: tabular-nums;
  box-shadow: 0 10px 26px rgba(19, 41, 75, 0.14);
  transition: opacity 120ms ease, transform 120ms ease;
  z-index: 9;
}

.kpiDash__fitOutcomeSegmentTip::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 100%;
  transform: translateX(-50%);
  border-width: 5px 5px 0;
  border-style: solid;
  border-color: #ffffff transparent transparent;
}

.kpiDash__fitOutcomeSegment:hover .kpiDash__fitOutcomeSegmentTip,
.kpiDash__fitOutcomeSegment:focus-visible .kpiDash__fitOutcomeSegmentTip {
  opacity: 1;
  transform: translate(-50%, 0);
}

.kpiDash__fitOutcomeLegend {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.3rem 0.7rem;
}

.kpiDash__fitOutcomeItem + .kpiDash__fitOutcomeItem {
  position: relative;
  padding-left: 0.64rem;
}

.kpiDash__fitOutcomeItem + .kpiDash__fitOutcomeItem::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  width: 1px;
  height: 0.88rem;
  transform: translateY(-50%);
  background: rgba(15, 95, 166, 0.16);
}

.kpiDash__fitOutcomeItem {
  display: grid;
  grid-template-columns: auto 1fr auto;
  grid-template-areas: "dot label metric";
  align-items: center;
  gap: 0.34rem 0.4rem;
  padding: 0.06rem 0;
  border: 0;
  border-radius: 0;
  background: transparent;
}

.kpiDash__fitOutcomeDot {
  grid-area: dot;
  width: 0.45rem;
  height: 0.45rem;
  border-radius: 999px;
}

.kpiDash__fitOutcomeDot--neg {
  background: #2c79c4;
}

.kpiDash__fitOutcomeDot--pos {
  background: #7db6ec;
}

.kpiDash__fitOutcomeLabel {
  grid-area: label;
  font-size: 0.7rem;
  color: var(--kpi-gray-600);
}

.kpiDash__fitOutcomeMetric {
  grid-area: metric;
  display: inline-flex;
  align-items: baseline;
  justify-self: end;
  gap: 0.18rem;
}

.kpiDash__fitOutcomeValue {
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--kpi-blue-900);
  font-variant-numeric: tabular-nums;
  line-height: 1;
}

.kpiDash__fitOutcomePct {
  font-size: 0.67rem;
  line-height: 1.05;
  color: var(--kpi-gray-500);
  font-weight: 400;
  font-variant-numeric: tabular-nums;
}

.kpiDash__fitOutcomeEmpty {
  margin: 0;
  font-size: 0.74rem;
  color: var(--kpi-gray-600);
}

.kpiDash__trk {
  border-top: 1px solid var(--kpi-divider);
  padding-top: var(--kpi-space-2);
  display: grid;
  gap: 0.55rem;
  --trk-accent: var(--kpi-blue-700);
  --trk-chip-bg: rgba(30, 111, 191, 0.12);
  --trk-chip-border: rgba(30, 111, 191, 0.26);
  --trk-chip-text: var(--kpi-blue-900);
  --trk-ring-main-1: #0a3f78;
  --trk-ring-main-2: #0f5c9f;
  --trk-ring-main-3: #2f82c5;
  --trk-ring-track-1: #d9e5f1;
  --trk-ring-track-2: #ebf1f8;
  --trk-ring-rest: rgba(136, 189, 242, 0.34);
  --trk-ring-edge: rgba(14, 72, 127, 0.2);
  --trk-ring-shadow: rgba(14, 55, 98, 0.2);
  --trk-ring-highlight: rgba(255, 255, 255, 0.44);
  --trk-ring-sheen: rgba(255, 255, 255, 0.18);
  --trk-gauge-center-1: #ffffff;
  --trk-gauge-center-2: #f5f9fd;
  --trk-gauge-core-border: rgba(14, 72, 127, 0.14);
}

.kpiDash__trkHead {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 0.7rem;
}

.kpiDash__trkMeta {
  display: grid;
  gap: 0.08rem;
}

.kpiDash__trkTitle {
  margin: 0;
  font-size: var(--kpi-title-md);
  font-weight: 620;
  color: var(--kpi-blue-900);
}

.kpiDash__trkSub {
  margin: 0;
  font-size: 0.61rem;
  color: var(--kpi-gray-500);
  letter-spacing: 0.01em;
}

.kpiDash__trkStatus {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 1.2rem;
  padding: 0.05rem 0.42rem;
  border-radius: 999px;
  border: 1px solid var(--trk-chip-border);
  background: var(--trk-chip-bg);
  color: var(--trk-chip-text);
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.01em;
}

.kpiDash__trkGap {
  font-size: 0.67rem;
  line-height: 1.2;
  font-weight: 600;
  color: var(--kpi-gray-600);
  font-variant-numeric: tabular-nums;
}

.kpiDash__trkBody {
  border: 1px solid var(--kpi-border-soft);
  border-radius: var(--kpi-radius-sm);
  background: linear-gradient(150deg, #f4f4f4, rgba(255, 255, 255, 0.94));
  padding: 0.58rem 0.64rem;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 0.55rem;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7);
}

.kpiDash__trkKpi {
  display: grid;
  gap: 0.14rem;
  min-width: 0;
}

.kpiDash__trkPrimary {
  display: flex;
  align-items: baseline;
  gap: 0.28rem;
}

.kpiDash__trkValue {
  font-size: clamp(0.94rem, 1.45vw, 1.12rem);
  line-height: 0.96;
  font-weight: 700;
  color: var(--kpi-blue-900);
  font-variant-numeric: tabular-nums;
}

.kpiDash__trkTarget {
  font-size: 0.62rem;
  color: var(--kpi-gray-500);
  letter-spacing: 0.01em;
}

.kpiDash__trkFactLine {
  font-size: 0.66rem;
  color: var(--kpi-gray-600);
  font-variant-numeric: tabular-nums;
}

.kpiDash__trkFactLine strong {
  font-size: 0.76rem;
  color: var(--kpi-blue-900);
  font-weight: 700;
}

.kpiDash__trkGaugeWrap {
  display: grid;
  justify-items: end;
}

.kpiDash__trkGauge {
  --trk-pct: 0;
  position: relative;
  width: 92px;
  height: 92px;
  border-radius: 50%;
  background: conic-gradient(
    from -90deg,
    var(--trk-ring-main-1) 0%,
    var(--trk-ring-main-2) calc(var(--trk-pct) * 0.55%),
    var(--trk-ring-main-3) calc(var(--trk-pct) * 1%),
    var(--trk-ring-track-1) calc(var(--trk-pct) * 1%),
    var(--trk-ring-track-2) 100%
  );
  display: grid;
  place-items: center;
  box-shadow:
    inset 0 0 0 1px var(--trk-ring-edge),
    0 6px 14px var(--trk-ring-shadow);
  overflow: visible;
  isolation: isolate;
}

.kpiDash__trkGauge::before {
  content: "";
  position: absolute;
  inset: 1px;
  border-radius: 50%;
  background: radial-gradient(
    circle at 30% 22%,
    var(--trk-ring-highlight) 0%,
    rgba(255, 255, 255, 0.12) 30%,
    transparent 58%,
    transparent 100%
  );
  pointer-events: none;
  z-index: 1;
}

.kpiDash__trkGauge::after {
  content: "";
  position: absolute;
  inset: 2px;
  border-radius: 50%;
  background: conic-gradient(
    from -90deg,
    rgba(255, 255, 255, 0.48) 0deg,
    rgba(255, 255, 255, 0.06) 52deg,
    transparent 120deg,
    transparent 300deg,
    var(--trk-ring-sheen) 338deg,
    rgba(255, 255, 255, 0.42) 360deg
  );
  pointer-events: none;
  z-index: 2;
}

.kpiDash__trkGaugeOverlay {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 4;
}

.kpiDash__trkGaugeHit {
  fill: none;
  stroke: transparent;
  stroke-width: 16;
  pointer-events: stroke;
  cursor: default;
}

.kpiDash__trkGaugeHit:focus-visible {
  outline: none;
}

.kpiDash__trkGaugeMarker {
  position: absolute;
  inset: 0;
  transform: rotate(calc((var(--trk-pct) * 3.6deg) - 90deg));
  transform-origin: 50% 50%;
  pointer-events: none;
  z-index: 5;
}

.kpiDash__trkGaugeMarker::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 2px;
  width: 4px;
  height: 10px;
  border-radius: 999px;
  transform: translateX(-50%);
  background: linear-gradient(180deg, #f7fbff 0%, #d8e8f8 58%, #9ebbd8 100%);
  box-shadow:
    0 0 0 1px rgba(251, 254, 255, 0.96),
    0 1px 3px rgba(12, 57, 99, 0.28);
}

.kpiDash__trkGaugeTip {
  position: absolute;
  left: 50%;
  bottom: calc(100% + 8px);
  transform: translate(-50%, 4px);
  opacity: 0;
  pointer-events: none;
  max-width: 180px;
  white-space: normal;
  text-align: center;
  padding: 0.26rem 0.44rem;
  border-radius: 9px;
  border: 1px solid var(--kpi-border-soft);
  background: #ffffff;
  color: var(--kpi-gray-700);
  font-size: 0.62rem;
  line-height: 1.25;
  box-shadow: 0 8px 22px rgba(19, 41, 75, 0.14);
  z-index: 4;
  transition: opacity 120ms ease, transform 120ms ease;
}

.kpiDash__trkGaugeTip::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 100%;
  transform: translateX(-50%);
  border-width: 5px 5px 0;
  border-style: solid;
  border-color: #ffffff transparent transparent;
}

.kpiDash__trkGaugeTip.is-visible {
  opacity: 1;
  transform: translate(-50%, 0);
}

.kpiDash__trkGaugeInner {
  position: relative;
  z-index: 3;
  width: 72%;
  height: 72%;
  border-radius: 50%;
  background: linear-gradient(160deg, var(--trk-gauge-center-1), var(--trk-gauge-center-2));
  border: 1px solid var(--trk-gauge-core-border);
  display: grid;
  place-items: center;
  align-content: center;
  gap: 0.06rem;
  text-align: center;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.92),
    0 2px 8px rgba(14, 60, 106, 0.12);
}

.kpiDash__trkGaugeValue {
  font-size: 0.76rem;
  line-height: 1;
  font-weight: 700;
  color: var(--kpi-blue-900);
  font-variant-numeric: tabular-nums;
}

.kpiDash__trkGaugeGoal {
  font-size: 0.5rem;
  line-height: 1;
  color: var(--kpi-gray-500);
}

.kpiDash__trk--strong {
  --trk-accent: #0b5fae;
  --trk-chip-bg: rgba(11, 95, 174, 0.14);
  --trk-chip-border: rgba(11, 95, 174, 0.28);
  --trk-chip-text: #0b4f8f;
  --trk-ring-main-1: #083a6f;
  --trk-ring-main-2: #0f5a9a;
  --trk-ring-main-3: #2a81c8;
  --trk-ring-track-1: #d4e2ef;
  --trk-ring-track-2: #ebf2f9;
}

.kpiDash__trk--good {
  --trk-accent: #1e6fbf;
  --trk-chip-bg: rgba(30, 111, 191, 0.12);
  --trk-chip-border: rgba(30, 111, 191, 0.24);
  --trk-chip-text: #0d4e8c;
  --trk-ring-main-1: #0a3f78;
  --trk-ring-main-2: #0f5c9f;
  --trk-ring-main-3: #2f82c5;
  --trk-ring-track-1: #d9e5f1;
  --trk-ring-track-2: #ebf1f8;
}

.kpiDash__trk--watch {
  --trk-accent: #3c7fc3;
  --trk-chip-bg: rgba(60, 127, 195, 0.14);
  --trk-chip-border: rgba(60, 127, 195, 0.24);
  --trk-chip-text: #1f5b97;
  --trk-ring-main-1: #2a5d90;
  --trk-ring-main-2: #467db2;
  --trk-ring-main-3: #7daed8;
  --trk-ring-track-1: #dce8f3;
  --trk-ring-track-2: #eef4fa;
}

.kpiDash__trk--empty {
  --trk-accent: #9aacbf;
  --trk-chip-bg: rgba(143, 161, 185, 0.16);
  --trk-chip-border: rgba(143, 161, 185, 0.26);
  --trk-chip-text: #5f738d;
  --trk-ring-main-1: #889db5;
  --trk-ring-main-2: #9eb3c8;
  --trk-ring-main-3: #bdcddd;
  --trk-ring-track-1: #dfe7ef;
  --trk-ring-track-2: #eff4f9;
  --trk-ring-rest: rgba(143, 161, 185, 0.28);
  --trk-gauge-center-2: #f4f7fa;
}

.kpiDash__trk--empty .kpiDash__trkValue,
.kpiDash__trk--empty .kpiDash__trkGaugeValue {
  color: var(--kpi-gray-600);
}

.kpiDash__trk--empty .kpiDash__trkGaugeMarker {
  display: none;
}

.kpiDash__card {
  background: var(--kpi-card);
  border: 1px solid var(--kpi-border-soft);
  border-radius: var(--kpi-radius-md);
  padding: var(--kpi-space-4);
  min-height: 106px;
  box-shadow: var(--kpi-shadow-card);
}

.kpiDash__cardLabel {
  display: block;
  font-size: 0.76rem;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  color: var(--kpi-muted);
}

.kpiDash__cardValue {
  display: block;
  margin-top: 0.35rem;
  font-size: clamp(1.35rem, 2.25vw, 1.72rem);
  line-height: 1.1;
  font-weight: 700;
  color: var(--kpi-blue-900);
}

.kpiDash__cardMeta {
  display: block;
  margin-top: 0.25rem;
  font-size: 0.82rem;
  color: var(--kpi-muted);
}

.kpiDash__charts {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--kpi-space-4);
}

.kpiDash__panel--bars,
.kpiDash__panel--aux {
  min-width: 0;
}

.kpiDash__panel {
  border: 1px solid var(--kpi-border-soft);
  border-radius: var(--kpi-radius-md);
  background: var(--kpi-card);
  padding: var(--kpi-space-4);
  box-shadow: var(--kpi-shadow-card);
}

.kpiDash__panelHeader {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--kpi-space-3);
  margin-bottom: var(--kpi-space-3);
}

.kpiDash__panelHeader h4 {
  margin: 0;
  font-size: var(--kpi-title-lg);
  font-weight: 620;
  color: var(--kpi-blue-900);
}

.kpiDash__panelHeader p {
  margin: 0;
  font-size: 0.79rem;
  color: var(--kpi-gray-600);
}

.kpiDash__chart {
  width: 100%;
  min-height: 286px;
}

.kpiDash__chartFallback {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 286px;
  border: 1px dashed var(--kpi-border);
  border-radius: 14px;
  text-align: center;
  color: var(--kpi-muted);
  font-size: 0.9rem;
  padding: 0.85rem;
}

.kpiDash__panelLegend {
  display: none;
  list-style: none;
  margin: 0;
  padding: 0;
}

.kpiDash__panelLegendItem {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.kpiDash__panelLegendSwatch {
  width: 12px;
  height: 12px;
  border-radius: 3px;
  flex: 0 0 auto;
}

.kpiDash__panelLegendText {
  color: var(--kpi-gray-600);
}

.kpiDash__panelLegendSwatch--participants {
  background: #0c4e8d;
}

.kpiDash__panelLegendSwatch--fit {
  background: #3c7fc3;
}

.kpiDash__panelLegendSwatch--outside {
  background: #88bdf2;
}

@media (min-width: 1025px) {
  body.page-home .kpiDash__reportHeader {
    padding: 0.92rem 0.96rem;
  }

  body.page-home .kpiDash__reportHeadMain h3 {
    font-size: 1.04rem;
    letter-spacing: -0.015em;
  }

  body.page-home .kpiDash__reportHeadMain p {
    margin-top: 0.18rem;
    font-size: 0.76rem;
    line-height: 1.32;
  }

  body.page-home .kpiDash__execHeader h4 {
    font-size: 1.02rem;
    letter-spacing: -0.012em;
  }

  body.page-home .kpiDash__execHeader p {
    font-size: 0.76rem;
    line-height: 1.32;
  }

  body.page-home .kpiDash__charts {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.96rem;
    align-items: stretch;
  }

  body.page-home .kpiDash__panel--bars {
    grid-column: auto;
    display: flex;
    flex-direction: column;
    position: relative;
    padding: 0.88rem 0.66rem 0.68rem;
  }

  body.page-home .kpiDash__panel--aux {
    grid-column: auto;
    padding: 0.94rem 0.88rem 0.96rem;
  }

  body.page-home .kpiDash__panelHeader {
    align-items: flex-start;
    margin-bottom: 0.68rem;
  }

  body.page-home .kpiDash__panel--bars .kpiDash__panelHeader {
    display: block;
    padding-right: 8.2rem;
    margin-bottom: 0.18rem;
  }

  body.page-home .kpiDash__panel--bars .kpiDash__panelHeader h4 {
    min-width: 0;
    padding-left: 14px;
  }

  body.page-home .kpiDash__panelLegend--bars {
    display: flex;
    position: absolute;
    top: 1.08rem;
    right: 1.34rem;
    width: 126px;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
    gap: 0.34rem;
    padding-top: 0;
  }

  body.page-home .kpiDash__panelLegend--bars .kpiDash__panelLegendItem {
    gap: 0.42rem;
  }

  body.page-home .kpiDash__panelLegend--bars .kpiDash__panelLegendSwatch {
    width: 12px;
    height: 12px;
    border-radius: 3px;
  }

  body.page-home .kpiDash__panelLegend--bars .kpiDash__panelLegendText {
    font-size: 10.6px;
    line-height: 1.12;
    font-weight: 580;
    letter-spacing: -0.01em;
  }

  body.page-home .kpiDash__panelHeader h4 {
    font-size: 1.04rem;
    letter-spacing: -0.018em;
  }

  body.page-home .kpiDash__panelHeader p {
    padding-top: 0.08rem;
    font-size: 0.73rem;
    line-height: 1.32;
  }

  body.page-home .kpiDash__panel--bars .kpiDash__chart,
  body.page-home .kpiDash__panel--bars .kpiDash__chartFallback {
    flex: 1 1 auto;
    min-height: 352px;
    height: auto;
  }

  body.page-home .kpiDash__panel--aux .ppccr-sankey {
    min-height: var(--ppccr-sankey-min-height-desktop, 344px);
  }
}

.kpiDash__funnel,
.kpiDash__stock {
  border: 1px solid var(--kpi-border-soft);
  border-radius: var(--kpi-radius-md);
  background: var(--kpi-card);
  padding: var(--kpi-space-4);
  box-shadow: var(--kpi-shadow-card);
}

/* Congela la apariencia de estas dos secciones aunque el resto use tokens ejecutivos. */
.kpiDash__funnel[aria-label="Flujo FIT por estación"],
.kpiDash__stock {
  --kpi-blue-900: #004b8f;
  --kpi-blue-700: #1e6fbf;
  --kpi-blue-500: #3c7fc3;
  --kpi-blue-300: #88bdf2;
  --kpi-blue-100: #eaf3ff;
  --kpi-ink: #13294b;
  --kpi-muted: #4c6287;
  --kpi-border: rgba(19, 41, 75, 0.11);
  --kpi-border-soft: rgba(19, 41, 75, 0.08);
  --kpi-divider: rgba(19, 41, 75, 0.09);
  --kpi-surface: #f5f9ff;
  --kpi-card: #ffffff;
  --kpi-shadow-card: 0 6px 18px rgba(19, 41, 75, 0.06);
  --kpi-shadow-soft: 0 1px 3px rgba(19, 41, 75, 0.06),
    0 8px 22px rgba(19, 41, 75, 0.05);
  --kpi-radius-sm: 12px;
  --kpi-radius-md: 16px;
  --kpi-radius-lg: 20px;
}

.kpiDash__tableWrap {
  overflow-x: auto;
  max-width: 100%;
  -webkit-overflow-scrolling: touch;
}

.kpiDash__table {
  width: 100%;
  min-width: 760px;
  border-collapse: collapse;
  font-size: 0.84rem;
}

.kpiDash__table--avance {
  min-width: 620px;
}

.kpiDash__table--avance thead th {
  position: sticky;
  top: 0;
  z-index: 4;
  background: #f8fbff;
  box-shadow: inset 0 -1px 0 var(--kpi-border-soft);
}

.kpiDash__table thead th {
  text-align: left;
  padding: 0.65rem 0.55rem;
  font-size: 0.73rem;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: var(--kpi-muted);
  border-bottom: 1px solid var(--kpi-border);
  vertical-align: middle;
}

.kpiDash__table--flow thead th {
  white-space: nowrap;
  padding-top: 0.76rem;
  padding-bottom: 0.76rem;
  vertical-align: top;
  height: 3.25rem;
}

.kpiDash__thMeta {
  display: block;
  margin-top: 0.16rem;
  font-size: 0.62rem;
  font-weight: 400;
  line-height: 1.15;
  letter-spacing: 0.01em;
  text-transform: none;
  white-space: normal;
  color: #7c8dad;
}

.kpiDash__thLegend {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.22rem;
  white-space: nowrap;
  width: 100%;
}

.kpiDash__thLegendText {
  color: #6f82a4;
  font-weight: 500;
}

.kpiDash__thPill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.15rem;
  height: 0.88rem;
  padding: 0 0.28rem;
  border-radius: 999px;
  font-size: 0.58rem;
  font-weight: 700;
  line-height: 1;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.58);
}

.kpiDash__thPill--neg {
  color: #f2f8ff;
  background: linear-gradient(150deg, #1e66ad, #2f7ec9);
  border: 1px solid rgba(19, 86, 152, 0.64);
}

.kpiDash__thPill--pos {
  color: #245487;
  background: linear-gradient(150deg, rgba(228, 239, 252, 0.96), rgba(199, 220, 245, 0.94));
  border: 1px solid rgba(128, 169, 214, 0.62);
}

.kpiDash__table--flow thead th:nth-child(2),
.kpiDash__table--flow thead th:nth-child(3),
.kpiDash__table--flow tbody td:nth-child(2),
.kpiDash__table--flow tbody td:nth-child(3),
.kpiDash__table--flow thead th:nth-child(4),
.kpiDash__table--flow tbody td:nth-child(4),
.kpiDash__table--flow thead th:nth-child(5),
.kpiDash__table--flow tbody td:nth-child(5),
.kpiDash__table--flow thead th:nth-child(6),
.kpiDash__table--flow tbody td:nth-child(6) {
  text-align: center;
}

.kpiDash__table--flow tbody td:nth-child(2),
.kpiDash__table--flow tbody td:nth-child(3),
.kpiDash__table--flow tbody td:nth-child(4),
.kpiDash__table--flow tbody td:nth-child(5),
.kpiDash__table--flow tbody td:nth-child(6) {
  font-size: 0.84rem;
  font-weight: 500;
  font-variant-numeric: tabular-nums;
}

.kpiDash__table--avance thead th:first-child,
.kpiDash__table--avance tbody td:first-child {
  position: sticky;
  left: 0;
  z-index: 3;
  background: #ffffff;
}

.kpiDash__table--avance thead th:first-child {
  z-index: 6;
  background: #f8fbff;
}

.kpiDash__table--avance tbody tr.kpiDash__rowTotal td {
  background: rgba(234, 243, 255, 0.95);
  font-weight: 700;
}

.kpiDash__table--avance tbody tr.kpiDash__rowTotal td:first-child {
  z-index: 3;
}

.kpiDash__table--avance tbody td {
  padding: 0.42rem 0.55rem;
}

.kpiDash__table--avance thead th:not(:first-child),
.kpiDash__table--avance tbody td:not(:first-child) {
  text-align: right;
}

.kpiDash__table--avance tbody td:not(:first-child) {
  font-variant-numeric: tabular-nums;
}

.kpiDash__table tbody td {
  padding: 0.6rem 0.55rem;
  border-bottom: 1px solid var(--kpi-blue-100);
  vertical-align: top;
}

.kpiDash__table tbody tr.kpiDash__rowTotal td {
  background: var(--kpi-blue-100);
  font-weight: 600;
}

.kpiDash__table tbody tr:last-child td {
  border-bottom: 0;
}

.kpiDash__station {
  color: var(--kpi-blue-900);
  font-weight: 600;
}

.kpiDash__stage {
  display: grid;
  gap: 0.25rem;
}

.kpiDash__stageValue {
  color: var(--kpi-ink);
  font-weight: 600;
}

.kpiDash__table--avance .kpiDash__stage {
  gap: 0.18rem;
  align-items: flex-end;
}

.kpiDash__table--avance .kpiDash__stageValue {
  font-weight: 500;
  font-variant-numeric: tabular-nums;
  line-height: 1.05;
  text-align: right;
}

.kpiDash__stageMeta {
  font-size: 0.62rem;
  color: #7084a7;
  line-height: 1.1;
}

.kpiDash__table--avance .kpiDash__progress {
  height: 4px;
  width: 100%;
  background: rgba(136, 189, 242, 0.26);
}

.kpiDash__table--avance .kpiDash__progress span {
  background: linear-gradient(
    90deg,
    rgba(30, 111, 191, 0.78),
    rgba(136, 189, 242, 0.82)
  );
}

.kpiDash__progress {
  position: relative;
  height: 7px;
  border-radius: 999px;
  overflow: hidden;
  background: var(--kpi-blue-100);
}

.kpiDash__progress span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(
    90deg,
    rgba(30, 111, 191, 0.78),
    rgba(136, 189, 242, 0.92)
  );
}

.kpiDash__flowCell {
  display: inline-grid;
  grid-template-columns: 3ch minmax(4.95rem, 5.35rem);
  align-items: center;
  column-gap: 0.22rem;
  white-space: nowrap;
}

.kpiDash__flowPrimary {
  color: var(--kpi-ink);
  font-weight: 500;
  line-height: 1.12;
  width: 3ch;
  text-align: left;
  font-variant-numeric: tabular-nums;
}

.kpiDash__flowProgress {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 1.03rem;
  min-width: 4.95rem;
  border-radius: 999px;
  overflow: hidden;
  background: linear-gradient(180deg, rgba(227, 238, 251, 0.96), rgba(212, 228, 246, 0.92));
  border: 1px solid rgba(136, 173, 218, 0.45);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.85);
}

.kpiDash__flowProgress::after {
  content: "";
  position: absolute;
  inset: 1px;
  border-radius: inherit;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.25), rgba(255, 255, 255, 0));
  pointer-events: none;
}

.kpiDash__flowProgressFill {
  position: absolute;
  inset: 0 auto 0 0;
  width: 0;
  border-radius: inherit;
  background: linear-gradient(90deg, rgba(26, 96, 168, 0.96), rgba(102, 164, 230, 0.95));
  box-shadow: inset 0 -1px 0 rgba(10, 70, 135, 0.24);
}

.kpiDash__flowProgressLabel {
  position: relative;
  z-index: 1;
  font-size: 0.64rem;
  line-height: 1;
  font-weight: 700;
  color: #18456f;
  letter-spacing: 0.01em;
  font-variant-numeric: tabular-nums;
  text-shadow: 0 1px 0 rgba(255, 255, 255, 0.45);
}

.kpiDash__informCell {
  display: inline-grid;
  grid-template-columns: minmax(1.6rem, auto) minmax(4.8rem, auto);
  align-items: center;
  justify-content: center;
  gap: 0.32rem;
  white-space: nowrap;
}

.kpiDash__informTotal {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.88rem;
  height: 1.2rem;
  padding: 0 0.42rem;
  border-radius: 7px;
  color: #0f3f72;
  font-size: 0.84rem;
  font-weight: 760;
  font-variant-numeric: tabular-nums;
  border: 1px solid rgba(76, 134, 197, 0.66);
  background:
    linear-gradient(160deg, rgba(230, 242, 255, 0.98), rgba(190, 217, 246, 0.95));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.92),
    0 1px 2px rgba(22, 73, 125, 0.06);
}

.kpiDash__informDetail {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  min-width: 4.8rem;
}

.kpiDash__informSplit {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.12rem;
  width: 100%;
  padding: 0.08rem 0.1rem;
  border-radius: 999px;
  background: linear-gradient(145deg, rgba(244, 249, 255, 0.95), rgba(225, 237, 252, 0.9));
  border: 1px solid rgba(181, 204, 232, 0.58);
}

.kpiDash__informSplitSep {
  width: 1px;
  height: 0.68rem;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(127, 167, 211, 0.28), rgba(88, 136, 191, 0.45));
}

.kpiDash__informChip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.62rem;
  height: 1.03rem;
  border-radius: 999px;
  padding: 0 0.36rem;
  border: 1px solid transparent;
  font-variant-numeric: tabular-nums;
}

.kpiDash__informChip--neg {
  color: #f3f8ff;
  background: linear-gradient(145deg, #1f66ad, #2b79c1);
  border-color: rgba(24, 90, 158, 0.72);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2);
}

.kpiDash__informChip--pos {
  color: #24568d;
  background: linear-gradient(145deg, rgba(224, 237, 252, 0.96), rgba(196, 218, 244, 0.94));
  border-color: rgba(130, 171, 216, 0.72);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.78);
}

.kpiDash__informChipSign {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 0.72rem;
  height: 0.72rem;
  margin-right: 0.15rem;
  border-radius: 999px;
  font-size: 0.56rem;
  font-weight: 700;
  line-height: 1;
}

.kpiDash__informChip--neg .kpiDash__informChipSign {
  color: #f4f9ff;
  background: rgba(255, 255, 255, 0.16);
}

.kpiDash__informChip--pos .kpiDash__informChipSign {
  color: #1f4f83;
  background: rgba(255, 255, 255, 0.58);
}

.kpiDash__informChipValue {
  font-size: 0.72rem;
  font-weight: 700;
  line-height: 1;
}

.kpiDash__table--flow tbody tr.kpiDash__rowTotal td:nth-child(2),
.kpiDash__table--flow tbody tr.kpiDash__rowTotal td:nth-child(3),
.kpiDash__table--flow tbody tr.kpiDash__rowTotal td:nth-child(4),
.kpiDash__table--flow tbody tr.kpiDash__rowTotal td:nth-child(5),
.kpiDash__table--flow tbody tr.kpiDash__rowTotal td:nth-child(6),
.kpiDash__table--flow tbody tr.kpiDash__rowTotal .kpiDash__flowPrimary,
.kpiDash__table--flow tbody tr.kpiDash__rowTotal .kpiDash__informTotal,
.kpiDash__table--flow tbody tr.kpiDash__rowTotal .kpiDash__informChipValue {
  font-weight: 700;
}

.kpiDash__stockGrid {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 0.7rem;
}

.kpiDash__stockItem {
  border: 1px solid var(--kpi-border);
  border-radius: 14px;
  background: linear-gradient(150deg, #ffffff, var(--kpi-surface));
  padding: 0.74rem;
  min-width: 0;
}

.kpiDash__stockItem--total {
  background: linear-gradient(150deg, var(--kpi-blue-900), var(--kpi-blue-700));
  border-color: rgba(0, 75, 143, 0.2);
}

.kpiDash__stockItem--total .kpiDash__stockStation,
.kpiDash__stockItem--total .kpiDash__stockValue,
.kpiDash__stockItem--total .kpiDash__stockMeta {
  color: #f5f9ff;
}

.kpiDash__stockTop {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.5rem;
}

.kpiDash__stockStation {
  margin: 0;
  font-weight: 600;
  color: var(--kpi-blue-900);
}

.kpiDash__stockValue {
  margin: 0.22rem 0 0;
  font-size: 1.03rem;
  font-weight: 700;
  color: var(--kpi-ink);
}

.kpiDash__stockMeta {
  margin: 0.2rem 0 0;
  color: var(--kpi-muted);
  font-size: 0.79rem;
}

.kpiDash__badge {
  font-size: 0.7rem;
  letter-spacing: 0.02em;
  border-radius: 999px;
  padding: 0.2rem 0.52rem;
  border: 1px solid transparent;
  white-space: nowrap;
}

.kpiDash__badge--ok {
  color: var(--kpi-ok);
  background: rgba(30, 111, 191, 0.1);
  border-color: rgba(30, 111, 191, 0.24);
}

.kpiDash__badge--warn {
  color: var(--kpi-warn);
  background: rgba(60, 127, 195, 0.12);
  border-color: rgba(60, 127, 195, 0.25);
}

.kpiDash__badge--critical {
  color: var(--kpi-critical);
  background: rgba(136, 189, 242, 0.3);
  border-color: rgba(0, 75, 143, 0.25);
}

@media (min-width: 1121px) {
  .kpiDash__shell {
    grid-template-columns: repeat(12, minmax(0, 1fr));
  }

  .kpiDash__reportHeader,
  .kpiDash__exec,
  .kpiDash__charts,
  .kpiDash__funnel--avance,
  .kpiDash__funnel[aria-label="Flujo FIT por estación"],
  .kpiDash__stock {
    grid-column: 1 / -1;
  }

  .kpiDash__exec {
    grid-template-columns: repeat(12, minmax(0, 1fr));
  }

  .kpiDash__exec > .kpiDash__summary {
    grid-column: span 6;
  }

  .kpiDash__exec > .kpiDash__fitFlow {
    grid-column: span 6;
  }

  .kpiDash__charts {
    grid-template-columns: repeat(12, minmax(0, 1fr));
  }

  .kpiDash__panel--bars {
    grid-column: span 6;
    padding-inline: 0.84rem;
  }

  .kpiDash__panel--aux {
    grid-column: span 6;
    padding-inline: 0.84rem;
  }

  .kpiDash__panel--aux .kpiDash__chart,
  .kpiDash__panel--aux .kpiDash__chartFallback {
    min-height: 304px;
  }
}

@media (max-width: 1120px) {
  .kpiDash__cards {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .kpiDash__exec {
    grid-template-columns: 1fr;
  }

  .kpiDash__reportHeader {
    flex-direction: column;
    align-items: flex-start;
  }

  .kpiDash__reportHeadMeta {
    width: 100%;
    justify-items: start;
  }

  .kpiDash__summaryReasons {
    grid-template-columns: 1fr;
  }

  .kpiDash__summary.kpiDash__execPanel {
    row-gap: 0.22rem;
  }

  .kpiDash__summaryCard {
    min-height: 0;
    gap: var(--kpi-space-3);
  }

  .kpiDash__summaryBadge {
    min-height: 64px;
  }

  .kpiDash__fitFlowBody {
    grid-template-columns: 1fr;
  }

  .kpiDash__fitFlowSteps {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .kpiDash__fitFlowSplit {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .kpiDash__fitStepArrow {
    display: none;
  }

  .kpiDash__fitFlowHint {
    justify-self: start;
  }

  .kpiDash__fitOutcomeLegend {
    grid-template-columns: 1fr;
  }

  .kpiDash__fitOutcomeItem + .kpiDash__fitOutcomeItem {
    padding-left: 0;
  }

  .kpiDash__fitOutcomeItem + .kpiDash__fitOutcomeItem::before {
    display: none;
  }

  .kpiDash__trkBody {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: stretch;
    gap: 0.5rem;
  }

  .kpiDash__trkGaugeWrap {
    justify-items: end;
  }

  .kpiDash__trkGauge {
    width: 84px;
    height: 84px;
  }

  .kpiDash__charts {
    grid-template-columns: 1fr;
  }

  .kpiDash__stockGrid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .kpiDash__loadingShell .kpiDash__exec,
  .kpiDash__loadingShell .kpiDash__charts {
    grid-template-columns: 1fr;
  }

  .kpiDash__loadingShell .kpiDash__stockGrid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 621px) and (max-width: 1024px) {
  .kpiDash__panel,
  .kpiDash__execPanel,
  .kpiDash__fitFlow,
  .kpiDash__funnel,
  .kpiDash__stock,
  .kpiDash__reportHeader {
    padding: 0.96rem;
  }

  .kpiDash__panel--bars .kpiDash__chart,
  .kpiDash__panel--bars .kpiDash__chartFallback {
    min-height: clamp(290px, 36vw, 360px);
  }

  .kpiDash__panel--aux .ppccr-sankey {
    min-height: clamp(260px, 34vw, 330px);
  }
}

@media (max-width: 620px) {
  .kpiDash__cards {
    grid-template-columns: 1fr;
  }

  .kpiDash__panel,
  .kpiDash__execPanel,
  .kpiDash__fitFlow,
  .kpiDash__funnel,
  .kpiDash__stock,
  .kpiDash__reportHeader {
    padding: 0.82rem;
  }

  .kpiDash__summaryCard {
    padding: 0;
  }

  .kpiDash__summaryTop {
    justify-content: flex-end;
    align-items: baseline;
  }

  .kpiDash__summarySplit,
  .kpiDash__summaryReasons {
    grid-template-columns: 1fr;
  }

  .kpiDash__fitFlowSteps {
    grid-template-columns: 1fr;
  }

  .kpiDash__fitFlowSplit {
    grid-template-columns: 1fr;
  }

  .kpiDash__fitStepLabel {
    min-height: 0;
  }

  .kpiDash__fitStepRow {
    gap: 0.42rem;
  }

  .kpiDash__fitOutcomeMetric {
    gap: 0.14rem;
  }

  .kpiDash__fitOutcomeSegmentTip {
    max-width: min(220px, calc(100vw - 2rem));
    white-space: normal;
  }

  .kpiDash__trkGaugeTip {
    max-width: min(180px, calc(100vw - 2rem));
  }

  .kpiDash__trkBody {
    padding: 0.7rem;
  }

  .kpiDash__trkFactLine {
    font-size: 0.64rem;
  }

  .kpiDash__reportHeadMain h3 {
    font-size: 1rem;
  }

  .kpiDash__reportHeadMain p,
  .kpiDash__panelHeader p {
    font-size: 0.72rem;
  }

  .kpiDash__panelHeader h4 {
    font-size: 0.94rem;
  }

  .kpiDash__reportActions {
    width: 100%;
  }

  .kpiDash__reportBtn {
    flex: 1;
  }

  .kpiDash__chart,
  .kpiDash__chartFallback {
    min-height: clamp(260px, 52vh, 340px);
  }

  .ppccr-sankey {
    min-height: clamp(245px, 50vh, 330px);
  }

  .kpiDash__stockGrid {
    grid-template-columns: 1fr;
  }

  .kpiDash__loadingShell .kpiDash__stockGrid,
  .kpiDash__loadingShell .kpiDash__loadingList {
    grid-template-columns: 1fr;
  }

  .kpiDash__loadingPanel {
    padding: 0.82rem;
  }
}

@page {
  size: A4 portrait;
  margin: 10mm;
}

@media print {
  html,
  body {
    margin: 0 !important;
    padding: 0 !important;
    background: #ffffff !important;
  }

  body > footer,
  body > main > :not(#kpis),
  .mobile-fixed-dock,
  .back-to-top,
  .modal {
    display: none !important;
  }

  body > header {
    display: block !important;
    position: static !important;
    box-shadow: none !important;
  }

  body > header .site-nav {
    display: none !important;
  }

  body > header .logo-strip {
    margin-bottom: 6mm !important;
  }

  #kpis {
    margin: 0 !important;
    padding: 0 !important;
  }

  #kpis .container {
    max-width: none !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  #kpis .section-header {
    display: none !important;
  }

  #kpi-dashboard-ppccr {
    margin: 0 !important;
  }

  [data-kpi-report-root] {
    background: #ffffff !important;
    color: #0f172a !important;
  }

  .kpiDash__reportActions {
    display: none !important;
  }

  .kpiDash__reportExportedAt {
    display: block !important;
  }

  .kpiDash__reportUpdated,
  .kpiDash__reportStatus {
    display: none !important;
  }

  .kpiDash__reportHeader,
  .kpiDash__execPanel,
  .kpiDash__panel,
  .kpiDash__funnel,
  .kpiDash__stock,
  .kpiDash__tableWrap {
    break-inside: avoid;
    page-break-inside: avoid;
    box-shadow: none !important;
    background: #ffffff !important;
  }

  .kpiDash__charts {
    break-before: page;
    page-break-before: always;
  }

  .kpiDash__funnel[aria-label="Flujo FIT por estación"] {
    break-before: page;
    page-break-before: always;
  }

  .kpiDash__tableWrap {
    overflow: visible !important;
  }

  .kpiDash__table {
    min-width: 0 !important;
    width: 100% !important;
  }

  .kpiDash__table thead {
    display: table-header-group;
  }

  .kpiDash__table tr {
    break-inside: avoid;
    page-break-inside: avoid;
  }

  .kpiDash__chart,
  .kpiDash__chartFallback,
  .ppccr-sankey {
    break-inside: avoid;
    page-break-inside: avoid;
  }
}
