:root {
  --sidebar-width: 336px;
  --sidebar-collapsed-width: 56px;
  --shell-sidebar-offset: calc(var(--sidebar-width) + 16px);
  --dom-col-pad: 10px;
  --dom-col-0: 60px;
  --dom-col-1: 66px;
  --dom-col-2: 88px;
  --dom-col-3: 66px;
  --dom-col-4: 60px;
}

* {
  box-sizing: border-box;
}

html,
body {
  min-height: 100%;
}

html {
  background: var(--bg);
}

body {
  margin: 0;
  min-height: 100vh;
  color: var(--text);
  font-family: Arial, Helvetica, sans-serif;
  background-color: var(--bg);
  background-image:
    radial-gradient(circle at top left, var(--body-accent-a), transparent 32rem),
    radial-gradient(circle at bottom right, var(--body-accent-b), transparent 30rem);
  background-repeat: no-repeat;
  background-attachment: fixed;
}

body[data-theme="dark"] {
  background-image:
    radial-gradient(circle at top left, var(--body-accent-a), transparent 32rem),
    radial-gradient(circle at bottom right, var(--body-accent-b), transparent 30rem);
}

body[data-theme="light"] {
  background-image:
    radial-gradient(circle at top left, var(--body-accent-a), transparent 32rem),
    radial-gradient(circle at bottom right, var(--body-accent-b), transparent 30rem);
}

button,
input,
select {
  font: inherit;
}

.shell {
  width: 100%;
  min-height: 100vh;
  margin: 0;
  padding: 24px 16px 88px 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  position: relative;
}

.topbar,
.chart-card,
.dom-panel,
.tape-panel,
.orderflow-panel,
.trade-panel {
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--panel) 90%, transparent);
  box-shadow: 0 10px 30px color-mix(in srgb, var(--black) 20%, transparent);
  backdrop-filter: blur(16px);
}

.topbar {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 4px;
  border-radius: 8px;
  position: fixed;
  right: 24px;
  bottom: 24px;
  top: auto;
  left: auto;
  width: auto;
  max-width: calc(100vw - 32px);
  max-height: calc(100vh - 32px);
  z-index: 10000;
  overflow: visible;
  color: var(--text);
  background: color-mix(in srgb, var(--bg) 86%, transparent);
  background: color-mix(in srgb, var(--panel) 88%, transparent);
  border-color: color-mix(in srgb, var(--muted) 24%, transparent);
  border-color: color-mix(in srgb, var(--line) 76%, transparent);
  box-shadow: 0 8px 18px color-mix(in srgb, var(--black) 16%, transparent), inset 0 1px 0 color-mix(in srgb, var(--on-color) 4%, transparent);
  backdrop-filter: blur(14px) saturate(1.08);
  transform: none;
  transform-origin: bottom right;
  user-select: none;
  transition: transform 160ms ease, opacity 160ms ease, box-shadow 160ms ease, border-color 160ms ease;
}

.topbar.dragging {
  box-shadow: 0 10px 22px color-mix(in srgb, var(--black) 22%, transparent), inset 0 1px 0 color-mix(in srgb, var(--on-color) 5%, transparent);
  transform: none !important;
}

.topbar-main {
  display: grid;
  gap: 7px;
}

.topbar-lower {
  display: none;
  align-items: center;
  gap: 8px;
  min-width: 0;
  padding: 0;
  border-top: 0;
}

.widget-toolbar-drag-handle {
  flex: 0 0 auto;
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  border: 1px solid color-mix(in srgb, var(--toolbar-border) 58%, transparent);
  border-radius: 9px;
  color: var(--toolbar-text);
  background: color-mix(in srgb, var(--toolbar-bg) 68%, transparent);
  cursor: move;
}

.widget-toolbar-drag-handle svg {
  width: 22px;
  height: 22px;
  display: block;
  fill: currentColor;
}

.widget-launcher-toggle {
  flex: 0 0 auto;
  width: 38px;
  height: 38px;
  min-width: 38px;
  min-height: 38px;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  line-height: 1.1;
  white-space: nowrap;
  border: 1px solid transparent;
  border-radius: 9px;
  color: var(--toolbar-text);
  background: transparent;
  box-shadow: none;
  transition: background 140ms ease, border-color 140ms ease, box-shadow 140ms ease, color 140ms ease, transform 140ms ease;
}

.widget-launcher-toggle:hover,
.widget-launcher-toggle:focus-visible {
  color: var(--toolbar-text);
  border-color: color-mix(in srgb, var(--toolbar-highlight) 34%, transparent);
  background: color-mix(in srgb, var(--toolbar-highlight) 14%, var(--toolbar-bg));
}

.sidebar-toggle-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 24px;
}

.sidebar-toggle-icon svg {
  width: 22px;
  height: 22px;
  display: block;
  fill: none;
  stroke: currentColor;
  stroke-width: 2.5;
  stroke-linecap: round;
  stroke-linejoin: round;
  transition: transform 140ms ease;
}

.widget-launcher.is-open .sidebar-toggle-icon svg {
  transform: rotate(180deg);
}

.sidebar-toggle-label {
  display: none;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.widget-launcher .topbar-main,
.widget-launcher .topbar-lower {
  display: none;
}

.widget-launcher.is-open {
  width: auto;
}

.widget-launcher.is-open .topbar-lower {
  display: flex;
  flex: 1 1 auto;
  min-width: 0;
  max-width: calc(100vw - 118px);
  overflow-x: auto;
  overflow-y: hidden;
  scrollbar-width: thin;
}

.widget-launcher.is-open .topbar-main {
  display: none;
}

.widget-launcher.is-open .widget-launcher-toggle {
  width: 38px;
  height: 38px;
  position: static;
  top: auto;
  right: auto;
  transform: none;
  box-shadow: none;
}

.widget-launcher:not(.is-open) {
  width: auto;
  height: auto;
  padding: 7px;
  overflow: hidden;
  cursor: default;
  display: flex;
  align-items: center;
  justify-content: center;
}

.widget-launcher:not(.is-open):hover {
  transform: translateY(-2px);
}

.widget-launcher:not(.is-open):active {
  transform: translateY(1px) scale(0.98);
}

.widget-launcher:not(.is-open) .topbar-main,
.widget-launcher:not(.is-open) .topbar-lower {
  opacity: 0;
  pointer-events: none;
}

@media (min-width: 921px) {
  .widget-launcher {
    right: 24px;
    bottom: 24px;
  }
}

.brand-block {
  min-width: 0;
}

.eyebrow {
  margin: 0 0 4px;
  color: var(--accent);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

h1 {
  margin: 0;
  font-size: clamp(22px, 2.2vw, 34px);
  letter-spacing: -0.045em;
}

.controls {
  display: flex;
  align-items: end;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}

.hidden-global-controls {
  display: none;
}

label {
  display: grid;
  gap: 5px;
  color: var(--muted);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

select,
input {
  min-height: 36px;
  color: var(--text);
  background: var(--panel-strong);
  border: 1px solid var(--line);
  border-radius: 9px;
  padding: 0 11px;
  outline: none;
}

input:focus,
select:focus {
  border-color: var(--line-active);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 14%, transparent);
}

.symbol-field input {
  width: 124px;
  text-transform: uppercase;
}

button {
  min-height: 36px;
  border: 0;
  border-radius: 9px;
  padding: 0 16px;
  color: var(--button-accent-text);
  background: linear-gradient(135deg, var(--button-accent-gradient), var(--accent));
  font-weight: 800;
  cursor: pointer;
}

button:hover {
  filter: brightness(1.06);
}

.secondary-button {
  color: var(--text);
  background: var(--panel-strong);
  border: 1px solid var(--line);
}

.secondary-button[aria-pressed="true"] {
  color: var(--button-buy-text);
  background: linear-gradient(135deg, var(--button-buy-gradient), var(--green));
  border-color: transparent;
}

.danger-button {
  color: var(--button-sell-text);
  background: linear-gradient(135deg, var(--button-sell-gradient), var(--red));
  border: 0;
}

.small-button {
  min-height: 28px;
  padding: 0 10px;
  border-radius: 7px;
  font-size: 12px;
}

.ticker-stats span {
  padding: 5px 9px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--panel-strong) 92%, transparent);
}

.widget-toolbar {
  display: flex;
  align-items: center;
  flex: 0 0 auto;
  gap: 4px;
  max-width: min(780px, calc(100vw - 200px));
  overflow-x: auto;
  overflow-y: hidden;
  scrollbar-width: thin;
}

.widget-toolbar-title {
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: lowercase;
  color: var(--muted);
  cursor: text;
  user-select: text;
}

.widget-toolbar .chart-toolbar-button,
.widget-system-toolbar .chart-toolbar-button {
  flex: 0 0 auto;
  width: 38px;
  height: 38px;
  min-width: 38px;
  min-height: 38px;
  border-radius: 8px;
}

.widget-toolbar svg,
.widget-system-toolbar svg {
  width: 22px;
  height: 22px;
  display: block;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.widget-toolbar button:disabled {
  opacity: 0.48;
  cursor: not-allowed;
}

.widget-system-toolbar {
  display: inline-flex;
  align-items: center;
  flex: 0 0 auto;
  gap: 4px;
}

.workspace-switcher {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  padding: 1px;
  border: 1px solid color-mix(in srgb, var(--toolbar-border) 42%, transparent);
  border-radius: 8px;
  background: color-mix(in srgb, var(--toolbar-bg) 52%, transparent);
}

.workspace-switcher select {
  width: 142px;
  min-height: 34px;
  border-color: transparent;
  border-radius: 7px;
  color: var(--toolbar-text);
  background: color-mix(in srgb, var(--panel-strong) 62%, transparent);
  font-size: 11px;
  font-weight: 800;
}

.workspace-switcher .chart-toolbar-button {
  width: 34px;
  min-width: 34px;
  height: 34px;
  min-height: 34px;
}

.palette-toggle-button {
  width: 45px;
  min-width: 45px;
  padding: 0;
}

.palette-toggle-button:disabled,
.palette-toggle-button.is-disabled {
  opacity: 0.36;
  cursor: not-allowed;
  filter: grayscale(1);
}

.palette-toggle-button:disabled:hover,
.palette-toggle-button.is-disabled:hover {
  transform: none;
}

.palette-swatch-stack {
  display: grid;
  grid-template-columns: repeat(3, 8px);
  grid-auto-rows: 11px;
  gap: 3px;
  align-items: stretch;
  justify-content: center;
}

.palette-swatch-stack span {
  display: block;
  border-radius: 2px;
  background: var(--swatch);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--on-color) 18%, transparent);
}

.instant-toolbar-tooltip {
  position: fixed;
  z-index: 10050;
  left: 0;
  top: 0;
  max-width: min(220px, calc(100vw - 16px));
  padding: 5px 8px;
  border: 1px solid color-mix(in srgb, var(--muted) 28%, transparent);
  border-radius: 6px;
  color: var(--text);
  background: color-mix(in srgb, var(--bg) 96%, transparent);
  background: color-mix(in srgb, var(--panel) 94%, transparent);
  box-shadow: 0 10px 24px color-mix(in srgb, var(--black) 28%, transparent);
  font-size: 11px;
  font-weight: 800;
  line-height: 1.2;
  letter-spacing: 0;
  text-transform: none;
  white-space: nowrap;
  pointer-events: none;
  opacity: 0;
  transform: translate3d(-9999px, -9999px, 0);
  transition: none;
}

.instant-toolbar-tooltip.is-visible {
  opacity: 1;
}

.launcher-actions {
  display: grid;
  gap: 8px;
}

.launcher-home-button {
  width: 100%;
}

.widget-board {
  position: relative;
  min-height: 1220px;
  border: 1px solid var(--line);
  border-radius: 22px;
  background:
    linear-gradient(color-mix(in srgb, var(--line) 50%, transparent) 1px, transparent 1px),
    linear-gradient(90deg, color-mix(in srgb, var(--line) 50%, transparent) 1px, transparent 1px),
    color-mix(in srgb, var(--bg) 72%, transparent);
  background-size: 28px 28px;
  overflow: hidden;
}

:root[data-theme="nord"] .widget-board {
  background: color-mix(in srgb, var(--bg) 72%, transparent);
}

.widget {
  position: absolute;
  display: grid;
  grid-template-rows: 24px minmax(0, 1fr);
  min-width: 260px;
  min-height: 130px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: color-mix(in srgb, var(--panel) 94%, transparent);
  box-shadow: 0 10px 28px color-mix(in srgb, var(--black) 22%, transparent);
  backdrop-filter: blur(16px);
  overflow: hidden;
}

.widget[data-widget="tape"] {
  min-width: 170px;
}

.widget[data-widget="heatmap"] .widget-body,
.widget[data-widget="journal"] .widget-body {
  overflow: hidden;
}

.widget-launcher {
  z-index: 10001;
}

.widget.hidden {
  display: none;
}

.widget.dragging,
.widget.resizing {
  z-index: 1000 !important;
  user-select: none;
}

.widget-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
  min-height: 22px;
  padding: 0 5px 0 8px;
  color: color-mix(in srgb, var(--muted) 72%, transparent);
  background: transparent;
  border-bottom: 1px solid color-mix(in srgb, var(--line) 22%, transparent);
  cursor: grab;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-transform: lowercase;
}

.widget-header:active {
  cursor: grabbing;
}

.widget-header-title {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  cursor: text;
  opacity: 0.78;
  user-select: text;
}

.widget-header-actions {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  flex: 0 0 auto;
  margin-left: auto;
}

.widget-close {
  width: 18px;
  min-height: 18px;
  padding: 0;
  border-radius: 4px;
  color: color-mix(in srgb, var(--muted) 58%, transparent);
  background: transparent;
  font-size: 13px;
  line-height: 14px;
}

.widget-close:hover {
  color: var(--danger-text);
  background: color-mix(in srgb, var(--red) 8%, transparent);
}

.widget-body {
  min-height: 0;
  overflow: auto;
}

.widget-stack {
  display: grid;
  grid-template-rows: minmax(0, 1fr);
  height: 100%;
  min-height: 0;
}

.widget-config-shell {
  display: inline-flex;
  align-items: center;
  min-height: 18px;
  border: 0;
  background: transparent;
}

.widget-config-shell.is-popout-open {
  background: transparent;
}

.widget-config-toggle {
  width: auto;
  min-height: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 5px;
  border: 0;
  border-radius: 4px;
  color: color-mix(in srgb, var(--muted) 64%, transparent);
  background: transparent;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-transform: lowercase;
}

.widget-config-toggle:hover,
.widget-config-toggle:focus-visible {
  color: color-mix(in srgb, var(--text) 88%, transparent);
  border-color: transparent;
  background: color-mix(in srgb, var(--text) 5%, transparent);
}

.widget-config-toggle.is-popout-open {
  color: var(--text);
  border-color: transparent;
  background: color-mix(in srgb, var(--accent) 8%, transparent);
  box-shadow: none;
}

.widget-config-toggle-copy {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.widget-config-toggle-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 14px;
  height: 14px;
  color: var(--accent);
  font-family: "Segoe UI Symbol", "Segoe UI", sans-serif;
  font-size: 14px;
  font-weight: 800;
  line-height: 1;
}

.widget-config-toggle-icon svg {
  width: 12px;
  height: 12px;
  display: block;
  fill: none;
  stroke: currentColor;
  stroke-width: 2.3;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.widget-config-popout {
  position: fixed;
  left: 10px;
  top: 10px;
  z-index: 10020;
  width: min(440px, calc(100vw - 20px));
  max-height: min(520px, calc(100vh - 20px));
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  overflow: hidden;
  color: var(--text);
  border: 1px solid color-mix(in srgb, var(--muted) 28%, transparent);
  border-radius: 8px;
  background: color-mix(in srgb, var(--bg) 94%, transparent);
  background: color-mix(in srgb, var(--panel) 92%, transparent);
  box-shadow: 0 10px 26px color-mix(in srgb, var(--black) 20%, transparent), inset 0 1px 0 color-mix(in srgb, var(--on-color) 4%, transparent);
  backdrop-filter: blur(16px) saturate(1.08);
}

.widget-config-popout[hidden] {
  display: none !important;
}

.widget-config-popout-header {
  min-height: 30px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 0 6px 0 10px;
  border-bottom: 1px solid color-mix(in srgb, var(--muted) 20%, transparent);
  color: var(--muted);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: grab;
  user-select: none;
}

.widget-config-popout-header span {
  cursor: text;
  user-select: text;
}

.widget-config-popout-header:active,
.widget-config-popout.is-dragging .widget-config-popout-header {
  cursor: grabbing;
}

.widget-config-popout-close {
  width: 22px;
  min-height: 22px;
  padding: 0;
  border-radius: 6px;
  color: var(--muted);
  background: color-mix(in srgb, var(--panel-strong) 72%, transparent);
  font-size: 16px;
  line-height: 18px;
}

.widget-config-popout-close:hover,
.widget-config-popout-close:focus-visible {
  color: var(--danger-text);
  background: color-mix(in srgb, var(--red) 52%, transparent);
}

.widget-config-popout-body {
  min-height: 0;
  overflow: auto;
}

.widget-config {
  display: flex;
  align-items: end;
  gap: 8px;
  flex-wrap: wrap;
  padding: 10px 12px;
  border-bottom: 0;
  background: transparent;
}

.widget-config label {
  gap: 4px;
  font-size: 10px;
}

.widget-config-group {
  display: grid;
  gap: 8px;
  padding: 9px;
  border: 1px solid color-mix(in srgb, var(--muted) 22%, transparent);
  border-radius: 8px;
  background: color-mix(in srgb, var(--bg) 34%, transparent);
  min-width: min(100%, 220px);
}

.market-widget-config {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: end;
  gap: 8px;
}

.market-widget-config > .widget-config-group {
  grid-column: 1 / -1;
}

.widget-config-group-head,
.market-credential-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.market-credential-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.market-credential-grid .full-span {
  grid-column: 1 / -1;
}

.market-credential-grid input {
  width: 100%;
  min-width: 0;
}

.market-credential-actions button {
  min-width: 96px;
}

.widget-config-group-title {
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
  font-weight: 700;
}

.widget-config select,
.widget-config input,
.widget-config button {
  min-height: 30px;
  border-radius: 8px;
}

.widget-config .symbol-field input {
  width: 118px;
}

.dom-display-control {
  min-width: 150px;
}

.dom-display-toggle {
  display: grid;
  min-width: 118px;
  grid-auto-flow: column;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
}

.dom-display-toggle input {
  width: 15px;
  height: 15px;
  accent-color: var(--accent);
}

.dom-column-toggle-group {
  min-width: min(100%, 360px);
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  margin: 0;
  padding: 7px;
  border: 1px solid color-mix(in srgb, var(--muted) 22%, transparent);
  border-radius: 8px;
  background: color-mix(in srgb, var(--bg) 28%, transparent);
}

.dom-column-toggle-group legend,
.tape-aggregate-controls legend {
  padding: 0 4px;
  color: var(--muted);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.tape-aggregate-controls {
  min-width: min(100%, 420px);
  display: grid;
  grid-template-columns: minmax(130px, 0.72fr) minmax(126px, 0.6fr) minmax(126px, 0.6fr);
  align-items: end;
  gap: 7px;
  margin: 0;
  padding: 7px;
  border: 1px solid color-mix(in srgb, var(--muted) 22%, transparent);
  border-radius: 8px;
  background: color-mix(in srgb, var(--bg) 28%, transparent);
}

.tape-aggregate-window,
.tape-refresh-rate {
  min-width: 126px;
}

.tape-aggregate-window select,
.tape-refresh-rate select {
  width: 100%;
}

.tape-venue-grid {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(3, minmax(112px, 1fr));
  gap: 5px;
}

.tape-venue-toggle {
  min-width: 0;
  min-height: 24px;
  padding: 0 6px;
  border: 1px solid color-mix(in srgb, var(--muted) 20%, transparent);
  border-radius: 6px;
  background: color-mix(in srgb, var(--panel-strong) 48%, transparent);
  font-size: 10px;
}

.dom-column-toggle {
  min-width: 86px;
  min-height: 24px;
  padding: 0 6px;
  border: 1px solid color-mix(in srgb, var(--muted) 20%, transparent);
  border-radius: 6px;
  background: color-mix(in srgb, var(--panel-strong) 48%, transparent);
  font-size: 10px;
}

.dom-column-toggle input:disabled {
  opacity: 0.58;
  cursor: not-allowed;
}

.range-with-value {
  display: grid;
  grid-template-columns: minmax(86px, 1fr) 34px;
  align-items: center;
  gap: 6px;
}

.range-with-value input[type="range"] {
  width: 100%;
  min-width: 0;
  accent-color: var(--accent);
}

.range-with-value strong {
  color: var(--text);
  font-size: 10px;
  font-weight: 800;
  text-align: right;
}

.heatmap-widget-config {
  display: grid;
  align-items: stretch;
  gap: 8px;
}

.heatmap-config-group {
  min-width: 0;
  display: grid;
  gap: 8px;
  margin: 0;
  padding: 8px;
  border: 1px solid color-mix(in srgb, var(--muted) 22%, transparent);
  border-radius: 8px;
  background: color-mix(in srgb, var(--bg) 28%, transparent);
}

.heatmap-config-group legend {
  padding: 0 4px;
  color: var(--muted);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.heatmap-config-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 7px;
}

.heatmap-config-field {
  min-width: 0;
}

.heatmap-config-wide {
  grid-column: 1 / -1;
}

.heatmap-config-field input,
.heatmap-config-field select {
  width: 100%;
}

.heatmap-config-actions {
  display: flex;
  align-items: center;
  gap: 8px;
}

.heatmap-config-reset {
  min-width: 112px;
  color: var(--muted);
  background: color-mix(in srgb, var(--panel-strong) 58%, transparent);
  white-space: nowrap;
}

.heatmap-config-reset:hover,
.heatmap-config-reset:focus-visible {
  color: var(--text);
  background: color-mix(in srgb, var(--accent) 12%, var(--panel-strong));
}

.widget-config-status {
  margin-left: auto;
  align-self: center;
  color: var(--muted);
  font-size: 11px;
  font-weight: 700;
}

.widget-config-status[data-status="live"] {
  color: var(--buy-text);
}

.widget-config-status[data-status="error"] {
  color: var(--sell-text);
}

.widget-config-status[data-status="loading"] {
  color: var(--accent);
}

.widget-resize {
  position: absolute;
  right: 0;
  bottom: 0;
  width: 18px;
  height: 18px;
  cursor: nwse-resize;
}

.widget-resize::after {
  content: "";
  position: absolute;
  right: 5px;
  bottom: 5px;
  width: 8px;
  height: 8px;
  border-right: 2px solid color-mix(in srgb, var(--muted) 34%, transparent);
  border-bottom: 2px solid color-mix(in srgb, var(--muted) 34%, transparent);
}

.chart-card {
  position: relative;
  overflow: hidden;
  height: 100%;
  min-height: 0;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  background: transparent;
}

.orderflow-heatmap-frame,
.trade-journal-frame {
  display: block;
  width: 100%;
  height: 100%;
  border: 0;
  background: var(--bg);
}

#chart {
  width: 100%;
  height: 100%;
  min-height: 0;
  overflow: hidden;
}

.mirror-chart {
  width: 100%;
  height: 100%;
  min-height: 0;
  overflow: hidden;
}

.loading-overlay {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  color: var(--muted);
  background: color-mix(in srgb, var(--bg) 72%, transparent);
  pointer-events: none;
  opacity: 0;
  transition: opacity 160ms ease;
}

.loading-overlay.visible {
  opacity: 1;
}

.chart-drawing-host {
  position: relative;
}

.chart-drawing-toolbar {
  position: absolute;
  top: 12px;
  left: 12px;
  z-index: 8;
  display: flex;
  align-items: center;
  gap: 6px;
  max-width: calc(100% - 24px);
  padding: 5px;
  border: 1px solid color-mix(in srgb, var(--muted) 24%, transparent);
  border: 1px solid color-mix(in srgb, var(--line) 76%, transparent);
  border-radius: 8px;
  background: color-mix(in srgb, var(--bg) 86%, transparent);
  background: color-mix(in srgb, var(--panel) 88%, transparent);
  box-shadow: 0 12px 30px color-mix(in srgb, var(--black) 24%, transparent), inset 0 1px 0 color-mix(in srgb, var(--on-color) 4%, transparent);
  backdrop-filter: blur(14px) saturate(1.08);
  cursor: move;
  user-select: none;
}

.chart-drawing-toolbar.dragging {
  user-select: none;
  box-shadow: 0 18px 34px color-mix(in srgb, var(--black) 32%, transparent), inset 0 1px 0 color-mix(in srgb, var(--on-color) 5%, transparent);
}

.chart-trade-toolbar {
  --chart-trade-scale: 0.75;
  position: absolute;
  left: 12px;
  bottom: 12px;
  z-index: 8;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 6px;
  width: min(292px, calc(100% - 24px));
  padding: 7px;
  border: 1px solid color-mix(in srgb, var(--muted) 24%, transparent);
  border-radius: 8px;
  background: color-mix(in srgb, var(--bg) 88%, transparent);
  background: color-mix(in srgb, var(--panel) 90%, transparent);
  box-shadow: 0 14px 32px color-mix(in srgb, var(--black) 26%, transparent), inset 0 1px 0 color-mix(in srgb, var(--on-color) 4%, transparent);
  backdrop-filter: blur(14px) saturate(1.08);
  transform: scale(var(--chart-trade-scale));
  transform-origin: left bottom;
  will-change: transform;
  cursor: move;
  user-select: none;
}

.chart-trade-toolbar.dragging {
  user-select: none;
  box-shadow: 0 19px 38px color-mix(in srgb, var(--black) 34%, transparent), inset 0 1px 0 color-mix(in srgb, var(--on-color) 5%, transparent);
}

.chart-trade-toolbar.hidden,
.chart-trade-toolbar[hidden] {
  display: none;
}

.chart-trade-group {
  display: grid;
  gap: 5px;
  min-width: 0;
  padding: 5px;
  border: 1px solid color-mix(in srgb, var(--muted) 16%, transparent);
  border: 1px solid color-mix(in srgb, var(--line) 54%, transparent);
  border-radius: 7px;
  background: color-mix(in srgb, var(--panel-strong) 46%, transparent);
  background: color-mix(in srgb, var(--panel-strong) 68%, transparent);
}

.chart-trade-inputs,
.chart-trade-market-actions,
.chart-trade-limit-actions,
.chart-trade-draft-actions {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.chart-trade-toolbar label {
  gap: 4px;
  color: var(--muted);
  font-size: 8px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: default;
}

.chart-trade-toolbar label span,
.chart-trade-status {
  cursor: text;
  user-select: text;
}

.chart-trade-toolbar input {
  width: 100%;
  min-height: 29px;
  min-width: 0;
  padding: 0 9px;
  border: 1px solid color-mix(in srgb, var(--muted) 22%, transparent);
  border-radius: 6px;
  background: color-mix(in srgb, var(--bg) 46%, transparent);
  color: var(--text);
  font-size: 12px;
  font-weight: 800;
  cursor: text;
}

.chart-trade-button {
  min-height: 30px;
  padding: 0 10px;
  border-radius: 6px;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.03em;
  white-space: nowrap;
  cursor: pointer;
  transition: background 140ms ease, border-color 140ms ease, color 140ms ease, opacity 140ms ease, transform 140ms ease;
}

.chart-trade-sell {
  border: 1px solid color-mix(in srgb, var(--red) 36%, transparent);
  background: color-mix(in srgb, var(--red) 18%, transparent);
  color: var(--sell-soft-text);
}

.chart-trade-sell:hover,
.chart-trade-sell:focus-visible {
  background: color-mix(in srgb, var(--red) 28%, transparent);
  border-color: color-mix(in srgb, var(--red) 56%, transparent);
}

.chart-trade-toolbar .chart-trade-buy {
  border: 1px solid color-mix(in srgb, var(--green) 36%, transparent);
  background: color-mix(in srgb, var(--green) 18%, transparent);
  color: var(--buy-soft-text);
}

.chart-trade-toolbar .chart-trade-buy:hover,
.chart-trade-toolbar .chart-trade-buy:focus-visible {
  background: color-mix(in srgb, var(--green) 28%, transparent);
  border-color: color-mix(in srgb, var(--green) 56%, transparent);
}

.chart-trade-limit-actions .chart-trade-button,
.chart-trade-draft-actions .chart-trade-button {
  border: 1px solid color-mix(in srgb, var(--muted) 20%, transparent);
  background: color-mix(in srgb, var(--bg) 42%, transparent);
  color: var(--muted);
}

.chart-trade-limit-actions .chart-trade-button:hover,
.chart-trade-limit-actions .chart-trade-button:focus-visible,
.chart-trade-draft-actions .chart-trade-button:hover,
.chart-trade-draft-actions .chart-trade-button:focus-visible {
  color: var(--text);
  border-color: color-mix(in srgb, var(--accent) 34%, transparent);
  background: color-mix(in srgb, var(--accent) 13%, var(--panel-strong));
}

.chart-trade-limit-actions .chart-trade-button[aria-pressed="true"] {
  color: var(--text);
  border-color: color-mix(in srgb, var(--accent) 48%, transparent);
  background: color-mix(in srgb, var(--accent) 22%, var(--panel-strong));
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--accent) 18%, transparent), 0 5px 14px color-mix(in srgb, var(--black) 18%, transparent);
}

.chart-trade-button:active {
  transform: translateY(1px);
}

.chart-trade-button:disabled {
  opacity: 0.42;
  cursor: not-allowed;
  transform: none;
}

.chart-trade-footer {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 8px;
  min-width: 0;
  padding: 2px 4px 1px;
}

.chart-trade-toolbar .chart-trade-reduce {
  min-height: 24px;
  gap: 6px;
  color: var(--muted);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: none;
}

.chart-trade-toolbar .chart-trade-reduce input {
  width: 14px;
  height: 14px;
  min-height: 0;
  padding: 0;
  border-radius: 4px;
  cursor: pointer;
}

.chart-trade-status {
  color: var(--muted);
  overflow: hidden;
  font-size: 10px;
  font-weight: 800;
  line-height: 1.2;
  text-align: right;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.chart-trade-status.live {
  color: var(--green);
}

.chart-trade-status.error {
  color: var(--sell-text);
}

.chart-trade-status.loading {
  color: var(--accent);
}

.chart-entry-layer {
  position: absolute;
  inset: 0;
  z-index: 7;
  pointer-events: none;
}

.chart-entry-layer.hidden {
  display: none;
}

.chart-entry-line {
  position: absolute;
  left: 0;
  right: 0;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0;
  height: 0;
  min-height: 0;
  padding: 0 clamp(62px, 8vw, 92px) 0 clamp(12px, 10vw, 132px);
  border: 0;
  border-top: 1px solid currentColor;
  border-radius: 0;
  background: transparent;
  color: var(--info);
  transform: translateY(-50%);
  pointer-events: auto;
  cursor: ns-resize;
  outline: 0;
  appearance: none;
  user-select: none;
  touch-action: none;
}

.chart-entry-line.tp {
  color: var(--green);
}

.chart-entry-line.sl {
  color: var(--warning-text);
}

.chart-entry-line.locked {
  cursor: default;
}

.chart-entry-line.hidden {
  display: none;
}

.chart-entry-line.dragging {
  filter: brightness(1.15);
}

.chart-entry-label,
.chart-entry-price,
.chart-entry-spawn-handle,
.chart-entry-close {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 22px;
  border: 1px solid color-mix(in srgb, var(--muted) 32%, transparent);
  border-left: 0;
  background: color-mix(in srgb, var(--bg) 92%, transparent);
  box-shadow: 0 6px 16px color-mix(in srgb, var(--black) 20%, transparent);
  font-size: 10px;
  font-weight: 800;
  line-height: 1;
  white-space: nowrap;
}

.chart-entry-spawn-handles {
  display: inline-flex;
  align-items: center;
  pointer-events: auto;
}

.chart-entry-spawn-handle {
  min-width: 30px;
  padding: 0 7px;
  cursor: ns-resize;
  touch-action: none;
}

.chart-entry-spawn-handle::before {
  content: none;
}

.chart-entry-label {
  min-width: 42px;
  padding: 0 8px;
  border-left: 1px solid currentColor;
  border-color: currentColor;
  border-radius: 4px 0 0 4px;
  color: var(--on-color);
}

.chart-entry-line.entry .chart-entry-label {
  background: var(--info);
}

.chart-entry-line.tp .chart-entry-label {
  background: var(--green);
}

.chart-entry-line.sl .chart-entry-label {
  background: var(--warning-text);
}

.chart-entry-price {
  min-width: 70px;
  padding: 0 8px;
  color: currentColor;
}

.chart-entry-close {
  min-width: 76px;
  padding: 0 8px;
  border-radius: 0 4px 4px 0;
  color: var(--sell-text);
  cursor: pointer;
  touch-action: manipulation;
}

.chart-entry-spawn-handles + .chart-entry-label {
  border-radius: 0;
}

.chart-entry-spawn-handle:first-child {
  border-left: 1px solid color-mix(in srgb, var(--muted) 32%, transparent);
  border-radius: 4px 0 0 4px;
}

.chart-entry-spawn-handle:last-child {
  border-radius: 0;
}

.chart-entry-line:not(.entry) .chart-entry-price {
  border-radius: 0 4px 4px 0;
}

.chart-entry-close:hover {
  background: color-mix(in srgb, var(--red) 20%, transparent);
}

.chart-toolbar-group {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  min-width: 0;
  padding: 2px;
  border: 1px solid color-mix(in srgb, var(--toolbar-border) 58%, transparent);
  border-radius: 7px;
  background: color-mix(in srgb, var(--toolbar-bg) 68%, transparent);
}

.chart-toolbar-button {
  display: grid;
  place-items: center;
  width: 25px;
  height: 25px;
  min-width: 25px;
  min-height: 25px;
  padding: 0;
  border: 1px solid transparent;
  border-radius: 6px;
  color: var(--toolbar-text);
  background: transparent;
  appearance: none;
  box-shadow: none;
  cursor: pointer;
  transition: background 140ms ease, border-color 140ms ease, box-shadow 140ms ease, color 140ms ease, transform 140ms ease;
}

.chart-drawing-toolbar svg {
  width: 15px;
  height: 15px;
  display: block;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.chart-toolbar-button[aria-pressed="true"] {
  color: var(--toolbar-text);
  border-color: color-mix(in srgb, var(--toolbar-active) 48%, transparent);
  background: transparent;
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--toolbar-active) 18%, transparent), 0 5px 14px color-mix(in srgb, var(--black) 18%, transparent);
}

.chart-toolbar-button:hover,
.chart-toolbar-button:focus-visible {
  color: var(--toolbar-text);
  border-color: color-mix(in srgb, var(--toolbar-highlight) 34%, transparent);
  background: color-mix(in srgb, var(--toolbar-highlight) 14%, var(--toolbar-bg));
}

.chart-toolbar-button:active {
  transform: translateY(1px);
}

.chart-toolbar-danger:hover,
.chart-toolbar-danger:focus-visible {
  color: var(--toolbar-danger);
  border-color: color-mix(in srgb, var(--toolbar-danger) 42%, transparent);
  background: color-mix(in srgb, var(--toolbar-danger) 14%, transparent);
}

.api-credentials-button[aria-expanded="true"] {
  color: var(--toolbar-text);
  border-color: color-mix(in srgb, var(--toolbar-active) 48%, transparent);
  background: transparent;
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--toolbar-active) 18%, transparent), 0 5px 14px color-mix(in srgb, var(--black) 18%, transparent);
}

.api-credentials-button.is-coming-soon {
  grid-auto-flow: column;
  grid-template-columns: auto 1fr;
  gap: 5px;
  width: auto;
  min-width: 104px;
  padding: 0 8px;
  font-size: 9px;
  font-weight: 850;
  letter-spacing: 0;
  line-height: 1;
  white-space: nowrap;
}

.api-credentials-button.is-coming-soon svg {
  width: 13px;
  height: 13px;
}

.api-credentials-button.is-coming-soon span {
  display: block;
}

.api-credential-popout {
  position: fixed;
  z-index: 10020;
  width: min(372px, calc(100vw - 20px));
  border: 1px solid color-mix(in srgb, var(--line) 92%, transparent);
  border-radius: 8px;
  color: var(--text);
  background: color-mix(in srgb, var(--panel) 97%, transparent);
  box-shadow: 0 24px 60px color-mix(in srgb, var(--black) 42%, transparent), inset 0 1px 0 color-mix(in srgb, var(--on-color) 6%, transparent);
  backdrop-filter: blur(16px);
}

.api-credential-popout[hidden] {
  display: none !important;
}

.api-credential-card {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 12px;
}

.api-credential-header,
.api-credential-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.api-credential-header span {
  display: block;
  color: var(--muted);
  font-size: 9px;
  font-weight: 850;
  letter-spacing: 0.08em;
  line-height: 1;
  text-transform: uppercase;
}

.api-credential-header strong {
  display: block;
  margin-top: 3px;
  font-size: 14px;
  line-height: 1.1;
}

.api-credential-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.api-credential-grid .full-span {
  grid-column: 1 / -1;
}

.api-credential-grid label {
  display: grid;
  gap: 4px;
  min-width: 0;
  color: var(--muted);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.api-credential-grid input {
  width: 100%;
  min-width: 0;
  min-height: 32px;
  letter-spacing: 0;
  text-transform: none;
}

.api-credential-grid input:disabled,
.api-credential-actions button:disabled {
  opacity: 0.58;
  cursor: not-allowed;
}

.api-credential-grid .inline-check {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--text);
  letter-spacing: 0;
  text-transform: none;
}

.api-credential-grid .inline-check input {
  width: auto;
  min-height: auto;
}

.api-credential-actions button {
  min-width: 92px;
}

.api-credential-actions .trade-status {
  text-align: right;
}

.chart-indicator-menu,
.chart-candle-menu {
  position: relative;
}

.chart-indicator-popover,
.chart-candle-popover {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  display: grid;
  gap: 4px;
  min-width: 214px;
  max-height: min(360px, calc(100vh - 180px));
  overflow: auto;
  padding: 5px;
  border: 1px solid color-mix(in srgb, var(--muted) 24%, transparent);
  border: 1px solid color-mix(in srgb, var(--line) 74%, transparent);
  border-radius: 8px;
  background: color-mix(in srgb, var(--bg) 96%, transparent);
  background: color-mix(in srgb, var(--panel) 96%, var(--black) 4%);
  box-shadow: 0 18px 38px color-mix(in srgb, var(--black) 34%, transparent);
}

.chart-candle-popover {
  min-width: 138px;
}

.chart-indicator-popover[hidden],
.chart-candle-popover[hidden] {
  display: none;
}

.chart-indicator-item {
  display: grid;
  gap: 4px;
  padding: 3px;
  border: 1px solid color-mix(in srgb, var(--muted) 14%, transparent);
  border: 1px solid color-mix(in srgb, var(--line) 52%, transparent);
  border-radius: 6px;
  background: color-mix(in srgb, var(--panel-strong) 72%, transparent);
}

.chart-indicator-row {
  display: flex;
  align-items: center;
  gap: 4px;
  min-width: 0;
}

.chart-indicator-popover button,
.chart-candle-popover button {
  display: flex;
  align-items: center;
  min-height: 26px;
  padding: 0 8px;
  border: 1px solid color-mix(in srgb, var(--line) 54%, transparent);
  border-radius: 5px;
  color: var(--muted);
  background: color-mix(in srgb, var(--panel) 74%, transparent);
  justify-content: flex-start;
  width: 100%;
  font-size: 10px;
  font-weight: 800;
  text-align: left;
  white-space: nowrap;
  cursor: pointer;
  transition: background 140ms ease, border-color 140ms ease, color 140ms ease;
}

.chart-indicator-popover .chart-indicator-toggle {
  flex: 1 1 auto;
  min-width: 0;
}

.chart-indicator-popover .chart-indicator-settings-toggle {
  flex: 0 0 auto;
  width: 26px;
  min-width: 26px;
  padding: 0;
  justify-content: center;
}

.chart-indicator-settings-toggle svg {
  width: 14px;
  height: 14px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.chart-indicator-popover button[aria-pressed="true"],
.chart-candle-popover button[aria-pressed="true"] {
  color: var(--toolbar-text, var(--text));
  border-color: color-mix(in srgb, var(--toolbar-active) 70%, transparent);
  background: color-mix(in srgb, var(--toolbar-active) 28%, var(--panel-strong));
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--toolbar-active) 42%, transparent);
}

.chart-indicator-settings-toggle[aria-expanded="true"] {
  color: var(--toolbar-text, var(--text));
  border-color: color-mix(in srgb, var(--toolbar-active) 70%, transparent);
  background: color-mix(in srgb, var(--toolbar-active) 32%, var(--panel-strong));
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--toolbar-active) 42%, transparent);
}

.chart-indicator-popover button:hover,
.chart-indicator-popover button:focus-visible,
.chart-candle-popover button:hover,
.chart-candle-popover button:focus-visible {
  color: var(--toolbar-text, var(--text));
  border-color: color-mix(in srgb, var(--toolbar-active) 54%, transparent);
  background: color-mix(in srgb, var(--toolbar-active) 16%, var(--panel-strong));
}

.chart-indicator-settings {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 4px;
  padding: 4px 1px 1px;
}

.chart-indicator-settings[hidden] {
  display: none;
}

.chart-indicator-settings label {
  gap: 2px;
  font-size: 8px;
  letter-spacing: 0.04em;
}

.chart-indicator-settings input {
  width: 100%;
  min-height: 23px;
  padding: 0 6px;
  border-radius: 5px;
  font-size: 10px;
}

.chart-drawing-layer {
  position: absolute;
  inset: 0;
  z-index: 5;
  pointer-events: none;
  overflow: hidden;
}

.chart-drawing-layer.is-drawing,
.chart-drawing-layer.is-trading {
  pointer-events: auto;
  cursor: crosshair;
}

.chart-drawing-layer.is-drawing:not(.is-trading) {
  pointer-events: none;
}

.chart-drawing-delete {
  position: absolute;
  z-index: 9;
  display: grid;
  place-items: center;
  width: 22px;
  min-width: 22px;
  max-width: 22px;
  height: 22px;
  min-height: 22px;
  max-height: 22px;
  aspect-ratio: 1 / 1;
  padding: 0;
  border: 1px solid color-mix(in srgb, var(--red) 34%, transparent);
  border-radius: 50%;
  color: var(--sell-text);
  background: color-mix(in srgb, var(--panel) 92%, transparent);
  box-shadow: 0 8px 18px color-mix(in srgb, var(--black) 22%, transparent);
  font-size: 13px;
  font-weight: 900;
  line-height: 1;
  transform: translate(-50%, -50%);
  pointer-events: auto;
}

.chart-drawing-delete:hover,
.chart-drawing-delete:focus-visible {
  color: var(--on-color);
  border-color: transparent;
  background: var(--red);
  box-shadow: none;
}

.chart-drawing-delete.hidden {
  display: none;
}

.chart-drawing-host.is-drawing {
  cursor: crosshair;
}

.chart-drawing-host.is-measuring {
  cursor: crosshair;
}

.chart-drawing-svg {
  display: block;
  width: 100%;
  height: 100%;
}

.chart-drawing-shape {
  fill: none;
  stroke: var(--drawing-color);
  stroke-width: 2;
  vector-effect: non-scaling-stroke;
  filter: drop-shadow(0 1px 2px color-mix(in srgb, var(--black) 35%, transparent));
}

.chart-drawing-rect {
  fill: color-mix(in srgb, var(--drawing-color) 10%, transparent);
}

.chart-price-measure {
  pointer-events: none;
}

.chart-price-measure-guide {
  stroke: color-mix(in srgb, var(--drawing-label-text) 38%, transparent);
  stroke-width: 1;
  stroke-dasharray: 4 4;
  vector-effect: non-scaling-stroke;
}

.chart-price-measure-line {
  stroke: var(--drawing-color);
  stroke-width: 2;
  vector-effect: non-scaling-stroke;
  filter: drop-shadow(0 2px 4px color-mix(in srgb, var(--black) 42%, transparent));
}

.chart-price-measure.active .chart-price-measure-line {
  stroke-width: 2.5;
}

.chart-price-measure-point {
  fill: var(--drawing-color);
  stroke: color-mix(in srgb, var(--bg) 86%, transparent);
  stroke-width: 2;
}

.chart-price-measure-point.end {
  fill: var(--drawing-label-text);
}

.chart-price-measure-mid {
  fill: color-mix(in srgb, var(--drawing-label-text) 80%, transparent);
}

.chart-price-measure-label rect {
  fill: color-mix(in srgb, var(--drawing-label-bg) 88%, transparent);
  stroke: color-mix(in srgb, var(--drawing-color) 62%, transparent);
  stroke-width: 1;
}

.chart-price-measure-label text {
  fill: var(--drawing-label-text);
  font-family: Consolas, "Courier New", monospace;
  font-size: 11px;
  font-weight: 900;
  text-anchor: middle;
}

.chart-heatmap {
  pointer-events: none;
}

.chart-heatmap-band,
.chart-heatmap-cell,
.chart-heatmap-trace {
  pointer-events: none;
  shape-rendering: geometricPrecision;
}

.chart-volume-profile-bin {
  opacity: 0.72;
}

.chart-volume-profile-sell {
  fill: color-mix(in srgb, var(--red) 34%, transparent);
}

.chart-volume-profile-buy {
  fill: color-mix(in srgb, var(--green) 38%, transparent);
}

.chart-big-trade-bubble {
  pointer-events: none;
}

.chart-big-trade-bubble circle {
  stroke-width: 1.5;
  vector-effect: non-scaling-stroke;
  filter: drop-shadow(0 2px 5px color-mix(in srgb, var(--black) 35%, transparent));
}

.chart-big-trade-bubble.buy circle {
  fill: color-mix(in srgb, var(--green) 18%, transparent);
  stroke: color-mix(in srgb, var(--green) 85%, transparent);
}

.chart-big-trade-bubble.sell circle {
  fill: color-mix(in srgb, var(--red) 18%, transparent);
  stroke: color-mix(in srgb, var(--red) 85%, transparent);
}

.chart-big-trade-bubble text {
  fill: var(--text);
  font-size: 10px;
  font-weight: 800;
  text-anchor: middle;
  paint-order: stroke;
  stroke: color-mix(in srgb, var(--bg) 90%, transparent);
  stroke-width: 3px;
}

.chart-trapped-traders-overlay,
.chart-trapped-trader-bubble {
  pointer-events: none;
}

.chart-trapped-trader-halo,
.chart-trapped-trader-core {
  vector-effect: non-scaling-stroke;
  filter: drop-shadow(0 3px 8px color-mix(in srgb, var(--black) 42%, transparent));
}

.chart-trapped-trader-halo {
  opacity: 0.2;
}

.chart-trapped-trader-core {
  stroke-width: 1.7;
}

.chart-trapped-trader-bubble.short-trap .chart-trapped-trader-halo {
  fill: var(--green);
}

.chart-trapped-trader-bubble.short-trap .chart-trapped-trader-core {
  fill: color-mix(in srgb, var(--green) 28%, transparent);
  stroke: color-mix(in srgb, var(--green) 95%, transparent);
}

.chart-trapped-trader-bubble.long-trap .chart-trapped-trader-halo {
  fill: var(--red);
}

.chart-trapped-trader-bubble.long-trap .chart-trapped-trader-core {
  fill: color-mix(in srgb, var(--red) 28%, transparent);
  stroke: color-mix(in srgb, var(--red) 95%, transparent);
}

.chart-trapped-trader-bubble text {
  fill: color-mix(in srgb, var(--text) 96%, transparent);
  font-family: Consolas, "Courier New", monospace;
  font-weight: 900;
  text-anchor: middle;
  paint-order: stroke;
  stroke: color-mix(in srgb, var(--black) 94%, transparent);
  stroke-width: 3.2px;
  vector-effect: non-scaling-stroke;
}

.chart-delta-bubbles-overlay,
.chart-delta-bubble,
.chart-exhaustion-bubbles-overlay,
.chart-exhaustion-bubble {
  pointer-events: none;
}

.chart-delta-bubble-halo,
.chart-delta-bubble-core,
.chart-exhaustion-arrow,
.chart-exhaustion-arrow-head,
.chart-exhaustion-halo,
.chart-exhaustion-core {
  vector-effect: non-scaling-stroke;
}

.chart-delta-bubble-halo {
  display: none;
}

.chart-delta-bubble-core {
  stroke: none;
  stroke-width: 0;
  filter: none;
}

.chart-delta-bubble.buy-delta .chart-delta-bubble-halo {
  fill: color-mix(in srgb, var(--green) 54%, var(--bg) 46%);
}

.chart-delta-bubble.buy-delta .chart-delta-bubble-core {
  fill: color-mix(in srgb, var(--green) 54%, var(--bg) 46%);
}

.chart-delta-bubble.sell-delta .chart-delta-bubble-halo {
  fill: color-mix(in srgb, var(--red) 54%, var(--bg) 46%);
}

.chart-delta-bubble.sell-delta .chart-delta-bubble-core {
  fill: color-mix(in srgb, var(--red) 54%, var(--bg) 46%);
}

.chart-delta-bubble.candle-delta .chart-delta-bubble-core {
  stroke-dasharray: 2 2;
}

.chart-exhaustion-arrow {
  stroke-width: 1.1;
  stroke-dasharray: 4 3;
  opacity: 0.46;
}

.chart-exhaustion-arrow-head {
  stroke-width: 1;
  opacity: 0.86;
}

.chart-exhaustion-halo {
  opacity: 0.1;
  filter: drop-shadow(0 3px 7px color-mix(in srgb, var(--black) 34%, transparent));
}

.chart-exhaustion-core {
  stroke-width: 1.1;
  filter: drop-shadow(0 1px 4px color-mix(in srgb, var(--black) 30%, transparent));
}

.chart-exhaustion-bubble.buy-exhaustion .chart-exhaustion-arrow,
.chart-exhaustion-bubble.buy-exhaustion .chart-exhaustion-arrow-head {
  stroke: color-mix(in srgb, var(--red) 78%, transparent);
}

.chart-exhaustion-bubble.buy-exhaustion .chart-exhaustion-arrow-head {
  fill: color-mix(in srgb, var(--red) 82%, transparent);
}

.chart-exhaustion-bubble.buy-exhaustion .chart-exhaustion-halo {
  fill: var(--red);
}

.chart-exhaustion-bubble.buy-exhaustion .chart-exhaustion-core {
  fill: color-mix(in srgb, var(--red) 18%, transparent);
  stroke: color-mix(in srgb, var(--red) 72%, transparent);
}

.chart-exhaustion-bubble.sell-exhaustion .chart-exhaustion-arrow,
.chart-exhaustion-bubble.sell-exhaustion .chart-exhaustion-arrow-head {
  stroke: color-mix(in srgb, var(--green) 78%, transparent);
}

.chart-exhaustion-bubble.sell-exhaustion .chart-exhaustion-arrow-head {
  fill: color-mix(in srgb, var(--green) 82%, transparent);
}

.chart-exhaustion-bubble.sell-exhaustion .chart-exhaustion-halo {
  fill: var(--green);
}

.chart-exhaustion-bubble.sell-exhaustion .chart-exhaustion-core {
  fill: color-mix(in srgb, var(--green) 18%, transparent);
  stroke: color-mix(in srgb, var(--green) 72%, transparent);
}

.chart-exhaustion-bubble text {
  fill: color-mix(in srgb, var(--text) 96%, transparent);
  font-family: Consolas, "Courier New", monospace;
  font-weight: 900;
  text-anchor: middle;
  paint-order: stroke;
  stroke: color-mix(in srgb, var(--black) 88%, transparent);
  stroke-width: 1.8px;
  vector-effect: non-scaling-stroke;
}

.chart-ta-orderflow-overlay,
.chart-ta-orderflow-signal {
  pointer-events: none;
}

.chart-ta-orderflow-level,
.chart-ta-orderflow-entry,
.chart-ta-orderflow-exit,
.chart-ta-orderflow-path,
.chart-ta-orderflow-arrow,
.chart-ta-orderflow-exit-arrow {
  vector-effect: non-scaling-stroke;
}

.chart-ta-orderflow-level {
  fill: none;
  stroke-width: 1.1;
  stroke-linecap: round;
  stroke-dasharray: 6 5;
  opacity: 0.38;
}

.chart-ta-orderflow-signal.structure-break .chart-ta-orderflow-level {
  stroke-width: 1.55;
  stroke-dasharray: 4 2;
  opacity: 0.62;
}

.chart-ta-orderflow-entry,
.chart-ta-orderflow-exit {
  stroke-width: 1.9;
  stroke-linecap: round;
  opacity: 0.86;
}

.chart-ta-orderflow-path {
  stroke-width: 1;
  stroke-dasharray: 3 3;
  opacity: 0.16;
}

.chart-ta-orderflow-signal.buy .chart-ta-orderflow-level,
.chart-ta-orderflow-signal.buy .chart-ta-orderflow-entry,
.chart-ta-orderflow-signal.buy .chart-ta-orderflow-exit,
.chart-ta-orderflow-signal.buy .chart-ta-orderflow-path {
  stroke: color-mix(in srgb, var(--green) 86%, transparent);
}

.chart-ta-orderflow-signal.sell .chart-ta-orderflow-level,
.chart-ta-orderflow-signal.sell .chart-ta-orderflow-entry,
.chart-ta-orderflow-signal.sell .chart-ta-orderflow-exit,
.chart-ta-orderflow-signal.sell .chart-ta-orderflow-path {
  stroke: color-mix(in srgb, var(--red) 86%, transparent);
}

.chart-ta-orderflow-arrow {
  stroke: color-mix(in srgb, var(--bg) 92%, transparent);
  stroke-width: 1.9;
  filter: drop-shadow(0 2px 5px color-mix(in srgb, var(--black) 42%, transparent));
}

.chart-ta-orderflow-exit-arrow {
  stroke: color-mix(in srgb, var(--bg) 88%, transparent);
  stroke-width: 1.65;
  opacity: 0.92;
  filter: drop-shadow(0 2px 4px color-mix(in srgb, var(--black) 36%, transparent));
}

.chart-ta-orderflow-signal.buy .chart-ta-orderflow-arrow {
  fill: var(--green);
}

.chart-ta-orderflow-signal.sell .chart-ta-orderflow-arrow {
  fill: var(--red);
}

.chart-ta-orderflow-signal.buy .chart-ta-orderflow-exit-arrow {
  fill: var(--red);
}

.chart-ta-orderflow-signal.sell .chart-ta-orderflow-exit-arrow {
  fill: var(--green);
}

.chart-ta-orderflow-callout-bg {
  fill: color-mix(in srgb, var(--bg) 84%, transparent);
  stroke: color-mix(in srgb, var(--muted) 26%, transparent);
  stroke-width: 1;
  filter: drop-shadow(0 5px 12px color-mix(in srgb, var(--black) 26%, transparent));
  vector-effect: non-scaling-stroke;
}

.chart-ta-orderflow-label,
.chart-ta-orderflow-price {
  fill: color-mix(in srgb, var(--text) 96%, transparent);
  font-family: Consolas, "Courier New", monospace;
  font-size: 10px;
  font-weight: 900;
  text-anchor: start;
  paint-order: stroke;
  stroke: color-mix(in srgb, var(--bg) 78%, transparent);
  stroke-width: 1.8px;
  vector-effect: non-scaling-stroke;
}

.chart-ta-orderflow-label.compact,
.chart-ta-orderflow-price.compact {
  font-size: 9px;
  stroke-width: 2.3px;
}

.chart-ta-orderflow-price {
  fill: color-mix(in srgb, var(--text) 88%, transparent);
  font-size: 9px;
  font-weight: 850;
  opacity: 0.92;
  stroke-width: 1.55px;
}

.chart-ta-orderflow-price.exit {
  fill: color-mix(in srgb, var(--muted) 96%, transparent);
}

.chart-ta-orderflow-signal.stop .chart-ta-orderflow-exit,
.chart-ta-orderflow-signal.stop .chart-ta-orderflow-path {
  stroke-dasharray: 2 4;
  opacity: 0.82;
}

.chart-ta-orderflow-signal.time .chart-ta-orderflow-exit,
.chart-ta-orderflow-signal.time .chart-ta-orderflow-path,
.chart-ta-orderflow-signal.projected .chart-ta-orderflow-exit,
.chart-ta-orderflow-signal.projected .chart-ta-orderflow-path {
  opacity: 0.44;
}

.chart-ta-orderflow-summary-bg {
  fill: color-mix(in srgb, var(--bg) 86%, transparent);
  stroke: color-mix(in srgb, var(--muted) 24%, transparent);
  stroke-width: 1;
  filter: drop-shadow(0 5px 14px color-mix(in srgb, var(--black) 24%, transparent));
  vector-effect: non-scaling-stroke;
}

.chart-ta-orderflow-summary-title,
.chart-ta-orderflow-summary-line,
.chart-ta-orderflow-summary-muted {
  fill: color-mix(in srgb, var(--text) 94%, transparent);
  font-family: Consolas, "Courier New", monospace;
  font-size: 10px;
  font-weight: 900;
  text-anchor: start;
  paint-order: stroke;
  stroke: color-mix(in srgb, var(--bg) 78%, transparent);
  stroke-width: 1.5px;
  vector-effect: non-scaling-stroke;
}

.chart-ta-orderflow-summary-line {
  fill: color-mix(in srgb, var(--text) 86%, transparent);
  font-size: 9.5px;
  font-weight: 850;
}

.chart-ta-orderflow-summary-muted {
  fill: color-mix(in srgb, var(--muted) 92%, transparent);
  font-size: 9px;
  font-weight: 820;
}

.chart-bracket-layer {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 4;
}

.chart-bracket-layer.hidden {
  display: none;
}

.chart-bracket-line {
  position: absolute;
  left: 0;
  right: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  min-height: 0;
  height: 0;
  padding: 0 14px 0 clamp(12px, 8vw, 122px);
  border: 0;
  border-top: 1px solid currentColor;
  border-radius: 0;
  background: transparent;
  color: var(--text);
  transform: translateY(-50%);
  pointer-events: auto;
  cursor: ns-resize;
  outline: 0;
}

.chart-bracket-line.hidden {
  display: none;
}

.chart-bracket-line.dragging {
  filter: brightness(1.12);
}

.chart-bracket-line.locked {
  cursor: default;
}

.chart-bracket-line.tp {
  color: var(--green);
}

.chart-bracket-line.entry {
  color: var(--info);
}

.chart-bracket-line.sl {
  color: var(--warning-text);
}

.chart-order-ticket {
  display: inline-grid;
  grid-template-columns: minmax(54px, auto) minmax(74px, auto) minmax(128px, auto) 30px;
  align-items: center;
  min-height: 32px;
  border: 1px solid currentColor;
  border-radius: 6px;
  overflow: hidden;
  background: color-mix(in srgb, var(--bg) 92%, transparent);
  box-shadow: 0 8px 22px color-mix(in srgb, var(--black) 22%, transparent);
}

.chart-order-kind,
.chart-order-size,
.chart-order-pnl,
.chart-order-close,
.chart-order-marker {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 32px;
  padding: 0 10px;
  border-right: 1px solid color-mix(in srgb, var(--on-color) 12%, transparent);
  color: currentColor;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0;
  white-space: nowrap;
}

.chart-order-kind {
  color: var(--on-color);
}

.chart-bracket-line.entry .chart-order-kind {
  background: var(--info);
}

.chart-bracket-line.tp .chart-order-kind {
  background: var(--green);
}

.chart-bracket-line.sl .chart-order-kind {
  background: var(--warning-text);
}

.chart-order-close {
  min-width: 30px;
  padding: 0;
  border-right: 0;
  font-size: 18px;
  line-height: 1;
}

.chart-order-close:hover {
  background: color-mix(in srgb, var(--on-color) 12%, transparent);
}

.chart-order-marker {
  position: absolute;
  right: 7%;
  bottom: 14px;
  min-height: 28px;
  border: 0;
  border-radius: 4px;
  background: color-mix(in srgb, var(--bg) 82%, transparent);
  color: color-mix(in srgb, var(--text) 92%, transparent);
  font-size: 12px;
  font-weight: 800;
  text-shadow: 0 1px 2px color-mix(in srgb, var(--black) 35%, transparent);
}

.chart-order-marker.hidden {
  display: none;
}

.chart-order-marker::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -26px;
  width: 0;
  height: 24px;
  border-left: 2px solid currentColor;
}

.chart-order-marker::before {
  content: "";
  position: absolute;
  left: calc(50% - 5px);
  bottom: -28px;
  width: 9px;
  height: 9px;
  border-left: 2px solid currentColor;
  border-top: 2px solid currentColor;
  transform: rotate(45deg);
}

@media (max-width: 720px) {
  .chart-order-ticket {
    grid-template-columns: minmax(42px, auto) minmax(56px, auto) minmax(84px, auto) 28px;
  }

  .chart-order-kind,
  .chart-order-size,
  .chart-order-pnl,
  .chart-order-close,
  .chart-order-marker {
    min-height: 28px;
    padding: 0 7px;
    font-size: 11px;
  }

  .chart-order-marker {
    right: 4%;
  }
}

.dom-panel {
  overflow: hidden;
  height: 100%;
  min-height: 0;
  border: 0;
  border-radius: 0;
  display: grid;
  grid-template-rows: auto auto auto minmax(0, 1fr);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--line) 22%, transparent), transparent 45%),
    color-mix(in srgb, var(--panel) 96%, transparent);
}

:root[data-theme="nord"] .dom-panel {
  background: color-mix(in srgb, var(--panel) 96%, transparent);
}

.dom-panel.hidden {
  display: none;
}

.tape-panel {
  overflow: hidden;
  height: 100%;
  min-height: 0;
  border: 0;
  border-radius: 0;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--line) 20%, transparent), transparent 48%),
    color-mix(in srgb, var(--panel) 96%, transparent);
}

:root[data-theme="nord"] .tape-panel {
  background: color-mix(in srgb, var(--panel) 96%, transparent);
}

.tape-panel.hidden {
  display: none;
}

.orderflow-panel {
  overflow: hidden;
  height: 100%;
  min-height: 0;
  padding: 10px;
  border: 0;
  border-radius: 0;
  display: grid;
  grid-template-rows: auto auto auto minmax(0, 1fr);
  gap: 8px;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--green) 8%, transparent), transparent 38%),
    linear-gradient(225deg, color-mix(in srgb, var(--red) 8%, transparent), transparent 42%),
    color-mix(in srgb, var(--panel) 96%, transparent);
}

.orderflow-panel-head {
  min-width: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  color: var(--muted);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.orderflow-panel-head span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.orderflow-panel-head strong {
  flex: 0 0 auto;
  padding: 5px 8px;
  border: 1px solid color-mix(in srgb, var(--line) 64%, transparent);
  border-radius: 999px;
  color: var(--muted);
  background: color-mix(in srgb, var(--panel-strong) 74%, transparent);
}

.orderflow-panel .buy,
.orderflow-panel-head strong.buy {
  color: var(--buy-text);
}

.orderflow-panel .sell,
.orderflow-panel-head strong.sell {
  color: var(--sell-text);
}

.orderflow-panel .neutral,
.orderflow-panel-head strong.neutral {
  color: var(--accent);
}

.orderflow-panel.hybrid-flow-panel {
  padding: 0;
  gap: 0;
  grid-template-rows: auto auto auto minmax(0, 1fr);
}

.hybrid-flow-head {
  min-height: 32px;
  padding: 6px 9px;
  border-bottom: 1px solid color-mix(in srgb, var(--line) 72%, transparent);
  background: color-mix(in srgb, var(--panel-strong) 64%, transparent);
}

.hybrid-summary {
  display: grid;
  grid-template-columns: repeat(5, minmax(92px, 1fr));
  gap: 1px;
  padding: 5px;
  border-bottom: 1px solid color-mix(in srgb, var(--line) 70%, transparent);
  background: color-mix(in srgb, var(--bg) 34%, transparent);
}

.hybrid-summary span,
.hybrid-current-stats span {
  min-width: 0;
  display: grid;
  gap: 2px;
  padding: 5px 7px;
  border: 1px solid color-mix(in srgb, var(--line) 50%, transparent);
  border-radius: 5px;
  background: color-mix(in srgb, var(--panel-strong) 72%, transparent);
}

.hybrid-summary em,
.hybrid-current-stats em {
  min-width: 0;
  overflow: hidden;
  color: var(--muted);
  font-size: 8px;
  font-style: normal;
  font-weight: 900;
  letter-spacing: 0.06em;
  line-height: 1.1;
  text-overflow: ellipsis;
  text-transform: uppercase;
  white-space: nowrap;
}

.hybrid-summary strong,
.hybrid-current-stats strong {
  min-width: 0;
  overflow: hidden;
  color: var(--text);
  font-family: Consolas, "Courier New", monospace;
  font-size: 11px;
  font-weight: 900;
  line-height: 1.15;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.hybrid-columns,
.hybrid-row {
  grid-template-columns: 58px 72px minmax(78px, 1fr) 66px 66px 58px;
}

.hybrid-columns {
  display: grid;
  align-items: center;
  min-height: 25px;
  padding: 0 8px;
  border-bottom: 1px solid color-mix(in srgb, var(--line) 72%, transparent);
  color: var(--muted);
  background: color-mix(in srgb, var(--panel-strong) 82%, transparent);
  font-size: 8px;
  font-weight: 900;
  letter-spacing: 0.07em;
  text-align: center;
  text-transform: uppercase;
}

.hybrid-columns span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.hybrid-flow-main {
  min-height: 0;
  display: grid;
  grid-template-columns: minmax(360px, 1fr) minmax(180px, 0.38fr);
}

.hybrid-ladder {
  min-height: 0;
  overflow: auto;
  border-right: 1px solid color-mix(in srgb, var(--line) 68%, transparent);
  scrollbar-width: thin;
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--green) 6%, transparent), transparent 35%, transparent 65%, color-mix(in srgb, var(--red) 6%, transparent)),
    repeating-linear-gradient(180deg, transparent 0, transparent 25px, color-mix(in srgb, var(--line) 28%, transparent) 26px),
    color-mix(in srgb, var(--bg) 28%, transparent);
}

.hybrid-row {
  position: relative;
  isolation: isolate;
  display: grid;
  align-items: center;
  min-height: 26px;
  padding: 0 8px;
  border-bottom: 1px solid color-mix(in srgb, var(--line) 56%, transparent);
  overflow: hidden;
  font-family: Consolas, "Courier New", monospace;
  font-size: 11px;
}

.hybrid-row > span:not(.hybrid-row-heat):not(.hybrid-row-bubble) {
  position: relative;
  z-index: 2;
  min-width: 0;
  min-height: 19px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  text-align: center;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.hybrid-row-heat {
  position: absolute;
  top: 2px;
  bottom: 2px;
  z-index: 0;
  width: var(--heat, 0%);
  border-radius: 5px;
  pointer-events: none;
}

.hybrid-row.bid .hybrid-row-heat {
  left: 0;
  background: linear-gradient(90deg, color-mix(in srgb, var(--green) 34%, transparent), transparent);
}

.hybrid-row.ask .hybrid-row-heat {
  right: 0;
  background: linear-gradient(270deg, color-mix(in srgb, var(--red) 34%, transparent), transparent);
}

.hybrid-row-bubble {
  position: absolute;
  top: 50%;
  z-index: 3;
  width: var(--bubble-size);
  height: var(--bubble-size);
  display: grid;
  place-items: center;
  border: 1px solid currentColor;
  border-radius: 999px;
  opacity: 0.9;
  pointer-events: none;
  transform: translateY(-50%);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--bg) 38%, transparent), 0 0 18px color-mix(in srgb, var(--accent) 22%, transparent);
}

.hybrid-row-bubble.buy {
  right: 54px;
  color: var(--buy-text);
  background: color-mix(in srgb, var(--green) 24%, var(--panel) 76%);
}

.hybrid-row-bubble.sell {
  left: 54px;
  color: var(--sell-text);
  background: color-mix(in srgb, var(--red) 24%, var(--panel) 76%);
}

.hybrid-row-bubble span {
  display: none;
}

.hybrid-print-cell {
  border-radius: 4px;
  color: color-mix(in srgb, var(--muted) 58%, transparent);
}

.hybrid-print-cell.buy {
  color: var(--market-buy-text);
  background: color-mix(in srgb, var(--green) 18%, transparent);
}

.hybrid-print-cell.sell {
  color: var(--market-sell-text);
  background: color-mix(in srgb, var(--red) 18%, transparent);
}

.hybrid-print-cell strong {
  overflow: hidden;
  text-overflow: ellipsis;
}

.hybrid-print-cell em {
  min-width: 13px;
  height: 13px;
  display: inline-grid;
  place-items: center;
  margin-left: 3px;
  border-radius: 999px;
  font-size: 8px;
  font-style: normal;
  font-weight: 900;
  background: color-mix(in srgb, var(--panel-strong) 82%, transparent);
}

.hybrid-delta-cell {
  border-radius: 4px;
  color: var(--muted);
  background: color-mix(in srgb, var(--panel-strong) 62%, transparent);
  font-weight: 900;
}

.hybrid-row.buy .hybrid-delta-cell,
.hybrid-summary .buy,
.hybrid-current-stats .buy,
.hybrid-order-row.buy {
  color: var(--buy-text);
}

.hybrid-row.sell .hybrid-delta-cell,
.hybrid-summary .sell,
.hybrid-current-stats .sell,
.hybrid-order-row.sell {
  color: var(--sell-text);
}

.hybrid-row.neutral .hybrid-delta-cell,
.hybrid-summary .neutral,
.hybrid-current-stats .neutral {
  color: var(--accent);
}

.hybrid-price {
  color: var(--text);
  border-left: 1px solid color-mix(in srgb, var(--line) 72%, transparent);
  border-right: 1px solid color-mix(in srgb, var(--line) 72%, transparent);
  background: color-mix(in srgb, var(--panel-strong) 78%, transparent);
  font-weight: 900;
}

.hybrid-row.inside-spread .hybrid-price {
  color: var(--accent);
  background: color-mix(in srgb, var(--accent) 12%, transparent);
}

.hybrid-row.last-traded .hybrid-price {
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--line-active) 88%, transparent);
}

.hybrid-depth.bid {
  color: var(--buy-text);
  font-weight: 900;
}

.hybrid-depth.ask {
  color: var(--sell-text);
  font-weight: 900;
}

.hybrid-side-feed {
  min-width: 0;
  min-height: 0;
  display: grid;
  grid-template-rows: minmax(130px, auto) minmax(0, 1fr);
  background: color-mix(in srgb, var(--panel) 78%, transparent);
}

.hybrid-feed-section {
  min-height: 0;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  border-bottom: 1px solid color-mix(in srgb, var(--line) 60%, transparent);
}

.hybrid-feed-section:last-child {
  border-bottom: 0;
}

.hybrid-feed-title {
  min-height: 25px;
  display: flex;
  align-items: center;
  padding: 0 8px;
  color: var(--muted);
  background: color-mix(in srgb, var(--panel-strong) 74%, transparent);
  font-size: 8px;
  font-weight: 900;
  letter-spacing: 0.07em;
  text-transform: uppercase;
}

.hybrid-current-stats {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 4px;
  padding: 5px;
}

.hybrid-current-list,
.hybrid-history {
  min-height: 0;
  overflow: auto;
  padding: 3px 0 6px;
}

.hybrid-order-row {
  min-height: 21px;
  display: grid;
  grid-template-columns: 34px minmax(44px, 0.75fr) minmax(68px, 1fr) 42px;
  align-items: center;
  gap: 4px;
  padding: 0 7px;
  border-bottom: 1px solid color-mix(in srgb, var(--line) 34%, transparent);
  font-family: Consolas, "Courier New", monospace;
  font-size: 10px;
}

.hybrid-order-row span,
.hybrid-order-row strong,
.hybrid-order-row em,
.hybrid-order-row small {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.hybrid-order-row span {
  font-weight: 900;
}

.hybrid-order-row em {
  color: var(--muted);
  font-style: normal;
}

.hybrid-order-row small {
  color: color-mix(in srgb, var(--muted) 74%, transparent);
  text-align: right;
}

@media (max-width: 720px) {
  .hybrid-summary {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .hybrid-flow-main {
    grid-template-columns: 1fr;
  }

  .hybrid-ladder {
    border-right: 0;
    border-bottom: 1px solid color-mix(in srgb, var(--line) 68%, transparent);
  }

  .hybrid-side-feed {
    grid-template-rows: auto minmax(180px, 1fr);
  }
}

.dom-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px;
  border-bottom: 1px solid var(--line);
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--accent) 14%, transparent), transparent 42%),
    linear-gradient(90deg, color-mix(in srgb, var(--green) 8%, transparent), color-mix(in srgb, var(--red) 8%, transparent)),
    color-mix(in srgb, var(--panel-strong) 90%, transparent);
}

.dom-panel .dom-header {
  display: none;
}

.dom-header h2 {
  margin: 0;
  font-size: 20px;
  letter-spacing: -0.03em;
}

.dom-status {
  padding: 5px 9px;
  color: var(--muted);
  background: color-mix(in srgb, var(--panel-strong) 92%, transparent);
  border-radius: 999px;
  font-size: 12px;
  font-weight: 800;
}

.dom-badges {
  display: flex;
  align-items: center;
  gap: 6px;
}

.dom-badges span {
  padding: 5px 9px;
  border-radius: 999px;
  color: var(--chart-trade-accent-soft);
  background: color-mix(in srgb, var(--accent) 14%, transparent);
  border: 1px solid color-mix(in srgb, var(--line-active) 60%, transparent);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.08em;
}

.dom-status.live {
  color: var(--buy-text);
  background: color-mix(in srgb, var(--green) 16%, transparent);
}

.dom-status.error {
  color: var(--sell-text);
  background: color-mix(in srgb, var(--red) 16%, transparent);
}

.error-toast-stack {
  position: fixed;
  bottom: 14px;
  left: 14px;
  z-index: 30000;
  display: flex;
  flex-direction: column;
  gap: 8px;
  width: min(360px, calc(100vw - 28px));
  pointer-events: none;
}

.error-toast-card {
  position: relative;
  display: grid;
  gap: 5px;
  padding: 10px 34px 10px 10px;
  color: var(--text);
  background: color-mix(in srgb, var(--panel-strong) 92%, var(--red) 8%);
  border: 1px solid color-mix(in srgb, var(--red) 34%, var(--line) 66%);
  border-radius: 8px;
  box-shadow: 0 12px 34px color-mix(in srgb, var(--black) 34%, transparent);
  font-size: 11px;
  line-height: 1.3;
  pointer-events: auto;
}

.error-toast-card strong {
  color: var(--sell-text);
  font-size: 12px;
  line-height: 1.2;
}

.error-toast-detail,
.error-toast-card small,
.error-toast-card code {
  overflow-wrap: anywhere;
}

.error-toast-card small {
  color: var(--muted);
}

.error-toast-card code {
  color: var(--muted);
  font-family: Consolas, "Courier New", monospace;
  font-size: 10px;
  white-space: pre-wrap;
}

.error-toast-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  align-items: center;
  color: var(--muted);
  font-size: 8px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.error-toast-count {
  padding: 1px 4px;
  color: var(--panel-strong);
  background: var(--sell-text);
  border-radius: 999px;
}

.error-toast-close {
  position: absolute;
  top: 7px;
  right: 7px;
  width: 20px;
  min-width: 20px;
  height: 20px;
  min-height: 20px;
  padding: 0;
  color: var(--muted);
  background: transparent;
  border: 1px solid color-mix(in srgb, var(--muted) 28%, transparent);
  border-radius: 999px;
  font-size: 11px;
  line-height: 1;
}

.error-toast-close:hover {
  color: var(--text);
  border-color: var(--sell-text);
}

.dom-trade-bar {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 4px;
  align-items: end;
  padding: 5px 7px 6px;
  border-bottom: 1px solid var(--line);
  background: color-mix(in srgb, var(--panel-strong) 92%, transparent);
}

.dom-trade-bar label {
  display: grid;
  min-width: 0;
  gap: 2px;
  color: var(--muted);
  font-size: 8px;
  font-weight: 900;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.dom-trade-bar input,
.dom-trade-bar select,
.dom-trade-bar button {
  width: 100%;
  min-height: 23px;
  height: 23px;
  padding: 0 5px;
  border-radius: 5px;
  font-size: 10px;
}

.dom-trade-bar button {
  min-width: 0;
  font-weight: 900;
  letter-spacing: 0;
  white-space: nowrap;
}

.dom-trade-reduce {
  display: inline-flex !important;
  grid-auto-flow: column;
  align-items: center;
  align-self: end;
  min-height: 23px;
  gap: 4px !important;
  padding-bottom: 2px;
  font-size: 8px !important;
  white-space: nowrap;
}

.dom-trade-reduce input {
  width: 13px;
  height: 13px;
  min-height: 13px;
  padding: 0;
}

.dom-market-actions,
.dom-protection-actions {
  display: contents;
}

.dom-trade-status {
  align-self: end;
  justify-self: stretch;
  min-height: 23px;
  padding: 4px 4px;
  font-size: 9px;
  overflow: hidden;
  text-align: center;
  text-overflow: ellipsis;
  white-space: nowrap;
}

@media (max-width: 720px) {
  .dom-trade-bar {
    grid-template-columns: repeat(5, minmax(48px, 1fr));
  }
}

.prop-dom-columns,
.prop-row {
  display: grid;
  align-items: center;
}

.prop-dom-columns {
  position: relative;
  padding: 8px 10px;
  color: var(--muted);
  background: color-mix(in srgb, var(--panel-strong) 92%, transparent);
  border-bottom: 1px solid var(--line);
  font-size: 9px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  user-select: none;
}

.dom-col-label,
.prop-row > span,
.spread-row {
  text-align: center;
}

.dom-col-label {
  appearance: none;
  min-height: 24px;
  padding: 0 4px;
  border: 0;
  color: inherit;
  background: transparent;
  font-size: inherit;
  font-weight: inherit;
  letter-spacing: inherit;
  text-transform: inherit;
  cursor: grab;
  user-select: none;
}

.dom-col-label.dragging {
  opacity: 0.35;
}

.dom-col-label.drop-target {
  color: var(--accent);
}

.dom-col-handle {
  position: absolute;
  top: 3px;
  bottom: 3px;
  width: 14px;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: transparent;
  transform: translateX(-50%);
  cursor: col-resize;
  z-index: 3;
  touch-action: none;
}

.dom-col-handle::before {
  content: "";
  position: absolute;
  top: 2px;
  bottom: 2px;
  left: 50%;
  width: 2px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--muted-soft) 55%, transparent);
  transform: translateX(-50%);
  transition: background 150ms ease, box-shadow 150ms ease;
}

.dom-col-handle:hover::before,
.dom-col-handle:focus-visible::before,
.dom-col-handle.active::before {
  background: color-mix(in srgb, var(--accent) 90%, transparent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 16%, transparent);
}

.dom-col-handle[data-dom-split="0"] {
  left: calc(var(--dom-col-pad) + var(--dom-col-0));
}

.dom-col-handle[data-dom-split="1"] {
  left: calc(var(--dom-col-pad) + var(--dom-col-0) + var(--dom-col-1));
}

.dom-col-handle[data-dom-split="2"] {
  left: calc(var(--dom-col-pad) + var(--dom-col-0) + var(--dom-col-1) + var(--dom-col-2));
}

.dom-col-handle[data-dom-split="3"] {
  left: calc(var(--dom-col-pad) + var(--dom-col-0) + var(--dom-col-1) + var(--dom-col-2) + var(--dom-col-3));
}

.prop-ladder {
  overflow-y: auto;
  overflow-x: hidden;
  overscroll-behavior: contain;
  scrollbar-width: thin;
  scrollbar-color: color-mix(in srgb, var(--muted) 52%, transparent) color-mix(in srgb, var(--panel-strong) 38%, transparent);
  min-height: 0;
  padding: 4px 0;
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--green) 5.5%, transparent), transparent 32%, transparent 68%, color-mix(in srgb, var(--red) 5.5%, transparent)),
    repeating-linear-gradient(180deg, transparent 0, transparent 24px, color-mix(in srgb, var(--line) 34%, transparent) 25px);
}

:root[data-theme="nord"] .prop-ladder {
  background: linear-gradient(90deg, color-mix(in srgb, var(--green) 5.5%, transparent), transparent 32%, transparent 68%, color-mix(in srgb, var(--red) 5.5%, transparent));
}

.prop-ladder::-webkit-scrollbar {
  width: 8px;
}

.prop-ladder::-webkit-scrollbar-track {
  background: color-mix(in srgb, var(--panel-strong) 38%, transparent);
}

.prop-ladder::-webkit-scrollbar-thumb {
  background: color-mix(in srgb, var(--muted) 48%, transparent);
  border-radius: 999px;
}

.prop-ladder::-webkit-scrollbar-thumb:hover {
  background: color-mix(in srgb, var(--text) 48%, transparent);
}

.prop-row {
  position: relative;
  isolation: isolate;
  min-height: 25px;
  padding: 0 10px;
  font-family: Consolas, "Courier New", monospace;
  font-size: 12px;
  border-bottom: 1px solid color-mix(in srgb, var(--line) 70%, transparent);
  overflow: visible;
}

.prop-row > span {
  position: relative;
  z-index: 1;
  min-height: 19px;
  display: grid;
  place-items: center;
}

.prop-row .cell-fill {
  overflow: hidden;
  border-radius: 4px;
}

.prop-row .cell-fill::before {
  content: "";
  position: absolute;
  top: 1px;
  bottom: 1px;
  width: var(--fill, 0%);
  pointer-events: none;
}

.prop-row .cell-fill > span {
  position: relative;
  z-index: 1;
}

.prop-row .bid-size {
  color: var(--buy-text);
  font-weight: 900;
}

.prop-row .bid-size::before {
  left: 0;
  background: color-mix(in srgb, var(--green) 24%, transparent);
}

.prop-row .ask-size {
  color: var(--sell-text);
  font-weight: 900;
}

.prop-row .ask-size::before {
  right: 0;
  background: color-mix(in srgb, var(--red) 24%, transparent);
}

.ladder-order-cell.active {
  cursor: pointer;
  outline: 0;
}

.ladder-order-cell.active:hover,
.ladder-order-cell.active:focus-visible {
  filter: brightness(1.18);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--accent) 55%, transparent);
}

.dom-order-overlays {
  position: absolute !important;
  inset: 0;
  z-index: 6;
  min-height: 0 !important;
  display: block !important;
  pointer-events: none;
}

.dom-order-row-band,
.dom-order-overlay,
.dom-order-overlay-label {
  position: absolute;
  inset: 0 10px;
  z-index: 5;
  pointer-events: none;
}

.dom-order-row-band {
  top: 2px;
  bottom: 2px;
  border: 1px solid currentColor;
  border-radius: 6px;
  opacity: 0.92;
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--bg) 30%, transparent), 0 0 13px color-mix(in srgb, var(--black) 20%, transparent);
}

.dom-order-row-band.tp {
  color: var(--chart-trade-buy);
  background: linear-gradient(90deg, color-mix(in srgb, var(--chart-trade-buy) 4%, transparent), color-mix(in srgb, var(--chart-trade-buy) 22%, transparent), color-mix(in srgb, var(--chart-trade-buy) 4%, transparent));
}

.dom-order-row-band.sl {
  color: var(--chart-trade-sell);
  background: linear-gradient(90deg, color-mix(in srgb, var(--info) 4%, transparent), color-mix(in srgb, var(--info) 24%, transparent), color-mix(in srgb, var(--info) 4%, transparent));
}

.dom-order-row-band.offscreen-above,
.dom-order-row-band.offscreen-below,
.dom-order-cell-box.offscreen-above,
.dom-order-cell-box.offscreen-below {
  border-style: dashed;
}

.dom-order-row-band.offscreen-above,
.dom-order-row-band.offscreen-below {
  opacity: 0.78;
}

.dom-order-overlay.entry {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--chart-trade-info);
  font-family: Inter, system-ui, sans-serif;
  font-size: 16px;
  font-weight: 900;
  text-shadow: 0 2px 4px color-mix(in srgb, var(--bg) 86%, transparent);
  z-index: 8;
}

.dom-order-overlay.entry::before {
  content: "";
  position: absolute;
  left: -4px;
  right: -4px;
  top: 50%;
  height: 4px;
  border-radius: 999px;
  background: currentColor;
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--bg) 55%, transparent), 0 0 17px color-mix(in srgb, var(--chart-trade-info) 62%, transparent);
}

.dom-order-overlay.entry.offscreen-above::before,
.dom-order-overlay.entry.offscreen-below::before {
  opacity: 0.82;
  background: repeating-linear-gradient(
    90deg,
    currentColor 0,
    currentColor 12px,
    transparent 12px,
    transparent 18px
  );
}

.dom-order-entry-label {
  position: relative;
  z-index: 1;
  padding: 1px 8px 2px;
  border: 1px solid color-mix(in srgb, var(--chart-trade-info) 58%, transparent);
  border-radius: 6px;
  color: var(--chart-trade-text-soft);
  background: color-mix(in srgb, var(--bg) 86%, transparent);
  box-shadow: 0 0 13px color-mix(in srgb, var(--chart-trade-info) 22%, transparent);
}

.dom-order-overlay-label {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--chart-trade-text);
  font-family: Inter, system-ui, sans-serif;
  font-size: 15px;
  font-weight: 900;
  text-shadow: 0 2px 5px color-mix(in srgb, var(--bg) 90%, transparent);
  z-index: 7;
}

.dom-order-overlay-label.tp {
  transform: translateX(14%);
}

.dom-order-overlay-label.sl {
  transform: translateX(10%);
}

.dom-order-overlay-label span {
  padding: 1px 7px 2px;
  border-radius: 6px;
  background: color-mix(in srgb, var(--bg) 78%, transparent);
  box-shadow: 0 2px 9px color-mix(in srgb, var(--black) 28%, transparent);
}

.dom-order-overlay-label.tp span {
  border: 1px solid color-mix(in srgb, var(--chart-trade-buy) 52%, transparent);
}

.dom-order-overlay-label.sl span {
  border: 1px solid color-mix(in srgb, var(--info) 58%, transparent);
}

.dom-order-overlay-label {
  display: none;
}

.dom-order-cell-box {
  appearance: none;
  position: absolute;
  top: 50%;
  bottom: auto;
  left: calc(var(--dom-order-box-left, 10px) + 5px);
  z-index: 8;
  width: max(34px, calc(var(--dom-order-box-width, 64px) - 10px));
  height: 18px;
  min-height: 0;
  max-height: 18px;
  margin: 0;
  padding: 0;
  display: grid;
  place-items: center;
  pointer-events: auto;
  border: 2px solid currentColor;
  border-radius: 5px;
  background: color-mix(in srgb, var(--bg) 36%, transparent);
  font: inherit;
  line-height: 1;
  cursor: ns-resize;
  touch-action: none;
  transform: translateY(-50%);
}

.dom-order-cell-box.tp {
  color: var(--chart-trade-buy);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--bg) 58%, transparent), 0 0 18px color-mix(in srgb, var(--chart-trade-buy) 46%, transparent);
}

.dom-order-cell-box.sl {
  color: var(--chart-trade-sell);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--bg) 58%, transparent), 0 0 18px color-mix(in srgb, var(--info) 50%, transparent);
}

.dom-order-cell-box span {
  color: var(--chart-trade-text);
  font-family: Inter, system-ui, sans-serif;
  font-size: 9px;
  font-weight: 900;
  line-height: 1;
  text-shadow: 0 1px 3px color-mix(in srgb, var(--black) 90%, transparent);
}

.dom-order-cell-box:hover,
.dom-order-cell-box:focus-visible {
  outline: 0;
  filter: brightness(1.12);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--text) 46%, transparent), 0 4px 14px color-mix(in srgb, var(--black) 36%, transparent);
}

.dom-protection-marker {
  position: absolute;
  inset: 2px;
  z-index: 9;
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 4px;
  min-width: 0;
  padding: 0 5px;
  border: 2px solid currentColor;
  border-radius: 5px;
  font-family: Inter, system-ui, sans-serif;
  font-size: 9px;
  font-weight: 900;
  line-height: 1;
  cursor: ns-resize;
  touch-action: none;
  text-shadow: 0 1px 2px color-mix(in srgb, var(--bg) 85%, transparent);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--bg) 40%, transparent), 0 0 12px color-mix(in srgb, var(--black) 28%, transparent);
}

.dom-protection-marker.tp {
  color: var(--chart-trade-buy);
  background: color-mix(in srgb, var(--green) 8%, transparent);
  border-color: var(--chart-trade-buy);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--bg) 45%, transparent), 0 0 12px color-mix(in srgb, var(--chart-trade-buy) 32%, transparent);
}

.dom-protection-marker.sl {
  color: var(--chart-trade-sell);
  background: color-mix(in srgb, var(--info) 10%, transparent);
  border-color: var(--chart-trade-sell);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--bg) 45%, transparent), 0 0 12px color-mix(in srgb, var(--info) 34%, transparent);
}

.dom-protection-marker strong {
  min-width: 0;
  overflow: hidden;
  font-size: 8px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.dom-protection-marker:hover,
.dom-protection-marker:focus-visible,
.dom-protection-marker.dragging {
  filter: brightness(1.08);
  outline: 0;
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--text) 42%, transparent), 0 4px 14px color-mix(in srgb, var(--black) 35%, transparent);
}

.widget.dom-protection-dragging .prop-ladder {
  cursor: ns-resize;
}

.prop-row .price {
  height: 100%;
  min-height: 25px;
  display: grid;
  place-items: center;
  color: var(--text);
  background: color-mix(in srgb, var(--panel-strong) 90%, transparent);
  border-left: 1px solid var(--line);
  border-right: 1px solid var(--line);
  font-weight: 800;
}

.prop-row.inside-spread .price {
  color: var(--accent);
  background: color-mix(in srgb, var(--accent) 12%, transparent);
}

.prop-row.last-traded .price {
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--line-active) 90%, transparent);
}

.prop-row .market-sell,
.prop-row .market-buy {
  min-height: 19px;
  display: inline-grid;
  grid-auto-flow: column;
  align-items: center;
  justify-content: center;
  gap: 3px;
  border-radius: 4px;
  font-weight: 900;
  line-height: 1;
}

.prop-row .market-sell:not(:empty) {
  color: var(--market-sell-text);
  background: color-mix(in srgb, var(--red) 24%, transparent);
}

.prop-row .market-buy:not(:empty) {
  color: var(--market-buy-text);
  background: color-mix(in srgb, var(--green) 24%, transparent);
}

.prop-row .market-print.fresh {
  box-shadow: inset 0 0 0 1px currentColor, 0 0 12px color-mix(in srgb, var(--accent) 14%, transparent);
}

.prop-row .market-print em {
  min-width: 13px;
  height: 13px;
  display: inline-grid;
  place-items: center;
  border-radius: 999px;
  font-family: Inter, system-ui, sans-serif;
  font-size: 8px;
  font-style: normal;
  font-weight: 900;
}

.prop-row .market-sell em {
  color: var(--market-sell-pill-text);
  background: var(--market-sell-pill-bg);
}

.prop-row .market-buy em {
  color: var(--market-buy-pill-text);
  background: var(--market-buy-pill-bg);
}

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

.dom-error-card {
  display: grid;
  gap: 6px;
  margin: 10px;
  padding: 10px;
  color: var(--text);
  background: color-mix(in srgb, var(--red) 10%, var(--panel-strong) 90%);
  border: 1px solid color-mix(in srgb, var(--red) 32%, var(--line) 68%);
  border-radius: 8px;
  font-size: 11px;
  line-height: 1.35;
}

.dom-error-card strong {
  color: var(--sell-text);
  font-size: 12px;
}

.dom-error-card em {
  color: var(--muted);
  font-size: 9px;
  font-style: normal;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.dom-error-card span,
.dom-error-card small {
  display: block;
}

.dom-error-card small {
  color: var(--muted);
}

.dom-error-card code {
  color: var(--muted);
  font-family: Consolas, "Courier New", monospace;
  font-size: 10px;
  overflow-wrap: anywhere;
  white-space: pre-wrap;
}

.dom-notice-card {
  background: color-mix(in srgb, var(--panel-strong) 88%, transparent);
  border-color: color-mix(in srgb, var(--muted) 24%, var(--line) 76%);
}

.dom-notice-card strong {
  color: var(--muted);
}

.spread-row {
  display: grid;
  align-items: center;
  justify-content: center;
  padding: 5px 10px;
  color: var(--muted);
  background: color-mix(in srgb, var(--accent) 8%, transparent);
  border-top: 1px solid color-mix(in srgb, var(--line-active) 60%, transparent);
  border-bottom: 1px solid color-mix(in srgb, var(--line-active) 60%, transparent);
  font-size: 12px;
}

.prop-spread {
  margin: 0;
}

.spread-cell {
  min-height: 22px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 0 6px;
  border-radius: 4px;
  background: color-mix(in srgb, var(--panel-strong) 72%, transparent);
  white-space: nowrap;
}

.spread-cell > span {
  font-size: 9px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.spread-cell strong {
  color: var(--accent);
  font-family: Consolas, "Courier New", monospace;
  font-size: 11px;
  font-weight: 900;
}

.dom-panel {
  background: color-mix(in srgb, var(--panel) 94%, transparent);
}

.dom-trade-bar {
  gap: 3px;
  padding: 4px 6px;
  border-bottom: 0;
  background: color-mix(in srgb, var(--panel) 82%, transparent);
}

.dom-trade-bar input,
.dom-trade-bar select {
  border-color: transparent;
  background: color-mix(in srgb, var(--panel-strong) 72%, transparent);
}

.dom-trade-bar .secondary-button {
  border-color: transparent;
}

.prop-dom-columns {
  padding: 5px 10px;
  border-bottom: 0;
  background: transparent;
  color: color-mix(in srgb, var(--muted) 78%, transparent);
  font-size: 8px;
}

.dom-col-handle::before {
  width: 1px;
  opacity: 0;
  background: color-mix(in srgb, var(--muted-soft) 42%, transparent);
}

.prop-dom-columns:hover .dom-col-handle::before,
.dom-col-handle:hover::before,
.dom-col-handle:focus-visible::before,
.dom-col-handle.active::before {
  opacity: 0.9;
}

.prop-ladder,
:root[data-theme="nord"] .prop-ladder {
  padding: 2px 0;
  background: color-mix(in srgb, var(--panel) 88%, transparent);
}

.prop-row {
  min-height: 22px;
  padding: 0 8px;
  border-bottom: 0;
  font-size: 11px;
}

.prop-row:hover {
  background: color-mix(in srgb, var(--text) 3%, transparent);
}

.prop-row > span {
  min-height: 17px;
}

.prop-row .cell-fill {
  border-radius: 2px;
}

.prop-row .cell-fill::before {
  top: 4px;
  bottom: 4px;
  opacity: 0.66;
}

.prop-row .bid-size,
.prop-row .ask-size {
  font-weight: 800;
}

.prop-row .bid-size::before {
  background: color-mix(in srgb, var(--green) 14%, transparent);
}

.prop-row .ask-size::before {
  background: color-mix(in srgb, var(--red) 14%, transparent);
}

.prop-row .price {
  min-height: 22px;
  color: color-mix(in srgb, var(--text) 92%, transparent);
  background: transparent;
  border-left: 0;
  border-right: 0;
  font-weight: 800;
}

.prop-row.inside-spread .price,
.prop-row.last-traded .price {
  color: var(--accent);
  background: color-mix(in srgb, var(--accent) 7%, transparent);
  box-shadow: none;
}

.prop-row .market-sell,
.prop-row .market-buy {
  min-height: 17px;
  border-radius: 2px;
  background: transparent;
}

.prop-row .market-sell:not(:empty) {
  background: color-mix(in srgb, var(--red) 10%, transparent);
}

.prop-row .market-buy:not(:empty) {
  background: color-mix(in srgb, var(--green) 10%, transparent);
}

.prop-row .market-print.fresh {
  box-shadow: none;
}

.spread-row {
  padding: 3px 10px;
  border-top: 0;
  border-bottom: 0;
  background: transparent;
}

.spread-cell {
  min-height: 18px;
  padding: 0;
  background: transparent;
}

.dom-order-row-band {
  top: 4px;
  bottom: 4px;
  border-width: 1px;
  border-radius: 4px;
  opacity: 0.66;
  box-shadow: none;
}

.dom-order-overlay.entry::before {
  height: 2px;
  box-shadow: none;
}

.dom-order-entry-label,
.dom-order-overlay-label span {
  box-shadow: none;
}

.dom-order-cell-box,
.dom-protection-marker {
  border-width: 1px;
  box-shadow: none;
}

.dom-order-cell-box.tp,
.dom-order-cell-box.sl,
.dom-protection-marker.tp,
.dom-protection-marker.sl {
  box-shadow: none;
}

.topbar,
.chart-drawing-toolbar,
.chart-trade-toolbar {
  border-color: transparent;
  background: color-mix(in srgb, var(--panel) 80%, transparent);
  box-shadow: none;
  backdrop-filter: blur(10px);
}

.topbar.dragging,
.chart-drawing-toolbar.dragging,
.chart-trade-toolbar.dragging {
  box-shadow: none;
}

.chart-toolbar-group {
  gap: 2px;
  padding: 1px;
  border-color: transparent;
  background: transparent;
}

.widget-toolbar,
.widget-system-toolbar {
  gap: 3px;
}

.widget-toolbar-drag-handle,
.widget-launcher-toggle,
.chart-toolbar-button,
.widget-config-toggle {
  border-color: transparent;
  background: transparent;
  box-shadow: none;
}

.widget-toolbar-drag-handle:hover,
.widget-toolbar-drag-handle:focus-visible,
.widget-launcher-toggle:hover,
.widget-launcher-toggle:focus-visible,
.chart-toolbar-button:hover,
.chart-toolbar-button:focus-visible,
.widget-config-toggle:hover,
.widget-config-toggle:focus-visible {
  border-color: transparent;
  background: color-mix(in srgb, var(--toolbar-highlight) 10%, transparent);
  box-shadow: none;
}

.chart-toolbar-button[aria-pressed="true"],
.api-credentials-button[aria-expanded="true"],
.widget-config-toggle.is-popout-open,
.widget-launcher.is-open .widget-launcher-toggle {
  color: var(--toolbar-text);
  border-color: transparent;
  background: color-mix(in srgb, var(--toolbar-active) 12%, transparent);
  box-shadow: none;
}

.chart-toolbar-danger:hover,
.chart-toolbar-danger:focus-visible {
  border-color: transparent;
  background: color-mix(in srgb, var(--toolbar-danger) 10%, transparent);
  box-shadow: none;
}

.palette-swatch-stack span {
  box-shadow: none;
}

.widget-header {
  min-height: 22px;
  padding: 0 5px 0 8px;
  color: color-mix(in srgb, var(--muted) 68%, transparent);
  background: transparent;
  border-bottom: 1px solid color-mix(in srgb, var(--line) 16%, transparent);
  font-weight: 700;
  letter-spacing: 0.03em;
}

.widget:hover .widget-header,
.widget.resizing .widget-header,
.widget.dragging .widget-header {
  color: color-mix(in srgb, var(--muted) 88%, transparent);
  background: color-mix(in srgb, var(--text) 2%, transparent);
}

.widget-close {
  color: color-mix(in srgb, var(--muted) 52%, transparent);
  background: transparent;
}

.widget-close:hover,
.widget-close:focus-visible {
  color: var(--danger-text);
  background: color-mix(in srgb, var(--red) 8%, transparent);
}

.chart-indicator-popover,
.chart-candle-popover,
.widget-config-popout,
.api-credential-popout {
  border-color: color-mix(in srgb, var(--line) 28%, transparent);
  box-shadow: 0 12px 28px color-mix(in srgb, var(--black) 22%, transparent);
}

.tape-header {
  display: grid;
  grid-template-columns: auto minmax(72px, 1fr) auto;
  align-items: center;
  gap: 5px;
  padding: 5px 7px;
  color: var(--muted);
  background: color-mix(in srgb, var(--panel-strong) 92%, transparent);
  border-top: 1px solid var(--line);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.tape-filter {
  display: contents;
}

.tape-filter label {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 4px;
  min-width: 0;
  color: var(--muted);
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.tape-filter input[type="range"] {
  width: 100%;
  min-width: 0;
  accent-color: var(--accent);
}

.tape-filter strong {
  min-width: 38px;
  color: var(--text);
  font-size: 9px;
  font-weight: 800;
  text-align: right;
}

.tape-panel > .tape-filter {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 4px;
  padding: 5px 7px;
  border-top: 1px solid color-mix(in srgb, var(--muted) 16%, transparent);
  background: color-mix(in srgb, var(--bg) 52%, transparent);
}

.market-tape {
  overflow: hidden;
  min-height: 0;
  padding-bottom: 6px;
}

.tape-row {
  display: grid;
  grid-template-columns: 82px 42px;
  justify-content: start;
  gap: 6px;
  align-items: center;
  min-height: 20px;
  padding: 0 6px;
  font-family: Consolas, "Courier New", monospace;
  font-size: 11px;
}

.tape-row.has-source {
  grid-template-columns: 82px 56px minmax(58px, 1fr);
}

.tape-row.buy {
  color: var(--buy-text);
}

.tape-row.sell {
  color: var(--sell-text);
}

.tape-row span {
  text-align: left;
}

.tape-source {
  overflow: hidden;
  color: var(--muted);
  font-size: 10px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.tape-count-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 16px;
  height: 14px;
  margin-left: 4px;
  padding: 0 3px;
  border-radius: 4px;
  color: var(--text);
  background: color-mix(in srgb, var(--muted) 18%, transparent);
  font-size: 9px;
  font-style: normal;
}

.trade-panel {
  height: 100%;
  border: 0;
  border-radius: 0;
  overflow: hidden;
  box-shadow: none;
  background: transparent;
}

.trade-panel.hidden {
  display: none;
}

.trade-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 16px;
  border-bottom: 1px solid var(--line);
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--accent) 14%, transparent), transparent 36%),
    color-mix(in srgb, var(--panel-strong) 88%, transparent);
}

.trade-header h2,
.trade-card h3 {
  margin: 0;
}

.trade-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.trade-status {
  padding: 6px 10px;
  color: var(--muted);
  background: color-mix(in srgb, var(--panel-strong) 92%, transparent);
  border-radius: 999px;
  font-size: 12px;
  font-weight: 800;
}

.trade-status.live {
  color: var(--buy-text);
  background: color-mix(in srgb, var(--green) 16%, transparent);
}

.trade-status.loading {
  color: var(--warning-text);
  background: color-mix(in srgb, var(--warning-text) 16%, transparent);
}

.trade-status.error {
  color: var(--sell-text);
  background: color-mix(in srgb, var(--red) 16%, transparent);
}

.trade-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  padding: 14px;
}

.trade-card {
  display: grid;
  gap: 10px;
  min-width: 0;
  padding: 14px;
  background: color-mix(in srgb, var(--panel-strong) 92%, transparent);
  border: 1px solid var(--line);
  border-radius: 14px;
}

.trade-card input,
.trade-card select {
  width: 100%;
}

.bracket-summary {
  display: grid;
  gap: 6px;
}

.market-terminal {
  display: grid;
  grid-template-rows: auto 1fr;
  height: 100%;
  min-height: 0;
  background:
    linear-gradient(160deg, color-mix(in srgb, var(--accent) 10%, transparent), transparent 44%),
    color-mix(in srgb, var(--panel-strong) 94%, transparent);
}

.market-terminal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 14px 10px;
  border-bottom: 1px solid var(--line);
}

.market-terminal-header h2 {
  margin: 0;
  font-size: 22px;
  letter-spacing: -0.04em;
}

.market-terminal-body {
  display: grid;
  align-content: start;
  gap: 14px;
  padding: 14px;
}

.market-terminal-tools {
  display: flex;
  justify-content: flex-end;
}

.market-terminal-position {
  display: grid;
  gap: 6px;
  padding: 10px;
  border: 1px solid color-mix(in srgb, var(--muted) 18%, transparent);
  border-radius: 8px;
  background: color-mix(in srgb, var(--bg) 28%, transparent);
}

.market-terminal-position.hidden {
  display: none;
}

.market-terminal-kcex {
  display: grid;
  gap: 10px;
  padding: 12px;
  border: 1px solid color-mix(in srgb, var(--muted) 18%, transparent);
  border-radius: 8px;
  background: color-mix(in srgb, var(--bg) 28%, transparent);
}

.market-terminal-kcex h3 {
  margin: 0;
}

.market-terminal-kcex input {
  width: 100%;
  min-height: 34px;
}

.market-terminal-kcex button {
  min-height: 34px;
}

.market-terminal-qty {
  gap: 6px;
}

.market-terminal-qty input {
  width: 100%;
  min-height: 42px;
  font-size: 20px;
  font-weight: 700;
  letter-spacing: -0.03em;
}

.market-terminal-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.market-terminal-actions button {
  min-height: 48px;
  font-size: 15px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  position: relative;
  transform: translateY(0);
  box-shadow: 0 6px 0 color-mix(in srgb, var(--black) 18%, transparent);
  transition:
    transform 120ms ease,
    box-shadow 120ms ease,
    filter 120ms ease,
    background-color 120ms ease,
    border-color 120ms ease;
  will-change: transform;
}

.market-terminal-actions button:hover {
  filter: brightness(1.03);
}

.market-terminal-actions button:active {
  transform: translateY(3px) scale(0.985);
  box-shadow: 0 2px 0 color-mix(in srgb, var(--black) 16%, transparent);
  filter: brightness(0.98);
}

.market-terminal-actions button:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--on-color) 50%, transparent);
  outline-offset: 2px;
}

.market-buy-button {
  background: var(--classic-buy);
  border-color: var(--classic-buy);
  color: var(--on-color);
}

.market-buy-button:hover {
  background: var(--classic-buy-hover);
  border-color: var(--classic-buy-hover);
}

.danger-button:active {
  box-shadow: 0 2px 0 color-mix(in srgb, var(--black) 16%, transparent);
}

.ticket-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.inline-check {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--text);
  text-transform: none;
  letter-spacing: 0;
}

.inline-check input {
  width: auto;
  min-height: auto;
}

.trade-note,
.empty-state {
  margin: 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
}

.trade-readout {
  align-content: start;
  max-height: 280px;
  overflow: auto;
}

.full-span {
  grid-column: 1 / -1;
}

.card-title-row,
.kv-row,
.order-row,
.position-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.kv-row,
.order-row,
.position-row {
  padding: 8px 0;
  border-bottom: 1px solid color-mix(in srgb, var(--line) 80%, transparent);
}

.kv-row span,
.order-row span,
.position-row span {
  color: var(--muted);
  font-size: 12px;
}

.order-row > div {
  display: grid;
  gap: 3px;
}

.trade-readout pre {
  overflow: auto;
  margin: 0;
  color: var(--muted);
  font-size: 11px;
}

.attribution {
  color: var(--muted);
  font-size: 12px;
  text-align: right;
}

.attribution a {
  color: var(--accent);
  text-decoration: none;
}

.attribution a:hover {
  text-decoration: underline;
}

@media (max-width: 920px) {
  .tape-aggregate-controls {
    grid-template-columns: 1fr;
    min-width: min(100%, 320px);
  }

  .tape-venue-grid {
    grid-template-columns: repeat(2, minmax(112px, 1fr));
  }

  .shell {
    width: 100%;
    padding: 10px;
  }

  .topbar {
    position: fixed;
    right: 10px;
    bottom: 10px;
    left: auto;
    top: auto;
    width: auto;
    max-width: calc(100vw - 20px);
    height: auto;
    gap: 5px;
    padding: 4px;
    z-index: 10000;
    overflow: visible;
  }

  .topbar {
    transform: none !important;
  }

  .controls {
    justify-content: stretch;
  }

  .controls label,
  .controls button {
    flex: 1 1 140px;
  }

  .symbol-field input {
    width: 100%;
  }

  .widget-toolbar {
    justify-content: flex-start;
    max-width: calc(100vw - 186px);
  }

  .widget-toolbar button {
    min-height: 38px;
    padding: 0;
  }

  .widget-config label,
  .widget-config button {
    flex: 1 1 132px;
  }

  .widget-config-status {
    width: 100%;
    margin-left: 0;
  }

  .widget-board {
    min-height: auto;
    display: grid;
    gap: 12px;
    overflow: visible;
    background-size: 22px 22px;
  }

  .widget {
    position: relative;
    left: auto !important;
    top: auto !important;
    width: 100% !important;
    height: 560px !important;
  }

  .widget[data-widget="tape"] {
    height: 320px !important;
  }

  .widget[data-widget="trade"] {
    height: auto !important;
    min-height: 720px;
  }

  .widget-resize {
    display: none;
  }

  .trade-header {
    align-items: flex-start;
    flex-direction: column;
  }

  .trade-grid {
    grid-template-columns: 1fr;
  }

  .ticket-row,
  .market-terminal-actions,
  .position-row {
    grid-template-columns: 1fr;
  }
}

body,
body[data-theme="dark"],
body[data-theme="light"] {
  background-color: var(--bg);
  background-image: none;
}

.widget-board,
:root[data-theme="nord"] .widget-board {
  border-color: transparent;
  border-radius: 10px;
  background: color-mix(in srgb, var(--bg) 92%, transparent);
  background-size: auto;
}

.orderflow-panel {
  padding: 8px;
  gap: 6px;
  background: color-mix(in srgb, var(--panel) 94%, transparent);
}

.orderflow-panel-head {
  font-size: 9px;
  letter-spacing: 0.06em;
}

.orderflow-panel-head strong {
  padding: 3px 6px;
  border-color: transparent;
  background: transparent;
}

.heatmap-config-group {
  padding: 6px;
  border-color: transparent;
  background: color-mix(in srgb, var(--panel) 58%, transparent);
}

.heatmap-config-group legend {
  padding: 0;
  letter-spacing: 0.06em;
}

.heatmap-config-field input,
.heatmap-config-field select {
  border-color: transparent;
  background: color-mix(in srgb, var(--panel-strong) 62%, transparent);
  box-shadow: none;
}

.orderflow-heatmap-frame,
.trade-journal-frame {
  background: var(--bg);
}

.dom-trade-bar button {
  box-shadow: none;
  filter: none;
  text-shadow: none;
}

.dom-trade-bar button:hover,
.dom-trade-bar button:focus-visible {
  filter: none;
  box-shadow: none;
}

.dom-trade-bar [data-dom-market-side] {
  border: 1px solid transparent;
  background-image: none;
  box-shadow: none;
  letter-spacing: 0.02em;
}

.dom-trade-bar [data-dom-market-side="BUY"] {
  color: var(--buy-text);
  background: color-mix(in srgb, var(--green) 12%, transparent);
}

.dom-trade-bar [data-dom-market-side="SELL"] {
  color: var(--sell-text);
  background: color-mix(in srgb, var(--red) 12%, transparent);
}

.dom-trade-bar [data-dom-market-side="BUY"]:hover,
.dom-trade-bar [data-dom-market-side="BUY"]:focus-visible {
  background: color-mix(in srgb, var(--green) 18%, transparent);
}

.dom-trade-bar [data-dom-market-side="SELL"]:hover,
.dom-trade-bar [data-dom-market-side="SELL"]:focus-visible {
  background: color-mix(in srgb, var(--red) 18%, transparent);
}

.dom-trade-bar [data-dom-market-side]:active {
  background: color-mix(in srgb, var(--accent) 10%, transparent);
}

.dom-trade-bar [data-dom-protection-cancel] {
  color: var(--sell-text);
  border-color: transparent;
  background: color-mix(in srgb, var(--red) 8%, transparent);
}

.dom-trade-bar [data-dom-protection-cancel]:hover,
.dom-trade-bar [data-dom-protection-cancel]:focus-visible {
  background: color-mix(in srgb, var(--red) 13%, transparent);
}

.ladder-order-cell.active:hover,
.ladder-order-cell.active:focus-visible {
  filter: none;
  box-shadow: none;
}

.prop-row .bid-size.ladder-order-cell.active:hover,
.prop-row .bid-size.ladder-order-cell.active:focus-visible {
  background: color-mix(in srgb, var(--green) 7%, transparent);
}

.prop-row .ask-size.ladder-order-cell.active:hover,
.prop-row .ask-size.ladder-order-cell.active:focus-visible {
  background: color-mix(in srgb, var(--red) 7%, transparent);
}

.chart-trade-toolbar {
  gap: 4px;
  padding: 6px;
  border-color: transparent;
  background: color-mix(in srgb, var(--panel) 78%, transparent);
  box-shadow: none;
  backdrop-filter: blur(8px);
}

.chart-trade-toolbar.dragging {
  box-shadow: none;
}

.chart-trade-group {
  gap: 4px;
  padding: 2px;
  border-color: transparent;
  background: transparent;
}

.chart-trade-toolbar label {
  gap: 3px;
  color: color-mix(in srgb, var(--muted) 78%, transparent);
  letter-spacing: 0.06em;
}

.chart-trade-toolbar input {
  min-height: 26px;
  height: 26px;
  padding: 0 7px;
  border-color: transparent;
  border-radius: 4px;
  background: color-mix(in srgb, var(--panel-strong) 62%, transparent);
  box-shadow: none;
  font-size: 11px;
}

.chart-trade-toolbar input:focus,
.chart-trade-toolbar input:focus-visible {
  border-color: transparent;
  background: color-mix(in srgb, var(--accent) 8%, var(--panel-strong));
  box-shadow: none;
}

.chart-trade-button {
  min-height: 26px;
  padding: 0 8px;
  border-color: transparent;
  background-image: none;
  box-shadow: none;
  text-shadow: none;
  transform: none;
  transition: background 120ms ease, color 120ms ease, opacity 120ms ease;
}

.chart-trade-button:hover,
.chart-trade-button:focus-visible,
.chart-trade-button:active {
  border-color: transparent;
  box-shadow: none;
  filter: none;
  transform: none;
}

.chart-trade-sell {
  color: var(--sell-text);
  border-color: transparent;
  background: color-mix(in srgb, var(--red) 12%, transparent);
}

.chart-trade-sell:hover,
.chart-trade-sell:focus-visible {
  border-color: transparent;
  background: color-mix(in srgb, var(--red) 18%, transparent);
}

.chart-trade-toolbar .chart-trade-buy {
  color: var(--buy-text);
  border-color: transparent;
  background: color-mix(in srgb, var(--green) 12%, transparent);
}

.chart-trade-toolbar .chart-trade-buy:hover,
.chart-trade-toolbar .chart-trade-buy:focus-visible {
  border-color: transparent;
  background: color-mix(in srgb, var(--green) 18%, transparent);
}

.chart-trade-limit-actions .chart-trade-button,
.chart-trade-draft-actions .chart-trade-button {
  color: color-mix(in srgb, var(--muted) 86%, transparent);
  border-color: transparent;
  background: color-mix(in srgb, var(--panel-strong) 45%, transparent);
}

.chart-trade-limit-actions .chart-trade-button:hover,
.chart-trade-limit-actions .chart-trade-button:focus-visible,
.chart-trade-draft-actions .chart-trade-button:hover,
.chart-trade-draft-actions .chart-trade-button:focus-visible {
  color: var(--text);
  border-color: transparent;
  background: color-mix(in srgb, var(--accent) 10%, transparent);
}

.chart-trade-limit-actions .chart-trade-button[aria-pressed="true"] {
  color: var(--text);
  border-color: transparent;
  background: color-mix(in srgb, var(--accent) 13%, transparent);
  box-shadow: none;
}

.chart-trade-button:disabled {
  opacity: 0.34;
  background: color-mix(in srgb, var(--panel-strong) 28%, transparent);
}

.chart-trade-footer {
  gap: 5px;
  padding: 0 3px;
}

.chart-trade-toolbar .chart-trade-reduce {
  min-height: 22px;
  gap: 5px;
  color: color-mix(in srgb, var(--muted) 80%, transparent);
  font-size: 9px;
}

.chart-trade-toolbar .chart-trade-reduce input {
  width: 13px;
  height: 13px;
  border-color: transparent;
  background: color-mix(in srgb, var(--panel-strong) 64%, transparent);
}

.chart-trade-status {
  color: color-mix(in srgb, var(--muted) 82%, transparent);
  font-size: 9px;
  font-weight: 750;
}
