/* ============== Trade Ideas page ============== */

.scan-banner {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-5);
  padding: var(--space-4) var(--space-5);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  margin: var(--space-5) 0;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
}
.scan-banner > div { display: flex; flex-direction: column; gap: 2px; }
.scan-banner .label { color: var(--color-text-dim); text-transform: uppercase; letter-spacing: 0.08em; }
.scan-banner .value { color: var(--color-text); font-size: var(--text-sm); }
.scan-banner .value.live { color: var(--color-accent); }

.spot-drift { font-size: var(--text-sm); color: var(--color-text-muted); }
.spot-drift.ok { color: var(--color-call); }
.spot-drift.warn { color: var(--color-put); }

.chapter-ideas { padding: var(--space-7) 0; }

/* ---------- Filters ---------- */

.filters {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4) var(--space-6);
  margin-bottom: var(--space-6);
  padding-bottom: var(--space-5);
  border-bottom: 1px solid var(--color-border);
}
.filter-group { display: flex; flex-direction: column; gap: var(--space-2); min-width: 0; }
.filter-label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-text-dim);
}
.chip-row { display: flex; flex-wrap: wrap; gap: var(--space-2); }
.chip-row button {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  color: var(--color-text-muted);
  font: inherit;
  font-size: var(--text-xs);
  padding: 6px 10px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-family: var(--font-mono);
  letter-spacing: 0.03em;
  transition: background var(--duration-fast), color var(--duration-fast), border-color var(--duration-fast);
}
.chip-row button:hover { background: var(--color-surface-hover); color: var(--color-text); }
.chip-row button.is-active {
  background: var(--color-accent-soft);
  color: var(--color-accent);
  border-color: var(--color-accent);
}

/* ---------- Layout split ---------- */

.ideas-layout {
  display: grid;
  grid-template-columns: minmax(320px, 380px) 1fr;
  gap: var(--space-5);
  align-items: start;
}

@media (max-width: 1024px) {
  .ideas-layout { grid-template-columns: 1fr; }
  .ideas-pane { order: 2; }
  .detail-pane { order: 1; }
}

.ideas-pane {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  max-height: calc(100vh - 6rem);
  position: sticky;
  top: 5rem;
}
.ideas-count-bar {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: 0.08em;
  color: var(--color-text-dim);
  text-transform: uppercase;
}
.ideas-list {
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding-right: var(--space-1);
}

/* ---------- Idea card ---------- */

.idea-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-4);
  cursor: pointer;
  font: inherit;
  text-align: left;
  color: var(--color-text);
  transition: background var(--duration-fast), border-color var(--duration-fast), transform var(--duration-fast);
}
.idea-card:hover { background: var(--color-surface-hover); border-color: var(--color-border-strong); }
.idea-card.is-selected {
  border-color: var(--color-accent);
  background: var(--color-accent-soft);
  box-shadow: var(--shadow-glow);
}

.idea-card-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.idea-strategy {
  font-family: var(--font-serif);
  font-size: var(--text-base);
  font-weight: 600;
}
.idea-meta {
  display: flex;
  gap: var(--space-3);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.05em;
  color: var(--color-text-muted);
  text-transform: uppercase;
}
.idea-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-2);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
}
.idea-stats > div { display: flex; flex-direction: column; }
.idea-stats .dim { color: var(--color-text-dim); font-size: 9px; letter-spacing: 0.08em; text-transform: uppercase; }
.idea-stats strong { color: var(--color-text); font-weight: 500; }
.idea-stats .profit { color: var(--color-call); }
.idea-stats .loss { color: var(--color-put); }

.cost-credit { color: var(--color-call); }
.cost-debit { color: var(--color-yellow); }

/* ---------- Bias badge ---------- */

.bias-badge {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.1em;
  padding: 2px 6px;
  border-radius: 3px;
  text-transform: uppercase;
  font-weight: 600;
}
.bias-neutral { background: oklch(78% 0.13 215 / 0.15); color: var(--color-cyan); }
.bias-bullish { background: oklch(72% 0.18 145 / 0.15); color: var(--color-call); }
.bias-bearish { background: oklch(65% 0.22 25 / 0.15); color: var(--color-put); }
.bias-volatile { background: oklch(72% 0.17 295 / 0.15); color: var(--color-violet); }

/* ---------- Detail pane ---------- */

.detail-pane { display: flex; flex-direction: column; gap: var(--space-4); }

.detail-header {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
}
.detail-header h2 { margin: 0; font-size: var(--text-2xl); }
.rank-tag {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--color-text-dim);
  margin-left: var(--space-2);
}

.detail-summary {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  letter-spacing: 0.02em;
}

.detail-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-4) var(--space-5);
}
.detail-card h4 {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-text-dim);
  margin: 0 0 var(--space-3);
}

.detail-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--space-4);
}

.metrics-block { display: flex; flex-direction: column; gap: var(--space-2); }
.metric {
  display: flex;
  justify-content: space-between;
  padding: var(--space-2) 0;
  border-bottom: 1px dashed var(--color-border);
  font-family: var(--font-mono);
  font-size: var(--text-sm);
}
.metric:last-child { border-bottom: none; }
.metric .label { color: var(--color-text-muted); }
.metric .value { color: var(--color-text); }
.metric .value.profit { color: var(--color-call); }
.metric .value.loss { color: var(--color-put); }

/* Legs table */
.legs-table {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
}
.legs-table th {
  text-align: left;
  padding: var(--space-2) var(--space-3);
  color: var(--color-text-dim);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  border-bottom: 1px solid var(--color-border);
}
.legs-table td {
  padding: var(--space-2) var(--space-3);
  border-bottom: 1px solid var(--color-border);
}
.legs-table tr:last-child td { border-bottom: none; }
.legs-table .call { color: var(--color-call); }
.legs-table .put  { color: var(--color-put); }
.action-buy { color: var(--color-call); font-weight: 600; }
.action-sell { color: var(--color-put); font-weight: 600; }

#detail-payoff svg { width: 100%; max-width: 760px; height: auto; display: block; }

/* Explainer */
#detail-explainer h3 {
  font-family: var(--font-serif);
  margin: 0 0 var(--space-3);
  font-size: var(--text-xl);
}
.explainer-grid {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  margin-bottom: var(--space-3);
}
.explainer-grid .dim { color: var(--color-text-dim); margin-right: var(--space-2); }
.explainer-how { line-height: var(--leading-normal); margin: var(--space-3) 0; }
.explainer-how .callout-title { display: block; margin-bottom: var(--space-1); }

.use-idea {
  margin-top: var(--space-4);
  padding: var(--space-3) var(--space-5);
  background: var(--color-accent-soft);
  border: 1px solid var(--color-accent);
  color: var(--color-accent);
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  border-radius: var(--radius-sm);
  transition: background var(--duration-fast);
}
.use-idea:hover { background: var(--color-accent); color: var(--color-bg); }

.empty-state {
  padding: var(--space-6);
  text-align: center;
  color: var(--color-text-dim);
  background: var(--color-surface);
  border: 1px dashed var(--color-border);
  border-radius: var(--radius-md);
}
