/* Masthead band — editorial Vol/No/date strip */
.masthead {
  background: var(--paper-soft);
  border-bottom: var(--border-width-3) double var(--ink);
}

.masthead-inner {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-4);
}

.masthead-meta {
  flex: 1;
  font-family: var(--font-mono);
  font-size: var(--font-size-2xs);
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--ink-muted);
}

.masthead-meta-right {
  text-align: right;
}

.masthead-wordmark .wordmark {
  font-size: var(--font-size-sm);
  letter-spacing: -0.005em;
  text-transform: none;
  color: var(--ink);
}

@media (max-width: 768px) {
  .masthead-wordmark { display: none; }
}

/* Asset Dashboard — editorial */

.asset-dashboard {
  padding: var(--space-5) 0;
  font-family: var(--font-sans);
}

.asset-dashboard h1 {
  color: var(--ink);
  margin-bottom: var(--space-6);
  font-family: var(--font-display);
  font-size: 44px;
  font-weight: var(--font-weight-normal);
  letter-spacing: var(--letter-spacing-display);
  line-height: 1.05;
  text-align: left;
}

/* Category Pills — small, rectilinear, ink-on-active */
.category-pills {
  display: flex;
  gap: var(--space-2);
  margin-bottom: var(--space-5);
  flex-wrap: wrap;
  overflow-x: auto;
  padding-bottom: var(--space-1);
}

.category-pill {
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-xs);
  background: transparent;
  border: var(--border-width-1) solid var(--line-strong);
  color: var(--ink-secondary);
  text-decoration: none;
  font-size: var(--font-size-tight);
  font-weight: var(--font-weight-medium);
  white-space: nowrap;
  transition: all var(--transition-default);
}

button.category-pill {
  cursor: pointer;
  font-family: var(--font-sans);
}

.category-pill:hover {
  background: var(--paper-warm);
  border-color: var(--ink);
  color: var(--ink);
}

.category-pill-active {
  background: var(--ink);
  border-color: var(--ink);
  color: var(--paper);
}

.category-pill-active:hover {
  background: var(--ink);
  border-color: var(--ink);
  color: var(--paper);
}

/* Assets Table — editorial: top+bottom ink rules, hairline rows, mono cells */
.assets-table-container {
  overflow-x: auto;
  background: var(--paper-soft);
  border-top: var(--border-width-1) solid var(--ink);
  border-bottom: var(--border-width-1) solid var(--ink);
  border-radius: 0;
  box-shadow: none;
}

.assets-table {
  width: 100%;
  border-collapse: collapse;
}

.assets-table thead {
  background: var(--paper-warm);
  border-bottom: var(--border-width-1) solid var(--ink);
}

.assets-table th {
  padding: 10px var(--space-4);
  text-align: left;
  font-family: var(--font-mono);
  font-weight: var(--font-weight-medium);
  font-size: var(--font-size-micro);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ink-muted);
}

.assets-table th.text-right {
  text-align: right;
}

.assets-table tbody tr {
  border-bottom: var(--border-width-1) solid var(--line);
  transition: background-color var(--transition-default);
  cursor: pointer;
}

.assets-table tbody tr:last-child {
  border-bottom: none;
}

.assets-table tbody tr:hover {
  background: var(--paper-warm);
}

.assets-table td {
  padding: var(--space-3) var(--space-4);
  font-size: var(--font-size-sm);
  color: var(--ink);
}

.asset-table-row {
  position: relative;
}

.asset-table-watchlist {
  position: relative;
  z-index: 1;
}

.asset-table-symbol a {
  color: var(--ink);
  text-decoration: none;
  font-weight: var(--font-weight-semibold);
  font-family: var(--font-mono);
  font-size: var(--font-size-sm);
  letter-spacing: 0.04em;
}

.asset-table-symbol a:hover {
  text-decoration: none;
  color: var(--accent);
}

.asset-table-symbol a.row-link::after {
  content: "";
  position: absolute;
  inset: 0;
  cursor: pointer;
}

.asset-table-name {
  color: var(--ink);
  font-family: var(--font-display);
  font-size: var(--font-size-base);
}

.asset-table-price {
  font-family: var(--font-mono);
  font-size: var(--font-size-sm);
  font-variant-numeric: tabular-nums;
}

.asset-table-change {
  font-family: var(--font-mono);
  font-size: var(--font-size-sm);
  font-variant-numeric: tabular-nums;
}

/* Empty State */
.empty-state {
  background: var(--paper);
  border: var(--border-width-1) solid var(--line-strong);
  border-radius: var(--card-border-radius);
  padding: var(--space-10);
  margin-top: var(--space-10);
}

.empty-state h4 {
  color: var(--color-gray-700);
  margin-bottom: var(--space-4);
  font-size: var(--font-size-2xl);
}

.empty-state p {
  color: var(--color-gray-600);
  margin: var(--space-2) 0;
  font-size: var(--font-size-base);
}

/* ============================================================
 * Asset Detail — editorial price hero
 * ============================================================ */
.asset-detail {
  padding: var(--space-5) 0;
  font-family: var(--font-sans);
}

/* Top breadcrumb + actions row */
.asset-topbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-4) 0;
  border-bottom: var(--border-width-1) solid var(--line);
  margin-bottom: var(--space-6);
  flex-wrap: wrap;
  gap: var(--space-3);
}

.asset-breadcrumb {
  font-family: var(--font-sans);
  font-size: var(--font-size-sm);
  color: var(--ink-muted);
  text-decoration: none;
  cursor: pointer;
  transition: color var(--transition-default);
}

.asset-breadcrumb:hover {
  color: var(--ink);
  text-decoration: none;
}

.asset-topbar-actions {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

/* Hero */
.asset-hero {
  margin-bottom: var(--space-6);
}

.asset-tags {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-2);
  font-size: var(--font-size-tight);
  color: var(--ink-muted);
}

.asset-tag-sym {
  font-family: var(--font-mono);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--ink);
  letter-spacing: 0.04em;
}

.asset-tag-dot {
  width: 4px;
  height: 4px;
  border-radius: var(--radius-full);
  background: var(--ink-faint);
}

.asset-tag-cat {
  font-family: var(--font-sans);
}

.asset-tag-exchange {
  font-family: var(--font-mono);
  font-size: var(--font-size-2xs);
  padding: 2px 8px;
  background: var(--paper-soft);
  border: var(--border-width-1) solid var(--line);
  border-radius: var(--radius-xs);
  color: var(--ink-muted);
  letter-spacing: 0.05em;
}

.asset-name {
  font-family: var(--font-display);
  font-size: 36px;
  font-weight: var(--font-weight-normal);
  letter-spacing: var(--letter-spacing-display);
  line-height: var(--line-height-tight);
  margin: 0 0 var(--space-3);
  color: var(--ink);
}

.asset-name em {
  color: var(--accent);
  font-style: italic;
}

.asset-price {
  font-family: var(--font-mono);
  font-size: 56px;
  font-weight: var(--font-weight-medium);
  letter-spacing: -0.025em;
  line-height: 1;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
}

.asset-delta {
  margin-top: var(--space-3);
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-family: var(--font-mono);
}

.asset-delta-pill {
  font-size: var(--font-size-tight);
  padding: 3px var(--space-3);
  border-radius: var(--radius-default);
  font-weight: var(--font-weight-semibold);
  font-variant-numeric: tabular-nums;
}

.asset-delta-meta {
  font-size: var(--font-size-tight);
  color: var(--ink-faint);
  font-family: var(--font-sans);
}

.asset-delta.is-positive .asset-delta-pill {
  background: var(--positive-bg);
  color: var(--positive);
}

.asset-delta.is-negative .asset-delta-pill {
  background: var(--negative-bg);
  color: var(--negative);
}

.asset-hero-caption {
  margin: var(--space-3) 0 0;
  font-family: var(--font-mono);
  font-size: var(--font-size-2xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-faint);
}

/* Returns strip — multi-window percent changes; --cols set per render */
.returns-strip {
  --cols: 7;
  margin: var(--space-5) 0 var(--space-6);
  display: grid;
  grid-template-columns: repeat(var(--cols), 1fr);
  background: var(--paper-soft);
  border: var(--border-width-1) solid var(--line-strong);
  border-radius: var(--radius-default);
  overflow: hidden;
}

.returns-cell {
  padding: var(--space-3) var(--space-4);
  text-align: center;
  border-right: var(--border-width-1) solid var(--line);
}

.returns-cell:last-child {
  border-right: none;
}

.returns-label {
  font-family: var(--font-mono);
  font-size: var(--font-size-micro);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-muted);
  margin-bottom: var(--space-1);
}

.returns-value {
  font-family: var(--font-mono);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  font-variant-numeric: tabular-nums;
}

.returns-value.pos { color: var(--positive); }
.returns-value.neg { color: var(--negative); }
.returns-value-unavailable { color: var(--ink-disabled); font-weight: var(--font-weight-normal); }

@media (max-width: 768px) {
  .returns-strip {
    grid-template-columns: repeat(4, 1fr) !important;
  }
  .returns-cell:nth-child(4) { border-right: none; }
  .returns-cell:nth-child(n+5) { border-top: var(--border-width-1) solid var(--line); }
}

/* Old asset-header / asset-info kept as quiet aliases for any partials still using them */
.asset-header {
  align-items: flex-start;
  margin-bottom: var(--space-6);
  padding: 0;
  background: transparent;
  border: none;
  border-radius: 0;
  box-shadow: none;
}

.asset-info h1 {
  font-family: var(--font-display);
  color: var(--ink);
  margin: 0 0 var(--space-3) 0;
  font-size: var(--font-size-4xl);
  font-weight: var(--font-weight-normal);
  letter-spacing: var(--letter-spacing-display);
}

.asset-meta {
  color: var(--ink-muted);
  font-size: var(--font-size-base);
  margin: 0;
}

/* ============================================================
 * Chart container — borderless, hairlines instead of card chrome
 * ============================================================ */
.chart-container {
  background: var(--paper-soft);
  border: var(--border-width-1) solid var(--line);
  border-radius: var(--radius-md);
  box-shadow: none;
  margin-bottom: var(--space-6);
  overflow: hidden;
}

.chart-header {
  background: var(--paper-warm);
  border-bottom: var(--border-width-1) solid var(--line);
  padding: var(--space-4) var(--space-5);
}

.chart-title {
  margin: 0;
  color: var(--ink);
  font-family: var(--font-sans);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
}

.chart-controls {
  display: flex;
  gap: var(--space-2);
}

.chart-body {
  padding: var(--space-6);
}

/* SMA Controls */
.indicator-controls {
  background: var(--paper-soft);
  border: var(--border-width-1) solid var(--line);
  border-radius: var(--card-border-radius);
  padding: var(--space-4) var(--space-5);
  margin-top: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.indicator-chip {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-full);
  border: 1px solid var(--line);
  cursor: pointer;
  user-select: none;
  transition: background-color 120ms, border-color 120ms, opacity 120ms;
}

.indicator-chip input[type="checkbox"] {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.indicator-chip:hover { background: var(--paper-warm); }

.indicator-chip:has(:focus-visible) {
  outline: 2px solid var(--ink);
  outline-offset: 2px;
}

.indicator-chip:not(:has(:checked)) { opacity: 0.55; }

.sma-toggles {
  display: flex;
  flex-wrap: wrap;
}

.sma-toggle {
  cursor: pointer;
  user-select: none;
}

.sma-color-dot {
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  flex-shrink: 0;
}

.sma-color-dot--20  { background-color: var(--color-sma-20); }
.sma-color-dot--50  { background-color: var(--color-sma-50); }
.sma-color-dot--100 { background-color: var(--color-sma-100); }
.sma-color-dot--200 { background-color: var(--color-sma-200); }

.ema-toggles {
  display: flex;
  flex-wrap: wrap;
}

.ema-toggle {
  cursor: pointer;
  user-select: none;
}

.ema-color-dot {
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  flex-shrink: 0;
}

.ema-color-dot--20  { background-color: var(--color-ema-20); }
.ema-color-dot--50  { background-color: var(--color-ema-50); }
.ema-color-dot--100 { background-color: var(--color-ema-100); }
.ema-color-dot--200 { background-color: var(--color-ema-200); }

.rsi-toggles {
  display: flex;
  flex-wrap: wrap;
}

.rsi-toggle {
  cursor: pointer;
  user-select: none;
}

.rsi-color-dot {
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  flex-shrink: 0;
}

.rsi-color-dot--9  { background-color: var(--color-rsi-9); }
.rsi-color-dot--14 { background-color: var(--color-rsi-14); }
.rsi-color-dot--21 { background-color: var(--color-rsi-21); }
.rsi-color-dot--25 { background-color: var(--color-rsi-25); }

.macd-toggles {
  display: flex;
  flex-wrap: wrap;
}

.macd-toggle {
  cursor: pointer;
  user-select: none;
}

.macd-color-dot {
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  flex-shrink: 0;
}

.macd-color-dot--26 { background-color: var(--color-macd-26); }

.bollinger_bands-toggle {
  cursor: pointer;
  user-select: none;
}

.bollinger_bands-color-dot {
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  flex-shrink: 0;
}

.bollinger_bands-color-dot--10 { background-color: var(--color-bb-10); }
.bollinger_bands-color-dot--20 { background-color: var(--color-bb-20); }
.bollinger_bands-color-dot--50 { background-color: var(--color-bb-50); }

.stochastic-toggle {
  cursor: pointer;
  user-select: none;
}

.stochastic-color-dot {
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  flex-shrink: 0;
}

.stochastic-color-dot--5  { background-color: var(--color-stochastic-5); }
.stochastic-color-dot--9  { background-color: var(--color-stochastic-9); }
.stochastic-color-dot--14 { background-color: var(--color-stochastic-14); }
.stochastic-color-dot--21 { background-color: var(--color-stochastic-21); }

.atr-toggle {
  cursor: pointer;
  user-select: none;
}

.atr-color-dot {
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  flex-shrink: 0;
}

.atr-color-dot--7  { background-color: var(--color-atr-7); }
.atr-color-dot--14 { background-color: var(--color-atr-14); }
.atr-color-dot--21 { background-color: var(--color-atr-21); }
.atr-color-dot--28 { background-color: var(--color-atr-28); }

.adx-toggle {
  cursor: pointer;
  user-select: none;
}

.adx-color-dot {
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  flex-shrink: 0;
}

.adx-color-dot--14 { background-color: var(--color-adx-14); }
.adx-color-dot--21 { background-color: var(--color-adx-21); }
.adx-color-dot--28 { background-color: var(--color-adx-28); }

.cci-toggle {
  cursor: pointer;
  user-select: none;
}

.cci-color-dot {
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  flex-shrink: 0;
}

.cci-color-dot--14 { background-color: var(--color-cci-14); }
.cci-color-dot--20 { background-color: var(--color-cci-20); }
.cci-color-dot--50 { background-color: var(--color-cci-50); }

.mfi-toggle {
  cursor: pointer;
  user-select: none;
}

.mfi-color-dot {
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  flex-shrink: 0;
}

.mfi-color-dot--9  { background-color: var(--color-mfi-9); }
.mfi-color-dot--14 { background-color: var(--color-mfi-14); }
.mfi-color-dot--21 { background-color: var(--color-mfi-21); }

.williams_r-color-dot {
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  flex-shrink: 0;
}

.williams_r-color-dot--9  { background-color: var(--color-williams_r-9); }
.williams_r-color-dot--14 { background-color: var(--color-williams_r-14); }
.williams_r-color-dot--21 { background-color: var(--color-williams_r-21); }
.williams_r-color-dot--28 { background-color: var(--color-williams_r-28); }

.aroon-color-dot {
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  flex-shrink: 0;
}

.aroon-color-dot--14 { background-color: var(--color-aroon-14); }
.aroon-color-dot--25 { background-color: var(--color-aroon-25); }
.aroon-color-dot--50 { background-color: var(--color-aroon-50); }

.stochastic_rsi-color-dot {
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  flex-shrink: 0;
}

.stochastic_rsi-color-dot--9  { background-color: var(--color-stochastic_rsi-9); }
.stochastic_rsi-color-dot--14 { background-color: var(--color-stochastic_rsi-14); }
.stochastic_rsi-color-dot--21 { background-color: var(--color-stochastic_rsi-21); }

.donchian_channels-color-dot {
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  flex-shrink: 0;
}

.donchian_channels-color-dot--10 { background-color: var(--color-donchian_channels-10); }
.donchian_channels-color-dot--20 { background-color: var(--color-donchian_channels-20); }
.donchian_channels-color-dot--55 { background-color: var(--color-donchian_channels-55); }

.cmf-color-dot {
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  flex-shrink: 0;
}

.cmf-color-dot--10 { background-color: var(--color-cmf-10); }
.cmf-color-dot--20 { background-color: var(--color-cmf-20); }
.cmf-color-dot--21 { background-color: var(--color-cmf-21); }

.roc-color-dot {
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  flex-shrink: 0;
}

.roc-color-dot--9  { background-color: var(--color-roc-9); }
.roc-color-dot--14 { background-color: var(--color-roc-14); }
.roc-color-dot--25 { background-color: var(--color-roc-25); }

.wma-color-dot {
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  flex-shrink: 0;
}

.wma-color-dot--20  { background-color: var(--color-wma-20); }
.wma-color-dot--50  { background-color: var(--color-wma-50); }
.wma-color-dot--100 { background-color: var(--color-wma-100); }
.wma-color-dot--200 { background-color: var(--color-wma-200); }

.hma-color-dot {
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  flex-shrink: 0;
}

.hma-color-dot--20  { background-color: var(--color-hma-20); }
.hma-color-dot--50  { background-color: var(--color-hma-50); }
.hma-color-dot--100 { background-color: var(--color-hma-100); }
.hma-color-dot--200 { background-color: var(--color-hma-200); }

.dema-color-dot {
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  flex-shrink: 0;
}

.dema-color-dot--20  { background-color: var(--color-dema-20); }
.dema-color-dot--50  { background-color: var(--color-dema-50); }
.dema-color-dot--100 { background-color: var(--color-dema-100); }
.dema-color-dot--200 { background-color: var(--color-dema-200); }

.tema-color-dot {
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  flex-shrink: 0;
}

.tema-color-dot--20  { background-color: var(--color-tema-20); }
.tema-color-dot--50  { background-color: var(--color-tema-50); }
.tema-color-dot--100 { background-color: var(--color-tema-100); }
.tema-color-dot--200 { background-color: var(--color-tema-200); }

.trix-color-dot {
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  flex-shrink: 0;
}

.trix-color-dot--9  { background-color: var(--color-trix-9); }
.trix-color-dot--14 { background-color: var(--color-trix-14); }
.trix-color-dot--25 { background-color: var(--color-trix-25); }

.ppo-color-dot {
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  flex-shrink: 0;
}

.ppo-color-dot--26 { background-color: var(--color-ppo-26); }

.dpo-color-dot {
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  flex-shrink: 0;
}

.dpo-color-dot--10 { background-color: var(--color-dpo-10); }
.dpo-color-dot--20 { background-color: var(--color-dpo-20); }
.dpo-color-dot--50 { background-color: var(--color-dpo-50); }

.tsi-color-dot {
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  flex-shrink: 0;
  background-color: var(--color-tsi);
}

.ultimate_oscillator-color-dot {
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  flex-shrink: 0;
  background-color: var(--color-ultimate_oscillator);
}

.fisher_transform-color-dot {
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  flex-shrink: 0;
}

.fisher_transform-color-dot--9  { background-color: var(--color-fisher_transform-9); }
.fisher_transform-color-dot--10 { background-color: var(--color-fisher_transform-10); }
.fisher_transform-color-dot--14 { background-color: var(--color-fisher_transform-14); }

.adl-color-dot {
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  flex-shrink: 0;
  background-color: var(--color-adl);
}

.force_index-color-dot {
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  flex-shrink: 0;
}

.force_index-color-dot--9  { background-color: var(--color-force_index-9); }
.force_index-color-dot--13 { background-color: var(--color-force_index-13); }
.force_index-color-dot--21 { background-color: var(--color-force_index-21); }

.mass_index-color-dot {
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  flex-shrink: 0;
  background-color: var(--color-mass_index);
}

.vortex-color-dot {
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  flex-shrink: 0;
}

.vortex-color-dot--14 { background-color: var(--color-vortex-14); }
.vortex-color-dot--21 { background-color: var(--color-vortex-21); }
.vortex-color-dot--28 { background-color: var(--color-vortex-28); }

.klinger-color-dot {
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  flex-shrink: 0;
  background-color: var(--color-klinger);
}

.standard_deviation-color-dot {
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  flex-shrink: 0;
}

.standard_deviation-color-dot--10 { background-color: var(--color-standard_deviation-10); }
.standard_deviation-color-dot--20 { background-color: var(--color-standard_deviation-20); }
.standard_deviation-color-dot--50 { background-color: var(--color-standard_deviation-50); }

.chaikin_volatility-color-dot {
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  flex-shrink: 0;
  background-color: var(--color-chaikin_volatility);
}

.coppock_curve-color-dot {
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  flex-shrink: 0;
  background-color: var(--color-coppock_curve);
}

.heikin_ashi-color-dot {
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  flex-shrink: 0;
  background-color: var(--color-heikin_ashi);
}

.pivot_points-color-dot {
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  flex-shrink: 0;
  background-color: var(--color-pivot_points-p);
}

.kama-color-dot {
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  flex-shrink: 0;
}

.kama-color-dot--10 { background-color: var(--color-kama-10); }
.kama-color-dot--20 { background-color: var(--color-kama-20); }
.kama-color-dot--30 { background-color: var(--color-kama-30); }

.chande_momentum_oscillator-color-dot {
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  flex-shrink: 0;
}

.chande_momentum_oscillator-color-dot--9  { background-color: var(--color-chande_momentum_oscillator-9); }
.chande_momentum_oscillator-color-dot--14 { background-color: var(--color-chande_momentum_oscillator-14); }
.chande_momentum_oscillator-color-dot--20 { background-color: var(--color-chande_momentum_oscillator-20); }

.choppiness_index-color-dot {
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  flex-shrink: 0;
}

.choppiness_index-color-dot--14 { background-color: var(--color-choppiness_index-14); }
.choppiness_index-color-dot--20 { background-color: var(--color-choppiness_index-20); }
.choppiness_index-color-dot--50 { background-color: var(--color-choppiness_index-50); }

.chaikin_oscillator-color-dot {
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  flex-shrink: 0;
  background-color: var(--color-chaikin_oscillator);
}

.elder_ray-color-dot {
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  border-radius: 50%;
  flex-shrink: 0;
}

.elder_ray-color-dot--9  { background-color: var(--color-elder_ray-9); }
.elder_ray-color-dot--13 { background-color: var(--color-elder_ray-13); }
.elder_ray-color-dot--21 { background-color: var(--color-elder_ray-21); }

.indicator-param-input {
  width: 5rem;
  padding: var(--space-1) var(--space-2);
  font-size: var(--font-size-sm);
  border: var(--border-width-1) solid var(--line-strong);
  border-radius: var(--radius-sm);
  background: var(--paper-soft);
  color: var(--ink);
}

/* Indicator Groups */
.indicator-group {
  border: var(--border-width-1) solid var(--line);
  border-radius: var(--card-border-radius);
  background: var(--paper);
  padding: var(--space-4);
  margin-bottom: var(--space-4);
}

.indicator-group-header {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: var(--ink-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: var(--space-3);
}

/* Indicator Sub-Panes */
.pane-label {
  position: absolute;
  top: var(--space-2);
  left: var(--space-3);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: var(--ink-muted);
  pointer-events: none;
  z-index: 1;
}

.indicator-pane {
  position: relative;
  border-top: var(--border-width-1) solid var(--line);
  padding: var(--space-4) var(--space-8);
  height: var(--indicator-pane-height);
}

.indicator-pane canvas {
  width: 100% !important;
  height: 100% !important;
}

/* Pane Chrome */
.pane-chrome {
  display: none;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  padding: var(--space-1) var(--space-3);
  align-items: center;
  justify-content: space-between;
  z-index: 2;
  background: transparent;
}

.indicator-pane:not([hidden]):hover .pane-chrome,
.indicator-pane:not([hidden]):focus-within .pane-chrome {
  display: flex;
}

.pane-chrome-actions {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.pane-chrome-btn {
  appearance: none;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--ink-muted);
  font-size: var(--font-size-xs);
  padding: var(--space-1);
  line-height: 1;
  border-radius: var(--radius-sm);
}

.pane-chrome-btn:hover {
  color: var(--ink);
  background: var(--paper);
}

.pane-drag-handle {
  cursor: grab;
  color: var(--ink-muted);
  font-size: var(--font-size-sm);
  padding: var(--space-1);
  line-height: 1;
  user-select: none;
}

.pane-drag-handle:active { cursor: grabbing; }

/* remove button generated by button_to */
.pane-remove-btn form,
.pane-remove-btn form button {
  all: unset;
  cursor: pointer;
  color: var(--ink-muted);
  font-size: var(--font-size-xs);
  padding: var(--space-1);
  line-height: 1;
  border-radius: var(--radius-sm);
}

.pane-remove-btn form button:hover {
  color: var(--negative);
}

/* Indicator controls card header */
.indicator-controls-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-2);
}

.indicator-controls-header .stat-title {
  margin-bottom: 0;
}

.indicator-controls-remove-btn form,
.indicator-controls-remove-btn form button {
  all: unset;
  cursor: pointer;
  color: var(--ink-muted);
  font-size: var(--font-size-sm);
  padding: var(--space-1) var(--space-2);
  line-height: 1;
  border-radius: var(--radius-sm);
}

.indicator-controls-remove-btn form button:hover {
  color: var(--negative);
}

/* Indicator Picker Button */
.indicator-picker-btn {
  margin: var(--space-3) var(--space-5) var(--space-4);
  display: inline-flex;
}

/* Indicator Picker Dialog */
.indicator-picker-dialog {
  border: var(--border-width-1) solid var(--line-strong);
  border-radius: var(--card-border-radius);
  box-shadow: var(--shadow-lg);
  padding: 0;
  max-width: 560px;
  width: 100%;
  max-height: 80vh;
  overflow: hidden;
}

.indicator-picker-dialog::backdrop {
  background: rgba(0, 0, 0, 0.4);
}

.indicator-picker-panel {
  display: flex;
  flex-direction: column;
  max-height: 80vh;
}

.indicator-picker-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-4) var(--space-5);
  border-bottom: var(--border-width-1) solid var(--line);
}

.indicator-picker-title {
  margin: 0;
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
}

.indicator-picker-close {
  appearance: none;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--ink-muted);
  font-size: var(--font-size-lg);
  line-height: 1;
  padding: var(--space-1);
}

.indicator-picker-close:hover { color: var(--ink); }

.indicator-picker-search {
  padding: var(--space-3) var(--space-5);
  border-bottom: var(--border-width-1) solid var(--line);
}

.indicator-picker-search-input {
  width: 100%;
  padding: var(--space-2) var(--space-3);
  border: var(--border-width-1) solid var(--line-strong);
  border-radius: var(--radius-default);
  font-size: var(--font-size-sm);
  background: var(--paper-soft);
  color: var(--ink);
}

.indicator-picker-list {
  overflow-y: auto;
  flex: 1;
  padding: var(--space-2) 0;
}

.indicator-picker-group { padding: 0 var(--space-3) var(--space-2); }

.indicator-picker-group-label {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: var(--ink-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: var(--space-2) var(--space-2) var(--space-1);
  margin: 0;
}

.indicator-picker-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding: var(--space-2) var(--space-2);
  border-radius: var(--radius-default);
}

.indicator-picker-row:hover { background: var(--paper); }

.indicator-picker-row-info {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.indicator-picker-row-name {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
}

.indicator-picker-row-summary {
  font-size: var(--font-size-xs);
  color: var(--ink-muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.indicator-picker-locked {
  flex-shrink: 0;
  font-size: var(--font-size-xs);
}

.indicator-picker-add-btn {
  flex-shrink: 0;
  white-space: nowrap;
}


/* Active panes container */
.indicator-active-panes { display: contents; }

/* Statistics Grid — editorial, no hover lift, mono cells */
.stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
  gap: var(--space-6);
  margin-top: var(--space-6);
}

.stat-card {
  background: var(--paper-soft);
  border: var(--border-width-1) solid var(--line);
  border-radius: var(--radius-md);
  box-shadow: none;
  overflow: hidden;
  transition: none;
}

.stat-card:hover {
  transform: none;
  box-shadow: none;
}

.stat-header {
  background: var(--paper-warm);
  border-bottom: var(--border-width-1) solid var(--line);
  padding: var(--space-3) var(--space-5);
}

.stat-title {
  margin: 0;
  color: var(--ink-muted);
  font-family: var(--font-mono);
  font-size: var(--font-size-2xs);
  font-weight: var(--font-weight-medium);
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

.stat-body {
  padding: var(--space-5);
}

.stat-row {
  align-items: start;
}

.stat-labels {
  font-family: var(--font-sans);
  font-weight: var(--font-weight-medium);
  color: var(--ink-muted);
  font-size: var(--font-size-sm);
  line-height: var(--line-height-relaxed);
}

.stat-values {
  font-family: var(--font-mono);
  color: var(--ink);
  font-size: var(--font-size-sm);
  font-variant-numeric: tabular-nums;
  line-height: var(--line-height-relaxed);
}

/* Comparison Card — editorial, hairline border, no gradient */
.comparison-card {
  border: var(--border-width-1) solid var(--line);
  background: var(--paper-soft);
}

.comparison-row {
  margin-bottom: var(--space-5);
}

.comparison-item {
  text-align: center;
  padding: var(--space-4);
  background: var(--paper-soft);
  border-radius: var(--radius-default);
  border: var(--border-width-1) solid var(--line);
}

.comparison-label {
  font-size: var(--font-size-sm);
  color: var(--color-gray-700);
  margin-bottom: var(--space-2);
}

.comparison-value {
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
}

.comparison-stats {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
  margin-bottom: var(--space-5);
}

.comparison-stat-item {
  padding: var(--space-3);
  background: var(--paper-soft);
  border-radius: var(--radius-default);
  border: var(--border-width-1) solid var(--line);
}

.comparison-stat-label {
  font-size: var(--font-size-sm);
  color: var(--color-gray-600);
  font-weight: var(--font-weight-medium);
}

.comparison-stat-value {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
}

.comparison-winner {
  text-align: center;
  padding: var(--space-4);
  background: var(--positive-tint);
  border: var(--border-width-2) solid var(--positive-strong);
  border-radius: var(--radius-default);
  color: var(--ink);
  font-size: var(--font-size-base);
  margin-top: var(--space-4);
}

.comparison-winner strong {
  color: var(--positive-strong);
}

/* Editorial masthead — replaces old SEO banner */
.seo-banner {
  background: var(--paper-soft);
  border-bottom: var(--border-width-3) double var(--ink);
  padding: var(--space-5) 0;
}

.seo-banner .container {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

.seo-banner-text {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  flex: 1;
}

.seo-banner-headline {
  font-family: var(--font-display);
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-normal);
  letter-spacing: var(--letter-spacing-display);
  color: var(--ink);
  line-height: var(--line-height-tight);
  margin: 0;
}

.seo-banner-subtitle {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--font-size-base);
  color: var(--ink-muted);
  margin: 0;
  line-height: var(--line-height-snug);
}

.seo-banner-dismiss {
  margin-left: auto;
  background: none;
  border: none;
  color: var(--ink-muted);
  cursor: pointer;
  font-size: var(--font-size-sm);
  padding: var(--space-1);
  line-height: 1;
  flex-shrink: 0;
  align-self: flex-start;
}

.seo-banner-dismiss:hover {
  color: var(--ink);
}

/* Change badges — pill-shaped positive/negative indicators */
.asset-table-change .positive,
.asset-table-change .negative {
  display: inline-block;
  padding: 3px var(--space-3);
  font-family: var(--font-mono);
  font-size: var(--font-size-tight);
  font-weight: var(--font-weight-semibold);
  font-variant-numeric: tabular-nums;
  border-radius: var(--radius-default);
  letter-spacing: 0;
}

.asset-table-change .positive {
  background: var(--positive-bg);
  color: var(--positive);
}

.asset-table-change .negative {
  background: var(--negative-bg);
  color: var(--negative);
}

/* No card accent bars — editorial uses hairlines, not colored top bars */
.stat-card,
.comparison-card {
  border-top: none;
}

/* Responsive Design */
@media (max-width: 768px) {
  .asset-dashboard,
  .asset-detail {
    padding: var(--space-4);
  }

  .category-pills {
    overflow-x: scroll;
    scrollbar-width: thin;
  }

  .assets-table-container {
    overflow-x: scroll;
  }

  .asset-header {
    flex-direction: column;
    align-items: stretch;
  }

  .chart-title-section {
    flex-direction: column;
    align-items: stretch;
  }

  .chart-controls {
    justify-content: center;
  }

  .stats-grid {
    grid-template-columns: 1fr;
    gap: var(--space-5);
  }

  .stat-row {
    grid-template-columns: 1fr;
    gap: var(--space-3);
  }

  .comparison-row {
    grid-template-columns: 1fr;
    gap: var(--space-4);
  }

  .comparison-stat-item {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-2);
  }

  .chart-body {
    padding: var(--space-5);
  }
}

@media (max-width: 768px) {
  .seo-banner .container {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-3);
  }

  .seo-banner-subtitle {
    display: none;
  }
}

@media (max-width: 480px) {
  .seo-banner-headline {
    font-size: var(--font-size-base);
  }

  .asset-dashboard h1,
  .asset-info h1 {
    font-size: var(--font-size-3xl);
  }

  .assets-table th,
  .assets-table td {
    padding: var(--space-2) var(--space-3);
    font-size: var(--font-size-xs);
  }

  .chart-body {
    padding: var(--space-4);
  }

  .stat-body {
    padding: var(--space-5);
  }
}
