/* ── Performance bar (dashboard) ─────────────────────────────────────────── */
.perf-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 16px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  margin: 8px 0;
  font-size: 13px;
  cursor: pointer;
  transition: border-color .2s;
  flex-wrap: wrap;
}
.perf-bar:hover { border-color: var(--accent); }
.perf-bar-icon  { font-size: 15px; }
.perf-bar-main  { font-weight: 500; }
.perf-bar-sep   { color: var(--text-muted); }
.perf-bar-item  { color: var(--text-muted); }
.perf-bar-item strong { color: var(--text); }
.perf-bar-caret { margin-left: auto; color: var(--accent); font-size: 12px; }
.pv-pos { color: var(--green); }
.pv-neg { color: var(--red);   }

/* ── Performance page layout ─────────────────────────────────────────────── */
.perf-period-bar { display: flex; gap: 6px; margin-bottom: 20px; flex-wrap: wrap; }
.perf-period-btn {
  padding: 6px 14px;
  border-radius: 20px;
  border: 1px solid var(--border);
  background: var(--bg-card);
  color: var(--text-muted);
  cursor: pointer;
  font-size: 13px;
  text-decoration: none;
  transition: all .15s;
}
.perf-period-btn:hover, .perf-period-btn.active {
  border-color: var(--accent); color: var(--text); background: var(--accent-dim);
}

/* hero cards */
.perf-hero {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 12px;
  margin-bottom: 24px;
}
.perf-hero-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 16px 18px;
}
.perf-hero-label {
  font-size: 11px; color: var(--text-muted);
  text-transform: uppercase; letter-spacing: .06em; margin-bottom: 6px;
}
.perf-hero-value  { font-size: 26px; font-weight: 700; line-height: 1.1; }
.perf-hero-sub    { font-size: 11px; color: var(--text-muted); margin-top: 4px; }
.perf-hero-card.good    .perf-hero-value { color: var(--green); }
.perf-hero-card.bad     .perf-hero-value { color: var(--red);   }
.perf-hero-card.neutral .perf-hero-value { color: var(--text);  }

/* chart section */
.perf-chart-wrap {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 20px;
  margin-bottom: 24px;
}
.perf-chart-title {
  font-size: 13px; font-weight: 600; color: var(--text-muted);
  text-transform: uppercase; letter-spacing: .05em; margin-bottom: 14px;
}
#benchmarkChart { width: 100%; height: 260px; display: block; }
.perf-chart-legend {
  display: flex; gap: 20px; margin-top: 12px; flex-wrap: wrap; font-size: 12px;
}
.perf-legend-item { display: flex; align-items: center; gap: 6px; }
.perf-legend-dot  { width: 10px; height: 10px; border-radius: 50%; display: inline-block; }

/* 3-col metrics */
.perf-metrics-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-bottom: 24px;
}
.perf-metrics-card {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 18px;
}
.perf-metrics-card h3 {
  font-size: 11px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .07em; color: var(--text-muted);
  margin-bottom: 14px; border-bottom: 1px solid var(--border); padding-bottom: 8px;
}
.perf-metric-row {
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 4px 0; font-size: 13px; border-bottom: 1px solid rgba(255,255,255,.03);
}
.perf-metric-row:last-child { border-bottom: none; }
.perf-metric-label { color: var(--text-muted); }
.perf-metric-value { font-weight: 600; font-variant-numeric: tabular-nums; }
.perf-metric-sub   { font-size: 11px; color: var(--text-muted); margin-top: 1px; }

/* heatmap */
.perf-heatmap-wrap {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 20px; margin-bottom: 24px; overflow-x: auto;
}
.perf-heatmap-title {
  font-size: 13px; font-weight: 600; color: var(--text-muted);
  text-transform: uppercase; letter-spacing: .05em; margin-bottom: 14px;
}
.heatmap-table { border-collapse: collapse; font-size: 12px; min-width: 700px; width: 100%; }
.heatmap-table th {
  padding: 4px 8px; color: var(--text-muted); font-weight: 500; text-align: center;
}
.heatmap-table td { padding: 5px 8px; text-align: center; border-radius: 4px; min-width: 70px; }
.hm-year { font-weight: 600; color: var(--text-muted); text-align: left; padding-right: 12px; }
.hm-ret  { font-size: 12px; font-weight: 600; }
.hm-spy  { font-size: 10px; color: var(--text-muted); }
.hm-dg   { background: rgba(34,197,94,.45);  color: var(--green); }
.hm-g    { background: rgba(34,197,94,.25);  color: #86efac; }
.hm-lg   { background: rgba(34,197,94,.1);   color: #bbf7d0; }
.hm-lr   { background: rgba(239,68,68,.1);   color: #fca5a5; }
.hm-r    { background: rgba(239,68,68,.25);  color: #f87171; }
.hm-dr   { background: rgba(239,68,68,.45);  color: var(--red); }
.hm-fut  { background: rgba(148,163,184,.05); color: var(--text-muted); }

/* alpha bar chart */
.perf-alpha-wrap {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 20px; margin-bottom: 24px;
}
#alphaChart { width: 100%; height: 150px; display: block; }
.perf-alpha-stats {
  display: flex; gap: 24px; margin-top: 12px;
  font-size: 12px; flex-wrap: wrap; color: var(--text-muted);
}
.perf-alpha-stats strong { color: var(--text); }

/* benchmark comparison table */
.perf-bm-table-wrap {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 20px; margin-bottom: 24px; overflow-x: auto;
}
.perf-bm-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.perf-bm-table th {
  padding: 8px 12px; text-align: right;
  font-size: 11px; text-transform: uppercase; color: var(--text-muted);
  border-bottom: 1px solid var(--border);
}
.perf-bm-table th:first-child { text-align: left; }
.perf-bm-table td {
  padding: 8px 12px; text-align: right;
  border-bottom: 1px solid rgba(255,255,255,.03);
}
.perf-bm-table td:first-child { text-align: left; font-weight: 500; }
.perf-bm-table tr:last-child td { border-bottom: none; }
.alpha-pos { color: var(--green); font-weight: 600; }
.alpha-neg { color: var(--red);   font-weight: 600; }

/* win rate / R:R */
.perf-rr-wrap {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 20px; margin-bottom: 24px;
}
.perf-rr-title {
  font-size: 13px; font-weight: 600; color: var(--text-muted);
  text-transform: uppercase; letter-spacing: .05em; margin-bottom: 14px;
}
.perf-rr-bars     { display: flex; flex-direction: column; gap: 10px; }
.perf-rr-bar-row  { display: flex; align-items: center; gap: 10px; font-size: 12px; }
.perf-rr-bar-label{ width: 90px; color: var(--text-muted); }
.perf-rr-bar-track{ flex: 1; height: 10px; background: rgba(255,255,255,.06); border-radius: 5px; overflow: hidden; }
.perf-rr-bar-fill { height: 100%; border-radius: 5px; transition: width .4s; }
.perf-rr-bar-val  { width: 50px; text-align: right; font-weight: 600; }
.perf-rr-ev  { margin-top: 14px; font-size: 13px; color: var(--text-muted); }
.perf-rr-ev strong { color: var(--text); }
.perf-rr-be  { margin-top: 8px; font-size: 12px; color: var(--text-muted); }

/* best / worst trades */
.perf-trades-wrap {
  display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 24px;
}
.perf-trades-card {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 18px;
}
.perf-trades-card h3 {
  font-size: 13px; font-weight: 700; margin-bottom: 12px;
  border-bottom: 1px solid var(--border); padding-bottom: 8px;
}
.perf-trade-row {
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 6px 0; font-size: 13px; border-bottom: 1px solid rgba(255,255,255,.03);
}
.perf-trade-row:last-child { border-bottom: none; }
.perf-trade-ticker  { font-weight: 700; font-family: monospace; }
.perf-trade-ret     { font-weight: 600; }
.perf-trade-sub     { font-size: 11px; color: var(--text-muted); }
.perf-trade-insight {
  margin-top: 12px; padding: 8px 10px;
  background: rgba(99,102,241,.08); border-radius: 6px;
  font-size: 12px; color: var(--text-muted);
}

/* profile table */
.perf-profile-wrap {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 20px; margin-bottom: 24px; overflow-x: auto;
}
.perf-profile-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.perf-profile-table th {
  padding: 6px 12px; text-align: right;
  font-size: 11px; text-transform: uppercase; color: var(--text-muted);
  border-bottom: 1px solid var(--border);
}
.perf-profile-table th:first-child { text-align: left; }
.perf-profile-table td { padding: 8px 12px; text-align: right; border-bottom: 1px solid rgba(255,255,255,.03); }
.perf-profile-table td:first-child { text-align: left; font-weight: 600; text-transform: capitalize; }

/* AI coach card */
.perf-coach-wrap {
  background: var(--bg-card); border: 1px solid var(--border);
  border-left: 3px solid var(--accent); border-radius: var(--radius);
  padding: 20px; margin-bottom: 24px;
}
.perf-coach-title    { font-size: 14px; font-weight: 700; margin-bottom: 14px; }
.perf-coach-headline { font-size: 13px; font-weight: 500; margin-bottom: 14px; color: var(--text-muted); }
.perf-coach-rows     { display: flex; flex-direction: column; gap: 8px; }
.perf-coach-row      { font-size: 13px; }
.perf-coach-row .coach-label { color: var(--text-muted); margin-right: 6px; }
.perf-coach-score {
  display: inline-block; padding: 1px 8px; border-radius: 10px;
  font-size: 11px; font-weight: 700;
}
.perf-coach-score.high   { background: rgba(34,197,94,.15);  color: var(--green); }
.perf-coach-score.medium { background: rgba(245,158,11,.15); color: var(--yellow); }
.perf-coach-score.low    { background: rgba(239,68,68,.15);  color: var(--red); }
.perf-coach-edge-yes { color: var(--green); font-weight: 700; }
.perf-coach-edge-no  { color: var(--red);   font-weight: 700; }

/* real vs phantom comparison */
.perf-cmp-wrap {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 20px; margin-bottom: 24px;
}
.perf-cmp-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.perf-cmp-table th {
  padding: 6px 12px; text-align: right;
  font-size: 11px; text-transform: uppercase; color: var(--text-muted);
  border-bottom: 1px solid var(--border);
}
.perf-cmp-table th:first-child { text-align: left; }
.perf-cmp-table td {
  padding: 8px 12px; text-align: right; border-bottom: 1px solid rgba(255,255,255,.03);
}
.perf-cmp-table td:first-child { text-align: left; color: var(--text-muted); }

/* drawdown chart */
.perf-dd-wrap {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 20px; margin-bottom: 24px;
}
#drawdownChart { width: 100%; height: 160px; display: block; }
.perf-dd-stats {
  display: flex; gap: 24px; margin-top: 12px;
  font-size: 12px; flex-wrap: wrap; color: var(--text-muted);
}
.perf-dd-stats strong { color: var(--text); }

.perf-page-title {
  font-size: 22px; font-weight: 700; margin-bottom: 4px;
}
.perf-page-sub {
  font-size: 13px; color: var(--text-muted); margin-bottom: 20px;
}
.perf-section-title {
  font-size: 13px; font-weight: 600; color: var(--text-muted);
  text-transform: uppercase; letter-spacing: .05em; margin-bottom: 14px;
}

@media (max-width: 900px) {
  .perf-hero         { grid-template-columns: repeat(2,1fr); }
  .perf-metrics-grid { grid-template-columns: 1fr; }
  .perf-trades-wrap  { grid-template-columns: 1fr; }
}
