/* ============================================================
   components.css — reusable controls: buttons, tabs, toggle, inputs,
   menus, indicator rows, drawing editor, badge. Match the Command Center.
   ============================================================ */

/* ---- Buttons (.ts-button, data-variant) ---- */
.ts-button {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--spacing-sm);
  padding: var(--spacing-sm) var(--spacing-lg);
  border: 1px solid var(--btn-border, var(--border-color));
  border-radius: var(--border-radius-md);
  background: var(--btn-bg, transparent); color: var(--btn-text, var(--text-primary));
  font-family: var(--font-body); font-size: var(--text-sm); font-weight: 600; letter-spacing: .02em;
  cursor: pointer;
  transition: background var(--transition-fast), color var(--transition-fast),
              border-color var(--transition-fast), box-shadow var(--transition-fast);
}
.ts-button[data-variant="primary"] { --btn-bg: var(--accent); --btn-border: var(--accent); --btn-text: var(--ref-neutral-0); }
.ts-button[data-variant="primary"]:hover { --btn-bg: var(--accent-bright); }
.ts-button[data-variant="secondary"] { --btn-text: var(--text-secondary); }
.ts-button[data-variant="secondary"]:hover { --btn-border: var(--accent); --btn-text: var(--text-primary); }
.ts-button[data-variant="icon"] { --btn-border: transparent; --btn-text: var(--text-secondary); padding: var(--spacing-sm); }
.ts-button[data-variant="icon"]:hover { --btn-text: var(--accent); }
.ts-button:disabled { opacity: .5; cursor: not-allowed; pointer-events: none; }

/* ---- Tabs / segmented control (.view-tabs > .view-tab) ---- */
.view-tabs { display: inline-flex; gap: var(--spacing-xs); }
.view-tab {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 44px; padding: var(--spacing-xs) var(--spacing-md);
  border: 1px solid transparent; border-radius: var(--border-radius-sm); background: transparent;
  color: var(--text-secondary); font-family: var(--font-body); font-size: var(--text-sm);
  font-weight: 600; letter-spacing: .03em; cursor: pointer;
  transition: background var(--transition-fast), border-color var(--transition-fast),
              color var(--transition-fast), box-shadow var(--transition-fast);
}
.view-tab:hover { border-color: var(--accent-40); color: var(--text-primary); }
.view-tab.active { border-color: var(--accent); color: var(--accent); box-shadow: 0 0 12px var(--accent-30); }

/* ---- Toggle: skeuomorphic 3D switch + neon outline (from Command Center) ---- */
.toggle-row {
  display: inline-flex; align-items: center; gap: var(--spacing-sm); cursor: pointer;
  color: var(--text-secondary); font-family: var(--font-body); font-size: var(--text-sm); font-weight: 600; user-select: none;
}
.toggle-row input { position: absolute; opacity: 0; pointer-events: none; }
.toggle-switch {
  position: relative; display: inline-block; flex-shrink: 0;
  width: 40px; height: 22px; border-radius: 11px;
  border: 1px solid rgba(255,255,255,0.04); background: rgba(255,255,255,0.04);
  box-shadow:
    -1px -1px 2px rgba(255,255,255,0.05), 1px 1px 3px rgba(0,0,0,0.5),
    inset 0 3px 6px rgba(0,0,0,0.5), inset -1px -1px 2px rgba(255,255,255,0.04), inset 1px 2px 3px rgba(0,0,0,0.25);
  cursor: pointer;
  transition: background .5s cubic-bezier(.65,0,.35,1), border-color .5s cubic-bezier(.65,0,.35,1), box-shadow .8s cubic-bezier(.2,0,0,1);
}
.toggle-switch::after {
  content: ''; position: absolute; top: 2px; left: 2px; z-index: 2;
  width: 16px; height: 16px; border-radius: 50%;
  background-color: hsl(223,10%,15%);
  background-image:
    radial-gradient(88% 88% at 50% 50%, hsl(223,10%,20%) 47%, transparent 50%),
    radial-gradient(88% 88% at 47% 47%, hsl(223,10%,85%) 45%, transparent 50%),
    radial-gradient(65% 70% at 40% 60%, hsl(223,10%,20%) 46%, transparent 50%);
  box-shadow: -1.5px -1.5px 1.5px hsl(223,10%,15%) inset, -2.5px -2.5px 2px hsl(223,10%,5%) inset;
  transition: transform .5s cubic-bezier(.65,0,.35,1), box-shadow .8s cubic-bezier(.2,0,0,1);
}
.toggle-neon { position: absolute; inset: 0; width: 100%; height: 100%; overflow: visible; pointer-events: none; z-index: 1; }
.toggle-neon path {
  fill: none; stroke: var(--accent); stroke-width: 2; filter: drop-shadow(0 0 3px var(--accent));
  stroke-dasharray: 0 100 0; transition: stroke-dasharray .5s cubic-bezier(.65,0,.35,1);
}
.toggle-row:hover .toggle-switch {
  box-shadow:
    -1px -1px 2px rgba(255,255,255,0.05), 1px 1px 3px rgba(0,0,0,0.5),
    inset 0 3px 6px rgba(0,0,0,0.5), 0 0 10px rgba(var(--accent-rgb),0.18);
}
.toggle-row input:checked + .toggle-switch { border-color: rgba(var(--accent-rgb),0.4); background: rgba(var(--accent-rgb),0.08); }
.toggle-row input:checked + .toggle-switch::after { transform: translateX(18px); }
.toggle-row input:checked + .toggle-switch .toggle-neon path { stroke-dasharray: 50 0 50; }
.toggle-only { gap: 0; }

/* ---- Inputs ---- */
.ts-input {
  width: 88px; padding: 6px 8px;
  background: var(--bg-field); border: 1px solid var(--border-color); border-radius: var(--border-radius-sm);
  color: var(--text-primary); font-family: var(--font-mono); font-size: var(--text-sm);
}
.ts-input:focus { outline: none; border-color: var(--accent); }
input[type="color"] {
  width: 46px; height: 28px; padding: 0;
  background: var(--bg-primary); border: 1px solid var(--border-color); border-radius: var(--border-radius-sm); cursor: pointer;
}

/* ---- Panel / card ---- */
.panel {
  padding: var(--spacing-md); background: var(--bg-secondary);
  border: 1px solid var(--border-color); border-radius: var(--border-radius-lg); box-shadow: var(--shadow-sm);
}

/* ---- Popover menu (chart type) ---- */
.menu-wrap { position: relative; flex-shrink: 0; }
.menu-pop {
  position: absolute; top: calc(100% + var(--spacing-sm)); right: 0;
  min-width: 170px; padding: var(--spacing-xs);
  background: var(--bg-popover); border: 1px solid var(--border-popover);
  border-radius: var(--border-radius-lg); box-shadow: var(--shadow-md); z-index: 1000; display: none;
}
.menu-pop.open { display: block; }
.menu-item {
  display: flex; align-items: center; gap: var(--spacing-sm); width: 100%;
  padding: var(--spacing-sm); background: transparent; border: none; border-radius: var(--border-radius-sm);
  color: var(--text-secondary); font-family: var(--font-body); font-size: var(--text-sm); font-weight: 600; text-align: left; cursor: pointer;
}
.menu-item:hover { background: var(--bg-tertiary); color: var(--text-primary); }
.menu-item.on { color: var(--accent); }

.menu-row { display: flex; align-items: center; }
.menu-row .menu-item { flex: 1; }
.menu-item-gear {
  flex-shrink: 0; display: flex; align-items: center; justify-content: center;
  width: 28px; height: 28px; margin-right: 4px;
  background: transparent; border: none; border-radius: var(--border-radius-sm);
  color: var(--text-muted); cursor: pointer; opacity: 0; transition: opacity 0.15s, color 0.15s;
}
.menu-row:hover .menu-item-gear { opacity: 1; }
.menu-item-gear:hover { color: var(--text-primary); background: var(--bg-tertiary); }


/* ---- Drawing editor (floating over chart) ---- */
.draw-editor {
  position: absolute; top: 10px; left: 50%; transform: translateX(-50%); display: none;
  align-items: center; gap: var(--spacing-sm); padding: 6px 10px;
  background: var(--bg-popover); border: 1px solid var(--border-popover);
  border-radius: var(--border-radius-md); box-shadow: var(--shadow-md); z-index: 20;
}
.draw-editor.show { display: flex; }
.de-label { color: var(--text-muted); font-size: var(--text-xs); font-weight: 700; letter-spacing: .05em; text-transform: uppercase; }
.de-swatch {
  width: 30px; height: 26px; padding: 0; border-radius: var(--border-radius-sm);
  border: 1px solid var(--border-color); cursor: pointer;
}
.de-select {
  background: var(--bg-field); border: 1px solid var(--border-color); border-radius: var(--border-radius-sm);
  color: var(--text-primary); font-family: var(--font-body); font-size: var(--text-sm); padding: 3px 6px; cursor: pointer;
}
.de-del {
  display: flex; align-items: center; justify-content: center; width: 28px; height: 26px;
  background: transparent; border: 1px solid var(--border-color); border-radius: var(--border-radius-sm);
  color: var(--text-secondary); cursor: pointer; transition: color var(--transition-fast), border-color var(--transition-fast);
}
.de-del:hover { color: var(--ref-error); border-color: var(--ref-error); }
.de-btn {
  display: flex; align-items: center; justify-content: center; width: 28px; height: 26px;
  background: transparent; border: 1px solid var(--border-color); border-radius: var(--border-radius-sm);
  color: var(--text-secondary); cursor: pointer; transition: color var(--transition-fast), border-color var(--transition-fast);
}
.de-btn:hover { color: var(--accent); border-color: var(--accent); }

/* ---- Symbol Search dropdown ---- */
.ss-drop {
  position: fixed; z-index: 2000;
  width: 380px;
  background: var(--bg-popover); border: 1px solid var(--border-popover);
  border-radius: var(--border-radius-lg); box-shadow: var(--shadow-md);
  display: none; flex-direction: column; overflow: hidden;
}
.ss-drop.ss-open { display: flex; }

.ss-search-row {
  display: flex; align-items: center; gap: var(--spacing-sm);
  padding: var(--spacing-sm) var(--spacing-md);
  border-bottom: 1px solid var(--border-color);
}
.ss-ico { color: var(--text-muted); font-size: 16px; flex-shrink: 0; }
.ss-input {
  flex: 1; background: transparent; border: none; outline: none;
  color: var(--text-primary); font-family: var(--font-body); font-size: var(--text-sm);
  font-weight: 600;
}
.ss-input::placeholder { color: var(--text-muted); }

.ss-list {
  max-height: 360px; overflow-y: auto;
  scrollbar-width: thin; scrollbar-color: var(--border-color) transparent;
}

.ss-section {
  padding: 6px 12px 4px;
  color: var(--text-muted); font-family: var(--font-body); font-size: 10px;
  font-weight: 700; letter-spacing: .08em; text-transform: uppercase;
}

.ss-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 7px 12px; cursor: pointer;
  transition: background var(--transition-fast);
}
.ss-row:hover, .ss-row.ss-active { background: var(--bg-tertiary); }

.ss-row-left { display: flex; align-items: center; gap: 6px; }
.ss-recent-ico { color: var(--text-muted); font-size: 12px; }
.ss-base { color: var(--text-primary); font-family: var(--font-mono); font-size: var(--text-sm); font-weight: 700; }
.ss-quote { color: var(--text-muted); font-family: var(--font-mono); font-size: var(--text-sm); font-weight: 600; }
.ss-name { color: var(--text-secondary); font-size: var(--text-xs); font-weight: 500; margin-left: 4px; }

.ss-tags { display: flex; gap: 4px; flex-shrink: 0; }
.ss-tag {
  padding: 1px 5px; border-radius: var(--border-radius-sm);
  background: var(--accent-20); color: var(--accent);
  font-family: var(--font-body); font-size: 9px; font-weight: 700; letter-spacing: .04em;
}

.ss-empty {
  padding: 24px 12px; text-align: center;
  color: var(--text-muted); font-size: var(--text-sm);
}

/* sym-pill separator */
.sym-sep { color: var(--text-muted); margin: 0 2px; }

/* ---- Badge / pill ---- */
.badge {
  display: inline-block; padding: 2px 8px;
  background: var(--accent-20); color: var(--accent); border-radius: var(--border-radius-full);
  font-family: var(--font-body); font-size: var(--text-xs); font-weight: 700; letter-spacing: .05em; text-transform: uppercase;
}

/* ---- Collapsible panel sections ---- */
.panel-section { display: flex; flex-direction: column; }

.phd {
  display: flex; align-items: center;
  user-select: none;
}
.phd-chev {
  margin-left: auto; padding-right: 4px;
  color: var(--text-muted); font-size: 13px; line-height: 1;
  pointer-events: none;
  transition: opacity var(--transition-fast);
}
.phd:hover .phd-chev { opacity: 1; color: var(--text-secondary); }

/* JS-measured height transition — symmetric expand and collapse */
.panel-body-wrap {
  overflow: hidden;
  transition: height 300ms cubic-bezier(0.16, 1, 0.3, 1);
}
.panel-body { min-height: 0; }

.ot-count { font-size: 10px; color: var(--text-muted); font-weight: 400; margin-left: 4px; }

/* ---- Watchlist ---- */
.wl-add-btn {
  width: 20px; height: 20px; display: flex; align-items: center; justify-content: center;
  background: transparent; border: none; color: var(--text-muted); cursor: pointer;
  border-radius: var(--border-radius-sm); font-size: 14px; flex-shrink: 0;
  margin-left: 4px;
  transition: color var(--transition-fast), background var(--transition-fast);
}
.wl-add-btn:hover { color: var(--accent); background: var(--bg-tertiary); }

.wl-list { display: flex; flex-direction: column; }
.wl-row {
  display: flex; align-items: center; gap: 6px; padding: 6px 10px;
  cursor: pointer; transition: background var(--transition-fast);
  border-bottom: 1px solid var(--border-subtle);
}
.wl-row:hover { background: var(--bg-tertiary); }
/* Ripple on click */
.wl-row { overflow: hidden; }
.wl-ripple {
  position: absolute; border-radius: 50%;
  width: 4px; height: 4px;
  background: var(--accent);
  opacity: .3;
  transform: scale(0);
  animation: wlRipple 550ms cubic-bezier(0.16, 1, 0.3, 1) forwards;
  pointer-events: none;
}
@keyframes wlRipple {
  to { transform: scale(90); opacity: 0; }
}
/* Active row — glowing accent highlight */
.wl-row-active {
  background: var(--accent-20);
  border-left: 3px solid var(--accent);
  padding-left: 7px;
  box-shadow: inset 3px 0 12px rgba(var(--accent-rgb), .12);
  transition:
    background var(--transition-reveal),
    box-shadow var(--transition-reveal);
}
.wl-row-active .wl-base { color: var(--accent); }
/* "just selected" flash — briefly boost background, then settles to accent-10 */
.wl-row-selecting {
  background: var(--accent-20) !important;
}
/* Price flash when watchlist row updates live */
@keyframes priceFlash {
  0%   { opacity: 1; }
  30%  { opacity: .4; }
  100% { opacity: 1; }
}
.wl-price.flash { animation: priceFlash 500ms ease-out forwards; }
.wl-row:hover .wl-remove { opacity: 1; }
.wl-sym { flex: 1; min-width: 0; }
.wl-base { font-size: var(--text-sm); font-weight: 700; color: var(--text-primary); }
.wl-quote { font-size: var(--text-xs); color: var(--text-muted); }
.wl-right { display: flex; flex-direction: column; align-items: flex-end; gap: 1px; flex-shrink: 0; }
.wl-price-row { display: flex; align-items: baseline; gap: 5px; }
.wl-price { font-size: var(--text-sm); font-weight: 700; color: var(--text-primary); font-family: var(--font-mono); }
.wl-chg { font-size: var(--text-xs); font-weight: 600; }
.wl-chg.pos { color: var(--ref-success); }
.wl-chg.neg { color: var(--ref-error); }
.wl-vol { font-size: 10px; color: var(--text-muted); font-family: var(--font-mono); letter-spacing: .01em; }
.wl-remove {
  opacity: 0; width: 18px; height: 18px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  background: transparent; border: none; color: var(--text-muted); cursor: pointer;
  border-radius: var(--border-radius-sm); font-size: 12px;
  transition: color var(--transition-fast), opacity var(--transition-fast);
}
.wl-remove:hover { color: var(--ref-error); }
.wl-empty {
  padding: 20px 10px; text-align: center;
  color: var(--text-muted); font-size: var(--text-xs); line-height: 1.6;
}

/* ---- Object Tree color dot (drawings) ---- */
.ot-color-dot {
  display: inline-block; width: 8px; height: 8px;
  border-radius: 50%; flex-shrink: 0; margin-right: 5px;
  vertical-align: middle; position: relative; top: -1px;
}

/* ---- Object Tree drag handles ---- */
.ot-drag {
  display: flex; align-items: center; justify-content: center;
  width: 14px; height: 22px; flex-shrink: 0;
  color: transparent; cursor: grab; font-size: 14px;
  transition: color var(--transition-fast);
}
.ot-row[draggable]:hover .ot-drag { color: var(--text-muted); }
.ot-row[draggable]:hover .ot-drag:hover { color: var(--accent); }
.ot-row.ot-dragging { opacity: .4; }
.ot-row.drag-over-top    { box-shadow: inset 0 2px 0 0 var(--accent); }
.ot-row.drag-over-bottom { box-shadow: inset 0 -2px 0 0 var(--accent); }

/* ---- Drawing row: selected state ---- */
.ot-row.ot-selected { background: rgba(var(--accent-rgb, 243,156,18), .10); }
.ot-row.ot-selected .ot-name { color: var(--accent); }

/* ---- Indented rows (inside a folder) ---- */
.ot-row--indent { padding-left: 22px; }

/* ---- Folder rows ---- */
.ot-folder {
  display: flex; align-items: center; gap: 4px;
  padding: 4px 8px 4px 6px;
  background: var(--bg-secondary);
  border-bottom: 1px solid var(--border-subtle);
  user-select: none;
}
.ot-folder-chev {
  display: flex; align-items: center; justify-content: center;
  width: 18px; height: 18px; flex-shrink: 0; padding: 0;
  background: transparent; border: none; color: var(--text-muted);
  cursor: pointer; font-size: 12px;
  transition: color var(--transition-fast);
}
.ot-folder-chev:hover { color: var(--text-primary); }
.ot-folder-name {
  flex: 1; min-width: 0; font-size: var(--text-xs); font-weight: 700;
  color: var(--text-secondary); letter-spacing: .04em; cursor: default;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  outline: none; border-radius: 2px;
}
.ot-folder-name--editing {
  background: var(--bg-tertiary); color: var(--text-primary);
  padding: 0 4px; cursor: text; text-overflow: clip;
}
.ot-folder-count { font-size: 10px; color: var(--text-muted); flex-shrink: 0; }
.ot-folder-x {
  display: flex; align-items: center; justify-content: center;
  width: 18px; height: 18px; flex-shrink: 0; padding: 0;
  background: transparent; border: none; color: transparent;
  cursor: pointer; border-radius: var(--border-radius-sm);
  transition: color var(--transition-fast), background var(--transition-fast);
}
.ot-folder:hover .ot-folder-x { color: var(--text-muted); }
.ot-folder-x:hover { color: var(--ref-error) !important; background: var(--bg-tertiary); }
.ot-folder.drag-over-folder {
  background: rgba(var(--accent-rgb, 243,156,18), .12);
  outline: 1px solid var(--accent);
}
.ot-folder-body { border-bottom: 1px solid var(--border-subtle); }

/* ---- Drawings section action bar (header) ---- */
.dt-actions {
  display: flex; align-items: center; gap: 2px;
  margin-left: auto; flex-shrink: 0;
}
.dt-sel-label {
  font-size: 10px; color: var(--text-muted); white-space: nowrap; padding: 0 4px;
}
.dt-btn {
  display: flex; align-items: center; justify-content: center;
  width: 20px; height: 20px; padding: 0;
  background: transparent; border: none; color: var(--text-muted);
  cursor: pointer; border-radius: var(--border-radius-sm); font-size: 13px;
  transition: color var(--transition-fast), background var(--transition-fast);
}
.dt-btn:hover { color: var(--text-primary); background: var(--bg-tertiary); }
.dt-btn.dt-del:hover { color: var(--ref-error); }

/* ---- Indicator folder picker ---- */
.ind-folder-picker {
  background: var(--bg-secondary);
  border: 1px solid var(--border-color);
  border-radius: var(--border-radius);
  box-shadow: 0 4px 16px rgba(0,0,0,.4);
  padding: 4px;
  min-width: 140px;
  display: flex; flex-direction: column; gap: 2px;
}
.ind-fp-item {
  width: 100%; text-align: left; padding: 6px 10px;
  background: transparent; border: none; border-radius: var(--border-radius-sm);
  color: var(--text-primary); font-size: 12px; cursor: pointer;
}
.ind-fp-item:hover { background: var(--bg-tertiary); }

/* ---- Generic context menu ---- */
.ctx-menu {
  position: fixed; z-index: 9000;
  min-width: 200px; padding: 4px 0;
  background: var(--bg-popover); border: 1px solid var(--border-popover);
  border-radius: var(--border-radius-md); box-shadow: var(--shadow-md);
  font-family: var(--font-body); font-size: var(--text-sm);
  user-select: none; pointer-events: none; opacity: 0;
  transform: scale(.96); transform-origin: top left;
  transition: opacity 120ms ease, transform 120ms ease;
}
.ctx-menu.open { pointer-events: auto; opacity: 1; transform: scale(1); }
.ctx-item {
  display: flex; align-items: center; gap: 8px;
  width: 100%; padding: 6px 12px; text-align: left;
  background: transparent; border: none; color: var(--text-primary);
  cursor: pointer; font-family: inherit; font-size: inherit;
  transition: background var(--transition-fast);
}
.ctx-item:hover:not(:disabled) { background: var(--bg-tertiary); color: var(--accent); }
.ctx-item:disabled { opacity: .4; cursor: not-allowed; }
.ctx-item.ctx-danger { color: var(--ref-error); }
.ctx-item.ctx-danger:hover:not(:disabled) { background: rgba(239,68,68,.12); color: var(--ref-error); }
.ctx-no-icon { display: inline-block; width: 14px; }
.ctx-label { flex: 1; }
.ctx-shortcut { font-size: var(--text-xs); color: var(--text-muted); }
.ctx-sep { height: 1px; background: var(--border-subtle); margin: 4px 0; }

/* ---- Price scale right-click menu ---- */
.pscale-menu {
  min-width: 220px; padding: 4px 0;
  background: var(--bg-popover); border: 1px solid var(--border-popover);
  border-radius: var(--border-radius-md); box-shadow: var(--shadow-md);
  font-family: var(--font-body); font-size: var(--text-sm);
  user-select: none;
}
.pscm-section-label {
  padding: 6px 12px 4px; font-size: var(--text-xs); font-weight: 700;
  letter-spacing: .08em; text-transform: uppercase; color: var(--text-muted);
}
.pscm-item {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 12px; color: var(--text-primary); cursor: pointer;
  transition: background var(--transition-fast);
}
.pscm-item:hover { background: var(--bg-tertiary); }
.pscm-item.pscm-active { color: var(--accent); }
.pscm-check { width: 14px; text-align: center; font-size: 11px; color: var(--accent); flex-shrink: 0; }
.pscm-sep { height: 1px; background: var(--border-subtle); margin: 4px 0; }

/* ============================================================
   Data Panel — collapsible Stats / Technicals / On-Chain / News
   ============================================================ */
.dp-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 10px; cursor: pointer;
  border-bottom: 1px solid var(--border-subtle);
}
.dp-title {
  font-size: var(--text-xs); font-weight: 700; letter-spacing: .08em;
  text-transform: uppercase; color: var(--text-muted);
}
.dp-chevron {
  display: flex; align-items: center; justify-content: center;
  width: 20px; height: 20px; background: transparent; border: none;
  color: var(--text-muted); cursor: pointer; font-size: 13px; padding: 0;
  transition: color var(--transition-fast);
}
.dp-chevron:hover { color: var(--accent); }

/* Collapse/expand — JS-measured height for symmetric animation */
.dp-collapse {
  overflow: hidden;
  transition: height 280ms cubic-bezier(0.16, 1, 0.3, 1);
}

/* Tabs */
.dp-tabs {
  display: flex; border-bottom: 1px solid var(--border-subtle);
  background: var(--bg-secondary);
}
.dp-tab {
  flex: 1; padding: 6px 4px; background: transparent; border: none;
  border-bottom: 2px solid transparent;
  font-family: var(--font-body); font-size: 10px; font-weight: 700;
  letter-spacing: .04em; text-transform: uppercase;
  color: var(--text-muted); cursor: pointer;
  transition: color var(--transition-fast), border-color var(--transition-fast);
}
.dp-tab:hover { color: var(--text-primary); }
.dp-tab-active { color: var(--accent); border-bottom-color: var(--accent); }

/* Content body */
.dp-body { padding: 6px 0; }

/* Rows */
.dp-row {
  display: flex; align-items: center; gap: 4px;
  padding: 4px 10px; font-size: var(--text-xs);
}
.dp-k { color: var(--text-muted); flex: 1; min-width: 0; white-space: nowrap; }
.dp-v { font-family: var(--font-mono); font-weight: 600; color: var(--text-primary); text-align: right; }
.dp-v.mono { font-family: var(--font-mono); }
.dp-signal {
  font-size: 10px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .04em; min-width: 44px; text-align: right;
}
.dp-signal.pos { color: var(--ref-success); }
.dp-signal.neg { color: var(--ref-error); }
.dp-signal.dp-neutral { color: var(--text-muted); }
.dp-na { color: var(--text-muted); opacity: .4; }
.dp-neutral { color: var(--text-muted); }
.dp-group-label {
  padding: 6px 10px 2px; font-size: 9px; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase; color: var(--text-muted); opacity: .5;
}
.dp-sep { height: 1px; background: var(--border-subtle); margin: 6px 0; }
.dp-empty {
  padding: 14px 10px; color: var(--text-muted); font-size: var(--text-xs);
  text-align: center; line-height: 1.6;
}
.dp-loading {
  display: flex; align-items: center; gap: 8px; justify-content: center;
  padding: 20px 10px; color: var(--text-muted); font-size: var(--text-xs);
}
@keyframes dpSpin { to { transform: rotate(360deg); } }
.dp-spinner {
  width: 14px; height: 14px; border-radius: 50%;
  border: 2px solid rgba(255,255,255,.08);
  border-top-color: var(--accent);
  animation: dpSpin 700ms linear infinite;
  flex-shrink: 0;
}

/* Gauge */
.dp-gauge-wrap { padding: 10px 10px 6px; }
.dp-gauge-label {
  font-size: var(--text-sm); font-weight: 800; letter-spacing: .02em;
  text-align: center; margin-bottom: 8px;
}
.dp-gauge-track {
  height: 6px; border-radius: 3px; background: rgba(255,255,255,.06);
  position: relative; overflow: hidden;
}
.dp-gauge-fill {
  height: 100%; border-radius: 3px;
  transition: width 600ms cubic-bezier(0.16, 1, 0.3, 1);
}
.dp-gauge-fill.pos { background: linear-gradient(90deg, #16a34a, #22c55e); }
.dp-gauge-fill.neg { background: linear-gradient(90deg, #ef4444, #dc2626); }
.dp-gauge-fill.dp-neutral { background: var(--text-muted); }
.dp-gauge-mid {
  position: absolute; top: 0; bottom: 0; left: 50%; width: 1px;
  background: rgba(255,255,255,.2);
}
.dp-gauge-sub {
  font-size: 10px; color: var(--text-muted); text-align: center;
  margin-top: 5px; letter-spacing: .02em;
}

/* News */
.dp-news-item {
  display: flex; align-items: flex-start; gap: 8px;
  padding: 8px 10px; text-decoration: none;
  border-bottom: 1px solid var(--border-subtle);
  transition: background var(--transition-fast);
}
.dp-news-item:hover { background: var(--bg-tertiary); }
.dp-news-thumb {
  width: 36px; height: 36px; border-radius: var(--border-radius-sm);
  object-fit: cover; flex-shrink: 0; background: var(--bg-tertiary);
}
.dp-news-nothumb { background: var(--bg-tertiary); }
.dp-news-body { flex: 1; min-width: 0; }
.dp-news-title {
  font-size: var(--text-xs); font-weight: 600; color: var(--text-primary);
  line-height: 1.4; display: -webkit-box; -webkit-line-clamp: 2;
  -webkit-box-orient: vertical; overflow: hidden;
}
.dp-news-meta {
  font-size: 10px; color: var(--text-muted); margin-top: 2px;
}

/* ---- DataPanel value flicker-in ---- */
@keyframes dpFlicker {
  0%   { opacity: 0; transform: translateY(3px); }
  40%  { opacity: 1; transform: translateY(0); }
  55%  { opacity: 0.6; }
  70%  { opacity: 1; }
  85%  { opacity: 0.8; }
  100% { opacity: 1; transform: translateY(0); }
}
.dp-val-flicker {
  animation: dpFlicker 420ms cubic-bezier(0.16, 1, 0.3, 1) both;
}

/* ---- Stats tab ---- */
.dp-perf-grid { padding: 2px 0; }
.dp-perf-row {
  display: flex; align-items: center; gap: 6px;
  padding: 3px 10px; font-size: var(--text-xs);
}
.dp-perf-label { width: 28px; flex-shrink: 0; color: var(--text-muted); font-weight: 600; font-size: 10px; }
.dp-perf-bar-wrap {
  flex: 1; height: 4px; background: rgba(255,255,255,.05);
  border-radius: 2px; overflow: hidden; position: relative;
}
.dp-perf-bar {
  height: 100%; border-radius: 2px;
  transition: width 500ms cubic-bezier(0.16, 1, 0.3, 1);
}
.dp-perf-bar.pos { background: linear-gradient(90deg, #16a34a80, var(--ref-success)); }
.dp-perf-bar.neg { background: linear-gradient(90deg, var(--ref-error), #ef444480); }
.dp-perf-val { width: 56px; text-align: right; font-family: var(--font-mono); font-weight: 700; font-size: var(--text-xs); flex-shrink: 0; }

.dp-vol-row { padding: 4px 10px 8px; display: flex; flex-direction: column; gap: 4px; }
.dp-vol-labels { display: flex; justify-content: space-between; font-size: var(--text-xs); }
.dp-vol-bar-wrap {
  height: 5px; background: rgba(255,255,255,.05); border-radius: 3px;
  position: relative; overflow: hidden;
}
.dp-vol-bar { height: 100%; border-radius: 3px; transition: width 500ms cubic-bezier(0.16, 1, 0.3, 1); }
.dp-vol-bar.pos { background: var(--ref-success); }
.dp-vol-bar.neg { background: var(--ref-error); }
.dp-vol-bar.dp-neutral-bar { background: var(--text-muted); }
.dp-vol-avg-line { position: absolute; top: 0; bottom: 0; left: 50%; width: 1.5px; background: rgba(255,255,255,.25); }
.dp-vol-ratio { font-size: 10px; font-family: var(--font-mono); font-weight: 700; text-align: right; }
.dp-vol-ratio.pos { color: var(--ref-success); }
.dp-vol-ratio.neg { color: var(--ref-error); }
.dp-vol-ratio.dp-neutral-bar { color: var(--text-muted); }

.dp-range-wrap {
  display: flex; align-items: center; gap: 8px; padding: 6px 10px 10px;
  font-size: 10px; font-family: var(--font-mono);
}
.dp-range-lo { color: var(--ref-error); flex-shrink: 0; font-weight: 600; }
.dp-range-hi { color: var(--ref-success); flex-shrink: 0; font-weight: 600; }
.dp-range-track {
  flex: 1; height: 5px; background: rgba(255,255,255,.07);
  border-radius: 3px; position: relative;
}
.dp-range-fill {
  position: absolute; left: 0; top: 0; bottom: 0; border-radius: 3px;
  background: linear-gradient(90deg, var(--ref-error), var(--ref-success));
}
.dp-range-dot {
  position: absolute; top: 50%; transform: translate(-50%, -50%);
  width: 9px; height: 9px; border-radius: 50%;
  background: var(--text-primary); border: 2px solid var(--bg-secondary);
  box-shadow: 0 0 4px rgba(0,0,0,.6);
  transition: left 700ms cubic-bezier(0.16, 1, 0.3, 1);
}

/* ---- Technicals tab ---- */
.dp-tech-summary { padding: 10px 10px 6px; }
.dp-tech-verdict {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  margin-bottom: 8px;
}
.dp-tech-icon { font-size: 14px; }
.dp-tech-label { font-size: var(--text-sm); font-weight: 800; letter-spacing: .02em; }
.dp-tech-verdict.strong-buy  .dp-tech-label, .dp-tech-verdict.strong-buy  .dp-tech-icon { color: #22c55e; }
.dp-tech-verdict.buy         .dp-tech-label, .dp-tech-verdict.buy         .dp-tech-icon { color: #4ade80; }
.dp-tech-verdict.neutral-sig .dp-tech-label, .dp-tech-verdict.neutral-sig .dp-tech-icon { color: var(--text-muted); }
.dp-tech-verdict.sell        .dp-tech-label, .dp-tech-verdict.sell        .dp-tech-icon { color: #f87171; }
.dp-tech-verdict.strong-sell .dp-tech-label, .dp-tech-verdict.strong-sell .dp-tech-icon { color: #ef4444; }

.dp-tech-counts {
  display: flex; justify-content: space-between; margin-bottom: 5px;
  font-size: 10px; font-weight: 700; letter-spacing: .03em;
}
.dp-tech-cnt.sell { color: var(--ref-error); }
.dp-tech-cnt.neu  { color: var(--text-muted); }
.dp-tech-cnt.buy  { color: var(--ref-success); }

.dp-tri-track {
  display: flex; height: 6px; border-radius: 3px; overflow: hidden; gap: 1px;
}
.dp-tri-seg { height: 100%; border-radius: 2px; transition: width 600ms cubic-bezier(0.16, 1, 0.3, 1); }
.dp-tri-seg.pos { background: var(--ref-success); }
.dp-tri-seg.neg { background: var(--ref-error); }
.dp-tri-seg.dp-neutral-bar { background: rgba(255,255,255,.15); }

/* Badges */
.dp-badge {
  font-size: 9px; font-weight: 800; letter-spacing: .06em; text-transform: uppercase;
  padding: 1px 6px; border-radius: 3px; flex-shrink: 0;
}
.dp-badge-buy  { background: rgba(34,197,94,.15);  color: #22c55e; }
.dp-badge-sell { background: rgba(239,68,68,.15);  color: #ef4444; }
.dp-badge-neu  { background: rgba(255,255,255,.07); color: var(--text-muted); }

/* RSI mini track */
.dp-rsi-track {
  position: relative; height: 4px; margin: 3px 10px 6px;
  background: rgba(255,255,255,.05); border-radius: 2px; overflow: visible;
}
.dp-rsi-fill {
  height: 100%; border-radius: 2px;
  transition: width 500ms cubic-bezier(0.16, 1, 0.3, 1);
}
.dp-rsi-fill.pos { background: var(--ref-success); }
.dp-rsi-fill.neg { background: var(--ref-error); }
.dp-rsi-fill.dp-neutral-bar { background: var(--text-muted); }
.dp-rsi-ob, .dp-rsi-os {
  position: absolute; top: -2px; bottom: -2px; width: 1px;
  background: rgba(255,255,255,.2);
}

/* ── Live Tape (TapePanel) ──────────────────────────────────────────────── */
.tp-controls { display: flex; gap: 4px; align-items: center; margin-left: auto; margin-right: 6px; }

/* Filter chip — shows the ACTIVE filter as text; opens the preset popover.
   Replaces the old raw "min $" number input in the header. */
.tp-chip {
  display: inline-flex; align-items: center; gap: 4px;
  height: 22px; padding: 0 6px 0 7px;
  background: var(--bg-tertiary); border: 1px solid var(--border-subtle);
  border-radius: 11px; color: var(--text-secondary);
  font-size: 10px; cursor: pointer; white-space: nowrap;
}
.tp-chip:hover { color: var(--text-primary); border-color: var(--border-hover); }
.tp-chip.is-active { color: var(--accent); border-color: color-mix(in srgb, var(--accent) 45%, transparent); }
.tp-chip.is-open { border-color: var(--accent); }
.tp-chip iconify-icon { font-size: 12px; }
.tp-chip-val { font-weight: 700; }
.tp-chip-caret { font-size: 11px !important; opacity: .6; }

/* Filter popover — reuses the .tp-venues-pop surface */
.tp-filter-pop { min-width: 190px; }
.tp-pop-label {
  font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em;
  color: var(--text-muted); padding: 4px 6px 2px;
}
.tp-pop-label span { font-weight: 400; text-transform: none; letter-spacing: 0; opacity: .8; }
.tp-pop-sep { height: 1px; background: var(--border-subtle); margin: 5px 2px; }
.tp-filter-opt {
  display: flex; align-items: center; gap: 6px; width: 100%;
  padding: 5px 8px; border: none; background: none; border-radius: 5px;
  color: var(--text-primary); font-size: 11px; text-align: left; cursor: pointer;
}
.tp-filter-opt:hover { background: var(--bg-hover); }
.tp-filter-opt.is-sel { color: var(--accent); background: var(--accent-10, rgba(243,156,18,.12)); }
.tp-filter-sub { margin-left: auto; font-size: 9px; color: var(--text-muted); }
.tp-filter-fixed { display: grid; grid-template-columns: 1fr 1fr; gap: 4px; padding: 2px; }
.tp-filter-chip {
  padding: 5px 6px; border: 1px solid var(--border-subtle); background: var(--bg-tertiary);
  border-radius: 5px; color: var(--text-secondary); font-size: 10px; cursor: pointer;
  font-variant-numeric: tabular-nums;
}
.tp-filter-chip:hover { color: var(--text-primary); border-color: var(--border-hover); }
.tp-filter-chip.is-sel { color: var(--accent); border-color: var(--accent); }

.tp-body {
  max-height: 260px; overflow-y: auto;
  font-family: 'Space Mono', monospace; font-size: 10px; line-height: 1.5;
}
.tp-row {
  display: grid; grid-template-columns: 52px minmax(0, 1fr) auto auto;
  gap: 6px; padding: 1px 8px; align-items: center;
}
.tp-time  { color: var(--text-muted); }
.tp-venue { color: var(--text-secondary); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.tp-price, .tp-size { text-align: right; font-variant-numeric: tabular-nums; }
.tp-size  { color: var(--text-primary); }
/* Row backgrounds, buy/sell price colors and the LIQ badge tint are INLINE
   from user settings (Tape gear → Colors) — the alpha baked into each tier
   color is its intensity control. */
.tp-liq-badge {
  font-size: 8px; font-weight: 700; padding: 0 3px; border-radius: 2px;
  vertical-align: 1px;
}
/* Perp marker — a small superscript 'ᴾ' after a perpetual-futures venue name,
   so spot (buys/sells) vs perp (position flow) is distinguishable at a glance. */
.tp-perp {
  font-size: 8px; font-weight: 700; color: var(--accent);
  vertical-align: 2px; margin-left: 1px; opacity: .8;
}
.tp-venues-pop {
  position: fixed; z-index: 9500; min-width: 170px;
  background: var(--bg-popover); border: 1px solid var(--border-popover);
  border-radius: 6px; padding: 6px; display: flex; flex-direction: column; gap: 2px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.5);
}
.tp-venue-opt {
  display: flex; gap: 6px; align-items: center; cursor: pointer;
  font-size: 11px; padding: 2px 6px; border-radius: 4px; color: var(--text-primary);
}
.tp-venue-opt:hover { background: var(--bg-hover); }
.tp-venue-count { margin-left: auto; color: var(--text-muted); font-size: 10px; }
