/* ================================================================
   消费轨迹系统 — stats.css
   统计页：概览卡片、图表容器、排行榜、时段选择器
   ================================================================ */

/* -----------------------------------------------------------------
   统计页容器
   ----------------------------------------------------------------- */
.stats-container {
  padding: var(--space-lg);
  flex: 1;
  overflow-y: auto;
}

/* -----------------------------------------------------------------
   时段选择器
   ----------------------------------------------------------------- */
.stats-period {
  display: flex;
  gap: var(--space-sm);
  margin-bottom: var(--space-lg);
}

/* -----------------------------------------------------------------
   概览卡片行（1×3）
   ----------------------------------------------------------------- */
.stats-overview {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-sm);
  margin-bottom: var(--space-xl);
}

.stats-card {
  background: var(--color-surface);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  text-align: center;
  box-shadow: var(--shadow-sm);
}

.stats-card__label {
  font-size: var(--font-size-xs);
  color: var(--color-text-tertiary);
  margin-bottom: 4px;
}

.stats-card__value {
  font-family: var(--font-mono);
  font-size: var(--font-size-xl);
  font-weight: 700;
  color: var(--color-text-primary);
}

.stats-card__unit {
  font-size: var(--font-size-xs);
  color: var(--color-text-secondary);
  font-weight: 400;
  margin-left: 2px;
}

/* -----------------------------------------------------------------
   图表区块
   ----------------------------------------------------------------- */
.stats-chart-section {
  margin-bottom: var(--space-xl);
}

.stats-chart-section__title {
  font-size: var(--font-size-md);
  font-weight: 600;
  margin-bottom: var(--space-md);
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.stats-chart-section__title::before {
  content: '';
  width: 4px;
  height: 16px;
  background: var(--color-primary);
  border-radius: 2px;
}

.stats-chart-wrapper {
  background: var(--color-surface);
  border-radius: var(--radius-md);
  padding: var(--space-lg);
  box-shadow: var(--shadow-sm);
  min-height: 100px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.stats-chart-wrapper canvas {
  max-width: 280px;
  width: 100%;
}

/* -----------------------------------------------------------------
   HTML 手绘图例（替代 Chart.js 内置图例，保证圆点为正圆）
   ----------------------------------------------------------------- */
.stats-chart-legend {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 6px 14px;
  margin-top: 8px;
  width: 100%;
}

.stats-chart-legend__item {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: var(--font-size-xs);
  color: var(--color-text-secondary);
}

.stats-chart-legend__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}

.stats-chart-legend__text {
  white-space: nowrap;
}

/* -----------------------------------------------------------------
   地点排行（横向进度条）
   ----------------------------------------------------------------- */
.stats-ranking-list {
  background: var(--color-surface);
  border-radius: var(--radius-md);
  padding: var(--space-md) var(--space-lg);
  box-shadow: var(--shadow-sm);
}

.stats-ranking-item {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-sm) 0;
  border-bottom: 1px solid var(--color-divider);
}

.stats-ranking-item:last-child {
  border-bottom: none;
}

.stats-ranking-item__rank {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--color-divider);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--font-size-xs);
  font-weight: 700;
  flex-shrink: 0;
  color: var(--color-text-secondary);
}

.stats-ranking-item:nth-child(1) .stats-ranking-item__rank {
  background: #FFD700;
  color: #fff;
}
.stats-ranking-item:nth-child(2) .stats-ranking-item__rank {
  background: #C0C0C0;
  color: #fff;
}
.stats-ranking-item:nth-child(3) .stats-ranking-item__rank {
  background: #CD7F32;
  color: #fff;
}

.stats-ranking-item__body {
  flex: 1;
  min-width: 0;
}

.stats-ranking-item__header {
  display: flex;
  justify-content: space-between;
  margin-bottom: 4px;
}

.stats-ranking-item__name {
  font-size: var(--font-size-sm);
  font-weight: 500;
}

.stats-ranking-item__amount {
  font-family: var(--font-mono);
  font-size: var(--font-size-sm);
  font-weight: 600;
  color: var(--color-text-primary);
}

.stats-ranking-item__bar-track {
  height: 6px;
  background: var(--color-divider);
  border-radius: 3px;
  overflow: hidden;
}

.stats-ranking-item__bar-fill {
  height: 100%;
  background: var(--color-primary);
  border-radius: 3px;
  transition: width var(--transition-normal);
}

/* -----------------------------------------------------------------
   CSS 降级图表（Chart.js 加载失败时显示）
   ----------------------------------------------------------------- */
.stats-fallback {
  width: 100%;
}

.stats-fallback__bar {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  margin-bottom: var(--space-sm);
}

.stats-fallback__label {
  width: 80px;
  font-size: var(--font-size-xs);
  text-align: right;
  flex-shrink: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.stats-fallback__track {
  flex: 1;
  height: 20px;
  background: var(--color-divider);
  border-radius: var(--radius-sm);
  overflow: hidden;
  position: relative;
}

.stats-fallback__fill {
  height: 100%;
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  padding-left: 8px;
  font-size: 11px;
  color: #fff;
  font-weight: 500;
  min-width: 0;
  transition: width var(--transition-normal);
}

.stats-fallback__fill--c0 { background: #5470C6; }
.stats-fallback__fill--c1 { background: #91CC75; }
.stats-fallback__fill--c2 { background: #FAC858; }
.stats-fallback__fill--c3 { background: #EE6666; }
.stats-fallback__fill--c4 { background: #73C0DE; }
.stats-fallback__fill--c5 { background: #FC8452; }
.stats-fallback__fill--c6 { background: #9A60B4; }
.stats-fallback__fill--c7 { background: #EA7CCC; }

.stats-fallback__track--empty {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-tertiary);
  font-size: var(--font-size-sm);
}

/* -----------------------------------------------------------------
   无数据空状态
   ----------------------------------------------------------------- */
.stats-empty {
  text-align: center;
  padding: var(--space-xxxl) var(--space-xl);
  color: var(--color-text-tertiary);
}

.stats-empty__icon {
  font-size: 48px;
  margin-bottom: var(--space-md);
}

.stats-empty__text {
  font-size: var(--font-size-md);
  margin-bottom: var(--space-sm);
  color: var(--color-text-secondary);
}

.stats-empty__hint {
  font-size: var(--font-size-sm);
}
