/* Card title */
.card-title {
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--text-muted);
  margin-bottom: 12px;
}
.section-title { font-size: 16px; font-weight: 700; color: var(--text-primary); margin-bottom: 16px; }

/* KPI Card */
.kpi { display: flex; flex-direction: column; gap: 4px; }
.kpi-value {
  font-size: 28px;
  font-weight: 800;
  letter-spacing: -.5px;
  font-variant-numeric: tabular-nums;
}
.kpi-glow {
  text-shadow: 0 0 20px currentColor;
}
.kpi-delta {
  font-size: 12px;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: 3px;
  padding: 2px 8px;
  border-radius: 6px;
  font-variant-numeric: tabular-nums;
}
.kpi-delta.up { color: var(--accent-success); background: var(--green-bg); }
.kpi-delta.down { color: var(--accent-danger); background: var(--red-bg); }
.kpi-sparkline { height: 32px; margin-top: 8px; }
.kpi-context { font-size: 11px; color: var(--text-muted); margin-top: 4px; }

/* Badge */
.badge { display: inline-block; padding: 2px 8px; border-radius: 6px; font-size: 11px; font-weight: 600; }
.badge-error { background: var(--red-bg); color: var(--accent-danger); }
.badge-warning { background: var(--amber-bg); color: var(--accent-warning); }
.badge-info { background: var(--accent-bg); color: var(--accent-primary-light); }
.badge-good { background: var(--green-bg); color: var(--accent-success); }

/* Button */
.btn {
  background: var(--accent-primary);
  color: #fff;
  border: none;
  padding: 8px 16px;
  border-radius: var(--radius-sm);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: var(--transition);
  font-family: inherit;
}
.btn:hover { background: var(--accent-primary-light); }
.btn-outline { background: transparent; border: 1px solid var(--glass-border); color: var(--text-secondary); }
.btn-outline:hover { border-color: var(--accent-primary); color: var(--accent-primary); }

/* Table */
.data-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.data-table th {
  text-align: left;
  padding: 10px 12px;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--text-muted);
  border-bottom: 1px solid var(--glass-border);
  cursor: pointer;
  user-select: none;
  white-space: nowrap;
}
.data-table th:hover { color: var(--text-primary); }
.data-table th.sort-asc::after { content: ' \2191'; }
.data-table th.sort-desc::after { content: ' \2193'; }
.data-table td { padding: 10px 12px; border-bottom: 1px solid var(--glass-border); color: var(--text-secondary); white-space: nowrap; font-variant-numeric: tabular-nums; }
.data-table tr:last-child td { border-bottom: none; }
.data-table tr:hover td { background: rgba(99,102,241,.06); }
.table-scroll { overflow-x: auto; }

/* Gauge */
.gauge-wrap { display: flex; flex-direction: column; align-items: center; gap: 8px; }
.gauge-svg { width: 140px; height: 80px; }
.gauge-label { font-size: 12px; color: var(--text-muted); text-transform: uppercase; letter-spacing: .5px; font-weight: 600; }
.gauge-value { font-size: 32px; font-weight: 800; font-variant-numeric: tabular-nums; }

/* Variant row */
.variant-row { display: flex; align-items: center; gap: 12px; padding: 8px 0; border-bottom: 1px solid var(--glass-border); }
.variant-row:last-child { border-bottom: none; }
.variant-name { font-size: 13px; font-weight: 600; min-width: 100px; }
.variant-bar-bg { flex: 1; height: 24px; background: rgba(255,255,255,0.04); border-radius: 6px; overflow: hidden; position: relative; }
.variant-bar { height: 100%; border-radius: 6px; transition: width .8s ease; }
.variant-rate { font-size: 13px; font-weight: 700; min-width: 60px; text-align: right; font-variant-numeric: tabular-nums; }

/* Funnel */
.funnel-step { display: flex; align-items: center; gap: 12px; padding: 10px 0; }
.funnel-label { min-width: 120px; font-size: 13px; font-weight: 600; }
.funnel-bar-bg { flex: 1; height: 32px; background: rgba(255,255,255,0.04); border-radius: 8px; overflow: hidden; position: relative; }
.funnel-bar { height: 100%; border-radius: 8px; transition: width 1s ease; display: flex; align-items: center; padding-left: 10px; font-size: 12px; font-weight: 600; color: #fff; font-variant-numeric: tabular-nums; }
.funnel-meta { min-width: 160px; text-align: right; font-size: 12px; color: var(--text-muted); }

/* Empty state */
.empty-state { text-align: center; padding: 60px 20px; }
.empty-state .icon { font-size: 48px; margin-bottom: 12px; opacity: .4; }
.empty-state h3 { font-size: 18px; font-weight: 700; margin-bottom: 8px; }
.empty-state p { font-size: 14px; color: var(--text-muted); }

/* CWV card */
.cwv-card { text-align: center; }
.cwv-value { font-size: 36px; font-weight: 800; font-variant-numeric: tabular-nums; }
.cwv-p75 { font-size: 12px; color: var(--text-muted); margin: 4px 0 8px; }

/* Exclusion patterns */
.pattern-list { list-style: none; }
.pattern-list li {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 12px;
  border-bottom: 1px solid var(--glass-border);
  font-family: 'SF Mono', 'Fira Code', monospace;
  font-size: 13px;
  color: var(--text-secondary);
}
.pattern-list li:last-child { border-bottom: none; }
.pattern-remove { background: none; border: none; color: var(--accent-danger); cursor: pointer; font-size: 16px; padding: 4px 8px; border-radius: 6px; }
.pattern-remove:hover { background: var(--red-bg); }
.pattern-input-row { display: flex; gap: 8px; margin-bottom: 16px; }
.pattern-input-row input {
  flex: 1;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  color: var(--text-primary);
  padding: 8px 12px;
  border-radius: var(--radius-sm);
  font-family: 'SF Mono', 'Fira Code', monospace;
  font-size: 13px;
}

/* Heatmap */
.form-abandon-highlight { background: var(--red-bg) !important; }
