:root {
  --bg: var(--bg-app);
  --text: var(--text-primary);
  --border: var(--border-subtle);
  --panel-bg: var(--bg-panel);
  --panel-bg-strong: var(--bg-panel-strong);
  --accent: var(--text-accent);
  --accent-strong: #36d399;
  --muted: var(--text-secondary);
  --brand-primary: var(--text-accent);
}

:root[data-theme="light"] {
  --bg: var(--bg-app);
  --text: var(--text-primary);
  --border: var(--border-subtle);
  --panel-bg: var(--bg-panel);
  --panel-bg-strong: var(--bg-panel-strong);
  --accent: var(--text-accent);
  --accent-strong: var(--positive);
  --muted: var(--text-secondary);
  --brand-primary: var(--text-accent);
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.app-shell {
  min-height: 100vh;
}

.topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-6);
  border-bottom: 1px solid var(--border-subtle);
  background: rgba(7, 17, 31, 0.48);
  backdrop-filter: blur(18px);
  position: sticky;
  top: 0;
  z-index: 60;
  transition: background var(--transition-normal), border-color var(--transition-normal);
}

:root[data-theme="light"] .topbar {
  background: rgba(244, 248, 252, 0.86);
}

.topbar__brand,
.topbar__nav,
.panel__header,
.hero-card__top,
.hero-metrics,
.monitor-layout,
.monitor-grid,
.rules-layout,
.form-actions,
.toggle-field,
.interval-switcher,
.market-list,
.event-list,
.indicator-grid {
  display: flex;
}

.topbar__brand,
.topbar__nav,
.panel__header,
.hero-card__top,
.hero-metrics,
.form-actions,
.toggle-field,
.interval-switcher {
  align-items: center;
}

.topbar__brand,
.topbar__nav,
.panel__header,
.hero-card__top,
.hero-metrics,
.form-actions,
.market-list,
.event-list,
.indicator-grid {
  gap: var(--space-4);
}

.brand-mark {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: linear-gradient(135deg, #4cc9f0, #36d399);
  box-shadow: 0 0 18px rgba(76, 201, 240, 0.4);
}

.brand-title {
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.02em;
}

.brand-subtitle {
  color: var(--text-muted);
  font-size: 0.78rem;
}

.nav-link,
.theme-toggle,
.interval-switcher__button,
.action-button,
.symbol-item,
.field__control,
.rules-table tbody tr,
.context-link {
  transition:
    color var(--transition-fast),
    background var(--transition-fast),
    border-color var(--transition-fast),
    box-shadow var(--transition-fast),
    transform var(--transition-fast),
    opacity var(--transition-fast);
}

.nav-link {
  color: var(--text-secondary);
  padding: var(--space-2) var(--space-3);
  border-radius: 999px;
}

.nav-link:hover,
.nav-link.is-active {
  color: var(--text-primary);
  background: var(--bg-subtle);
}

.theme-toggle {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  border: 1px solid var(--border-subtle);
  background: var(--bg-panel);
  border-radius: 999px;
  padding: 6px 10px;
}

.theme-toggle__track {
  width: 38px;
  height: 22px;
  background: var(--bg-subtle);
  border-radius: 999px;
  padding: 2px;
  display: inline-flex;
  align-items: center;
}

.theme-toggle__thumb {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: linear-gradient(135deg, #4cc9f0, #36d399);
  transform: translateX(16px);
  transition: transform var(--transition-normal);
}

:root[data-theme="light"] .theme-toggle__thumb {
  transform: translateX(0);
}

.theme-toggle__label {
  color: var(--text-secondary);
  font-size: 0.86rem;
}

.user-menu {
  position: relative;
}

.user-menu__trigger {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid var(--border-subtle);
  background: var(--bg-panel);
  color: var(--text-primary);
}

.user-menu__avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border-radius: 999px;
  background: linear-gradient(135deg, #4cc9f0, #36d399);
  color: #fff;
  font-size: 0.8rem;
  font-weight: 700;
  overflow: hidden;
}

.user-menu__avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.user-menu__avatar--lg {
  width: 42px;
  height: 42px;
}

.user-menu__identity,
.user-menu__summary-text {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
}

.user-menu__identity strong,
.user-menu__summary-text strong {
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--text-primary);
}

.user-menu__identity span,
.user-menu__summary-text span {
  display: inline-flex;
  align-items: center;
  min-height: 22px;
  padding: 0 8px;
  border-radius: 999px;
  background: var(--bg-subtle);
  color: var(--text-secondary);
  font-size: 0.7rem;
  font-weight: 600;
}

.user-menu__dropdown {
  position: absolute;
  right: 0;
  top: calc(100% + 10px);
  width: 280px;
  padding: 14px;
  border: 1px solid var(--border-subtle);
  border-radius: 16px;
  background: var(--bg-panel-strong);
  box-shadow: var(--shadow-strong);
  display: grid;
  gap: 12px;
  z-index: 30;
}

.user-menu__dropdown[hidden] {
  display: none;
}

.user-menu__summary {
  display: flex;
  align-items: center;
  gap: 12px;
}

.user-menu__status,
.user-menu__link {
  font-size: 0.76rem;
  line-height: 1.45;
  color: var(--text-secondary);
}

.user-menu__link a {
  color: var(--brand-primary);
  word-break: break-all;
}

.user-menu__action {
  justify-content: center;
}

.user-menu__toggle {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border: 1px solid var(--border-subtle);
  border-radius: 12px;
  background: var(--bg-subtle);
  color: var(--text-primary);
  font-size: 0.78rem;
  font-weight: 600;
}

.user-menu__toggle input {
  margin: 0;
}

.user-menu__toggle span {
  color: var(--text-primary);
}

.page-shell {
  padding: var(--space-6);
}

.monitor-layout,
.rules-layout {
  gap: var(--space-6);
  align-items: flex-start;
}

.monitor-layout {
  display: grid;
  grid-template-columns: minmax(260px, 320px) minmax(0, 1fr);
}

.rules-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(340px, 420px);
}

.monitor-main,
.panel--sidebar,
.rule-form,
.market-list,
.event-list,
.indicator-grid,
.condition-stack {
  display: flex;
  flex-direction: column;
}

.monitor-main,
.panel--sidebar,
.rule-form,
.market-list,
.event-list,
.indicator-grid,
.condition-stack {
  gap: var(--space-5);
}

.panel,
.hero-card,
.chart-card,
.metric-card,
.indicator-card,
.symbol-item,
.action-button,
.field__control,
.rules-table-shell,
.theme-toggle {
  border: 1px solid var(--border-subtle);
  background: var(--bg-panel);
  box-shadow: var(--shadow-soft);
}

.panel,
.hero-card,
.rules-table-shell {
  border-radius: var(--radius-lg);
}

.panel,
.hero-card,
.rules-table-shell {
  padding: var(--space-5);
}

.panel--primary-surface,
.hero-card {
  background: linear-gradient(180deg, var(--bg-panel-strong), var(--bg-panel));
}

.panel__header {
  justify-content: space-between;
}

.panel__header--compact {
  gap: var(--space-3);
  margin-bottom: var(--space-2);
}

.panel__title {
  margin: 0;
  font-size: 1.08rem;
  font-weight: 700;
}

.panel__subtitle,
.eyebrow,
.context-link,
.table-empty,
.empty-state,
.field__label,
.status-chip,
.rule-meta,
.metric-card__label,
.indicator-card__label,
.symbol-item__meta,
.event-card__meta {
  color: var(--text-secondary);
}

.panel__subtitle,
.empty-state,
.table-empty,
.symbol-item__meta,
.event-card__meta,
.field__label,
.context-link {
  font-size: 0.9rem;
}

.eyebrow {
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.75rem;
  margin-bottom: var(--space-2);
}

.hero-card__title {
  margin: 0;
  font-size: clamp(1.6rem, 2vw, 2.25rem);
}

.hero-card__top {
  justify-content: space-between;
  flex-wrap: wrap;
}

.hero-metrics,
.monitor-grid,
.indicator-grid {
  display: grid;
}

.hero-metrics {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.metric-card,
.indicator-card,
.symbol-item,
.event-card {
  border-radius: var(--radius-md);
  padding: var(--space-4);
}

.metric-card {
  background: var(--bg-accent);
}

.metric-card__label,
.indicator-card__label {
  display: block;
  margin-bottom: var(--space-2);
}

.metric-card__value,
.indicator-card__value,
.symbol-item__price {
  font-family: var(--font-mono);
  font-size: 1.1rem;
  font-weight: 700;
}

.chart-card {
  border-radius: var(--radius-lg);
  padding: var(--space-2);
}

.chart-card__surface {
  height: 460px;
  width: 100%;
  border-radius: calc(var(--radius-lg) - 4px);
  background: rgba(6, 14, 24, 0.45);
}

.interval-switcher {
  flex-wrap: wrap;
}

.interval-switcher__button,
.action-button {
  border-radius: 8px;
  padding: 10px 14px;
  font-weight: 600;
}

.interval-switcher__button {
  color: var(--text-secondary);
}

.interval-switcher__button:hover,
.interval-switcher__button.is-active {
  color: var(--text-primary);
  background: var(--bg-subtle);
  border-color: var(--border-strong);
}

.action-button {
  cursor: pointer;
}

.action-button--primary {
  color: #04111d;
  background: linear-gradient(135deg, #4cc9f0, #36d399);
}

.action-button--secondary {
  color: var(--text-primary);
}

.action-button:hover,
.action-button.is-active,
.symbol-item:hover,
.context-link:hover,
.theme-toggle:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-strong);
}

.action-button.is-active {
  border-color: rgba(76, 201, 240, 0.4);
  background: var(--bg-subtle);
}

.market-list {
  min-height: 240px;
}

.symbol-item {
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
}

.symbol-item.is-active {
  border-color: rgba(76, 201, 240, 0.5);
  background: var(--bg-subtle);
}

.symbol-item__lhs,
.symbol-item__rhs {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.symbol-item__change--positive { color: var(--positive); }
.symbol-item__change--negative { color: var(--negative); }

.monitor-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-6);
}

.indicator-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.indicator-card--wide {
  grid-column: span 2;
}

.event-list {
  min-height: 180px;
}

.event-card {
  background: var(--bg-subtle);
  border: 1px solid var(--border-subtle);
}

.event-card__title {
  margin: 0 0 var(--space-2);
  font-size: 0.98rem;
}

.rules-table-shell {
  overflow: auto;
}

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

.rules-table th,
.rules-table td {
  padding: var(--space-3);
  border-bottom: 1px solid var(--border-subtle);
  text-align: left;
  vertical-align: top;
}

.rules-table th {
  color: var(--text-secondary);
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.rules-table tbody tr:hover {
  background: var(--bg-subtle);
}

.rule-form {
  gap: var(--space-4);
}

.telegram-settings-card {
  padding-bottom: var(--space-5);
  margin-bottom: var(--space-5);
  border-bottom: 1px solid var(--border-subtle);
}

.telegram-settings-form {
  gap: var(--space-4);
}

.settings-meta {
  font-size: 0.88rem;
  color: var(--text-secondary);
}

.settings-meta[data-tone="success"] {
  color: var(--positive);
}

.settings-meta[data-tone="warning"] {
  color: var(--warning);
}

.settings-meta[data-tone="error"] {
  color: var(--negative);
}

.field {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.field__control {
  width: 100%;
  border-radius: var(--radius-md);
  color: var(--text-primary);
  padding: 12px 14px;
  outline: none;
}

.field__control:focus {
  border-color: var(--border-strong);
  box-shadow: 0 0 0 3px rgba(76, 201, 240, 0.14);
}

.toggle-field {
  gap: var(--space-3);
}

.toggle-field__text {
  font-weight: 600;
}

.status-chip {
  border-radius: 999px;
  padding: 6px 10px;
  border: 1px solid var(--border-subtle);
  font-size: 0.78rem;
}

.status-chip--live {
  color: var(--positive);
  background: rgba(54, 211, 153, 0.12);
}

.status-badge {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 4px 10px;
  font-size: 0.8rem;
  font-weight: 600;
}

.status-badge--enabled { background: rgba(54, 211, 153, 0.12); color: var(--positive); }
.status-badge--disabled { background: rgba(251, 113, 133, 0.12); color: var(--negative); }

.context-link {
  white-space: nowrap;
}

.empty-state,
.table-empty {
  padding: var(--space-6);
  text-align: center;
}

.skeleton-card {
  height: 84px;
  border-radius: var(--radius-md);
  background: linear-gradient(90deg, rgba(120, 145, 180, 0.12), rgba(120, 145, 180, 0.2), rgba(120, 145, 180, 0.12));
  background-size: 200% 100%;
  animation: shimmer 1.6s linear infinite;
}

@keyframes shimmer {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

@media (max-width: 1100px) {
  .monitor-layout,
  .rules-layout,
  .monitor-grid,
  .hero-metrics,
  .indicator-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  .topbar,
  .page-shell {
    padding: var(--space-4);
  }

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

  .topbar__nav,
  .hero-card__top,
  .panel__header {
    flex-direction: column;
    align-items: stretch;
  }

  .chart-card__surface {
    height: 320px;
  }

  .rules-table th:nth-child(3),
  .rules-table td:nth-child(3),
  .rules-table th:nth-child(4),
  .rules-table td:nth-child(4) {
    display: none;
  }
}

/* --- TradingView-style Workspace --- */
.tv-workspace {
  --tv-dark-bg: #0e1621;
  --tv-dark-panel: #131722;
  --tv-dark-border: #2a2e39;
  --tv-dark-text: #d1d4dc;
  --tv-dark-muted: #a3adbb;
  --tv-dark-active: #2a2e39;
  --tv-blue: #2962ff;
  
  --tv-light-bg: #ffffff;
  --tv-light-panel: rgba(255, 255, 255, 0.95);
  --tv-light-border: #e0e3eb;
  --tv-light-text: #131722;
  --tv-light-muted: #5f6673;
  --tv-light-active: #f0f3fa;
  --tv-light-overlay: rgba(255, 255, 255, 0.94);
  --tv-light-dock: #eef2f8;
  --tv-light-divider: rgba(148, 163, 184, 0.22);
  --tv-light-overlay-border: rgba(148, 163, 184, 0.34);
  --tv-light-overlay-border-strong: rgba(148, 163, 184, 0.42);
  --tv-light-resizer-bg: linear-gradient(180deg, rgba(238, 242, 248, 0.96), rgba(226, 232, 240, 0.96));
  --tv-workspace-bg: var(--tv-dark-bg);
  --tv-chart-bg: var(--tv-dark-bg);
  --tv-panel-bg: var(--tv-dark-panel);
  --tv-panel-elevated: rgba(14, 22, 33, 0.92);
  --tv-dock-bg: var(--tv-dark-panel);
  --tv-border-color: var(--tv-dark-border);
  --tv-text-color: var(--tv-dark-text);
  --tv-muted-color: var(--tv-dark-muted);
  --tv-active-bg: var(--tv-dark-active);
  --tv-divider-subtle: rgba(120, 123, 134, 0.16);
  --tv-overlay-bg: rgba(14, 22, 33, 0.92);
  --tv-overlay-border: rgba(120, 123, 134, 0.3);
  --tv-overlay-border-strong: rgba(120, 123, 134, 0.32);
  --tv-overlay-border-soft: rgba(120, 123, 134, 0.24);
  --tv-resizer-bg: linear-gradient(180deg, rgba(14, 22, 33, 0.92), rgba(19, 23, 34, 0.96));
  --tv-card-hover: rgba(41, 98, 255, 0.10);
  --tv-card-selected: rgba(41, 98, 255, 0.18);
  --tv-card-selected-border: rgba(41, 98, 255, 0.34);
  --tv-overlay-shadow: 0 10px 24px rgba(0,0,0,0.22);
  --tv-dock-rail-bg: #11151d;
  --tv-dock-rail-border: rgba(255, 255, 255, 0.08);
  --tv-dock-icon-color: rgba(240, 243, 250, 0.84);
  --tv-dock-icon-active: #ffffff;
  --tv-dock-hover-bg: rgba(240, 243, 250, 0.08);
  --tv-dock-active-bg: #363a45;
  --tv-dock-divider: rgba(240, 243, 250, 0.16);

  display: grid;
  --tv-rail-width: 320px;
  grid-template-columns: minmax(520px, 1fr) 6px minmax(260px, var(--tv-rail-width));
  height: 100%;
  min-height: 0;
  background: var(--tv-workspace-bg);
  color: var(--tv-text-color);
}

:root[data-theme="light"] .tv-workspace {
  --tv-workspace-bg: var(--tv-light-bg);
  --tv-chart-bg: var(--tv-light-bg);
  --tv-panel-bg: var(--tv-light-panel);
  --tv-panel-elevated: var(--tv-light-overlay);
  --tv-dock-bg: var(--tv-light-dock);
  --tv-border-color: var(--tv-light-border);
  --tv-text-color: var(--tv-light-text);
  --tv-muted-color: var(--tv-light-muted);
  --tv-active-bg: var(--tv-light-active);
  --tv-divider-subtle: var(--tv-light-divider);
  --tv-overlay-bg: var(--tv-light-overlay);
  --tv-overlay-border: var(--tv-light-overlay-border);
  --tv-overlay-border-strong: var(--tv-light-overlay-border-strong);
  --tv-overlay-border-soft: rgba(148, 163, 184, 0.26);
  --tv-resizer-bg: var(--tv-light-resizer-bg);
  --tv-card-hover: rgba(41, 98, 255, 0.08);
  --tv-card-selected: rgba(41, 98, 255, 0.12);
  --tv-card-selected-border: rgba(41, 98, 255, 0.28);
  --positive: #047857;
  --negative: #c0264f;
  --warning: #8a5a00;
  --tv-overlay-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
  --tv-dock-rail-bg: #11151d;
  --tv-dock-rail-border: rgba(255, 255, 255, 0.08);
  --tv-dock-icon-color: rgba(240, 243, 250, 0.84);
  --tv-dock-icon-active: #ffffff;
  --tv-dock-hover-bg: rgba(240, 243, 250, 0.08);
  --tv-dock-active-bg: #363a45;
  --tv-dock-divider: rgba(240, 243, 250, 0.16);
  --tv-dark-bg: var(--tv-light-bg);
  --tv-dark-panel: var(--tv-light-panel);
  --tv-dark-border: var(--tv-light-border);
  --tv-dark-text: var(--tv-light-text);
  --tv-dark-muted: var(--tv-light-muted);
  --tv-dark-active: var(--tv-light-active);
}

.tv-workspace.is-sidebar-collapsed {
  grid-template-columns: minmax(520px, 1fr) 12px 48px;
}

.tv-workspace.is-sidebar-collapsed .tv-sidebar-panel {
  display: none !important;
}

.tv-workspace.is-sidebar-collapsed .tv-rail-tabs {
  flex-direction: column;
  align-items: center;
  gap: 4px;
  margin: 8px 4px 0;
  border-bottom: none;
}

.tv-workspace.is-sidebar-collapsed .tv-rail-tabs .tv-rail-tab {
  flex: 0 0 auto;
  width: 38px;
  height: 38px;
  min-height: 38px;
  padding: 0;
  border-radius: 8px;
  border-bottom: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.tv-workspace.is-sidebar-collapsed .tv-rail-tab-label {
  display: none;
}

.tv-main {
  display: flex;
  flex-direction: column;
  border-right: 1px solid var(--tv-border-color);
  min-width: 0;
  min-height: 0;
  height: 100%;
  overflow: hidden;
}

.tv-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  min-height: 38px;
  padding: 4px 10px;
  border-bottom: 1px solid var(--tv-border-color);
  background: var(--tv-panel-bg);
  position: relative;
  z-index: 20;
}

.tv-toolbar__left,
.tv-toolbar__right {
  display: flex;
  align-items: center;
  gap: 10px;
}

.tv-toolbar__left {
  min-width: 0;
  flex: 1 1 auto;
}

.tv-toolbar__right {
  flex: 0 0 auto;
}

.tv-toolbar__chart-controls {
  display: flex;
  align-items: center;
  gap: 6px;
  min-width: 0;
  max-width: 100%;
  flex: 1 1 auto;
  overflow: visible;
}

.tv-toolbar__icon-actions {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  flex: 0 0 auto;
  position: relative;
}

.tv-toolbar-title {
  font-size: 0.95rem;
  font-weight: 700;
  margin: 0;
  color: var(--tv-text-color);
}

.tv-toolbar-divider {
  width: 1px;
  height: 22px;
  background: var(--tv-border-color);
}

.tv-metric {
  display: flex;
  flex-direction: column;
  line-height: 1.2;
}

.tv-metric__label {
  font-size: 0.62rem;
  color: var(--tv-muted-color);
  text-transform: uppercase;
}

.tv-metric__value {
  font-size: 0.74rem;
  font-family: monospace;
  font-weight: 600;
  color: var(--tv-text-color);
}

.tv-metric__value.is-live-pulse {
  color: #36d399;
  text-shadow: 0 0 8px rgba(54, 211, 153, 0.55);
}

.tv-metric--updated .tv-metric__value {
  font-size: 0.7rem;
}

.tv-chart-area {
  flex: 1;
  min-height: 0;
  background: var(--tv-workspace-bg);
  position: relative;
  display: flex;
  flex-direction: row;
  padding: 0;
  border-top: 1px solid var(--tv-border-color);
}

.tv-left-dock {
  display: flex;
  align-items: stretch;
  min-height: 0;
  flex: 0 0 auto;
}

.tv-chart-wrapper {
  flex: 1;
  position: relative;
  min-width: 0;
  min-height: 0;
  overflow: hidden;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  grid-template-rows: minmax(0, 1fr) auto;
}

.tv-chart-stack {
  flex: 1 1 auto;
  min-width: 0;
  min-height: 0;
  display: flex;
  flex-direction: column;
  background: var(--tv-workspace-bg);
}

.tv-chart-wrapper > .chart-card__surface {
  position: relative;
  z-index: 1;
  min-width: 0;
  min-height: 0;
  overflow: hidden;
}

.tv-drawing-dock {
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  gap: 3px;
  align-items: center;
  flex: 0 0 52px;
  width: 52px;
  background: var(--tv-dock-rail-bg);
  border-right: 1px solid var(--tv-dock-rail-border);
  padding: 7px 8px;
  z-index: 5;
  position: relative;
  overflow-y: auto;
  overflow-x: hidden;
  max-height: 100%;
  scrollbar-width: thin;
  color: var(--tv-dock-icon-color);
}

.tv-shared-panel {
  width: 320px;
  min-width: 260px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 14px 12px 12px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--tv-panel-bg) 96%, transparent), color-mix(in srgb, var(--tv-workspace-bg) 92%, transparent));
  border-right: 1px solid var(--tv-border-color);
  overflow-y: auto;
  overflow-x: hidden;
  scrollbar-width: thin;
}

.tv-sidebar-panel.tv-shared-panel {
  width: auto;
  min-width: 0;
  padding: 0;
  gap: 0;
  border-right: none;
  background: var(--tv-panel-bg);
}

.tv-shared-panel__shell {
  min-height: 100%;
  border-bottom: none;
}

.tv-shared-panel .tv-panel-body {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 10px 12px 12px;
}

.tv-shared-panel__header,
.tv-shared-panel__status-top,
.tv-shared-panel__status-main,
.tv-shared-panel__section-header,
.tv-shared-workspace-card__header,
.tv-shared-workspace-card__footer,
.tv-shared-workspace-request__header,
.tv-shared-workspace-presence__header,
.tv-shared-workspace-member__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.tv-shared-panel__header {
  align-items: flex-start;
}

.tv-shared-panel__eyebrow {
  font-size: 0.66rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--tv-blue);
  margin-bottom: 4px;
}

.tv-shared-panel__title {
  margin: 0;
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--tv-text-color);
}

.tv-shared-panel__status,
.tv-shared-panel__meta-card,
.tv-shared-workspace-card,
.tv-shared-workspace-request,
.tv-shared-workspace-member,
.tv-shared-workspace-presence {
  border: 1px solid var(--tv-overlay-border);
  background: color-mix(in srgb, var(--tv-panel-elevated) 88%, transparent);
  border-radius: 10px;
  box-shadow: var(--tv-overlay-shadow);
  backdrop-filter: blur(10px);
}

.tv-shared-panel__status {
  padding: 12px;
  display: grid;
  gap: 8px;
}

.tv-shared-panel__status[data-tone="success"] {
  border-color: rgba(54, 211, 153, 0.24);
}

.tv-shared-panel__status[data-tone="warning"] {
  border-color: rgba(247, 195, 95, 0.28);
}

.tv-shared-panel__status[data-tone="error"] {
  border-color: rgba(251, 113, 133, 0.28);
}

.tv-shared-panel__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 24px;
  padding: 0 10px;
  border-radius: 999px;
  border: 1px solid var(--tv-card-selected-border);
  background: var(--tv-card-selected);
  color: var(--tv-text-color);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.04em;
}

.tv-shared-panel__badge[data-state="synced"] {
  border-color: rgba(54, 211, 153, 0.32);
  background: rgba(54, 211, 153, 0.12);
  color: var(--positive);
}

.tv-shared-panel__badge[data-state="connecting"] {
  border-color: rgba(247, 195, 95, 0.34);
  background: rgba(247, 195, 95, 0.12);
  color: var(--warning);
}

.tv-shared-panel__badge[data-state="offline"] {
  border-color: rgba(120, 123, 134, 0.22);
  background: rgba(120, 123, 134, 0.12);
  color: var(--tv-muted-color);
}

.tv-shared-panel__status-main {
  align-items: flex-start;
  flex-direction: column;
}

.tv-shared-panel__status-main strong {
  color: var(--tv-text-color);
  font-size: 0.88rem;
  line-height: 1.25;
}

.tv-shared-panel__status-main span {
  color: var(--tv-muted-color);
  font-size: 0.72rem;
  font-family: monospace;
}

.tv-shared-panel__status-text {
  margin: 0;
}

.tv-shared-panel__primary-action {
  margin-top: 2px;
}

.tv-shared-panel__primary-button {
  width: 100%;
  justify-content: center;
  box-shadow: none;
}

.tv-shared-panel__primary-button:disabled {
  cursor: default;
  opacity: 0.78;
}

.tv-shared-panel__meta-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.tv-shared-panel__meta-grid--single {
  grid-template-columns: minmax(0, 1fr);
}

.tv-shared-panel__meta-card {
  display: grid;
  gap: 4px;
  padding: 10px;
}

.tv-shared-panel__meta-card span {
  color: var(--tv-muted-color);
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.tv-shared-panel__meta-card strong {
  color: var(--tv-text-color);
  font-size: 1rem;
  font-family: monospace;
}

.tv-shared-panel__field {
  margin: 0;
}

.tv-shared-panel__field .field__label {
  font-size: 0.74rem;
  color: var(--tv-muted-color);
}

.tv-shared-panel__field .field__control {
  background: color-mix(in srgb, var(--tv-workspace-bg) 92%, transparent);
  border-color: var(--tv-overlay-border);
  color: var(--tv-text-color);
}

.tv-shared-panel__field .field__control::placeholder {
  color: var(--tv-muted-color);
}

.tv-shared-panel__sections {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 2px;
  min-height: 0;
}

.tv-shared-panel__section {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.tv-shared-panel__section-title {
  margin: 0;
  color: var(--tv-text-color);
  font-size: 0.8rem;
  font-weight: 700;
}

.tv-shared-panel__section-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 28px;
  min-height: 22px;
  padding: 0 8px;
  border-radius: 999px;
  background: var(--bg-subtle);
  color: var(--text-secondary);
  font-size: 0.74rem;
  font-weight: 700;
}

.tv-shared-panel__section-hint {
  color: var(--tv-muted-color);
  font-size: 0.68rem;
}

.tv-shared-panel__list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.tv-shared-workspace-card,
.tv-shared-workspace-request,
.tv-shared-workspace-member,
.tv-shared-workspace-presence {
  padding: 10px;
}

.tv-shared-workspace-card.is-active,
.tv-shared-workspace-card.is-current,
.tv-shared-workspace-request.is-pending {
  border-color: var(--tv-card-selected-border);
  box-shadow: 0 0 0 1px var(--tv-card-selected-border), var(--tv-overlay-shadow);
}

.tv-shared-workspace-card__title,
.tv-shared-workspace-request__title,
.tv-shared-workspace-member__name,
.tv-shared-workspace-presence__name {
  color: var(--tv-text-color);
  font-size: 0.82rem;
  font-weight: 700;
  line-height: 1.25;
}

.tv-shared-workspace-card__badge,
.tv-shared-workspace-request__badge,
.tv-shared-workspace-presence__badge,
.tv-shared-workspace-member__badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 8px;
  border-radius: 999px;
  background: rgba(41, 98, 255, 0.12);
  color: var(--tv-blue);
  font-size: 0.66rem;
  font-weight: 700;
  letter-spacing: 0.04em;
}

.tv-shared-workspace-card__body,
.tv-shared-workspace-request__body,
.tv-shared-workspace-member__body,
.tv-shared-workspace-presence__body {
  display: grid;
  gap: 4px;
  margin-top: 8px;
}

.tv-shared-workspace-card__meta,
.tv-shared-workspace-request__meta,
.tv-shared-workspace-member__meta,
.tv-shared-workspace-presence__meta,
.tv-shared-workspace-card__id {
  color: var(--tv-muted-color);
  font-size: 0.7rem;
  line-height: 1.35;
}

.tv-shared-workspace-card__id,
.tv-shared-workspace-member__meta code,
.tv-shared-workspace-request__meta code,
.tv-shared-workspace-presence__meta code {
  font-family: monospace;
}

.tv-shared-workspace-card__footer,
.tv-shared-workspace-request__actions {
  margin-top: 10px;
  flex-wrap: wrap;
}

.tv-shared-workspace-card__footer .action-button,
.tv-shared-workspace-request__actions .action-button {
  flex: 1 1 auto;
}

.tv-shared-workspace-presence__indicator {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--positive);
  box-shadow: 0 0 0 4px rgba(54, 211, 153, 0.14);
  flex: 0 0 auto;
}

.tv-shared-workspace-presence__header {
  justify-content: flex-start;
}

.tv-shared-workspace-request__actions,
.tv-shared-workspace-card__footer,
.tv-shared-workspace-card__chips,
.tv-shared-workspace-member__chips,
.tv-shared-workspace-presence__chips {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.tv-shared-workspace-card__chips,
.tv-shared-workspace-member__chips,
.tv-shared-workspace-presence__chips {
  margin-top: 8px;
}

.tv-shared-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 8px;
  border-radius: 999px;
  border: 1px solid var(--tv-overlay-border);
  color: var(--tv-muted-color);
  font-size: 0.66rem;
  font-weight: 600;
  background: color-mix(in srgb, var(--tv-workspace-bg) 88%, transparent);
}

.tv-shared-chip--owner,
.tv-shared-workspace-member__badge.is-owner {
  color: #f7c35f;
  background: rgba(247, 195, 95, 0.12);
}

.tv-shared-chip--member,
.tv-shared-workspace-member__badge.is-member {
  color: #7dd3fc;
  background: rgba(125, 211, 252, 0.12);
}

.tv-shared-chip--pending,
.tv-shared-workspace-request__badge.is-pending {
  color: var(--warning);
  background: rgba(251, 191, 36, 0.12);
}

.tv-shared-chip--online,
.tv-shared-workspace-presence__badge.is-online {
  color: var(--positive);
  background: rgba(54, 211, 153, 0.12);
}

.tv-shared-chip--offline,
.tv-shared-workspace-presence__badge.is-offline {
  color: var(--tv-muted-color);
  background: rgba(120, 123, 134, 0.14);
}

.tv-shared-workspace-card.is-disabled {
  opacity: 0.72;
}

.tv-shared-panel .empty-state {
  padding: 14px 12px;
  margin: 0;
  border: 1px dashed var(--tv-overlay-border);
  border-radius: 10px;
  color: var(--tv-muted-color);
  background: color-mix(in srgb, var(--tv-workspace-bg) 88%, transparent);
}

.tv-dock-group {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3px;
  width: 100%;
  min-width: 0;
  max-width: 100%;
}

.tv-dock-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border: none;
  border-radius: 7px;
  background: transparent;
  color: var(--tv-dock-icon-color);
  cursor: pointer;
  padding: 0;
  transition:
    color var(--transition-fast),
    background var(--transition-fast),
    box-shadow var(--transition-fast),
    transform var(--transition-fast);
}

.tv-dock-icon {
  width: 20px;
  height: 20px;
  flex: 0 0 auto;
  stroke: currentColor;
  fill: none;
  pointer-events: none;
}

.tv-dock-tool-group {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.tv-dock-btn--group {
  position: relative;
}

.tv-dock-btn__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
}

.tv-dock-chevron {
  position: absolute;
  right: 2px;
  bottom: 2px;
  width: 10px;
  height: 10px;
  color: color-mix(in srgb, var(--tv-dock-icon-color) 76%, transparent);
  pointer-events: none;
  transition: transform var(--transition-fast), color var(--transition-fast);
}

.tv-dock-btn--group.is-open .tv-dock-chevron {
  transform: rotate(180deg);
  color: var(--tv-dock-icon-active);
}

.tv-drawing-tool-flyout {
  box-sizing: border-box;
  position: fixed;
  z-index: 1300;
  display: grid;
  gap: 3px;
  width: 252px;
  max-width: calc(100vw - 16px);
  padding: 8px;
  overflow-y: auto;
  overflow-x: hidden;
  border: 1px solid var(--tv-overlay-border);
  border-radius: 10px;
  background: color-mix(in srgb, var(--tv-panel-elevated) 96%, transparent);
  color: var(--tv-text-color);
  box-shadow: var(--tv-overlay-shadow);
  backdrop-filter: blur(14px);
  scrollbar-width: thin;
}

.tv-drawing-tool-flyout[hidden] {
  display: none;
}

.tv-drawing-tool-flyout__heading {
  padding: 4px 6px 6px;
  color: var(--tv-muted-color);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.tv-drawing-tool-flyout__item {
  display: grid;
  grid-template-columns: 24px minmax(0, 1fr);
  align-items: center;
  gap: 8px;
  width: 100%;
  min-height: 36px;
  padding: 6px 8px;
  border: 1px solid transparent;
  border-radius: 7px;
  background: transparent;
  color: var(--tv-text-color);
  cursor: pointer;
  text-align: left;
  transition:
    color var(--transition-fast),
    background var(--transition-fast),
    border-color var(--transition-fast),
    transform var(--transition-fast);
}

.tv-drawing-tool-flyout__item .tv-dock-icon {
  width: 18px;
  height: 18px;
}

.tv-drawing-tool-flyout__item span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 0.78rem;
  font-weight: 600;
}

.tv-drawing-tool-flyout__item:hover,
.tv-drawing-tool-flyout__item:focus-visible,
.tv-drawing-tool-flyout__item.is-active {
  outline: none;
  background: var(--tv-dock-hover-bg);
  border-color: var(--tv-card-selected-border);
  color: var(--tv-dock-icon-active);
}

.tv-drawing-tool-flyout__item.is-active {
  background: var(--tv-dock-active-bg);
}

.tv-drawing-tool-flyout__item:active {
  transform: translateY(1px);
}

.tv-dock-btn:hover,
.tv-dock-btn:focus-visible,
.tv-dock-btn.is-active {
  color: var(--tv-dock-icon-active);
}

.tv-dock-btn:hover,
.tv-dock-btn:focus-visible {
  background: var(--tv-dock-hover-bg);
}

.tv-dock-btn.is-active {
  background: var(--tv-dock-active-bg);
}

.tv-dock-btn:hover,
.tv-dock-btn:focus-visible {
  outline: none;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08);
}

.tv-dock-btn:active {
  transform: translateY(1px);
}

.tv-dock-divider {
  height: 1px;
  width: 24px;
  background: var(--tv-dock-divider);
  margin: 4px auto;
}

.tv-dock-section-label {
  width: 22px;
  height: 1px;
  margin: 6px auto 5px;
  padding: 0;
  background: var(--tv-dock-divider);
  color: transparent;
  font-size: 0;
  line-height: 0;
  overflow: hidden;
}

.tv-drawing-panel-drawer {
  box-sizing: border-box;
  position: fixed;
  left: 64px;
  top: auto;
  bottom: 12px;
  width: min(280px, calc(100vw - 80px));
  max-height: min(46dvh, calc(100dvh - 24px), 420px);
  overflow-y: auto;
  overflow-x: hidden;
  border: 1px solid var(--tv-border-color);
  border-radius: 4px;
  background: var(--tv-panel-elevated);
  box-shadow: var(--tv-overlay-shadow);
  padding: 10px;
  z-index: 1200;
}

.tv-drawing-panel-drawer[hidden] {
  display: none !important;
}

.tv-chart-overlay {
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  z-index: 8;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  pointer-events: none;
}

.tv-chart-overlay:has(.tv-overlay-popover:not([hidden])) {
  z-index: 1200;
}

.tv-chart-overlay__left {
  position: relative;
  z-index: 9;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
  min-width: 0;
  padding: 8px 10px;
  pointer-events: none;
  flex: 1 1 auto;
}

.tv-chart-overlay__left .tv-chart-legend {
  margin-inline: 0;
  max-width: min(760px, calc(100vw - 160px));
}

.tv-chart-overlay__left:empty {
  display: none;
}

.tv-chart-overlay__left > * {
  pointer-events: auto;
}

.tv-chart-overlay__right {
  display: none;
}

.tv-overlay-popover,
.tv-inline-panel {
  pointer-events: auto;
  background: var(--tv-overlay-bg);
  border: 1px solid var(--tv-overlay-border);
  border-radius: 8px;
  padding: 10px;
  box-shadow: var(--tv-overlay-shadow);
  min-width: 220px;
  color: var(--tv-text-color);
  backdrop-filter: blur(12px);
}

#indicator-editor {
  width: min(840px, calc(100vw - 120px));
  max-height: min(638px, calc(100vh - 180px));
  overflow-y: auto;
}

#tv-chart-footer {
  position: relative;
  z-index: 12;
  grid-row: 2;
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  max-width: 100%;
  min-height: 30px;
  padding: 5px 10px;
  border-top: 1px solid var(--tv-border-color);
  background: color-mix(in srgb, var(--tv-panel-elevated) 92%, transparent);
  color: var(--tv-muted-color);
  font-size: 0.72rem;
  font-family: monospace;
}

.tv-chart-footer__group {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  white-space: nowrap;
}

.tv-replay-toggle.is-active {
  color: var(--tv-accent-color, #2962ff);
  border-color: color-mix(in srgb, var(--tv-accent-color, #2962ff) 60%, transparent);
  background: color-mix(in srgb, var(--tv-accent-color, #2962ff) 16%, transparent);
}

.tv-replay-bar {
  position: absolute;
  left: 50%;
  bottom: 66px;
  transform: translateX(-50%);
  z-index: 20;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  border: 1px solid var(--tv-border-color);
  border-radius: 10px;
  background: color-mix(in srgb, var(--tv-panel-elevated) 96%, transparent);
  box-shadow: 0 6px 24px rgba(0, 0, 0, 0.28);
  backdrop-filter: blur(6px);
}

.tv-replay-bar[hidden] {
  display: none;
}

.tv-replay-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 30px;
  height: 28px;
  padding: 0 8px;
  border: 1px solid var(--tv-border-color);
  border-radius: 7px;
  background: transparent;
  color: var(--tv-text-color);
  font-size: 0.82rem;
  cursor: pointer;
  transition: background 0.15s ease, border-color 0.15s ease;
}

.tv-replay-btn:hover {
  background: color-mix(in srgb, var(--tv-text-color) 8%, transparent);
}

.tv-replay-btn--play {
  color: var(--tv-accent-color, #2962ff);
  border-color: color-mix(in srgb, var(--tv-accent-color, #2962ff) 50%, transparent);
}

.tv-replay-btn--exit {
  margin-left: 2px;
  font-size: 0.74rem;
  color: var(--tv-muted-color);
}

.tv-replay-slider {
  width: 180px;
  accent-color: var(--tv-accent-color, #2962ff);
  cursor: pointer;
}

.tv-replay-position {
  min-width: 150px;
  color: var(--tv-muted-color);
  font-family: monospace;
  font-size: 0.72rem;
  white-space: nowrap;
}

.tv-replay-speeds {
  display: inline-flex;
  gap: 2px;
}

.tv-replay-speed {
  min-width: 30px;
  height: 26px;
  padding: 0 6px;
  border: 1px solid var(--tv-border-color);
  border-radius: 6px;
  background: transparent;
  color: var(--tv-muted-color);
  font-size: 0.72rem;
  cursor: pointer;
}

.tv-replay-speed.is-active {
  color: var(--tv-accent-color, #2962ff);
  border-color: color-mix(in srgb, var(--tv-accent-color, #2962ff) 55%, transparent);
  background: color-mix(in srgb, var(--tv-accent-color, #2962ff) 14%, transparent);
}

.tv-chart-footer__group--ranges {
  flex: 0 1 auto;
  min-width: 0;
  max-width: min(440px, 42vw);
  gap: 2px;
  overflow-x: auto;
  overflow-y: hidden;
  scrollbar-width: thin;
}

.tv-chart-footer__group--visible-range {
  flex: 1 1 auto;
  min-width: 154px;
}

.tv-chart-footer__range-button {
  flex: 0 0 auto;
  min-width: 28px;
  height: 22px;
  padding: 0 7px;
  border: 1px solid transparent;
  border-radius: 6px;
  background: transparent;
  color: var(--tv-muted-color);
  font: inherit;
  line-height: 20px;
  cursor: pointer;
}

.tv-chart-footer__range-button:hover,
.tv-chart-footer__range-button:focus-visible {
  outline: none;
  color: var(--tv-text-color);
  background: var(--tv-card-hover);
  border-color: var(--tv-card-selected-border);
}

.tv-chart-footer__range-button.is-active,
.tv-chart-footer__range-button[aria-pressed="true"] {
  color: var(--tv-text-color);
  background: var(--tv-active-bg);
  border-color: var(--tv-card-selected-border);
}

.tv-chart-footer__group--source {
  color: var(--tv-text-color);
  font-weight: 700;
}

.tv-chart-footer__group--hint {
  color: var(--tv-muted-color);
}

.tv-chart-footer__dot {
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: var(--positive);
  box-shadow: 0 0 0 4px rgba(54, 211, 153, 0.12);
}

#indicator-choice-list {
  max-height: min(540px, calc(100vh - 260px));
  overflow-y: auto;
  scrollbar-width: thin;
}

.tv-overlay-popover__title {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--tv-muted-color);
  margin-bottom: 8px;
}

.tv-choice-list {
  display: grid;
  gap: 8px;
}

.tv-choice-item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.82rem;
  color: var(--tv-text-color);
}

.tv-choice-section-title {
  margin: 8px 0 4px;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--tv-muted-color);
}

.tv-indicator-picker__group {
  display: grid;
  gap: 6px;
}

.tv-indicator-picker__item {
  border: 1px solid transparent;
  border-radius: 8px;
  background: transparent;
  padding: 7px 10px;
  cursor: pointer;
  text-align: left;
  justify-content: space-between;
  width: 100%;
}

.tv-indicator-picker__item:hover,
.tv-indicator-picker__item:focus-visible {
  outline: none;
  background: var(--tv-card-hover);
  border-color: var(--tv-card-selected-border);
}

.tv-choice-item__meta {
  color: var(--tv-muted-color);
  font-size: 0.72rem;
}

.tv-choice-tag {
  display: inline-block;
  margin-left: 6px;
  padding: 1px 6px;
  border-radius: 6px;
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--tv-accent-color, #2962ff);
  background: color-mix(in srgb, var(--tv-accent-color, #2962ff) 16%, transparent);
}

.tv-choice-empty {
  margin: 8px 4px;
  font-size: 0.78rem;
  color: var(--tv-muted-color);
}

.tv-choice-item--indicator-library {
  width: 100%;
  justify-content: flex-start;
  border: 1px solid transparent;
  border-radius: 8px;
  background: transparent;
  padding: 7px 10px;
  cursor: pointer;
  text-align: left;
}

.tv-choice-item--indicator-library:hover,
.tv-choice-item--indicator-library:focus-visible {
  outline: none;
  background: var(--tv-card-hover);
  border-color: var(--tv-card-selected-border);
}

.tv-inline-actions,
.tv-panel-actions,
.tv-pane-controls {
  display: flex;
  align-items: center;
  gap: 4px;
  flex-wrap: wrap;
  margin-top: 12px;
}

.tv-pane-controls {
  position: absolute;
  inset: 0;
  z-index: 4;
  pointer-events: none;
  margin-top: 0;
}

.tv-toolbar__chart-controls .interval-switcher {
  position: relative;
  z-index: 2;
  background: var(--tv-panel-elevated);
  border: 1px solid var(--tv-overlay-border-strong);
  border-radius: 6px;
  padding: 1px;
  display: flex;
  gap: 2px;
  box-shadow: none;
  backdrop-filter: blur(10px);
  min-width: 0;
  flex: 1 1 auto;
}

.tv-toolbar__chart-controls .interval-switcher__button {
  color: var(--tv-muted-color);
  border: none;
  background: transparent;
  border-radius: 4px;
  padding: 3px 7px;
  font-size: 0.76rem;
  white-space: nowrap;
  flex: 0 0 auto;
}

.tv-toolbar__chart-controls .interval-switcher__button:hover,
.tv-toolbar__chart-controls .interval-switcher__button:focus-visible,
.tv-toolbar__chart-controls .interval-switcher__button.is-active {
  color: var(--tv-text-color);
  background: var(--tv-card-selected);
}

.tv-toolbar__chart-controls .interval-switcher__button:focus-visible,
.tv-toolbar__chart-controls .action-button--secondary:focus-visible,
.tv-chart-overlay .action-button--secondary:focus-visible {
  outline: none;
  box-shadow: inset 0 0 0 1px var(--tv-card-selected-border);
}

.tv-toolbar__chart-controls .action-button--secondary:hover,
.tv-chart-overlay .action-button--secondary:hover,
.tv-toolbar__chart-controls .action-button--secondary.is-active,
.tv-chart-overlay .action-button--secondary.is-active {
  color: var(--tv-text-color);
  background: var(--tv-card-selected);
  border-color: var(--tv-card-selected-border);
}

.tv-toolbar__chart-controls .action-button,
.tv-chart-overlay .action-button,
.tv-overlay-popover,
.tv-inline-panel {
  pointer-events: auto;
}

.tv-toolbar__chart-controls .action-button--secondary,
.tv-chart-overlay .action-button--secondary {
  position: relative;
  z-index: 10;
  background: var(--tv-panel-elevated);
  border: 1px solid var(--tv-overlay-border-strong);
  color: var(--tv-text-color);
  border-radius: 6px;
  padding: 3px 8px;
  font-size: 0.76rem;
  box-shadow: none;
}

.tv-chart-type-switcher,
.tv-template-menu {
  position: relative;
  display: inline-flex;
  max-width: 100%;
  flex: 0 0 auto;
}

.tv-chart-export-button {
  flex: 0 0 auto;
}

.tv-chart-type-switcher__button {
  max-width: min(10rem, 100%);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.tv-chart-type-switcher__short-label {
  display: none;
}

.tv-chart-type-menu {
  position: absolute;
  top: calc(100% + var(--space-1));
  left: 0;
  z-index: 100;
  min-width: 9rem;
  max-width: min(16rem, calc(100vw - var(--space-6)));
  padding: var(--space-1) 0;
  border: 1px solid var(--tv-overlay-border-strong);
  border-radius: 8px;
  background: var(--tv-overlay-bg);
  box-shadow: var(--tv-overlay-shadow);
  backdrop-filter: blur(12px);
}

.tv-chart-type-menu__item {
  display: block;
  width: 100%;
  min-height: 36px;
  padding: var(--space-2) var(--space-3);
  border: none;
  background: transparent;
  color: var(--tv-text-color);
  text-align: left;
  cursor: pointer;
  font-size: 0.8rem;
}

.tv-chart-type-menu__item:hover,
.tv-chart-type-menu__item:focus-visible {
  outline: none;
  background: var(--tv-card-hover);
}

.tv-chart-export-popover {
  position: absolute;
  z-index: 20;
  width: min(280px, calc(100vw - 32px));
}

.tv-chart-export-popover[hidden] {
  display: none !important;
}

.tv-chart-export-popover__status {
  margin: 0;
  color: var(--tv-muted-color);
  font-size: 0.76rem;
  line-height: 1.45;
  word-break: break-word;
}

.tv-chart-export-popover__status[data-tone="success"] {
  color: var(--positive);
}

.tv-chart-export-popover__status[data-tone="error"] {
  color: var(--negative);
}

.tv-toolbar__chart-controls #timeframe-selector {
  flex-wrap: nowrap;
  white-space: nowrap;
  overflow-x: auto;
  scrollbar-width: none;
  min-width: 0;
  inline-size: 100%;
  max-width: 100%;
  overscroll-behavior-inline: contain;
  -webkit-overflow-scrolling: touch;
}

.tv-toolbar__chart-controls #timeframe-selector::-webkit-scrollbar {
  display: none;
}

.action-button--icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0;
}

.action-button--icon svg {
  flex: 0 0 auto;
}

.action-button--icon-compact {
  width: 28px;
  height: 28px;
  padding: 0;
  border-radius: 8px;
}

.tv-chart-legend {
  max-width: min(760px, calc(100vw - 120px));
  overflow: visible;
  padding: 0;
  border: none;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
  margin-inline: auto;
  pointer-events: auto;
}

.tv-chart-legend::-webkit-scrollbar,
.tv-pane-legend::-webkit-scrollbar,
.tv-drawing-dock::-webkit-scrollbar,
.tv-drawing-tool-flyout::-webkit-scrollbar,
.tv-sidebar-panel::-webkit-scrollbar,
.tv-panel-body::-webkit-scrollbar,
.tv-market-list::-webkit-scrollbar,
.tv-paper-trading-panel::-webkit-scrollbar,
.tv-overlay-popover::-webkit-scrollbar,
.tv-inline-panel::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}

.tv-chart-legend::-webkit-scrollbar-track,
.tv-pane-legend::-webkit-scrollbar-track,
.tv-drawing-dock::-webkit-scrollbar-track,
.tv-drawing-tool-flyout::-webkit-scrollbar-track,
.tv-sidebar-panel::-webkit-scrollbar-track,
.tv-panel-body::-webkit-scrollbar-track,
.tv-market-list::-webkit-scrollbar-track,
.tv-paper-trading-panel::-webkit-scrollbar-track,
.tv-overlay-popover::-webkit-scrollbar-track,
.tv-inline-panel::-webkit-scrollbar-track {
  background: transparent;
}

.tv-chart-legend::-webkit-scrollbar-thumb,
.tv-pane-legend::-webkit-scrollbar-thumb,
.tv-drawing-dock::-webkit-scrollbar-thumb,
.tv-drawing-tool-flyout::-webkit-scrollbar-thumb,
.tv-sidebar-panel::-webkit-scrollbar-thumb,
.tv-panel-body::-webkit-scrollbar-thumb,
.tv-market-list::-webkit-scrollbar-thumb,
.tv-paper-trading-panel::-webkit-scrollbar-thumb,
.tv-overlay-popover::-webkit-scrollbar-thumb,
.tv-inline-panel::-webkit-scrollbar-thumb {
  border-radius: 999px;
  background: color-mix(in srgb, var(--tv-muted-color) 46%, transparent);
}

.tv-chart-overlay__left .tv-chart-legend {
  align-self: flex-start;
  margin-inline: 0;
}

#tv-indicator-legend {
  align-self: flex-start;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

.tv-chart-legend__row {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.tv-chart-legend__row + .tv-chart-legend__row {
  margin-top: 4px;
}

.tv-chart-legend__row--meta {
  justify-content: space-between;
  gap: 12px;
}

.tv-chart-legend__symbol,
.tv-chart-legend__time,
.tv-chart-legend__value,
.tv-chart-legend__ohlc-value {
  font-family: monospace;
}

.tv-chart-legend__symbol {
  color: var(--tv-text-color);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.04em;
}

.tv-chart-legend__time {
  color: var(--tv-muted-color);
  font-size: 0.72rem;
}

.tv-chart-legend__ohlc-item,
.tv-chart-legend__item {
  display: inline-flex;
  align-items: baseline;
  gap: 4px;
  min-height: 18px;
}

.tv-chart-legend__label,
.tv-chart-legend__ohlc-label {
  color: var(--tv-muted-color);
  font-size: 0.68rem;
  text-transform: uppercase;
}

.tv-chart-legend__value,
.tv-chart-legend__ohlc-value {
  font-size: 0.74rem;
  font-weight: 600;
  color: var(--tv-text-color);
}

.tv-chart-legend__row--ohlc,
.tv-chart-legend__row--indicators {
  color: var(--tv-text-color);
}

.tv-pane-controls {
  padding: 0;
  border: none;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
}

.tv-pane-controls__group {
  position: absolute;
  bottom: 64px;
  right: 64px;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--tv-panel-elevated) 86%, transparent);
  border: 1px solid var(--tv-overlay-border);
  box-shadow: var(--tv-overlay-shadow);
  backdrop-filter: blur(10px);
  pointer-events: auto;
}

.tv-pane-controls .action-button--secondary {
  min-width: 24px;
  width: 24px;
  height: 24px;
  padding: 0;
  background: transparent;
  border: 1px solid transparent;
  color: var(--tv-text-color);
  border-radius: 999px;
  box-shadow: none;
  font-size: 0.68rem;
  font-weight: 700;
}

.tv-pane-controls .action-button--secondary:hover,
.tv-pane-controls .action-button--secondary.is-active {
  background: var(--tv-card-selected);
  border-color: var(--tv-card-selected-border);
  color: var(--tv-text-color);
}

/* ---- Chart right-click context menu (TradingView-style) ---- */
.tv-chart-context-menu {
  position: absolute;
  z-index: 60;
  min-width: 216px;
  padding: 6px;
  border: 1px solid var(--tv-overlay-border, var(--tv-border-color));
  border-radius: 10px;
  background: color-mix(in srgb, var(--tv-panel-elevated) 97%, transparent);
  box-shadow: var(--tv-overlay-shadow, 0 12px 36px rgba(0, 0, 0, 0.38));
  backdrop-filter: blur(12px);
  color: var(--tv-text-color);
  font-size: 0.78rem;
  user-select: none;
}

.tv-chart-context-menu[hidden] {
  display: none;
}

.tv-chart-context-menu__item {
  display: flex;
  align-items: center;
  gap: 9px;
  width: 100%;
  padding: 7px 9px;
  border: none;
  border-radius: 7px;
  background: transparent;
  color: var(--tv-text-color);
  font-size: 0.78rem;
  text-align: left;
  cursor: pointer;
  transition: background 0.12s ease;
}

.tv-chart-context-menu__item:hover {
  background: color-mix(in srgb, var(--tv-text-color) 9%, transparent);
}

.tv-chart-context-menu__item.is-active {
  color: var(--tv-accent-color, #2962ff);
}

.tv-chart-context-menu__icon {
  display: inline-flex;
  flex: 0 0 16px;
  color: var(--tv-muted-color);
}

.tv-chart-context-menu__item.is-active .tv-chart-context-menu__icon {
  color: var(--tv-accent-color, #2962ff);
}

.tv-chart-context-menu__check-slot {
  display: inline-flex;
  flex: 0 0 16px;
  justify-content: center;
  color: var(--tv-accent-color, #2962ff);
  font-size: 0.74rem;
}

.tv-chart-context-menu__meta {
  margin-left: auto;
  padding-left: 12px;
  color: var(--tv-muted-color);
  font-family: monospace;
  font-size: 0.72rem;
}

.tv-chart-context-menu__divider {
  height: 1px;
  margin: 5px 4px;
  background: var(--tv-border-color);
}

.tv-chart-context-menu__group-label {
  padding: 4px 9px 2px;
  color: var(--tv-muted-color);
  font-size: 0.66rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.tv-chart-legend__value--ma7 { color: #7dd3fc; }
.tv-chart-legend__value--ma25 { color: #f7c35f; }
.tv-chart-legend__value--ma99 { color: #c084fc; }
.tv-chart-legend__value--rsi { color: #fb923c; }
.tv-chart-legend__value--macd { color: #93c5fd; }
.tv-chart-legend__value--signal { color: #fda4af; }
.tv-chart-legend__value--histogram-positive { color: #26a69a; }
.tv-chart-legend__value--histogram-negative { color: #ef5350; }

.tv-crosshair-tooltip {
  position: absolute;
  left: 0;
  top: 0;
  z-index: 12;
  min-width: 168px;
  max-width: calc(100% - 16px);
  box-sizing: border-box;
  padding: var(--space-2) var(--space-3);
  border: 1px solid var(--tv-overlay-border, var(--tv-border-color));
  border-radius: 6px;
  background: color-mix(in srgb, var(--tv-panel-elevated) 96%, transparent);
  color: var(--tv-text-color);
  box-shadow: var(--tv-overlay-shadow);
  pointer-events: none;
  opacity: 0;
  transition: opacity var(--transition-fast), transform var(--transition-fast);
  font-family: 'JetBrains Mono', var(--font-mono), monospace;
  font-size: 0.72rem;
  line-height: 1.35;
  font-variant-numeric: tabular-nums;
  backdrop-filter: blur(10px);
  will-change: transform;
}

.tv-crosshair-tooltip.is-visible {
  opacity: 1;
}

.tv-crosshair-tooltip[hidden] {
  display: block;
  opacity: 0;
  visibility: hidden;
}

.tv-crosshair-tooltip__header,
.tv-crosshair-tooltip__grid {
  display: grid;
  gap: 4px 12px;
}

.tv-crosshair-tooltip__header {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  margin-bottom: 6px;
  padding-bottom: 5px;
  border-bottom: 1px solid var(--tv-border-color);
  color: var(--tv-muted-color);
  font-size: 0.66rem;
}

.tv-crosshair-tooltip__grid {
  grid-template-columns: auto minmax(8ch, 1fr);
}

.tv-crosshair-tooltip__label {
  color: var(--tv-muted-color);
  text-transform: uppercase;
}

.tv-crosshair-tooltip__value {
  color: var(--tv-text-color);
  text-align: right;
  font-weight: 700;
}

.tv-chart-legend__row--indicators {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.tv-chart-legend__row--pane {
  justify-content: space-between;
  flex-wrap: nowrap;
  gap: 8px;
}

.tv-chart-legend__group {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.tv-chart-legend__group + .tv-chart-legend__group {
  margin-top: 6px;
}

.tv-chart-legend__group-title {
  display: none;
}

.tv-chart-legend__group-items {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.tv-chart-legend__indicator-row {
  display: flex;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 8px;
  min-width: 0;
}

.tv-chart-legend__indicator-main {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: nowrap;
  min-width: 0;
  flex: 1 1 min(260px, 100%);
  overflow: hidden;
}

.tv-chart-legend__indicator-name {
  color: var(--tv-text-color);
  font-size: 0.75rem;
  font-weight: 600;
  white-space: nowrap;
  flex: 0 0 auto;
}

.tv-chart-legend__indicator-placement {
  display: none;
}

.tv-chart-legend__indicator-actions {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  opacity: 0;
  transition: opacity 0.15s ease;
  flex: 0 0 auto;
}

.tv-chart-legend__indicator-row:hover .tv-chart-legend__indicator-actions,
.tv-chart-legend__indicator-row.is-settings-open .tv-chart-legend__indicator-actions {
  opacity: 1;
}

.tv-chart-legend__indicator-actions .action-button--icon-compact {
  width: 22px;
  height: 22px;
  border-radius: 6px;
  padding: 0;
  box-shadow: none;
}

.tv-chart-legend__indicator-actions .action-button--secondary {
  background: color-mix(in srgb, var(--tv-overlay-bg) 74%, transparent);
  border-color: var(--tv-overlay-border-soft);
}

.tv-chart-legend__indicator-values {
  display: inline-flex;
  align-items: baseline;
  gap: 8px;
  flex-wrap: nowrap;
  min-width: 0;
  overflow-x: auto;
  scrollbar-width: none;
}

.tv-chart-legend__indicator-values::-webkit-scrollbar {
  display: none;
}

.tv-chart-legend__indicator-row.is-disabled {
  opacity: 0.55;
}

.tv-chart-legend__indicator-shell {
  width: 100%;
  flex: 0 0 100%;
  order: 3;
  margin-left: 0;
  display: none;
  margin-top: 4px;
  padding: 8px 10px;
  border: 1px solid var(--tv-overlay-border);
  border-radius: 8px;
  background: var(--tv-panel-elevated);
}

.tv-chart-legend__indicator-row.is-settings-open .tv-chart-legend__indicator-shell {
  display: block;
}

.tv-chart-legend__indicator-shell-title {
  font-size: 0.7rem;
  text-transform: uppercase;
  color: var(--tv-muted-color);
  margin-bottom: 6px;
}

.tv-chart-legend__param-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(88px, 1fr));
  gap: 8px;
  margin-bottom: 8px;
}

.tv-chart-legend__param-field {
  display: grid;
  gap: 4px;
  font-size: 0.72rem;
  color: var(--tv-muted-color);
}

.tv-chart-legend__param-field input {
  width: 100%;
  border: 1px solid var(--tv-border-color);
  border-radius: 6px;
  background: var(--tv-workspace-bg);
  color: var(--tv-text-color);
  padding: 6px 8px;
  font: inherit;
}

.tv-chart-legend__shell-actions {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
}

.tv-pane-legends {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 3;
}

.tv-pane-legend {
  position: absolute;
  left: 12px;
  right: 12px;
  pointer-events: none;
}

.tv-pane-legend .tv-chart-legend__row {
  flex-wrap: nowrap;
}

.tv-pane-legend .tv-chart-legend__indicator-row,
.tv-pane-legend .tv-chart-legend__indicator-main,
.tv-pane-legend .tv-chart-legend__indicator-values {
  min-width: 0;
}

.tv-pane-legend .tv-chart-legend__indicator-actions,
.tv-pane-legend .tv-chart-legend__indicator-shell,
.tv-pane-legend .tv-chart-legend__shell-actions,
.tv-pane-legend .tv-chart-legend__indicator-row > * {
  pointer-events: auto;
}

.tv-watchlist-search-field {
  margin-bottom: 10px;
}

.tv-watchlist-choice-list {
  max-height: 320px;
  overflow-y: auto;
}

.tv-watchlist-choice-item {
  justify-content: space-between;
  gap: 10px;
  width: 100%;
  padding: 8px 0;
  border-bottom: 1px solid var(--tv-divider-subtle);
}

.tv-watchlist-choice-item:last-child {
  border-bottom: none;
}

.tv-watchlist-choice-symbol {
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.tv-watchlist-choice-symbol strong {
  color: var(--tv-text-color);
}

.tv-watchlist-choice-symbol span {
  color: var(--tv-muted-color);
  font-size: 0.74rem;
}

.tv-watchlist-remove {
  width: 22px;
  height: 22px;
  padding: 0;
  border-radius: 6px;
  flex: 0 0 auto;
}

@media (max-width: 1220px) {
  .tv-toolbar {
    flex-wrap: wrap;
    align-items: flex-start;
  }

  .tv-toolbar__left,
  .tv-toolbar__right {
    width: 100%;
  }

  .tv-toolbar__left {
    flex-wrap: wrap;
    gap: 10px;
  }

  .tv-toolbar__chart-controls {
    width: 100%;
  }
}

@media (max-width: 720px) {
  .tv-toolbar__chart-controls {
    flex-wrap: wrap;
  }

  .tv-toolbar-divider {
    display: none;
  }

  .tv-toolbar__icon-actions {
    margin-left: auto;
  }

  .tv-chart-legend {
    max-width: calc(100vw - 92px);
  }
}

.tv-drawing-item {
  display: grid;
  gap: 6px;
  padding: 7px 8px;
  border: 1px solid var(--tv-border-color);
  border-radius: 4px;
  background: var(--tv-panel-bg);
  color: var(--tv-text-color);
}

.tv-drawing-item.is-selected {
  border-color: var(--tv-blue);
  background: var(--tv-card-selected);
}

.tv-drawing-item.is-hidden {
  opacity: 0.55;
}

.tv-drawing-item.is-locked {
  background: color-mix(in srgb, var(--tv-panel-bg) 82%, var(--tv-blue));
  box-shadow: inset 0 0 0 1px var(--tv-card-selected-border);
}

.tv-drawing-item.is-hidden .tv-drawing-item__label {
  color: var(--tv-muted-color);
}

.tv-drawing-item.is-locked .tv-drawing-item__meta {
  color: var(--tv-text-color);
}

.tv-drawing-item__top,
.tv-drawing-item__actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  flex-wrap: wrap;
}

.tv-drawing-item__label {
  font-size: 0.8rem;
  font-weight: 600;
}

.tv-drawing-item__meta {
  font-size: 0.72rem;
  color: var(--tv-muted-color);
  font-family: monospace;
}

.tv-drawing-item__editor {
  display: none;
  gap: 8px;
}

.tv-drawing-item__editor.is-open {
  display: grid;
}

.tv-drawing-item__editor-label {
  display: grid;
  gap: 4px;
  font-size: 0.72rem;
  color: var(--tv-muted-color);
}

.tv-drawing-item__editor-label input {
  width: 100%;
  border: 1px solid var(--tv-border-color);
  border-radius: 4px;
  background: var(--tv-workspace-bg);
  color: var(--tv-text-color);
  padding: 6px 8px;
}

.tv-drawing-item__editor-colors,
.tv-drawing-item__editor-actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.drawing-context-toolbar {
  position: absolute;
  z-index: 30;
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 5px 7px;
  border-radius: 10px;
  background: var(--tv-panel-bg, #1c2030);
  border: 1px solid var(--tv-border-color, rgba(255, 255, 255, 0.12));
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
  backdrop-filter: blur(8px);
  pointer-events: auto;
  max-width: calc(100% - 12px);
  flex-wrap: nowrap;
}

.drawing-context-toolbar[hidden] {
  display: none;
}

.drawing-context-toolbar__sep {
  width: 1px;
  align-self: stretch;
  margin: 2px 2px;
  background: var(--tv-border-color, rgba(255, 255, 255, 0.14));
}

.drawing-context-toolbar__swatch {
  position: relative;
  width: 26px;
  height: 26px;
  border-radius: 7px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  border: 1px solid transparent;
}

.drawing-context-toolbar__swatch:hover {
  border-color: var(--tv-blue, #3aa0ff);
  background: rgba(255, 255, 255, 0.06);
}

.drawing-context-toolbar__swatch-dot {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, 0.35);
  background: #3aa0ff;
  pointer-events: none;
}

.drawing-context-toolbar__swatch-dot--fill {
  border-radius: 4px;
}

.drawing-context-toolbar__swatch input[type="color"] {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  cursor: pointer;
  border: none;
  padding: 0;
}

.drawing-context-toolbar__select {
  height: 26px;
  border-radius: 7px;
  background: var(--tv-input-bg, rgba(255, 255, 255, 0.06));
  color: var(--tv-text-primary, #e8ebf2);
  border: 1px solid var(--tv-border-color, rgba(255, 255, 255, 0.14));
  font-size: 12px;
  padding: 0 6px;
  cursor: pointer;
}

.drawing-context-toolbar__btn {
  width: 28px;
  height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 7px;
  border: 1px solid transparent;
  background: transparent;
  color: var(--tv-text-secondary, #aab2c5);
  cursor: pointer;
  transition: background 0.12s ease, color 0.12s ease;
}

.drawing-context-toolbar__btn:hover {
  background: rgba(255, 255, 255, 0.08);
  color: var(--tv-text-primary, #e8ebf2);
}

.drawing-context-toolbar__btn.is-active {
  background: var(--tv-blue, #3aa0ff);
  color: #fff;
}

.drawing-context-toolbar__btn--danger:hover {
  background: rgba(229, 72, 77, 0.16);
  color: #ff6b6b;
}

@media (max-width: 520px) {
  .drawing-context-toolbar {
    gap: 2px;
    padding: 4px 5px;
  }
  .drawing-context-toolbar__btn {
    width: 26px;
    height: 26px;
  }
  .drawing-context-toolbar__select {
    font-size: 11px;
    padding: 0 4px;
  }
}

.tv-rail-resizer {
  width: 6px;
  cursor: col-resize;
  background: var(--tv-resizer-bg);
  border-left: 1px solid var(--tv-border-color);
  border-right: 1px solid var(--tv-border-color);
}

.tv-rail-resizer:hover,
.tv-workspace.is-resizing .tv-rail-resizer {
  background: var(--tv-blue);
}

.tv-chart-area .chart-card__surface {
  box-sizing: border-box;
  height: 100%;
  width: 100%;
  max-width: 100%;
  min-height: 0;
  border-radius: 0;
  background: var(--tv-chart-bg);
  pointer-events: auto;
}

.tv-panel-header {
  padding: 8px 12px;
  border-bottom: 1px solid var(--tv-border-color);
  background: var(--tv-panel-bg);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.tv-panel-title {
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--tv-text-color);
  margin: 0;
}

.tv-panel-body {
  padding: 12px;
  overflow-y: auto;
  flex: 1;
}

.tv-rail {
  display: flex;
  flex-direction: column;
  background: var(--tv-workspace-bg);
  min-height: 0;
  overflow: hidden;
}

.tv-rail-tabs {
  margin: 0;
  padding: 0;
  flex-shrink: 0;
  display: flex;
  border-bottom: 1px solid var(--tv-border-color);
  background: var(--tv-panel-bg);
}

.tv-rail-tabs .tv-rail-tab {
  flex: 1;
  border-radius: 0;
  min-width: 0;
  min-height: 42px;
  padding: 6px 8px;
  font-size: 0.85rem;
  font-family: inherit;
  font-weight: 600;
  color: var(--tv-muted-color);
  border: none;
  border-bottom: 2px solid transparent;
  background: transparent;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3px;
  transition:
    color var(--transition-fast),
    background var(--transition-fast),
    border-color var(--transition-fast);
}

.tv-rail-tab-icon {
  width: 18px;
  height: 18px;
  flex: 0 0 auto;
}

.tv-rail-tab-label {
  font-size: 0.66rem;
  line-height: 1;
}

.tv-rail-tabs .tv-rail-tab:hover,
.tv-rail-tabs .tv-rail-tab:focus-visible {
  outline: none;
  color: var(--tv-text-color);
  background: var(--tv-active-bg);
}

.tv-rail-tabs .tv-rail-tab.is-active {
  color: var(--tv-blue);
  border-bottom-color: var(--tv-blue);
  background: var(--tv-panel-bg);
}

.tv-sidebar-panel {
  display: none;
  flex-direction: column;
  flex: 1;
  min-height: 0;
  overflow: hidden;
  background: var(--tv-panel-bg);
}

.tv-sidebar-panel.is-active {
  display: flex;
  overflow-y: auto;
  overflow-x: hidden;
}

.tv-sidebar-panel[data-sidebar-content="market"].is-active {
  overflow-y: auto;
  overflow-x: hidden;
}

.tv-sidebar-panel[data-sidebar-content="market"].is-active .tv-rail-section--watchlist {
  flex: 1 1 auto;
  min-height: 0;
}

.tv-sidebar-panel[data-sidebar-content="market"].is-active .tv-market-list {
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
}

.tv-sidebar-panel > .tv-panel-body,
.tv-sidebar-panel.is-active > .tv-panel-body {
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
}

.tv-rail-section {
  display: flex;
  flex-direction: column;
  border-bottom: 1px solid var(--tv-border-color);
  background: var(--tv-panel-bg);
}

.tv-rail-section .tv-panel-header {
  border-bottom: none;
}

.tv-market-list {
  display: flex;
  flex-direction: column;
}

.tv-market-list .symbol-item {
  padding: 0;
  border: none;
  border-bottom: 1px solid var(--tv-border-color);
  border-radius: 0;
  background: transparent;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
  color: var(--tv-text-color);
}

.tv-market-list .symbol-item:hover,
.tv-market-list .symbol-item.is-active,
.tv-market-list .symbol-item:focus-within {
  background: var(--tv-active-bg);
}

.tv-market-list .symbol-item.is-active,
.tv-market-list .symbol-item:focus-within {
  box-shadow: inset 0 0 0 1px var(--tv-card-selected-border);
}

.tv-market-list .symbol-item__select {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
  width: 100%;
  min-width: 0;
  border: none;
  background: transparent;
  color: inherit;
  padding: 6px 12px;
  text-align: left;
  appearance: none;
  -webkit-appearance: none;
  cursor: pointer;
  font: inherit;
  border-radius: 0;
}

.tv-market-list .symbol-item__select:hover,
.tv-market-list .symbol-item__select:focus,
.tv-market-list .symbol-item__select:focus-visible {
  outline: none;
  box-shadow: none;
  background: transparent;
}

.tv-market-list .symbol-item__lhs,
.tv-market-list .symbol-item__rhs {
  min-width: 0;
}

.tv-market-list .symbol-item__meta,
.tv-market-list .symbol-item__price--muted {
  color: var(--tv-muted-color);
}

.tv-watchlist-remove.action-button--secondary {
  background: transparent;
  border-color: transparent;
  color: var(--tv-muted-color);
  box-shadow: none;
}

.tv-watchlist-remove.action-button--secondary:hover,
.tv-watchlist-remove.action-button--secondary:focus-visible {
  background: var(--tv-card-hover);
  border-color: var(--tv-card-selected-border);
  color: var(--tv-text-color);
}

.symbol-item__select {
  border: none;
  margin: 0;
  font: inherit;
  background: transparent;
  color: inherit;
  text-align: left;
  appearance: none;
  -webkit-appearance: none;
}

.symbol-item__rhs {
  align-items: flex-end;
}

.symbol-item__price,
.symbol-item__change--positive,
.symbol-item__change--negative {
  min-width: 7ch;
  text-align: right;
  font-variant-numeric: tabular-nums;
  font-size: 0.85rem;
}

.symbol-item__price--muted {
  color: var(--tv-muted-color);
}

.tv-main-pane-legend {
  max-width: min(760px, calc(100vw - 96px));
}

.tv-pane-legends {
  position: absolute;
  inset: 0;
  z-index: 3;
  pointer-events: none;
}

.tv-pane-legend {
  position: absolute;
  left: 8px;
  width: fit-content;
  max-width: min(480px, 100%);
  top: -9999px;
  padding: 0;
  border: none;
  border-radius: 0;
  background: transparent;
  backdrop-filter: none;
  color: var(--tv-text-color);
  box-shadow: none;
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  pointer-events: auto;
}

.tv-pane-legend:empty {
  display: none;
}

.tv-pane-legend__title {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--tv-muted-color);
}

.tv-pane-legend__value {
  font-size: 0.78rem;
  font-weight: 600;
  font-family: monospace;
}

.tv-pane-legend__value--positive {
  color: #26a69a;
}

.tv-pane-legend__value--negative {
  color: #ef5350;
}

.tv-drawing-context-toolbar {
  position: absolute;
  z-index: 9;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 6px;
  border-radius: 8px;
  border: 1px solid var(--tv-overlay-border);
  background: var(--tv-overlay-bg);
  box-shadow: var(--tv-overlay-shadow);
  backdrop-filter: blur(12px);
}

.tv-drawing-context-toolbar[hidden] {
  display: none !important;
}

.tv-drawing-context-toolbar__colors {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.tv-drawing-context-toolbar__color {
  width: 14px;
  height: 14px;
  padding: 0;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.18);
  cursor: pointer;
}

.tv-drawing-context-toolbar__color.is-active {
  box-shadow: 0 0 0 2px rgba(255,255,255,0.24);
}

.tv-drawing-context-toolbar__color.is-cyan { background: #4cc9f0; }
.tv-drawing-context-toolbar__color.is-green { background: #36d399; }
.tv-drawing-context-toolbar__color.is-amber { background: #f7c35f; }
.tv-drawing-context-toolbar__color.is-rose { background: #fb7185; }

.tv-rule-card {
  background: var(--tv-workspace-bg);
  border: 1px solid var(--tv-border-color);
  border-radius: 4px;
  padding: 10px;
  margin: 8px 12px;
  font-size: 0.85rem;
}

.tv-rule-card__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 8px;
  color: var(--tv-text-color);
}

.tv-rule-card__body {
  color: var(--tv-muted-color);
}

.tv-rule-card__actions {
  margin-top: 10px;
  justify-content: flex-end;
}

.action-button--sm {
  padding: 4px 8px;
  font-size: 0.75rem;
  border-radius: 4px;
}

.tv-indicator-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 6px 0;
  border-bottom: 1px solid var(--tv-border-color);
}

.tv-indicator-row:last-child {
  border-bottom: none;
}

.tv-indicator-label {
  color: var(--tv-muted-color);
  font-size: 0.85rem;
}

.tv-indicator-value {
  font-family: monospace;
  font-weight: 600;
  font-size: 0.9rem;
}

.tv-monitoring-panel .event-card {
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--tv-border-color);
  padding: 8px 12px;
  border-radius: 0;
  margin: 0;
  color: var(--tv-text-color);
}
.tv-monitoring-panel .event-card:last-child {
  border-bottom: none;
}
.tv-monitoring-panel .event-card__title {
  font-size: 0.85rem;
  margin-bottom: 4px;
}
.tv-monitoring-panel .event-card__meta {
  font-size: 0.75rem;
  color: var(--tv-muted-color);
}
.tv-monitoring-panel .event-card p {
  margin: 4px 0 0 0;
  font-size: 0.8rem;
  color: var(--tv-text-color);
}

.tv-monitoring-panel {
  padding: 0;
}

.tv-rail-section .field { gap: 4px; margin-bottom: 12px; }
.tv-rail-section .field__label { font-size: 0.75rem; color: var(--tv-muted-color); }
.tv-rail-section .field__control { 
  padding: 6px 10px; 
  font-size: 0.85rem; 
  background: var(--tv-workspace-bg); 
  border: 1px solid var(--tv-border-color); 
  color: var(--tv-text-color); 
  border-radius: 4px;
}
.tv-rail-section .field__control:focus {
  border-color: var(--tv-blue);
  outline: none;
}
.tv-rail-section .action-button--primary {
  background: var(--tv-blue);
  color: #fff;
  border: none;
  border-radius: 4px;
}
.tv-rail-section .action-button--secondary {
  background: var(--tv-workspace-bg);
  border: 1px solid var(--tv-border-color);
  color: var(--tv-text-color);
  border-radius: 4px;
}

.tv-trade-panel {
  padding: 0;
}

.tv-paper-trading-panel {
  display: flex;
  flex-direction: column;
  min-height: 0;
  flex: 1 1 auto;
  height: 100%;
  overflow: hidden;
  background: var(--tv-panel-bg);
}

/* Top: compact order ticket */
.paper-ticket-zone {
  flex: 0 0 auto;
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 12px;
  border-bottom: 1px solid var(--tv-border-color);
}

.paper-ticket-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--tv-text-color);
}

.paper-ticket-badge {
  font-size: 10px;
  font-weight: 500;
  color: var(--tv-muted-color);
  padding: 2px 6px;
  border: 1px solid var(--tv-border-color);
  border-radius: 4px;
}

.tv-paper-trading-panel .order-form {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.tv-paper-trading-panel .order-submit-btn {
  align-self: stretch;
}

/* Bar Replay coupling — gate shown when no replay session is active */
.paper-replay-gate {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  margin-bottom: 6px;
  border: 1px dashed var(--tv-border-color);
  border-radius: 8px;
  background: color-mix(in srgb, var(--tv-accent-color, #2962ff) 8%, transparent);
  color: var(--tv-muted-color);
  font-size: 0.74rem;
  line-height: 1.3;
}

.paper-replay-gate__icon {
  font-size: 0.9rem;
  color: var(--tv-accent-color, #2962ff);
}

.order-form.is-disabled {
  opacity: 0.45;
  pointer-events: none;
  filter: grayscale(0.3);
}

.paper-replay-price {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
  padding: 3px 8px;
  border-radius: 6px;
  background: color-mix(in srgb, var(--tv-accent-color, #2962ff) 12%, transparent);
  color: var(--tv-muted-color);
  font-size: 0.7rem;
  font-family: var(--font-mono), monospace;
}

.paper-replay-price strong {
  color: var(--tv-accent-color, #2962ff);
  font-variant-numeric: tabular-nums;
}

.order-bracket {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px;
}

#tv-chart.is-dragging-order {
  cursor: ns-resize;
}

.order-input--tp {
  border-color: color-mix(in srgb, #26a69a 50%, var(--tv-border-color)) !important;
}

.order-input--sl {
  border-color: color-mix(in srgb, #ef5350 50%, var(--tv-border-color)) !important;
}

/* Paper terminal is hidden until a Bar Replay session is active */
.paper-replay-prompt {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 12px;
  padding: 18px 16px;
  border: 1px dashed var(--tv-border-color);
  border-radius: 10px;
  background: color-mix(in srgb, var(--tv-accent-color, #2962ff) 6%, transparent);
  color: var(--tv-muted-color);
}

.paper-replay-prompt[hidden] { display: none; }

.paper-replay-prompt__icon {
  font-size: 1.4rem;
  color: var(--tv-accent-color, #2962ff);
}

.paper-replay-prompt__text {
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.paper-replay-prompt__text strong {
  color: var(--tv-text-color);
  font-size: 0.82rem;
}

.paper-replay-prompt__text span {
  font-size: 0.74rem;
  line-height: 1.35;
}

.paper-terminal {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
}

.paper-terminal[hidden] { display: none; }

.paper-ticket-head__right {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-left: auto;
}

.paper-reset-btn {
  padding: 2px 9px;
  border: 1px solid var(--tv-border-color);
  border-radius: 6px;
  background: transparent;
  color: var(--tv-muted-color);
  font-size: 0.7rem;
  cursor: pointer;
}

.paper-reset-btn:hover {
  color: var(--tv-text-color);
  background: color-mix(in srgb, var(--tv-text-color) 8%, transparent);
}

.paper-cost-preview {
  min-height: 1em;
  font-size: 0.72rem;
  color: var(--tv-muted-color);
  font-family: var(--font-mono), monospace;
}

.paper-cost-preview.is-insufficient {
  color: #ef5350;
  font-weight: 600;
}

/* Right: tabbed activity area */
.paper-activity-zone {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  min-width: 0;
  min-height: 0;
}

.paper-tabs {
  display: flex;
  gap: 2px;
  padding: 6px 10px 0;
  border-bottom: 1px solid var(--tv-border-color);
  flex: 0 0 auto;
  overflow-x: auto;
  scrollbar-width: none;
}

.paper-tabs::-webkit-scrollbar { display: none; }

.paper-tab {
  appearance: none;
  background: transparent;
  border: none;
  border-bottom: 2px solid transparent;
  color: var(--tv-muted-color);
  font-size: 12px;
  font-weight: 500;
  padding: 6px 12px;
  cursor: pointer;
  white-space: nowrap;
}

.paper-tab:hover {
  color: var(--tv-text-color);
}

.paper-tab.is-active {
  color: var(--tv-text-color);
  border-bottom-color: var(--tv-blue);
}

.paper-tab-panels {
  flex: 1 1 auto;
  min-height: 0;
}

.paper-tab-panel {
  display: none;
  height: 100%;
  overflow-y: auto;
  padding: 8px 12px;
}

.paper-tab-panel.is-active {
  display: block;
}

.tv-paper-trading-panel .paper-terminal-list {
  overflow: visible;
}

.tv-paper-trading-panel .panel-title {
  margin-bottom: 8px;
  color: var(--tv-text-color);
  font-size: 0.8rem;
  font-weight: 600;
}

.paper-account {
  padding: 8px 12px;
  background: var(--tv-workspace-bg);
  border: 1px solid var(--tv-border-color);
  border-radius: 4px;
  margin-bottom: 8px;
  font-size: 12px;
  color: var(--tv-text-color);
}

.paper-account-pnl {
  display: flex;
  flex-wrap: wrap;
  gap: 4px 16px;
  margin-top: -4px;
  margin-bottom: 8px;
  padding: 0 2px;
  font-size: 11px;
  color: var(--tv-muted-color);
}

.paper-account-pnl span {
  white-space: nowrap;
}

.paper-metric--up {
  color: var(--positive);
}

.paper-metric--down {
  color: var(--negative);
}

.paper-metric--flat {
  color: var(--tv-muted-color);
}

.paper-evaluation {
  font-size: 11px;
}

.paper-eval-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px;
}

.paper-eval-cell {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 6px 8px;
  background: var(--tv-workspace-bg);
  border: 1px solid var(--tv-border-color);
  border-radius: 4px;
  min-width: 0;
}

.paper-eval-cell__label {
  font-size: 10px;
  color: var(--tv-muted-color);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.paper-eval-cell__value {
  font-size: 13px;
  font-weight: 600;
  color: var(--tv-text-color);
  font-variant-numeric: tabular-nums;
}

.rules-status-toast {
  position: fixed;
  bottom: 24px;
  left: 50%;
  transform: translate(-50%, 12px);
  z-index: 9999;
  max-width: min(92vw, 420px);
  padding: 10px 16px;
  border-radius: 8px;
  font-size: 13px;
  line-height: 1.4;
  color: var(--tv-text-color, #d1d4dc);
  background: var(--tv-panel-bg, #1e222d);
  border: 1px solid var(--tv-border-color, #2a2e39);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.35);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.18s ease, transform 0.18s ease;
}

.rules-status-toast--visible {
  opacity: 1;
  transform: translate(-50%, 0);
}

.rules-status-toast[data-variant="success"] {
  border-color: var(--positive, #36d399);
}

.rules-status-toast[data-variant="error"] {
  border-color: var(--negative, #f6465d);
}

.order-form {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.order-side-btns {
  display: flex;
  gap: 4px;
}

.order-btn {
  flex: 1;
  padding: 6px;
  border: 1px solid var(--tv-border-color);
  background: transparent;
  color: var(--tv-muted-color);
  cursor: pointer;
  border-radius: 4px;
  font-size: 12px;
  transition:
    color var(--transition-fast),
    background var(--transition-fast),
    border-color var(--transition-fast),
    transform var(--transition-fast);
}

.order-btn:hover,
.order-btn:focus-visible {
  outline: none;
  color: var(--tv-text-color);
  background: var(--tv-active-bg);
  border-color: var(--tv-card-selected-border);
}

.order-btn:active,
.order-submit-btn:active {
  transform: translateY(1px);
}

.order-btn.active {
  background: var(--tv-blue);
  color: #ffffff;
  border-color: var(--tv-blue);
}

.order-btn.sell.active {
  background: var(--negative);
  border-color: var(--negative);
}

.order-input {
  padding: 6px 8px;
  background: var(--tv-workspace-bg);
  border: 1px solid var(--tv-border-color);
  color: var(--tv-text-color);
  border-radius: 4px;
  font-size: 12px;
  width: 100%;
  box-sizing: border-box;
}

.order-input::placeholder {
  color: var(--tv-muted-color);
}

.order-input:focus {
  border-color: var(--tv-blue);
  outline: none;
  box-shadow: 0 0 0 2px var(--tv-card-selected);
}

.order-submit-btn {
  padding: 8px;
  background: var(--tv-blue);
  color: #ffffff;
  border: none;
  border-radius: 4px;
  cursor: pointer;
  font-size: 13px;
  font-weight: bold;
  transition:
    background var(--transition-fast),
    filter var(--transition-fast),
    transform var(--transition-fast);
}

.order-submit-btn:hover,
.order-submit-btn:focus-visible {
  outline: none;
  filter: brightness(1.08);
}

.order-row,
.position-row {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  padding: 4px 0;
  font-size: 11px;
  color: var(--tv-muted-color);
  border-bottom: 1px solid var(--tv-border-color);
}

.order-row:last-child,
.position-row:last-child {
  border-bottom: none;
}

@media (max-width: 1200px) {
  .tv-workspace {
    --tv-rail-width: 280px;
    grid-template-columns: minmax(420px, 1fr) 6px minmax(240px, var(--tv-rail-width));
  }

  .tv-toolbar {
    padding: 8px 12px;
  }
}

@media (max-width: 1024px) {
  .tv-workspace {
    grid-template-columns: 1fr;
    height: auto;
  }

  .tv-workspace.is-sidebar-collapsed {
    grid-template-columns: 1fr;
  }

  .tv-rail-resizer {
    display: none;
  }

  .tv-main {
    border-right: none;
    border-bottom: 1px solid var(--tv-border-color);
    min-height: 0;
  }

  .tv-chart-area {
    min-height: 420px;
  }

   .tv-left-dock {
    width: auto;
  }

  .tv-shared-panel {
    width: min(360px, 42vw);
  }

  .tv-drawing-panel-drawer {
    width: min(360px, calc(100vw - 64px));
    max-height: 280px;
  }

  .tv-rail {
    overflow: visible;
  }

  .tv-rail-section {
    padding: 12px;
  }
}

@media (max-width: 640px) {
  .tv-workspace {
    grid-template-columns: 1fr;
  }
  .tv-left-dock {
    flex-direction: column;
    width: 100%;
  }
  .tv-drawing-dock {
    width: 100%;
    flex-direction: row;
    min-height: 52px;
    height: auto;
    border-right: none;
    border-bottom: 1px solid var(--tv-dock-rail-border);
    padding: var(--space-1) var(--space-2);
    overflow-x: auto;
    overflow-y: hidden;
  }
  .tv-dock-group {
    flex-direction: row;
    gap: var(--space-1);
    width: auto;
    min-width: max-content;
  }
  .tv-shared-panel {
    width: 100%;
    min-width: 0;
    border-right: none;
    border-bottom: 1px solid var(--tv-border-color);
    max-height: 42vh;
  }
  .tv-shared-panel__meta-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .tv-dock-divider {
    width: 1px;
    height: 24px;
    margin: auto 6px;
  }
  .tv-chart-overlay {
    flex-direction: column;
    align-items: stretch;
  }
  .tv-chart-legend {
    max-width: none;
  }
}

/* --- Responsive trading workspace overrides --- */
.tv-workspace,
.tv-main,
.tv-rail,
.tv-toolbar,
.tv-chart-area,
.tv-chart-wrapper,
.tv-drawing-dock,
.tv-shared-panel {
  transition:
    grid-template-columns var(--transition-normal),
    grid-template-rows var(--transition-normal),
    background var(--transition-normal),
    border-color var(--transition-normal),
    box-shadow var(--transition-normal),
    transform var(--transition-normal),
    opacity var(--transition-normal);
}

/* Keep this tablet block after generic <=1024px rules so chart min-height cannot cover the rail. */
@media (min-width: 768px) and (max-width: 1024px) {
  .tv-workspace {
    height: 100%;
    grid-template-rows: minmax(0, 1fr) minmax(260px, 34vh);
    overflow: hidden;
  }

  @supports (height: 100dvh) {
    .tv-workspace {
      grid-template-rows: minmax(0, 1fr) minmax(260px, 34dvh);
    }
  }

  .tv-main,
  .tv-rail {
    min-height: 0;
  }

  .tv-main {
    overflow: hidden;
  }

  .tv-toolbar {
    flex-wrap: wrap;
    align-items: flex-start;
    gap: var(--space-3);
    padding: var(--space-3);
    overflow: hidden;
  }

  .tv-toolbar__left,
  .tv-toolbar__right {
    width: 100%;
  }

  .tv-toolbar__left,
  .tv-toolbar__chart-controls,
  .tv-toolbar__right {
    flex-wrap: wrap;
    gap: var(--space-2);
  }

  .tv-toolbar__right {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .tv-toolbar-title {
    font-size: 1rem;
  }

  .tv-toolbar__chart-controls #timeframe-selector {
    flex: 1 1 100%;
  }

  .tv-chart-area {
    flex: 1 1 auto;
    min-height: 0;
  }

  .tv-chart-stack {
    min-height: 0;
  }

  .tv-drawing-dock {
    flex: 0 0 56px;
    box-sizing: border-box;
    width: 56px;
    padding: var(--space-2) 6px;
    overflow-x: hidden;
  }

  .tv-dock-group {
    width: 100%;
    min-width: 0;
    max-width: 100%;
    align-items: center;
  }

  .tv-drawing-tool-flyout__item {
    min-height: 44px;
  }

  .tv-drawing-panel-drawer {
    left: 64px;
    right: auto;
    bottom: var(--space-3);
    width: min(320px, calc(100vw - 80px));
    max-height: min(34dvh, calc(100dvh - var(--space-6)));
  }

  .tv-dock-btn,
  .action-button--icon-compact,
  .tv-watchlist-remove {
    min-width: 44px;
    min-height: 44px;
  }

  .tv-toolbar__chart-controls .interval-switcher__button,
  .tv-toolbar__chart-controls .action-button,
  .tv-chart-type-menu__item,
  .symbol-item,
  .order-input {
    min-width: 44px;
    min-height: 44px;
  }

  .tv-rail-tabs .tv-rail-tab,
  .tv-rail .action-button,
  .tv-market-list .symbol-item__select,
  .tv-rail-section .field__control,
  .order-btn,
  .order-submit-btn {
    min-height: 44px;
  }

  .tv-watchlist-choice-list {
    max-height: min(320px, 42vh);
  }

  .tv-chart-overlay {
    bottom: 0;
    overflow: hidden;
  }

  .tv-chart-overlay__left {
    max-height: 100%;
    overflow: hidden;
  }

  .tv-chart-overlay__left .tv-chart-legend,
  #tv-indicator-legend {
    max-height: 220px;
    overflow-y: auto;
    scrollbar-width: thin;
    pointer-events: auto;
  }

  .tv-rail {
    border-top: 1px solid var(--tv-border-color);
    overflow: hidden;
  }

  .tv-sidebar-panel.is-active {
    overflow-y: auto;
    overflow-x: hidden;
  }
}

@media (max-width: 767px) {
  html,
  body {
    height: auto !important;
    overflow-x: clip !important;
    overflow-y: auto !important;
  }

  .app-shell {
    height: auto !important;
    min-height: 100dvh;
    max-width: 100vw;
    overflow-x: clip !important;
    overflow-y: visible !important;
  }

  .page-shell {
    flex: 0 0 auto !important;
    height: auto !important;
    overflow: visible !important;
  }

  .tv-workspace {
    display: flex;
    flex-direction: column;
    flex: 0 0 auto;
    grid-template-columns: 1fr;
    grid-template-rows: auto auto;
    width: 100%;
    max-width: 100vw;
    height: auto;
    min-height: 0;
    overflow-x: clip;
  }

  .tv-workspace.is-sidebar-collapsed {
    grid-template-columns: 1fr;
  }

  .tv-main {
    order: 1;
    flex: 0 0 auto;
    min-width: 0;
    height: auto;
    overflow: visible;
    border-right: none;
    border-bottom: 1px solid var(--tv-border-color);
  }

  .tv-rail-resizer {
    display: none;
  }

  .tv-rail {
    order: 2;
    width: 100%;
    flex: 0 0 auto;
    max-height: 44dvh;
    border-top: 1px solid var(--tv-border-color);
    overflow-y: auto;
  }

  .tv-workspace.is-sidebar-collapsed .tv-rail {
    display: flex;
  }

  .tv-workspace.is-sidebar-collapsed .tv-rail-tabs {
    flex-direction: row;
    margin: 0;
  }

  .tv-workspace.is-sidebar-collapsed .tv-rail-tabs .tv-rail-tab {
    writing-mode: horizontal-tb;
    text-orientation: mixed;
  }

  .tv-workspace.is-sidebar-collapsed .tv-sidebar-panel.is-active {
    display: flex !important;
  }

  .tv-toolbar {
    flex-wrap: wrap;
    align-items: stretch;
    gap: var(--space-3);
    padding: var(--space-3);
    width: 100%;
    max-width: 100vw;
    overflow: hidden;
  }

  .tv-toolbar__left,
  .tv-toolbar__right,
  .tv-toolbar__chart-controls {
    width: 100%;
    min-width: 0;
  }

  .tv-toolbar__left,
  .tv-toolbar__chart-controls {
    flex-wrap: wrap;
    gap: var(--space-2);
  }

  .tv-toolbar__chart-controls {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    overflow: hidden;
    max-width: 100%;
  }

  .tv-toolbar__chart-controls #timeframe-selector {
    grid-column: 1 / -1;
    grid-row: 1;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    overflow: visible;
    flex-wrap: wrap;
    white-space: normal;
    scroll-padding-inline: var(--space-2);
    touch-action: pan-x;
  }

  .tv-toolbar__chart-controls .interval-switcher__button {
    min-width: 44px;
    min-height: 44px;
    padding: var(--space-2) var(--space-3);
  }

  .tv-chart-type-switcher {
    grid-column: 1;
    grid-row: 2;
    min-width: 0;
    max-width: 100%;
  }

  .tv-chart-type-switcher__button {
    max-width: 100%;
    min-height: 44px;
  }

  .tv-chart-type-switcher__full-label {
    display: none;
  }

  .tv-chart-type-switcher__short-label {
    display: inline;
  }

  .tv-chart-type-menu {
    max-height: min(280px, 50dvh);
    overflow-y: auto;
  }

  .tv-template-menu {
    grid-column: 2;
    grid-row: 3;
    justify-self: end;
  }

  .tv-chart-export-button {
    grid-column: 2;
    grid-row: 2;
    justify-self: end;
  }

  .tv-toolbar__right {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--space-2);
  }

  .tv-toolbar-title {
    font-size: clamp(0.95rem, 4vw, 1.1rem);
    line-height: 1.2;
  }

  .tv-metric__label {
    font-size: 0.68rem;
  }

  .tv-metric__value {
    font-size: clamp(0.78rem, 3vw, 0.9rem);
  }

  .tv-toolbar-divider {
    display: none;
  }

  .tv-toolbar__icon-actions {
    grid-column: 2;
    grid-row: 1;
    justify-self: end;
    margin-left: 0;
  }

  .tv-chart-area {
    flex: 0 0 auto;
    flex-direction: column;
    width: 100%;
    min-height: clamp(560px, 92dvh, 760px);
  }

  .tv-left-dock {
    width: 100%;
    min-height: 0;
  }

  .tv-chart-wrapper {
    width: 100%;
    min-height: 360px;
  }

  .tv-chart-stack {
    min-height: 0;
  }

  .tv-chart-area .chart-card__surface,
  .tv-chart-wrapper > .chart-card__surface {
    width: 100%;
  }

  .tv-drawing-dock {
    flex: 0 0 auto;
    width: 100%;
    min-height: 52px;
    height: auto;
    flex-direction: row;
    align-items: center;
    gap: var(--space-1);
    padding: var(--space-1) var(--space-2);
    border-right: none;
    border-bottom: 1px solid var(--tv-dock-rail-border);
    overflow-x: auto;
    overflow-y: hidden;
    scrollbar-width: thin;
  }

  .tv-dock-group {
    flex-direction: row;
    align-items: center;
    width: auto;
    max-width: none;
    min-width: max-content;
  }

  .tv-drawing-tool-flyout.is-mobile-sheet {
    width: min(320px, calc(100vw - var(--space-4)));
    max-width: calc(100vw - var(--space-4));
  }

  .tv-drawing-tool-flyout__item {
    min-height: 44px;
  }

  .tv-dock-section-label {
    flex: 0 0 1px;
    width: 1px;
    min-width: 1px;
    height: 28px;
    min-height: 28px;
    margin: 0 var(--space-1);
    display: block;
    padding: 0;
  }

  .tv-dock-divider {
    width: 1px;
    height: 28px;
    margin: 0 var(--space-1);
  }

  .tv-drawing-panel-drawer {
    left: var(--space-2);
    right: var(--space-2);
    top: clamp(60px, 38dvh, 360px);
    bottom: auto;
    width: auto;
    max-height: min(42dvh, calc(100dvh - clamp(60px, 38dvh, 360px) - var(--space-2)));
  }

  .tv-drawing-context-toolbar {
    max-width: calc(100vw - var(--space-4));
    flex-wrap: wrap;
  }

  .tv-chart-overlay {
    flex-direction: column;
    align-items: stretch;
  }

  .tv-chart-overlay {
    bottom: 0;
    overflow: hidden;
  }

  .tv-chart-overlay__left {
    padding: var(--space-2);
    max-width: calc(100vw - var(--space-4));
    max-height: 100%;
    overflow: hidden;
  }

  .tv-chart-overlay__left .tv-chart-legend,
  .tv-main-pane-legend,
  .tv-chart-legend,
  #tv-indicator-legend {
    max-width: 100%;
  }

  .tv-chart-overlay__left .tv-chart-legend,
  #tv-indicator-legend {
    max-height: 220px;
    overflow-y: auto;
    scrollbar-width: thin;
    pointer-events: auto;
  }

  .tv-chart-legend__row,
  .tv-chart-legend__indicator-row,
  .tv-chart-legend__indicator-main {
    flex-wrap: wrap;
  }

  .tv-chart-legend__row--meta,
  .tv-chart-legend__row--ohlc {
    max-width: 100%;
    overflow-x: auto;
    scrollbar-width: none;
  }

  .tv-chart-legend__row--meta::-webkit-scrollbar,
  .tv-chart-legend__row--ohlc::-webkit-scrollbar {
    display: none;
  }

  .tv-chart-legend__indicator-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: start;
    gap: var(--space-1) var(--space-2);
    max-width: 100%;
  }

  .tv-chart-legend__indicator-main {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
    gap: var(--space-1) var(--space-2);
  }

  .tv-chart-legend__indicator-name {
    max-width: 8rem;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .tv-chart-legend__indicator-values,
  .tv-chart-legend__item {
    max-width: 100%;
  }

  .tv-chart-legend__indicator-actions {
    display: inline-flex;
    flex: 0 0 auto;
    width: auto;
    gap: 4px;
    opacity: 1;
    pointer-events: auto;
    justify-self: end;
  }

  .tv-chart-legend__indicator-actions .action-button--secondary,
  .tv-chart-legend__shell-actions .action-button--secondary {
    min-height: 36px;
    min-width: 0;
    padding: var(--space-1) var(--space-2);
  }

  .tv-chart-legend__indicator-shell {
    padding: var(--space-2);
    grid-column: 1 / -1;
  }

  .tv-chart-legend__shell-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    width: 100%;
  }

  .tv-rail-tabs {
    position: sticky;
    top: 0;
    z-index: 2;
    overflow-x: auto;
    scrollbar-width: none;
    background: var(--tv-panel-bg);
  }

  .tv-rail-tabs::-webkit-scrollbar {
    display: none;
  }

  .tv-rail-tabs .tv-rail-tab {
    flex: 1 0 max(33.333%, 8rem);
    min-height: 44px;
    padding: var(--space-2) var(--space-3);
    white-space: nowrap;
  }

  .tv-sidebar-panel.is-active {
    max-height: calc(44dvh - 45px);
    overflow-y: auto;
  }

  .tv-rail-section {
    padding: var(--space-2);
  }

  .tv-panel-header,
  .tv-shared-panel__section-header,
  .tv-drawing-item__top,
  .tv-drawing-item__actions {
    flex-wrap: wrap;
    gap: var(--space-2);
  }

  .tv-panel-title,
  .tv-shared-panel__title,
  .tv-shared-panel__section-title {
    font-size: clamp(0.82rem, 3.4vw, 0.95rem);
  }

  .tv-inline-panel,
  .tv-overlay-popover {
    width: min(100%, calc(100vw - var(--space-4)));
    min-width: 0;
    max-height: min(420px, 58dvh);
    overflow-y: auto;
  }

  #indicator-editor,
  #timeframe-editor {
    position: fixed;
    inset: var(--space-2);
    width: auto;
    max-height: calc(100dvh - (var(--space-2) * 2));
    z-index: 1200;
  }

  .tv-indicator-search-row {
    grid-template-columns: minmax(0, 1fr);
  }

  #btn-clear-indicator-search {
    min-height: 44px;
  }

  .tv-indicator-picker__group {
    gap: var(--space-1);
  }

  .tv-indicator-picker__item,
  .tv-choice-item--indicator-library,
  #indicator-choice-list .tv-choice-item {
    min-height: 44px;
    min-width: 0;
  }

  .tv-indicator-picker__item span:first-child,
  #indicator-choice-list .tv-choice-item span:first-child {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .tv-watchlist-search-field {
    margin-bottom: var(--space-2);
  }

  .tv-watchlist-choice-list {
    max-height: min(260px, 30dvh);
  }

  .tv-watchlist-choice-item,
  .tv-market-list .symbol-item__select {
    min-height: 52px;
  }

  .tv-market-list .symbol-item__select {
    gap: var(--space-2);
    padding: var(--space-2) var(--space-3);
    grid-template-columns: minmax(0, 1fr) minmax(7ch, auto);
  }

  .tv-market-list .symbol-item__lhs strong,
  .tv-market-list .symbol-item__meta {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .tv-market-list .symbol-item__rhs {
    min-width: 7ch;
  }

  .symbol-item__price,
  .symbol-item__change--positive,
  .symbol-item__change--negative {
    font-size: clamp(0.78rem, 3vw, 0.9rem);
  }

  .tv-shared-panel__meta-grid {
    grid-template-columns: 1fr;
  }

  .form-actions,
  .tv-form-actions-compact,
  .tv-inline-actions,
  .tv-panel-actions {
    flex-wrap: wrap;
  }

  .action-button,
  .interval-switcher__button,
  .nav-link,
  .theme-toggle,
  .user-menu__trigger,
  .user-menu__toggle,
  .field__control,
  .tv-rail-section .field__control,
  .tv-dock-btn,
  .action-button--icon-compact,
  .tv-watchlist-remove,
  .order-btn,
  .order-input,
  .order-submit-btn,
  .tv-drawing-context-toolbar__color {
    min-width: 44px;
    min-height: 44px;
  }

  .action-button--icon-compact,
  .tv-watchlist-remove {
    width: 44px;
    height: 44px;
  }

  .tv-drawing-context-toolbar__color {
    width: 44px;
    height: 44px;
  }

}

@media (max-width: 420px) {
  .tv-toolbar__right {
    grid-template-columns: 1fr;
  }

  .tv-chart-area {
    min-height: clamp(380px, 70dvh, 560px);
  }

  .tv-chart-wrapper {
    min-height: 320px;
  }

  .tv-rail {
    max-height: 48dvh;
  }

  .tv-sidebar-panel.is-active {
    max-height: calc(48dvh - 45px);
  }
}

@media (prefers-reduced-motion: reduce) {
  .tv-workspace,
  .tv-main,
  .tv-rail,
  .tv-toolbar,
  .tv-chart-area,
  .tv-chart-wrapper,
  .tv-drawing-dock,
  .tv-shared-panel {
    transition: none;
  }
}

/* Task 5.6 TradingView-like visual density pass. */
@media (min-width: 1025px) {
  .tv-toolbar {
    min-height: 38px;
    padding-block: 3px;
  }

  .tv-toolbar__right {
    display: grid;
    grid-template-columns: repeat(4, max-content);
    align-items: center;
    gap: 8px;
  }

  .tv-metric {
    display: grid;
    grid-template-columns: auto auto;
    align-items: baseline;
    column-gap: 5px;
    line-height: 1;
  }

  .tv-metric__label {
    font-size: 0.58rem;
  }

  .tv-metric__value,
  .tv-metric--updated .tv-metric__value {
    font-size: 0.7rem;
  }

  .tv-chart-overlay__left .tv-chart-legend,
  .tv-main-pane-legend,
  .tv-chart-legend,
  #tv-indicator-legend {
    height: auto;
    min-height: 0;
    max-height: none;
    overflow: visible;
    pointer-events: auto;
  }

  .tv-chart-legend {
    display: block;
  }

  .tv-chart-legend__indicator-row {
    min-height: 20px;
  }

  .tv-chart-legend__indicator-shell {
    overflow-y: visible;
  }
}


.tv-indicator-search-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: stretch;
  gap: 8px;
  margin-bottom: 8px;
}

.tv-indicator-search {
  display: block;
  min-width: 0;
}

.tv-indicator-search .field__control {
  width: 100%;
  min-height: 32px;
  background: color-mix(in srgb, var(--tv-workspace-bg) 92%, transparent);
  border-color: var(--tv-overlay-border);
  color: var(--tv-text-color);
}

#btn-clear-indicator-search {
  min-height: 32px;
  box-shadow: none;
}

.tv-chart-legend__param-field--boolean {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
}

.tv-chart-legend__param-field--boolean input {
  width: auto;
  justify-self: end;
}

.tv-choice-item--indicator-search-result {
  justify-content: space-between;
  width: 100%;
  padding: 7px 9px;
  border: 1px solid var(--tv-overlay-border-soft);
  border-radius: 8px;
  background: color-mix(in srgb, var(--tv-panel-elevated) 76%, transparent);
}

.tv-object-panel__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 28px;
  min-height: 22px;
  padding: 0 8px;
  border-radius: 999px;
  background: var(--tv-card-selected);
  color: var(--tv-text-color);
  font-size: 0.72rem;
  font-weight: 700;
}

.tv-object-tree {
  display: grid;
  gap: 8px;
}

.tv-object-tree__row {
  display: grid;
  align-items: center;
  gap: 8px;
  padding: 8px 9px;
  border: 1px solid var(--tv-overlay-border-soft);
  border-radius: 8px;
  background: color-mix(in srgb, var(--tv-panel-elevated) 82%, transparent);
}

.tv-object-tree__row {
  grid-template-columns: auto minmax(0, 1fr) auto;
}

.tv-object-tree__row.is-selected {
  border-color: var(--tv-card-selected-border);
  background: var(--tv-card-selected);
}

.tv-object-tree__index {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 6px;
  background: color-mix(in srgb, var(--tv-workspace-bg) 88%, transparent);
  color: var(--tv-muted-color);
  font-size: 0.68rem;
  font-family: monospace;
}

.tv-object-tree__main {
  display: grid;
  gap: 2px;
  min-width: 0;
  appearance: none;
  border: none;
  background: transparent;
  padding: 0;
  margin: 0;
  text-align: left;
  cursor: pointer;
  color: inherit;
}

.tv-object-tree__main strong {
  color: var(--tv-text-color);
  font-size: 0.78rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.tv-object-tree__main span,
.tv-object-tree__state {
  color: var(--tv-muted-color);
  font-size: 0.68rem;
}

.tv-object-tree__state {
  justify-self: end;
  white-space: nowrap;
}

.tv-object-tree__row.is-hidden .tv-object-tree__main strong,
.tv-object-tree__row.is-hidden .tv-object-tree__main span {
  opacity: 0.45;
}

.tv-object-tree__actions {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  justify-self: end;
}

.tv-object-tree__action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 26px;
  padding: 0;
  border: none;
  border-radius: 6px;
  background: transparent;
  color: var(--tv-muted-color);
  cursor: pointer;
  transition: background 0.12s ease, color 0.12s ease;
}

.tv-object-tree__action:hover {
  background: color-mix(in srgb, var(--tv-text-color) 12%, transparent);
  color: var(--tv-text-color);
}

.tv-object-tree__action[aria-pressed="true"] {
  color: var(--tv-blue);
}

.tv-object-tree__action--danger:hover {
  background: color-mix(in srgb, var(--negative) 18%, transparent);
  color: var(--negative);
}

.paper-trading-disclaimer {
  margin-top: 6px;
  padding: 8px 9px;
  border: 1px solid rgba(247, 195, 95, 0.28);
  border-radius: 8px;
  background: rgba(247, 195, 95, 0.1);
  color: var(--tv-text-color);
  font-size: 0.72rem;
  line-height: 1.45;
}


/* 2026-06-19 P0 TradingView visual pass: terminal chrome, compact watchlist, paper ticket, object tree, mobile chart-first. */
.app-shell:has(.tv-workspace) .topbar {
  min-height: 32px;
  padding: 0 var(--space-2);
  gap: var(--space-2);
  background: var(--tv-dark-panel, #131722);
  border-bottom: 1px solid var(--tv-dark-border, #2a2e39);
  box-shadow: none;
  backdrop-filter: none;
}

.app-shell:has(.tv-workspace) .topbar__brand {
  gap: var(--space-2);
  min-width: 0;
}

.app-shell:has(.tv-workspace) .brand-mark {
  width: 8px;
  height: 8px;
  background: var(--positive);
  box-shadow: none;
}

.app-shell:has(.tv-workspace) .brand-title {
  color: var(--tv-dark-text, #d1d4dc);
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.01em;
  line-height: 1;
  white-space: nowrap;
}

.app-shell:has(.tv-workspace) .brand-subtitle,
.app-shell:has(.tv-workspace) .theme-toggle__label,
.app-shell:has(.tv-workspace) .user-menu__identity span {
  display: none;
}

.app-shell:has(.tv-workspace) .topbar__nav {
  gap: var(--space-1);
  margin-left: auto;
}

.app-shell:has(.tv-workspace) .nav-link,
.app-shell:has(.tv-workspace) .user-menu__trigger,
.app-shell:has(.tv-workspace) .theme-toggle {
  min-height: 26px;
  padding: 3px 8px;
  border-radius: 4px;
  background: transparent;
  border: 1px solid transparent;
  color: var(--tv-dark-muted, #a3adbb);
  box-shadow: none;
}

.app-shell:has(.tv-workspace) .nav-link:hover,
.app-shell:has(.tv-workspace) .nav-link.is-active,
.app-shell:has(.tv-workspace) .user-menu__trigger:hover,
.app-shell:has(.tv-workspace) .theme-toggle:hover {
  color: var(--tv-dark-text, #d1d4dc);
  background: var(--tv-dark-active, #2a2e39);
  border-color: var(--tv-dark-border, #2a2e39);
  transform: none;
  box-shadow: none;
}

.app-shell:has(.tv-workspace) .user-menu__trigger {
  gap: var(--space-1);
}

.app-shell:has(.tv-workspace) .user-menu__avatar {
  width: 18px;
  height: 18px;
  background: var(--tv-blue);
  font-size: 0.62rem;
}

.app-shell:has(.tv-workspace) .user-menu__identity strong {
  max-width: 9ch;
  color: var(--tv-dark-text, #d1d4dc);
  font-size: 0.72rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.app-shell:has(.tv-workspace) .theme-toggle__track {
  width: 28px;
  height: 16px;
  padding: 1px;
  background: var(--tv-dark-active, #2a2e39);
}

.app-shell:has(.tv-workspace) .theme-toggle__thumb {
  width: 14px;
  height: 14px;
  background: var(--tv-dark-text, #d1d4dc);
  transform: translateX(12px);
}

:root[data-theme="light"] .app-shell:has(.tv-workspace) .theme-toggle__thumb {
  transform: translateX(0);
}

.app-shell:has(.tv-workspace) .user-menu__dropdown {
  top: calc(100% + var(--space-1));
  background: var(--tv-dark-panel, #131722);
  border-color: var(--tv-dark-border, #2a2e39);
  color: var(--tv-dark-text, #d1d4dc);
}

.tv-toolbar {
  min-height: 32px;
  padding: 2px 8px;
  gap: var(--space-2);
}

.tv-toolbar__left,
.tv-toolbar__right {
  gap: var(--space-2);
}

.tv-toolbar-title {
  max-width: 11rem;
  font-size: 0.82rem;
  line-height: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.tv-toolbar-divider {
  height: 18px;
}

.tv-toolbar__chart-controls .interval-switcher {
  background: transparent;
  border-color: transparent;
  padding: 0;
  backdrop-filter: none;
}

.tv-toolbar__chart-controls .interval-switcher__button {
  min-height: 24px;
  padding: 2px 6px;
  font-size: 0.72rem;
}

.tv-toolbar__chart-controls .action-button--secondary,
.tv-chart-overlay .action-button--secondary {
  min-height: 24px;
  padding: 2px 7px;
}

.tv-toolbar__chart-controls .action-button--icon-compact {
  width: 24px;
  height: 24px;
}

.tv-metric__label {
  font-size: 0.56rem;
}

.tv-metric__value,
.tv-metric--updated .tv-metric__value {
  font-size: 0.66rem;
}

.tv-rail-tabs .tv-rail-tab {
  min-height: 30px;
  padding: 6px 4px;
  font-size: 0.7rem;
  letter-spacing: 0;
}

.tv-panel-header {
  min-height: 30px;
  padding: 6px 10px;
}

.tv-panel-title {
  font-size: 0.74rem;
}

.tv-sidebar-panel[data-sidebar-content="market"].is-active .tv-rail-section--watchlist {
  flex: 1 1 46%;
}

.tv-market-list {
  background: var(--tv-panel-bg);
}

.tv-market-list::before {
  content: "Symbol Price Chg";
  display: grid;
  grid-template-columns: minmax(0, 1fr) 9ch 7ch;
  gap: 6px;
  padding: 4px 10px;
  border-block: 1px solid var(--tv-border-color);
  color: var(--tv-muted-color);
  font-family: var(--font-mono);
  font-size: 0.58rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  white-space: pre;
}

.tv-market-list .symbol-item {
  min-height: 30px;
  border-bottom-color: var(--tv-divider-subtle);
  box-shadow: none;
}

.tv-market-list .symbol-item:hover,
.tv-market-list .symbol-item.is-active,
.tv-market-list .symbol-item:focus-within {
  background: color-mix(in srgb, var(--tv-active-bg) 72%, transparent);
  transform: none;
  box-shadow: none;
}

.tv-market-list .symbol-item.is-active,
.tv-market-list .symbol-item:focus-within {
  box-shadow: inset 0 0 0 1px var(--tv-card-selected-border);
}

.tv-market-list .symbol-item__select,
.tv-market-list .symbol-item {
  grid-template-columns: minmax(0, 1fr) minmax(16ch, auto);
}

.tv-market-list .symbol-item__select,
.tv-market-list .symbol-item:not(:has(.symbol-item__select)) {
  padding: 3px 10px;
}

.tv-market-list .symbol-item__lhs strong {
  color: var(--tv-text-color);
  font-size: 0.74rem;
  font-weight: 700;
  line-height: 1.05;
}

.tv-market-list .symbol-item__meta {
  font-size: 0.6rem;
  line-height: 1.05;
}

.tv-market-list .symbol-item__rhs {
  display: grid;
  grid-template-columns: 9ch 7ch;
  align-items: baseline;
  gap: 6px;
  min-width: 16ch;
}

.symbol-item__price,
.symbol-item__change--positive,
.symbol-item__change--negative {
  min-width: 0;
  font-size: 0.72rem;
  line-height: 1.1;
}

.paper-account {
  display: grid;
  gap: 2px;
  margin-bottom: 5px;
  padding: 6px 8px;
  border-color: var(--tv-divider-subtle);
  background: color-mix(in srgb, var(--tv-workspace-bg) 84%, transparent);
  font-family: var(--font-mono);
  font-size: 0.68rem;
  line-height: 1.25;
}

.paper-trading-disclaimer {
  margin-top: 0;
  padding: 5px 7px;
  border-color: color-mix(in srgb, var(--warning) 28%, transparent);
  border-radius: 4px;
  background: color-mix(in srgb, var(--warning) 10%, var(--tv-panel-bg));
  color: var(--tv-text-color);
  font-size: 0.62rem;
  line-height: 1.35;
}

.order-form {
  gap: 5px;
}

.order-side-btns,
.order-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 4px;
}

.order-input,
.order-btn,
.order-submit-btn {
  min-height: 28px;
  font-size: 0.68rem;
  box-shadow: none;
}

.order-input {
  padding: 4px 7px;
  border-radius: 3px;
}

.order-btn {
  padding: 4px 6px;
  border-radius: 3px;
}

.order-btn.active {
  background: color-mix(in srgb, var(--positive) 70%, var(--tv-workspace-bg));
  border-color: color-mix(in srgb, var(--positive) 70%, transparent);
}

.order-btn.sell.active {
  background: color-mix(in srgb, var(--negative) 78%, var(--tv-workspace-bg));
  border-color: color-mix(in srgb, var(--negative) 72%, transparent);
}

.order-submit-btn {
  padding: 5px 8px;
  border: 1px solid var(--tv-blue);
  border-radius: 3px;
  background: var(--tv-blue);
  font-size: 0.7rem;
}

.paper-terminal-list {
  display: grid;
  gap: 0;
  color: var(--tv-muted-color);
  font-size: 0.66rem;
}

.order-row,
.position-row {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.4fr);
  align-items: center;
  gap: 6px;
  padding: 4px 0;
  border-bottom-color: var(--tv-divider-subtle);
  font-size: 0.64rem;
  line-height: 1.25;
}

.order-row__symbol,
.position-row__symbol {
  color: var(--tv-text-color);
  font-weight: 700;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.order-row__meta,
.position-row__meta {
  justify-self: end;
  text-align: right;
  color: var(--tv-muted-color);
  font-family: var(--font-mono);
}

.order-btn--inline {
  min-height: 22px;
  margin-left: 4px;
  padding: 2px 5px;
  font-size: 0.62rem;
}

.tv-drawing-panel-drawer {
  width: min(320px, calc(100vw - 80px));
  max-height: min(52dvh, calc(100dvh - 24px), 460px);
  padding: 0;
  border-color: var(--tv-border-color);
  border-radius: 6px;
  background: var(--tv-panel-bg);
  color: var(--tv-text-color);
  box-shadow: var(--tv-overlay-shadow, 0 18px 40px rgba(0, 0, 0, 0.42));
}

.tv-drawing-panel__header {
  min-height: 30px;
  padding: 5px 8px;
  border-bottom: 1px solid var(--tv-border-color);
  background: var(--tv-panel-bg);
  color: var(--tv-text-color);
}

.tv-drawing-panel__header span {
  font-size: 0.72rem;
  font-weight: 700;
}

.tv-drawing-panel__header .action-button {
  min-height: 24px;
  padding: 2px 7px;
  border-color: var(--tv-border-color);
  background: var(--tv-workspace-bg);
  color: var(--tv-muted-color);
  box-shadow: none;
}

.tv-drawing-list {
  display: grid;
  gap: 0;
  padding: 4px 0;
}

.tv-drawing-list .empty-state {
  margin: 6px;
  padding: 10px;
  border: 1px dashed var(--tv-border-color);
  border-radius: 4px;
  background: var(--tv-workspace-bg);
  color: var(--tv-muted-color);
  font-size: 0.72rem;
}

.tv-drawing-item {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 6px;
  padding: 4px 6px;
  border: none;
  border-bottom: 1px solid var(--tv-divider-subtle);
  border-radius: 0;
  background: transparent;
  color: var(--tv-text-color);
}

.tv-drawing-item:hover,
.tv-drawing-item.is-selected {
  background: rgba(41, 98, 255, 0.16);
}

.tv-drawing-item.is-selected {
  box-shadow: inset 0 0 0 1px rgba(41, 98, 255, 0.38);
}

.tv-drawing-item.is-locked {
  background: rgba(41, 98, 255, 0.12);
  box-shadow: none;
}

.tv-drawing-item__top {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 1px;
  min-width: 0;
}

.tv-drawing-item__label {
  color: var(--tv-text-color);
  font-size: 0.7rem;
  font-weight: 700;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.tv-drawing-item__index {
  color: var(--tv-muted-color);
  font-family: var(--font-mono);
  font-weight: 600;
}

.tv-drawing-item__meta {
  color: var(--tv-muted-color);
  font-size: 0.6rem;
  line-height: 1.1;
}

.tv-drawing-item__actions {
  justify-content: flex-end;
  flex-wrap: nowrap;
  gap: 2px;
}

.tv-drawing-item__actions .tv-drawing-action,
.tv-drawing-item__actions .action-button--icon-compact {
  width: 23px;
  min-width: 23px;
  height: 23px;
  min-height: 23px;
  padding: 0;
  border-color: transparent;
  border-radius: 4px;
  background: transparent;
  color: #a3adbb;
  box-shadow: none;
}

.tv-drawing-item__actions .tv-drawing-action:hover,
.tv-drawing-item__actions .tv-drawing-action:focus-visible {
  outline: none;
  background: #2a2e39;
  color: #d1d4dc;
}

.tv-drawing-item__actions .tv-drawing-action--danger:hover,
.tv-drawing-item__actions .tv-drawing-action--danger:focus-visible {
  color: var(--negative);
}

.tv-object-tree {
  gap: 0;
}

.tv-object-tree__row {
  min-height: 28px;
  padding: 5px 8px;
  border: none;
  border-bottom: 1px solid var(--tv-divider-subtle);
  border-radius: 0;
  background: transparent;
}

.tv-object-tree__index {
  width: 18px;
  height: 18px;
  border-radius: 3px;
  font-size: 0.58rem;
}

.tv-object-tree__main strong {
  font-size: 0.7rem;
}

.tv-object-tree__main span,
.tv-object-tree__state {
  font-size: 0.6rem;
}

@media (min-width: 1025px) {
  .app-shell:has(.tv-workspace) .page-shell {
    min-height: calc(100vh - 33px);
  }

  .tv-toolbar {
    min-height: 32px;
    padding-block: 2px;
  }

  .tv-toolbar__right {
    grid-template-columns: repeat(4, max-content);
    gap: 6px;
  }
}

@media (max-width: 1220px) {
  .tv-toolbar {
    flex-wrap: nowrap;
    align-items: center;
  }

  .tv-toolbar__left,
  .tv-toolbar__right {
    width: auto;
  }

  .tv-toolbar__left {
    flex-wrap: nowrap;
  }

  .tv-toolbar__chart-controls {
    width: auto;
  }

  .tv-toolbar__right {
    display: none;
  }
}

@media (max-width: 767px) {
  .app-shell:has(.tv-workspace) .topbar {
    position: sticky;
    min-height: 48px;
    flex-direction: row;
    align-items: center;
    padding: 2px var(--space-1);
  }

  .app-shell:has(.tv-workspace) .user-menu__trigger,
  .app-shell:has(.tv-workspace) .theme-toggle {
    min-height: 40px;
    padding: 6px 8px;
  }

  .app-shell:has(.tv-workspace) .topbar__brand {
    flex: 1 1 auto;
  }

  .app-shell:has(.tv-workspace) .brand-title {
    max-width: 11rem;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .app-shell:has(.tv-workspace) .topbar__nav {
    flex: 0 0 auto;
    flex-direction: row;
    align-items: center;
  }

  .app-shell:has(.tv-workspace) .nav-link {
    display: none;
  }

  .app-shell:has(.tv-workspace) .user-menu__identity {
    display: none;
  }

  .tv-toolbar {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 2px;
    padding: 2px 6px;
  }

  .tv-toolbar__left,
  .tv-toolbar__chart-controls {
    flex-wrap: nowrap;
    gap: 4px;
  }

  .tv-toolbar-title {
    max-width: 8rem;
    font-size: 0.74rem;
  }

  .tv-toolbar__chart-controls {
    display: flex;
    overflow: hidden;
  }

  .tv-toolbar__chart-controls #timeframe-selector {
    grid-column: auto;
    width: auto;
    overflow-x: auto;
    overflow-y: hidden;
    flex-wrap: nowrap;
    white-space: nowrap;
  }

  .tv-toolbar__chart-controls .interval-switcher__button {
    min-width: 40px;
    min-height: 40px;
    padding: 4px 8px;
    font-size: 0.7rem;
  }

  .tv-toolbar__chart-controls .tv-chart-type-switcher__button {
    min-height: 40px;
    padding: 6px 10px;
    font-size: 0.72rem;
  }

  .tv-toolbar__icon-actions {
    margin-left: 0;
  }

  .tv-toolbar__right {
    display: none;
  }

  .tv-chart-area {
    min-height: clamp(640px, 92dvh, 820px);
  }

  .tv-chart-wrapper {
    min-height: 420px;
  }

  .tv-drawing-dock {
    min-height: 40px;
    padding: 3px 6px;
  }

  .tv-dock-btn,
  .action-button--icon-compact,
  .tv-watchlist-remove {
    min-width: 40px;
    min-height: 40px;
    width: 40px;
    height: 40px;
  }

  .tv-toolbar__chart-controls .action-button--icon-compact,
  .tv-toolbar__icon-actions .action-button--icon-compact,
  .tv-template-menu .action-button--icon-compact,
  .tv-chart-legend__indicator-actions .action-button--icon-compact {
    min-width: 40px;
    min-height: 40px;
    width: 40px;
    height: 40px;
  }

  .tv-chart-footer__group--range .tv-chart-footer__range-button,
  .tv-chart-footer__range-button {
    min-width: 40px;
    min-height: 40px;
    padding: 6px 8px;
  }

  .tv-drawing-panel-drawer {
    left: var(--space-2);
    right: var(--space-2);
    top: calc(30px + 32px + 40px + var(--space-2));
    bottom: auto;
    width: auto;
    max-height: min(46dvh, calc(100dvh - 112px));
  }

  .tv-rail {
    max-height: 34dvh;
  }

  .tv-sidebar-panel.is-active {
    max-height: calc(34dvh - 33px);
  }

  .tv-rail-tabs .tv-rail-tab {
    flex: 1 0 max(25%, 5.5rem);
    min-height: 40px;
    padding: 8px 8px;
    font-size: 0.7rem;
  }

  .tv-market-list::before {
    grid-template-columns: minmax(0, 1fr) 8ch 6ch;
    padding-inline: 8px;
  }

  .tv-market-list .symbol-item__select,
  .tv-market-list .symbol-item:not(:has(.symbol-item__select)) {
    min-height: 40px;
    padding: 6px 8px;
  }

  .tv-market-list .symbol-item__rhs {
    grid-template-columns: 8ch 6ch;
    min-width: 14ch;
  }

  .order-row,
  .position-row {
    grid-template-columns: minmax(0, 1fr);
  }

  .order-row__meta,
  .position-row__meta {
    justify-self: stretch;
    text-align: left;
  }

  .order-input,
  .order-btn,
  .order-submit-btn {
    min-height: 40px;
  }

  /* 2026-06-19 mobile visual clipping fix: keep chart-first density while making dense controls scroll instead of clipping. */
  .tv-chart-overlay__left {
    max-height: min(44dvh, calc(100% - var(--space-2)));
  }

  #tv-indicator-legend {
    max-height: min(26dvh, 156px);
    padding-right: 2px;
    overflow-y: auto;
    overscroll-behavior: contain;
    scroll-padding-block: var(--space-1);
  }

  .tv-chart-legend__indicator-row {
    align-items: start;
    min-height: 0;
    row-gap: 3px;
  }

  .tv-chart-legend__indicator-main {
    align-items: start;
    min-height: 0;
    line-height: 1.25;
  }

  .tv-chart-legend__indicator-name,
  .tv-chart-legend__indicator-values,
  .tv-chart-legend__value {
    line-height: 1.25;
  }

  .tv-chart-legend__indicator-values {
    white-space: normal;
    overflow-wrap: anywhere;
  }

  .tv-drawing-dock {
    box-sizing: border-box;
    max-width: 100%;
    padding-inline: 6px 16px;
    overflow-x: auto;
    overflow-y: hidden;
    overscroll-behavior-x: contain;
    scroll-padding-inline: 6px 18px;
  }

  .tv-dock-group {
    flex: 0 0 auto;
    min-width: max-content;
    max-width: none;
  }

  .tv-dock-group:last-child {
    padding-right: 8px;
  }

  .tv-dock-btn {
    flex: 0 0 34px;
  }

  .tv-drawing-tool-flyout.is-mobile-sheet {
    padding: 6px;
    border-radius: 8px;
  }

  .tv-drawing-tool-flyout__item {
    min-height: 38px;
    padding: 5px 7px;
  }

  #tv-chart-footer {
    flex-wrap: wrap;
    justify-content: flex-start;
    align-content: center;
    gap: 3px 6px;
    min-height: 0;
    padding: 4px 6px;
    overflow: hidden;
  }

  #tv-chart-footer .tv-chart-footer__group {
    min-width: 0;
  }

  .tv-chart-footer__group--ranges {
    order: 1;
    flex: 1 1 100%;
    max-width: 100%;
    padding-bottom: 1px;
    scroll-padding-inline: 4px 12px;
  }

  .tv-chart-footer__group--source {
    order: 2;
    flex: 0 0 auto;
  }

  .tv-chart-footer__group--visible-range {
    order: 3;
    flex: 1 1 13rem;
    min-width: 0;
    max-width: 100%;
    overflow-x: auto;
    overflow-y: hidden;
    scrollbar-width: none;
  }

  .tv-chart-footer__group--visible-range::-webkit-scrollbar {
    display: none;
  }

  .tv-chart-footer__group--hint {
    order: 4;
    flex: 0 0 auto;
    margin-left: auto;
  }

  .tv-rail {
    max-height: min(28dvh, 230px);
  }

  .tv-sidebar-panel.is-active {
    max-height: calc(min(28dvh, 230px) - 33px);
  }

  .tv-sidebar-panel[data-sidebar-content="market"].is-active .tv-rail-section--watchlist {
    flex: 1 1 58%;
    min-height: 88px;
  }

  .tv-sidebar-panel[data-sidebar-content="market"].is-active {
    overflow-y: auto;
    overflow-x: hidden;
    overscroll-behavior: contain;
  }

  .tv-sidebar-panel[data-sidebar-content="market"].is-active .tv-rail-section--watchlist {
    flex: 0 0 auto;
    min-height: 118px;
    max-height: none;
  }

  .tv-sidebar-panel[data-sidebar-content="market"].is-active .tv-market-list {
    flex: 0 0 auto;
    max-height: 132px;
    overflow-y: auto;
    overflow-x: hidden;
  }

  .tv-paper-trading-panel #submit-order {
    scroll-margin-block: 12px;
  }
}


@media (max-width: 420px) {
  .tv-chart-area {
    min-height: clamp(660px, 94dvh, 840px);
  }

  .tv-chart-wrapper {
    min-height: 450px;
  }

  #tv-indicator-legend {
    max-height: min(24dvh, 132px);
  }

  .tv-chart-footer__group--visible-range {
    flex-basis: 11rem;
  }

  .tv-rail {
    max-height: min(24dvh, 196px);
  }

  .tv-sidebar-panel.is-active {
    max-height: calc(min(24dvh, 196px) - 33px);
  }

  .tv-sidebar-panel[data-sidebar-content="market"].is-active .tv-rail-section--watchlist {
    min-height: 96px;
  }

  .tv-sidebar-panel[data-sidebar-content="market"].is-active .tv-market-list {
    max-height: 108px;
  }
}
